Add support for a target variable in regular links.
This will initially be used for supporting "post://" links.
This commit is contained in:
parent
cb5d131097
commit
86d4e25aa0
@ -11,6 +11,7 @@ use super::RenderObject;
|
|||||||
#[serde(tag = "type")]
|
#[serde(tag = "type")]
|
||||||
#[serde(rename = "regular_link")]
|
#[serde(rename = "regular_link")]
|
||||||
pub(crate) struct RenderRegularLink {
|
pub(crate) struct RenderRegularLink {
|
||||||
|
target: String,
|
||||||
raw_link: String,
|
raw_link: String,
|
||||||
children: Vec<RenderObject>,
|
children: Vec<RenderObject>,
|
||||||
post_blank: organic::types::PostBlank,
|
post_blank: organic::types::PostBlank,
|
||||||
@ -25,7 +26,13 @@ render!(RenderRegularLink, IRegularLink, original, render_context, {
|
|||||||
ret
|
ret
|
||||||
};
|
};
|
||||||
|
|
||||||
|
let target = original
|
||||||
|
.target
|
||||||
|
.generate_final_target()?
|
||||||
|
.unwrap_or_else(|| "".to_owned());
|
||||||
|
|
||||||
Ok(RenderRegularLink {
|
Ok(RenderRegularLink {
|
||||||
|
target: target,
|
||||||
raw_link: original.raw_link.clone(),
|
raw_link: original.raw_link.clone(),
|
||||||
children,
|
children,
|
||||||
post_blank: original.post_blank,
|
post_blank: original.post_blank,
|
||||||
|
@ -9,6 +9,7 @@ use crate::error::CustomError;
|
|||||||
pub(crate) struct IRegularLink {
|
pub(crate) struct IRegularLink {
|
||||||
pub(crate) raw_link: String,
|
pub(crate) raw_link: String,
|
||||||
pub(crate) children: Vec<IObject>,
|
pub(crate) children: Vec<IObject>,
|
||||||
|
pub(crate) target: LinkTarget,
|
||||||
pub(crate) post_blank: organic::types::PostBlank,
|
pub(crate) post_blank: organic::types::PostBlank,
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -25,10 +26,32 @@ intermediate!(
|
|||||||
}
|
}
|
||||||
ret
|
ret
|
||||||
};
|
};
|
||||||
|
let raw_link = original.get_raw_link();
|
||||||
|
let target = LinkTarget::from_string(&raw_link)?;
|
||||||
Ok(IRegularLink {
|
Ok(IRegularLink {
|
||||||
raw_link: original.get_raw_link().into_owned(),
|
raw_link: raw_link.into_owned(),
|
||||||
children,
|
children,
|
||||||
|
target,
|
||||||
post_blank: original.get_post_blank(),
|
post_blank: original.get_post_blank(),
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
|
#[derive(Debug, Clone)]
|
||||||
|
pub(crate) enum LinkTarget {
|
||||||
|
Raw(String),
|
||||||
|
Post { post_id: String },
|
||||||
|
}
|
||||||
|
|
||||||
|
impl LinkTarget {
|
||||||
|
pub(crate) fn from_string<S: AsRef<str>>(input: S) -> Result<LinkTarget, CustomError> {
|
||||||
|
fn impl_from_string(input: &str) -> Result<LinkTarget, CustomError> {
|
||||||
|
Ok(LinkTarget::Raw(input.to_owned()))
|
||||||
|
}
|
||||||
|
impl_from_string(input.as_ref())
|
||||||
|
}
|
||||||
|
|
||||||
|
pub(crate) fn generate_final_target(&self) -> Result<Option<String>, CustomError> {
|
||||||
|
todo!()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user