Skip to content

Commit

Permalink
html: new note style from daniel
Browse files Browse the repository at this point in the history
Cc: Daniel Daquino <[email protected]>
  • Loading branch information
jb55 committed Jan 24, 2024
1 parent ef86990 commit 939e12d
Show file tree
Hide file tree
Showing 2 changed files with 67 additions and 10 deletions.
56 changes: 48 additions & 8 deletions src/html.rs
Original file line number Diff line number Diff line change
Expand Up @@ -86,19 +86,23 @@ pub fn serve_note_html(
// 1: abbreviated description
// 2: hostname
// 3: bech32 entity
// 4: Full content
// 5: formatted date
// 6: pfp url

let hostname = "https://damus.io";
let abbrev_content = html_escape::encode_text(abbreviate(&note_data.note.content, 64));
let profile_name = html_escape::encode_text(&note_data.profile.name);
let bech32 = nip19.to_bech32().unwrap();

write!(
data,
r#"
<html>
<head>
<title>{0} on nostr</title>
<link rel="stylesheet" href="https://damus.io/css/notecrumbs.css" type="text/css" />
<meta name="viewport" content="width=device-width, initial-scale=1">
<meta name="apple-itunes-app" content="app-id=1628663131, app-argument=damus:nostr:{3}"/>
<meta charset="UTF-8">
<meta property="og:description" content="{1}" />
Expand All @@ -119,13 +123,35 @@ pub fn serve_note_html(
</head>
<body>
<h3>Note!</h3>
<div class="note">
<div class="note-content">"#,
<main>
<div class="container">
<div class="top-menu">
<a href="https://damus.io" target="_blank">
<img src="https://damus.io/logo_icon.png" class="logo" />
</a>
<!--
<a href="damus:nostr:note1234..." id="top-menu-open-in-damus-button" class="accent-button">
Open in Damus
</a>
-->
</div>
<h3 class="page-heading">Note</h3>
<div class="note-container">
<div class="note">
<div class="note-header">
<img src="{5}" class="note-author-avatar" />
<div class="note-author-name">{0}</div>
<div class="note-header-separator">·</div>
<div class="note-timestamp">{4}</div>
</div>
<div class="note-content">"#,
profile_name,
abbrev_content,
hostname,
nip19.to_bech32().unwrap()
bech32,
note_data.note.timestamp,
note_data.profile.pfp_url,
)?;

let ok = (|| -> Result<(), nostrdb::Error> {
Expand All @@ -150,12 +176,26 @@ pub fn serve_note_html(

write!(
data,
"
r#"
</div>
</div>
</div>
<div class="note-actions-footer">
<a href="nostr:{}" class="muted-link">Open with default Nostr client</a>
</div>
</div>
</main>
<footer>
<span class="footer-note">
<a href="https://damus.io">Damus</a> is a decentralized social network app built on the Nostr protocol.
</span>
<span class="copyright-note">
© Damus Nostr Inc.
</span>
</footer>
</body>
</html>
"
"#,
bech32
);

Ok(Response::builder()
Expand Down
21 changes: 19 additions & 2 deletions src/render.rs
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ impl ProfileRenderData {
name: "nostrich".to_string(),
display_name: None,
about: "A am a nosy nostrich".to_string(),
pfp_url: "https://damus.io/img/no-profile.svg".to_owned(),
pfp: pfp,
}
}
Expand All @@ -31,12 +32,14 @@ impl ProfileRenderData {
pub struct NoteData {
pub id: Option<[u8; 32]>,
pub content: String,
pub timestamp: u64,
}

pub struct ProfileRenderData {
pub name: String,
pub display_name: Option<String>,
pub about: String,
pub pfp_url: String,
pub pfp: egui::ImageData,
}

Expand Down Expand Up @@ -97,7 +100,12 @@ impl From<EventId> for EventSource {
impl NoteData {
fn default() -> Self {
let content = "".to_string();
NoteData { content, id: None }
let timestamp = 0;
NoteData {
content,
timestamp,
id: None,
}
}
}

Expand Down Expand Up @@ -188,25 +196,34 @@ fn get_profile_render_data(
let about = profile.about().unwrap_or("").to_string();
let display_name = profile.display_name().as_ref().map(|a| a.to_string());
let pfp = app.default_pfp.clone();
let pfp_url = "https://damus.io/img/no-profile.svg".to_owned();

Ok(ProfileRenderData {
name,
pfp,
about,
pfp_url,
display_name,
})
}

fn ndb_note_to_data(note: &Note) -> NoteData {
let content = note.content().to_string();
let id = Some(*note.id());
NoteData { content, id }
let timestamp = note.created_at();
NoteData {
content,
timestamp,
id,
}
}

fn sdk_note_to_note_data(note: &Event) -> NoteData {
let content = note.content.clone();
let timestamp = note.created_at.as_u64();
NoteData {
content,
timestamp,
id: Some(note.id.to_bytes()),
}
}
Expand Down

0 comments on commit 939e12d

Please sign in to comment.