pub mod get_launch_asset;
pub mod get_manifest;
pub mod put_hosting_url;
pub mod service;
#[jacquard_derive::lexicon]
#[derive(
serde::Serialize,
serde::Deserialize,
Debug,
Clone,
PartialEq,
Eq,
jacquard_derive::IntoStatic,
Default
)]
#[serde(rename_all = "camelCase")]
pub struct AdaptiveIcon<'a> {
#[serde(skip_serializing_if = "std::option::Option::is_none")]
#[serde(borrow)]
pub background_color: std::option::Option<jacquard_common::CowStr<'a>>,
#[serde(skip_serializing_if = "std::option::Option::is_none")]
#[serde(borrow)]
pub foreground_image: std::option::Option<jacquard_common::CowStr<'a>>,
#[serde(skip_serializing_if = "std::option::Option::is_none")]
#[serde(borrow)]
pub foreground_image_blob: std::option::Option<
jacquard_common::types::blob::BlobRef<'a>,
>,
}
fn lexicon_doc_app_ocho_plugin_defs() -> ::jacquard_lexicon::lexicon::LexiconDoc<
'static,
> {
::jacquard_lexicon::lexicon::LexiconDoc {
lexicon: ::jacquard_lexicon::lexicon::Lexicon::Lexicon1,
id: ::jacquard_common::CowStr::new_static("app.ocho.plugin.defs"),
revision: None,
description: None,
defs: {
let mut map = ::alloc::collections::BTreeMap::new();
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static("adaptiveIcon"),
::jacquard_lexicon::lexicon::LexUserType::Object(::jacquard_lexicon::lexicon::LexObject {
description: None,
required: None,
nullable: None,
properties: {
#[allow(unused_mut)]
let mut map = ::alloc::collections::BTreeMap::new();
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"backgroundColor",
),
::jacquard_lexicon::lexicon::LexObjectProperty::String(::jacquard_lexicon::lexicon::LexString {
description: Some(
::jacquard_common::CowStr::new_static(
"The background color of the adaptive icon.",
),
),
format: None,
default: None,
min_length: None,
max_length: None,
min_graphemes: None,
max_graphemes: None,
r#enum: None,
r#const: None,
known_values: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"foregroundImage",
),
::jacquard_lexicon::lexicon::LexObjectProperty::String(::jacquard_lexicon::lexicon::LexString {
description: Some(
::jacquard_common::CowStr::new_static(
"The URL to the foreground image of the adaptive icon.",
),
),
format: None,
default: None,
min_length: None,
max_length: None,
min_graphemes: None,
max_graphemes: None,
r#enum: None,
r#const: None,
known_values: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"foregroundImageBlob",
),
::jacquard_lexicon::lexicon::LexObjectProperty::Blob(::jacquard_lexicon::lexicon::LexBlob {
description: None,
accept: None,
max_size: None,
}),
);
map
},
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static("android"),
::jacquard_lexicon::lexicon::LexUserType::Object(::jacquard_lexicon::lexicon::LexObject {
description: None,
required: None,
nullable: None,
properties: {
#[allow(unused_mut)]
let mut map = ::alloc::collections::BTreeMap::new();
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"adaptiveIcon",
),
::jacquard_lexicon::lexicon::LexObjectProperty::Ref(::jacquard_lexicon::lexicon::LexRef {
description: None,
r#ref: ::jacquard_common::CowStr::new_static(
"#adaptiveIcon",
),
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"edgeToEdgeEnabled",
),
::jacquard_lexicon::lexicon::LexObjectProperty::Boolean(::jacquard_lexicon::lexicon::LexBoolean {
description: None,
default: None,
r#const: None,
}),
);
map
},
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"androidStatusBar",
),
::jacquard_lexicon::lexicon::LexUserType::Object(::jacquard_lexicon::lexicon::LexObject {
description: Some(
::jacquard_common::CowStr::new_static(
"Android status bar configuration.",
),
),
required: None,
nullable: None,
properties: {
#[allow(unused_mut)]
let mut map = ::alloc::collections::BTreeMap::new();
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"backgroundColor",
),
::jacquard_lexicon::lexicon::LexObjectProperty::String(::jacquard_lexicon::lexicon::LexString {
description: Some(
::jacquard_common::CowStr::new_static(
"The background color of the Android status bar.",
),
),
format: None,
default: None,
min_length: None,
max_length: None,
min_graphemes: None,
max_graphemes: None,
r#enum: None,
r#const: None,
known_values: None,
}),
);
map
},
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static("asset"),
::jacquard_lexicon::lexicon::LexUserType::Object(::jacquard_lexicon::lexicon::LexObject {
description: None,
required: Some(
vec![
::jacquard_common::deps::smol_str::SmolStr::new_static("hash"),
::jacquard_common::deps::smol_str::SmolStr::new_static("blob"),
::jacquard_common::deps::smol_str::SmolStr::new_static("type")
],
),
nullable: None,
properties: {
#[allow(unused_mut)]
let mut map = ::alloc::collections::BTreeMap::new();
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"blob",
),
::jacquard_lexicon::lexicon::LexObjectProperty::Blob(::jacquard_lexicon::lexicon::LexBlob {
description: None,
accept: None,
max_size: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"hash",
),
::jacquard_lexicon::lexicon::LexObjectProperty::String(::jacquard_lexicon::lexicon::LexString {
description: Some(
::jacquard_common::CowStr::new_static(
"The hash of the asset",
),
),
format: None,
default: None,
min_length: None,
max_length: None,
min_graphemes: None,
max_graphemes: None,
r#enum: None,
r#const: None,
known_values: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"type",
),
::jacquard_lexicon::lexicon::LexObjectProperty::String(::jacquard_lexicon::lexicon::LexString {
description: Some(
::jacquard_common::CowStr::new_static(
"The type of the asset",
),
),
format: None,
default: None,
min_length: None,
max_length: None,
min_graphemes: None,
max_graphemes: None,
r#enum: None,
r#const: None,
known_values: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"updatedAt",
),
::jacquard_lexicon::lexicon::LexObjectProperty::String(::jacquard_lexicon::lexicon::LexString {
description: Some(
::jacquard_common::CowStr::new_static(
"The date and time when this asset was last updated. Used to reset the jetstream cache, among other things.",
),
),
format: Some(
::jacquard_lexicon::lexicon::LexStringFormat::Datetime,
),
default: None,
min_length: None,
max_length: None,
min_graphemes: None,
max_graphemes: None,
r#enum: None,
r#const: None,
known_values: None,
}),
);
map
},
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static("db"),
::jacquard_lexicon::lexicon::LexUserType::Object(::jacquard_lexicon::lexicon::LexObject {
description: None,
required: Some(
vec![
::jacquard_common::deps::smol_str::SmolStr::new_static("id")
],
),
nullable: None,
properties: {
#[allow(unused_mut)]
let mut map = ::alloc::collections::BTreeMap::new();
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static("id"),
::jacquard_lexicon::lexicon::LexObjectProperty::String(::jacquard_lexicon::lexicon::LexString {
description: Some(
::jacquard_common::CowStr::new_static(
"The ID of the database.",
),
),
format: None,
default: None,
min_length: None,
max_length: None,
min_graphemes: None,
max_graphemes: None,
r#enum: None,
r#const: None,
known_values: None,
}),
);
map
},
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static("developer"),
::jacquard_lexicon::lexicon::LexUserType::Object(::jacquard_lexicon::lexicon::LexObject {
description: None,
required: Some(
vec![
::jacquard_common::deps::smol_str::SmolStr::new_static("tool")
],
),
nullable: None,
properties: {
#[allow(unused_mut)]
let mut map = ::alloc::collections::BTreeMap::new();
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"tool",
),
::jacquard_lexicon::lexicon::LexObjectProperty::String(::jacquard_lexicon::lexicon::LexString {
description: Some(
::jacquard_common::CowStr::new_static(
"The tool used for development, e.g., 'expo-cli'.",
),
),
format: None,
default: None,
min_length: None,
max_length: None,
min_graphemes: None,
max_graphemes: None,
r#enum: None,
r#const: None,
known_values: None,
}),
);
map
},
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static("expoClient"),
::jacquard_lexicon::lexicon::LexUserType::Object(::jacquard_lexicon::lexicon::LexObject {
description: None,
required: Some(
vec![
::jacquard_common::deps::smol_str::SmolStr::new_static("name"),
::jacquard_common::deps::smol_str::SmolStr::new_static("slug")
],
),
nullable: None,
properties: {
#[allow(unused_mut)]
let mut map = ::alloc::collections::BTreeMap::new();
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"android",
),
::jacquard_lexicon::lexicon::LexObjectProperty::Ref(::jacquard_lexicon::lexicon::LexRef {
description: None,
r#ref: ::jacquard_common::CowStr::new_static("#android"),
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"androidStatusBar",
),
::jacquard_lexicon::lexicon::LexObjectProperty::Ref(::jacquard_lexicon::lexicon::LexRef {
description: None,
r#ref: ::jacquard_common::CowStr::new_static(
"#androidStatusBar",
),
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"expirements",
),
::jacquard_lexicon::lexicon::LexObjectProperty::Unknown(::jacquard_lexicon::lexicon::LexUnknown {
description: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"extra",
),
::jacquard_lexicon::lexicon::LexObjectProperty::Unknown(::jacquard_lexicon::lexicon::LexUnknown {
description: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"icon",
),
::jacquard_lexicon::lexicon::LexObjectProperty::String(::jacquard_lexicon::lexicon::LexString {
description: Some(
::jacquard_common::CowStr::new_static(
"The URL to the app icon.",
),
),
format: None,
default: None,
min_length: None,
max_length: None,
min_graphemes: None,
max_graphemes: None,
r#enum: None,
r#const: None,
known_values: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"ios",
),
::jacquard_lexicon::lexicon::LexObjectProperty::Ref(::jacquard_lexicon::lexicon::LexRef {
description: None,
r#ref: ::jacquard_common::CowStr::new_static("#ios"),
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"locales",
),
::jacquard_lexicon::lexicon::LexObjectProperty::Unknown(::jacquard_lexicon::lexicon::LexUnknown {
description: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"name",
),
::jacquard_lexicon::lexicon::LexObjectProperty::String(::jacquard_lexicon::lexicon::LexString {
description: Some(
::jacquard_common::CowStr::new_static(
"The name of the Expo client application.",
),
),
format: None,
default: None,
min_length: None,
max_length: None,
min_graphemes: None,
max_graphemes: None,
r#enum: None,
r#const: None,
known_values: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"newArchEnabled",
),
::jacquard_lexicon::lexicon::LexObjectProperty::Boolean(::jacquard_lexicon::lexicon::LexBoolean {
description: None,
default: None,
r#const: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"orientation",
),
::jacquard_lexicon::lexicon::LexObjectProperty::String(::jacquard_lexicon::lexicon::LexString {
description: Some(
::jacquard_common::CowStr::new_static(
"The default orientation of the app.",
),
),
format: None,
default: None,
min_length: None,
max_length: None,
min_graphemes: None,
max_graphemes: None,
r#enum: None,
r#const: None,
known_values: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"platforms",
),
::jacquard_lexicon::lexicon::LexObjectProperty::Array(::jacquard_lexicon::lexicon::LexArray {
description: Some(
::jacquard_common::CowStr::new_static(
"The platforms supported by the app.",
),
),
items: ::jacquard_lexicon::lexicon::LexArrayItem::String(::jacquard_lexicon::lexicon::LexString {
description: None,
format: None,
default: None,
min_length: None,
max_length: None,
min_graphemes: None,
max_graphemes: None,
r#enum: None,
r#const: None,
known_values: None,
}),
min_length: None,
max_length: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"plugins",
),
::jacquard_lexicon::lexicon::LexObjectProperty::Unknown(::jacquard_lexicon::lexicon::LexUnknown {
description: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"scheme",
),
::jacquard_lexicon::lexicon::LexObjectProperty::String(::jacquard_lexicon::lexicon::LexString {
description: Some(
::jacquard_common::CowStr::new_static(
"The custom URI scheme for deep linking.",
),
),
format: None,
default: None,
min_length: None,
max_length: None,
min_graphemes: None,
max_graphemes: None,
r#enum: None,
r#const: None,
known_values: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"sdkVersion",
),
::jacquard_lexicon::lexicon::LexObjectProperty::String(::jacquard_lexicon::lexicon::LexString {
description: Some(
::jacquard_common::CowStr::new_static(
"The SDK version of the Expo client.",
),
),
format: None,
default: None,
min_length: None,
max_length: None,
min_graphemes: None,
max_graphemes: None,
r#enum: None,
r#const: None,
known_values: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"slug",
),
::jacquard_lexicon::lexicon::LexObjectProperty::String(::jacquard_lexicon::lexicon::LexString {
description: Some(
::jacquard_common::CowStr::new_static(
"A URL-friendly identifier for the app.",
),
),
format: None,
default: None,
min_length: None,
max_length: None,
min_graphemes: None,
max_graphemes: None,
r#enum: None,
r#const: None,
known_values: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"userInterfaceStyle",
),
::jacquard_lexicon::lexicon::LexObjectProperty::String(::jacquard_lexicon::lexicon::LexString {
description: Some(
::jacquard_common::CowStr::new_static(
"The default user interface style.",
),
),
format: None,
default: None,
min_length: None,
max_length: None,
min_graphemes: None,
max_graphemes: None,
r#enum: None,
r#const: None,
known_values: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"version",
),
::jacquard_lexicon::lexicon::LexObjectProperty::String(::jacquard_lexicon::lexicon::LexString {
description: Some(
::jacquard_common::CowStr::new_static(
"The version of the app.",
),
),
format: None,
default: None,
min_length: None,
max_length: None,
min_graphemes: None,
max_graphemes: None,
r#enum: None,
r#const: None,
known_values: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"web",
),
::jacquard_lexicon::lexicon::LexObjectProperty::Ref(::jacquard_lexicon::lexicon::LexRef {
description: None,
r#ref: ::jacquard_common::CowStr::new_static("#web"),
}),
);
map
},
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static("expoGo"),
::jacquard_lexicon::lexicon::LexUserType::Object(::jacquard_lexicon::lexicon::LexObject {
description: None,
required: Some(
vec![
::jacquard_common::deps::smol_str::SmolStr::new_static("developer")
],
),
nullable: None,
properties: {
#[allow(unused_mut)]
let mut map = ::alloc::collections::BTreeMap::new();
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"developer",
),
::jacquard_lexicon::lexicon::LexObjectProperty::Ref(::jacquard_lexicon::lexicon::LexRef {
description: None,
r#ref: ::jacquard_common::CowStr::new_static("#developer"),
}),
);
map
},
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static("ios"),
::jacquard_lexicon::lexicon::LexUserType::Object(::jacquard_lexicon::lexicon::LexObject {
description: None,
required: None,
nullable: None,
properties: {
#[allow(unused_mut)]
let mut map = ::alloc::collections::BTreeMap::new();
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"supportsTablet",
),
::jacquard_lexicon::lexicon::LexObjectProperty::Boolean(::jacquard_lexicon::lexicon::LexBoolean {
description: None,
default: None,
r#const: None,
}),
);
map
},
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static("launchAsset"),
::jacquard_lexicon::lexicon::LexUserType::Object(::jacquard_lexicon::lexicon::LexObject {
description: None,
required: Some(
vec![
::jacquard_common::deps::smol_str::SmolStr::new_static("key"),
::jacquard_common::deps::smol_str::SmolStr::new_static("contentType"),
::jacquard_common::deps::smol_str::SmolStr::new_static("url")
],
),
nullable: None,
properties: {
#[allow(unused_mut)]
let mut map = ::alloc::collections::BTreeMap::new();
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"contentType",
),
::jacquard_lexicon::lexicon::LexObjectProperty::String(::jacquard_lexicon::lexicon::LexString {
description: Some(
::jacquard_common::CowStr::new_static(
"The MIME type of the asset, e.g., 'image/png'.",
),
),
format: None,
default: None,
min_length: None,
max_length: None,
min_graphemes: None,
max_graphemes: None,
r#enum: None,
r#const: None,
known_values: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"key",
),
::jacquard_lexicon::lexicon::LexObjectProperty::String(::jacquard_lexicon::lexicon::LexString {
description: Some(
::jacquard_common::CowStr::new_static(
"The unique key for this asset, used to reference it in the plugin.",
),
),
format: None,
default: None,
min_length: None,
max_length: None,
min_graphemes: None,
max_graphemes: None,
r#enum: None,
r#const: None,
known_values: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"url",
),
::jacquard_lexicon::lexicon::LexObjectProperty::String(::jacquard_lexicon::lexicon::LexString {
description: Some(
::jacquard_common::CowStr::new_static(
"The URL where the asset can be accessed.",
),
),
format: Some(
::jacquard_lexicon::lexicon::LexStringFormat::Uri,
),
default: None,
min_length: None,
max_length: None,
min_graphemes: None,
max_graphemes: None,
r#enum: None,
r#const: None,
known_values: None,
}),
);
map
},
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static("manifest"),
::jacquard_lexicon::lexicon::LexUserType::Object(::jacquard_lexicon::lexicon::LexObject {
description: None,
required: Some(
vec![
::jacquard_common::deps::smol_str::SmolStr::new_static("id"),
::jacquard_common::deps::smol_str::SmolStr::new_static("createdAt"),
::jacquard_common::deps::smol_str::SmolStr::new_static("runtimeVersion"),
::jacquard_common::deps::smol_str::SmolStr::new_static("launchAsset"),
::jacquard_common::deps::smol_str::SmolStr::new_static("metadata"),
::jacquard_common::deps::smol_str::SmolStr::new_static("extra")
],
),
nullable: None,
properties: {
#[allow(unused_mut)]
let mut map = ::alloc::collections::BTreeMap::new();
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"createdAt",
),
::jacquard_lexicon::lexicon::LexObjectProperty::String(::jacquard_lexicon::lexicon::LexString {
description: Some(
::jacquard_common::CowStr::new_static(
"The date and time when this plugin manifest was created.",
),
),
format: Some(
::jacquard_lexicon::lexicon::LexStringFormat::Datetime,
),
default: None,
min_length: None,
max_length: None,
min_graphemes: None,
max_graphemes: None,
r#enum: None,
r#const: None,
known_values: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"extra",
),
::jacquard_lexicon::lexicon::LexObjectProperty::Ref(::jacquard_lexicon::lexicon::LexRef {
description: None,
r#ref: ::jacquard_common::CowStr::new_static(
"app.ocho.plugin.defs#manifestExtra",
),
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static("id"),
::jacquard_lexicon::lexicon::LexObjectProperty::String(::jacquard_lexicon::lexicon::LexString {
description: Some(
::jacquard_common::CowStr::new_static(
"The unique identifier for this plugin manifest.",
),
),
format: None,
default: None,
min_length: None,
max_length: None,
min_graphemes: None,
max_graphemes: None,
r#enum: None,
r#const: None,
known_values: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"launchAsset",
),
::jacquard_lexicon::lexicon::LexObjectProperty::Ref(::jacquard_lexicon::lexicon::LexRef {
description: None,
r#ref: ::jacquard_common::CowStr::new_static(
"app.ocho.plugin.defs#launchAsset",
),
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"metadata",
),
::jacquard_lexicon::lexicon::LexObjectProperty::Unknown(::jacquard_lexicon::lexicon::LexUnknown {
description: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"runtimeVersion",
),
::jacquard_lexicon::lexicon::LexObjectProperty::String(::jacquard_lexicon::lexicon::LexString {
description: Some(
::jacquard_common::CowStr::new_static(
"The version of the Expo runtime this plugin is compatible with.",
),
),
format: None,
default: None,
min_length: None,
max_length: None,
min_graphemes: None,
max_graphemes: None,
r#enum: None,
r#const: None,
known_values: None,
}),
);
map
},
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static("manifestExtra"),
::jacquard_lexicon::lexicon::LexUserType::Object(::jacquard_lexicon::lexicon::LexObject {
description: None,
required: Some(
vec![
::jacquard_common::deps::smol_str::SmolStr::new_static("expoClient"),
::jacquard_common::deps::smol_str::SmolStr::new_static("expoGo")
],
),
nullable: None,
properties: {
#[allow(unused_mut)]
let mut map = ::alloc::collections::BTreeMap::new();
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"expoClient",
),
::jacquard_lexicon::lexicon::LexObjectProperty::Ref(::jacquard_lexicon::lexicon::LexRef {
description: None,
r#ref: ::jacquard_common::CowStr::new_static("#expoClient"),
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"expoGo",
),
::jacquard_lexicon::lexicon::LexObjectProperty::Ref(::jacquard_lexicon::lexicon::LexRef {
description: None,
r#ref: ::jacquard_common::CowStr::new_static("#expoGo"),
}),
);
map
},
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static("plugin"),
::jacquard_lexicon::lexicon::LexUserType::Array(::jacquard_lexicon::lexicon::LexArray {
description: None,
items: ::jacquard_lexicon::lexicon::LexArrayItem::Union(::jacquard_lexicon::lexicon::LexRefUnion {
description: None,
refs: vec![
::jacquard_common::CowStr::new_static("#stringId"),
::jacquard_common::CowStr::new_static("#pluginConfig")
],
closed: None,
}),
min_length: None,
max_length: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static("pluginConfig"),
::jacquard_lexicon::lexicon::LexUserType::Unknown(::jacquard_lexicon::lexicon::LexUnknown {
description: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static("stringId"),
::jacquard_lexicon::lexicon::LexUserType::String(::jacquard_lexicon::lexicon::LexString {
description: Some(
::jacquard_common::CowStr::new_static(
"A string identifier for a plugin, used to reference it in the app.",
),
),
format: None,
default: None,
min_length: None,
max_length: None,
min_graphemes: None,
max_graphemes: None,
r#enum: None,
r#const: None,
known_values: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static("web"),
::jacquard_lexicon::lexicon::LexUserType::Object(::jacquard_lexicon::lexicon::LexObject {
description: None,
required: None,
nullable: None,
properties: {
#[allow(unused_mut)]
let mut map = ::alloc::collections::BTreeMap::new();
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"bundler",
),
::jacquard_lexicon::lexicon::LexObjectProperty::String(::jacquard_lexicon::lexicon::LexString {
description: Some(
::jacquard_common::CowStr::new_static(
"The bundler used for the web app.",
),
),
format: None,
default: None,
min_length: None,
max_length: None,
min_graphemes: None,
max_graphemes: None,
r#enum: None,
r#const: None,
known_values: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"favicon",
),
::jacquard_lexicon::lexicon::LexObjectProperty::String(::jacquard_lexicon::lexicon::LexString {
description: Some(
::jacquard_common::CowStr::new_static(
"The URL to the favicon for the web app.",
),
),
format: None,
default: None,
min_length: None,
max_length: None,
min_graphemes: None,
max_graphemes: None,
r#enum: None,
r#const: None,
known_values: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"faviconBlob",
),
::jacquard_lexicon::lexicon::LexObjectProperty::Blob(::jacquard_lexicon::lexicon::LexBlob {
description: None,
accept: None,
max_size: None,
}),
);
map.insert(
::jacquard_common::deps::smol_str::SmolStr::new_static(
"output",
),
::jacquard_lexicon::lexicon::LexObjectProperty::String(::jacquard_lexicon::lexicon::LexString {
description: Some(
::jacquard_common::CowStr::new_static(
"The output directory for the web app.",
),
),
format: None,
default: None,
min_length: None,
max_length: None,
min_graphemes: None,
max_graphemes: None,
r#enum: None,
r#const: None,
known_values: None,
}),
);
map
},
}),
);
map
},
}
}
impl<'a> ::jacquard_lexicon::schema::LexiconSchema for AdaptiveIcon<'a> {
fn nsid() -> &'static str {
"app.ocho.plugin.defs"
}
fn def_name() -> &'static str {
"adaptiveIcon"
}
fn lexicon_doc() -> ::jacquard_lexicon::lexicon::LexiconDoc<'static> {
lexicon_doc_app_ocho_plugin_defs()
}
fn validate(
&self,
) -> ::core::result::Result<(), ::jacquard_lexicon::validation::ConstraintError> {
Ok(())
}
}
#[jacquard_derive::lexicon]
#[derive(
serde::Serialize,
serde::Deserialize,
Debug,
Clone,
PartialEq,
Eq,
jacquard_derive::IntoStatic,
Default
)]
#[serde(rename_all = "camelCase")]
pub struct Android<'a> {
#[serde(skip_serializing_if = "std::option::Option::is_none")]
#[serde(borrow)]
pub adaptive_icon: std::option::Option<crate::app_ocho::plugin::AdaptiveIcon<'a>>,
#[serde(skip_serializing_if = "std::option::Option::is_none")]
pub edge_to_edge_enabled: std::option::Option<bool>,
}
impl<'a> ::jacquard_lexicon::schema::LexiconSchema for Android<'a> {
fn nsid() -> &'static str {
"app.ocho.plugin.defs"
}
fn def_name() -> &'static str {
"android"
}
fn lexicon_doc() -> ::jacquard_lexicon::lexicon::LexiconDoc<'static> {
lexicon_doc_app_ocho_plugin_defs()
}
fn validate(
&self,
) -> ::core::result::Result<(), ::jacquard_lexicon::validation::ConstraintError> {
Ok(())
}
}
#[jacquard_derive::lexicon]
#[derive(
serde::Serialize,
serde::Deserialize,
Debug,
Clone,
PartialEq,
Eq,
jacquard_derive::IntoStatic,
Default
)]
#[serde(rename_all = "camelCase")]
pub struct AndroidStatusBar<'a> {
#[serde(skip_serializing_if = "std::option::Option::is_none")]
#[serde(borrow)]
pub background_color: std::option::Option<jacquard_common::CowStr<'a>>,
}
impl<'a> ::jacquard_lexicon::schema::LexiconSchema for AndroidStatusBar<'a> {
fn nsid() -> &'static str {
"app.ocho.plugin.defs"
}
fn def_name() -> &'static str {
"androidStatusBar"
}
fn lexicon_doc() -> ::jacquard_lexicon::lexicon::LexiconDoc<'static> {
lexicon_doc_app_ocho_plugin_defs()
}
fn validate(
&self,
) -> ::core::result::Result<(), ::jacquard_lexicon::validation::ConstraintError> {
Ok(())
}
}
#[jacquard_derive::lexicon]
#[derive(
serde::Serialize,
serde::Deserialize,
Debug,
Clone,
PartialEq,
Eq,
jacquard_derive::IntoStatic
)]
#[serde(rename_all = "camelCase")]
pub struct Asset<'a> {
#[serde(borrow)]
pub blob: jacquard_common::types::blob::BlobRef<'a>,
#[serde(borrow)]
pub hash: jacquard_common::CowStr<'a>,
#[serde(borrow)]
pub r#type: jacquard_common::CowStr<'a>,
#[serde(skip_serializing_if = "std::option::Option::is_none")]
pub updated_at: std::option::Option<jacquard_common::types::string::Datetime>,
}
pub mod asset_state {
pub use crate::builder_types::{Set, Unset, IsSet, IsUnset};
#[allow(unused)]
use ::core::marker::PhantomData;
mod sealed {
pub trait Sealed {}
}
pub trait State: sealed::Sealed {
type Hash;
type Type;
type Blob;
}
pub struct Empty(());
impl sealed::Sealed for Empty {}
impl State for Empty {
type Hash = Unset;
type Type = Unset;
type Blob = Unset;
}
pub struct SetHash<S: State = Empty>(PhantomData<fn() -> S>);
impl<S: State> sealed::Sealed for SetHash<S> {}
impl<S: State> State for SetHash<S> {
type Hash = Set<members::hash>;
type Type = S::Type;
type Blob = S::Blob;
}
pub struct SetType<S: State = Empty>(PhantomData<fn() -> S>);
impl<S: State> sealed::Sealed for SetType<S> {}
impl<S: State> State for SetType<S> {
type Hash = S::Hash;
type Type = Set<members::r#type>;
type Blob = S::Blob;
}
pub struct SetBlob<S: State = Empty>(PhantomData<fn() -> S>);
impl<S: State> sealed::Sealed for SetBlob<S> {}
impl<S: State> State for SetBlob<S> {
type Hash = S::Hash;
type Type = S::Type;
type Blob = Set<members::blob>;
}
#[allow(non_camel_case_types)]
pub mod members {
pub struct hash(());
pub struct r#type(());
pub struct blob(());
}
}
pub struct AssetBuilder<'a, S: asset_state::State> {
_phantom_state: ::core::marker::PhantomData<fn() -> S>,
__unsafe_private_named: (
::core::option::Option<jacquard_common::types::blob::BlobRef<'a>>,
::core::option::Option<jacquard_common::CowStr<'a>>,
::core::option::Option<jacquard_common::CowStr<'a>>,
::core::option::Option<jacquard_common::types::string::Datetime>,
),
_phantom: ::core::marker::PhantomData<&'a ()>,
}
impl<'a> Asset<'a> {
pub fn new() -> AssetBuilder<'a, asset_state::Empty> {
AssetBuilder::new()
}
}
impl<'a> AssetBuilder<'a, asset_state::Empty> {
pub fn new() -> Self {
AssetBuilder {
_phantom_state: ::core::marker::PhantomData,
__unsafe_private_named: (None, None, None, None),
_phantom: ::core::marker::PhantomData,
}
}
}
impl<'a, S> AssetBuilder<'a, S>
where
S: asset_state::State,
S::Blob: asset_state::IsUnset,
{
pub fn blob(
mut self,
value: impl Into<jacquard_common::types::blob::BlobRef<'a>>,
) -> AssetBuilder<'a, asset_state::SetBlob<S>> {
self.__unsafe_private_named.0 = ::core::option::Option::Some(value.into());
AssetBuilder {
_phantom_state: ::core::marker::PhantomData,
__unsafe_private_named: self.__unsafe_private_named,
_phantom: ::core::marker::PhantomData,
}
}
}
impl<'a, S> AssetBuilder<'a, S>
where
S: asset_state::State,
S::Hash: asset_state::IsUnset,
{
pub fn hash(
mut self,
value: impl Into<jacquard_common::CowStr<'a>>,
) -> AssetBuilder<'a, asset_state::SetHash<S>> {
self.__unsafe_private_named.1 = ::core::option::Option::Some(value.into());
AssetBuilder {
_phantom_state: ::core::marker::PhantomData,
__unsafe_private_named: self.__unsafe_private_named,
_phantom: ::core::marker::PhantomData,
}
}
}
impl<'a, S> AssetBuilder<'a, S>
where
S: asset_state::State,
S::Type: asset_state::IsUnset,
{
pub fn r#type(
mut self,
value: impl Into<jacquard_common::CowStr<'a>>,
) -> AssetBuilder<'a, asset_state::SetType<S>> {
self.__unsafe_private_named.2 = ::core::option::Option::Some(value.into());
AssetBuilder {
_phantom_state: ::core::marker::PhantomData,
__unsafe_private_named: self.__unsafe_private_named,
_phantom: ::core::marker::PhantomData,
}
}
}
impl<'a, S: asset_state::State> AssetBuilder<'a, S> {
pub fn updated_at(
mut self,
value: impl Into<Option<jacquard_common::types::string::Datetime>>,
) -> Self {
self.__unsafe_private_named.3 = value.into();
self
}
pub fn maybe_updated_at(
mut self,
value: Option<jacquard_common::types::string::Datetime>,
) -> Self {
self.__unsafe_private_named.3 = value;
self
}
}
impl<'a, S> AssetBuilder<'a, S>
where
S: asset_state::State,
S::Hash: asset_state::IsSet,
S::Type: asset_state::IsSet,
S::Blob: asset_state::IsSet,
{
pub fn build(self) -> Asset<'a> {
Asset {
blob: self.__unsafe_private_named.0.unwrap(),
hash: self.__unsafe_private_named.1.unwrap(),
r#type: self.__unsafe_private_named.2.unwrap(),
updated_at: self.__unsafe_private_named.3,
extra_data: Default::default(),
}
}
pub fn build_with_data(
self,
extra_data: std::collections::BTreeMap<
jacquard_common::deps::smol_str::SmolStr,
jacquard_common::types::value::Data<'a>,
>,
) -> Asset<'a> {
Asset {
blob: self.__unsafe_private_named.0.unwrap(),
hash: self.__unsafe_private_named.1.unwrap(),
r#type: self.__unsafe_private_named.2.unwrap(),
updated_at: self.__unsafe_private_named.3,
extra_data: Some(extra_data),
}
}
}
impl<'a> ::jacquard_lexicon::schema::LexiconSchema for Asset<'a> {
fn nsid() -> &'static str {
"app.ocho.plugin.defs"
}
fn def_name() -> &'static str {
"asset"
}
fn lexicon_doc() -> ::jacquard_lexicon::lexicon::LexiconDoc<'static> {
lexicon_doc_app_ocho_plugin_defs()
}
fn validate(
&self,
) -> ::core::result::Result<(), ::jacquard_lexicon::validation::ConstraintError> {
Ok(())
}
}
#[jacquard_derive::lexicon]
#[derive(
serde::Serialize,
serde::Deserialize,
Debug,
Clone,
PartialEq,
Eq,
jacquard_derive::IntoStatic,
Default
)]
#[serde(rename_all = "camelCase")]
pub struct Db<'a> {
#[serde(borrow)]
pub id: jacquard_common::CowStr<'a>,
}
impl<'a> ::jacquard_lexicon::schema::LexiconSchema for Db<'a> {
fn nsid() -> &'static str {
"app.ocho.plugin.defs"
}
fn def_name() -> &'static str {
"db"
}
fn lexicon_doc() -> ::jacquard_lexicon::lexicon::LexiconDoc<'static> {
lexicon_doc_app_ocho_plugin_defs()
}
fn validate(
&self,
) -> ::core::result::Result<(), ::jacquard_lexicon::validation::ConstraintError> {
Ok(())
}
}
#[jacquard_derive::lexicon]
#[derive(
serde::Serialize,
serde::Deserialize,
Debug,
Clone,
PartialEq,
Eq,
jacquard_derive::IntoStatic,
Default
)]
#[serde(rename_all = "camelCase")]
pub struct Developer<'a> {
#[serde(borrow)]
pub tool: jacquard_common::CowStr<'a>,
}
impl<'a> ::jacquard_lexicon::schema::LexiconSchema for Developer<'a> {
fn nsid() -> &'static str {
"app.ocho.plugin.defs"
}
fn def_name() -> &'static str {
"developer"
}
fn lexicon_doc() -> ::jacquard_lexicon::lexicon::LexiconDoc<'static> {
lexicon_doc_app_ocho_plugin_defs()
}
fn validate(
&self,
) -> ::core::result::Result<(), ::jacquard_lexicon::validation::ConstraintError> {
Ok(())
}
}
#[jacquard_derive::lexicon]
#[derive(
serde::Serialize,
serde::Deserialize,
Debug,
Clone,
PartialEq,
Eq,
jacquard_derive::IntoStatic,
Default
)]
#[serde(rename_all = "camelCase")]
pub struct ExpoClient<'a> {
#[serde(skip_serializing_if = "std::option::Option::is_none")]
#[serde(borrow)]
pub android: std::option::Option<crate::app_ocho::plugin::Android<'a>>,
#[serde(skip_serializing_if = "std::option::Option::is_none")]
#[serde(borrow)]
pub android_status_bar: std::option::Option<
crate::app_ocho::plugin::AndroidStatusBar<'a>,
>,
#[serde(skip_serializing_if = "std::option::Option::is_none")]
#[serde(borrow)]
pub expirements: std::option::Option<jacquard_common::types::value::Data<'a>>,
#[serde(skip_serializing_if = "std::option::Option::is_none")]
#[serde(borrow)]
pub extra: std::option::Option<jacquard_common::types::value::Data<'a>>,
#[serde(skip_serializing_if = "std::option::Option::is_none")]
#[serde(borrow)]
pub icon: std::option::Option<jacquard_common::CowStr<'a>>,
#[serde(skip_serializing_if = "std::option::Option::is_none")]
#[serde(borrow)]
pub ios: std::option::Option<crate::app_ocho::plugin::Ios<'a>>,
#[serde(skip_serializing_if = "std::option::Option::is_none")]
#[serde(borrow)]
pub locales: std::option::Option<jacquard_common::types::value::Data<'a>>,
#[serde(borrow)]
pub name: jacquard_common::CowStr<'a>,
#[serde(skip_serializing_if = "std::option::Option::is_none")]
pub new_arch_enabled: std::option::Option<bool>,
#[serde(skip_serializing_if = "std::option::Option::is_none")]
#[serde(borrow)]
pub orientation: std::option::Option<jacquard_common::CowStr<'a>>,
#[serde(skip_serializing_if = "std::option::Option::is_none")]
#[serde(borrow)]
pub platforms: std::option::Option<Vec<jacquard_common::CowStr<'a>>>,
#[serde(skip_serializing_if = "std::option::Option::is_none")]
#[serde(borrow)]
pub plugins: std::option::Option<jacquard_common::types::value::Data<'a>>,
#[serde(skip_serializing_if = "std::option::Option::is_none")]
#[serde(borrow)]
pub scheme: std::option::Option<jacquard_common::CowStr<'a>>,
#[serde(skip_serializing_if = "std::option::Option::is_none")]
#[serde(borrow)]
pub sdk_version: std::option::Option<jacquard_common::CowStr<'a>>,
#[serde(borrow)]
pub slug: jacquard_common::CowStr<'a>,
#[serde(skip_serializing_if = "std::option::Option::is_none")]
#[serde(borrow)]
pub user_interface_style: std::option::Option<jacquard_common::CowStr<'a>>,
#[serde(skip_serializing_if = "std::option::Option::is_none")]
#[serde(borrow)]
pub version: std::option::Option<jacquard_common::CowStr<'a>>,
#[serde(skip_serializing_if = "std::option::Option::is_none")]
#[serde(borrow)]
pub web: std::option::Option<crate::app_ocho::plugin::Web<'a>>,
}
impl<'a> ::jacquard_lexicon::schema::LexiconSchema for ExpoClient<'a> {
fn nsid() -> &'static str {
"app.ocho.plugin.defs"
}
fn def_name() -> &'static str {
"expoClient"
}
fn lexicon_doc() -> ::jacquard_lexicon::lexicon::LexiconDoc<'static> {
lexicon_doc_app_ocho_plugin_defs()
}
fn validate(
&self,
) -> ::core::result::Result<(), ::jacquard_lexicon::validation::ConstraintError> {
Ok(())
}
}
#[jacquard_derive::lexicon]
#[derive(
serde::Serialize,
serde::Deserialize,
Debug,
Clone,
PartialEq,
Eq,
jacquard_derive::IntoStatic
)]
#[serde(rename_all = "camelCase")]
pub struct ExpoGo<'a> {
#[serde(borrow)]
pub developer: crate::app_ocho::plugin::Developer<'a>,
}
pub mod expo_go_state {
pub use crate::builder_types::{Set, Unset, IsSet, IsUnset};
#[allow(unused)]
use ::core::marker::PhantomData;
mod sealed {
pub trait Sealed {}
}
pub trait State: sealed::Sealed {
type Developer;
}
pub struct Empty(());
impl sealed::Sealed for Empty {}
impl State for Empty {
type Developer = Unset;
}
pub struct SetDeveloper<S: State = Empty>(PhantomData<fn() -> S>);
impl<S: State> sealed::Sealed for SetDeveloper<S> {}
impl<S: State> State for SetDeveloper<S> {
type Developer = Set<members::developer>;
}
#[allow(non_camel_case_types)]
pub mod members {
pub struct developer(());
}
}
pub struct ExpoGoBuilder<'a, S: expo_go_state::State> {
_phantom_state: ::core::marker::PhantomData<fn() -> S>,
__unsafe_private_named: (
::core::option::Option<crate::app_ocho::plugin::Developer<'a>>,
),
_phantom: ::core::marker::PhantomData<&'a ()>,
}
impl<'a> ExpoGo<'a> {
pub fn new() -> ExpoGoBuilder<'a, expo_go_state::Empty> {
ExpoGoBuilder::new()
}
}
impl<'a> ExpoGoBuilder<'a, expo_go_state::Empty> {
pub fn new() -> Self {
ExpoGoBuilder {
_phantom_state: ::core::marker::PhantomData,
__unsafe_private_named: (None,),
_phantom: ::core::marker::PhantomData,
}
}
}
impl<'a, S> ExpoGoBuilder<'a, S>
where
S: expo_go_state::State,
S::Developer: expo_go_state::IsUnset,
{
pub fn developer(
mut self,
value: impl Into<crate::app_ocho::plugin::Developer<'a>>,
) -> ExpoGoBuilder<'a, expo_go_state::SetDeveloper<S>> {
self.__unsafe_private_named.0 = ::core::option::Option::Some(value.into());
ExpoGoBuilder {
_phantom_state: ::core::marker::PhantomData,
__unsafe_private_named: self.__unsafe_private_named,
_phantom: ::core::marker::PhantomData,
}
}
}
impl<'a, S> ExpoGoBuilder<'a, S>
where
S: expo_go_state::State,
S::Developer: expo_go_state::IsSet,
{
pub fn build(self) -> ExpoGo<'a> {
ExpoGo {
developer: self.__unsafe_private_named.0.unwrap(),
extra_data: Default::default(),
}
}
pub fn build_with_data(
self,
extra_data: std::collections::BTreeMap<
jacquard_common::deps::smol_str::SmolStr,
jacquard_common::types::value::Data<'a>,
>,
) -> ExpoGo<'a> {
ExpoGo {
developer: self.__unsafe_private_named.0.unwrap(),
extra_data: Some(extra_data),
}
}
}
impl<'a> ::jacquard_lexicon::schema::LexiconSchema for ExpoGo<'a> {
fn nsid() -> &'static str {
"app.ocho.plugin.defs"
}
fn def_name() -> &'static str {
"expoGo"
}
fn lexicon_doc() -> ::jacquard_lexicon::lexicon::LexiconDoc<'static> {
lexicon_doc_app_ocho_plugin_defs()
}
fn validate(
&self,
) -> ::core::result::Result<(), ::jacquard_lexicon::validation::ConstraintError> {
Ok(())
}
}
#[jacquard_derive::lexicon]
#[derive(
serde::Serialize,
serde::Deserialize,
Debug,
Clone,
PartialEq,
Eq,
jacquard_derive::IntoStatic,
Default
)]
#[serde(rename_all = "camelCase")]
pub struct Ios<'a> {
#[serde(skip_serializing_if = "std::option::Option::is_none")]
pub supports_tablet: std::option::Option<bool>,
}
impl<'a> ::jacquard_lexicon::schema::LexiconSchema for Ios<'a> {
fn nsid() -> &'static str {
"app.ocho.plugin.defs"
}
fn def_name() -> &'static str {
"ios"
}
fn lexicon_doc() -> ::jacquard_lexicon::lexicon::LexiconDoc<'static> {
lexicon_doc_app_ocho_plugin_defs()
}
fn validate(
&self,
) -> ::core::result::Result<(), ::jacquard_lexicon::validation::ConstraintError> {
Ok(())
}
}
#[jacquard_derive::lexicon]
#[derive(
serde::Serialize,
serde::Deserialize,
Debug,
Clone,
PartialEq,
Eq,
jacquard_derive::IntoStatic
)]
#[serde(rename_all = "camelCase")]
pub struct LaunchAsset<'a> {
#[serde(borrow)]
pub content_type: jacquard_common::CowStr<'a>,
#[serde(borrow)]
pub key: jacquard_common::CowStr<'a>,
#[serde(borrow)]
pub url: jacquard_common::types::string::UriValue<'a>,
}
pub mod launch_asset_state {
pub use crate::builder_types::{Set, Unset, IsSet, IsUnset};
#[allow(unused)]
use ::core::marker::PhantomData;
mod sealed {
pub trait Sealed {}
}
pub trait State: sealed::Sealed {
type Url;
type Key;
type ContentType;
}
pub struct Empty(());
impl sealed::Sealed for Empty {}
impl State for Empty {
type Url = Unset;
type Key = Unset;
type ContentType = Unset;
}
pub struct SetUrl<S: State = Empty>(PhantomData<fn() -> S>);
impl<S: State> sealed::Sealed for SetUrl<S> {}
impl<S: State> State for SetUrl<S> {
type Url = Set<members::url>;
type Key = S::Key;
type ContentType = S::ContentType;
}
pub struct SetKey<S: State = Empty>(PhantomData<fn() -> S>);
impl<S: State> sealed::Sealed for SetKey<S> {}
impl<S: State> State for SetKey<S> {
type Url = S::Url;
type Key = Set<members::key>;
type ContentType = S::ContentType;
}
pub struct SetContentType<S: State = Empty>(PhantomData<fn() -> S>);
impl<S: State> sealed::Sealed for SetContentType<S> {}
impl<S: State> State for SetContentType<S> {
type Url = S::Url;
type Key = S::Key;
type ContentType = Set<members::content_type>;
}
#[allow(non_camel_case_types)]
pub mod members {
pub struct url(());
pub struct key(());
pub struct content_type(());
}
}
pub struct LaunchAssetBuilder<'a, S: launch_asset_state::State> {
_phantom_state: ::core::marker::PhantomData<fn() -> S>,
__unsafe_private_named: (
::core::option::Option<jacquard_common::CowStr<'a>>,
::core::option::Option<jacquard_common::CowStr<'a>>,
::core::option::Option<jacquard_common::types::string::UriValue<'a>>,
),
_phantom: ::core::marker::PhantomData<&'a ()>,
}
impl<'a> LaunchAsset<'a> {
pub fn new() -> LaunchAssetBuilder<'a, launch_asset_state::Empty> {
LaunchAssetBuilder::new()
}
}
impl<'a> LaunchAssetBuilder<'a, launch_asset_state::Empty> {
pub fn new() -> Self {
LaunchAssetBuilder {
_phantom_state: ::core::marker::PhantomData,
__unsafe_private_named: (None, None, None),
_phantom: ::core::marker::PhantomData,
}
}
}
impl<'a, S> LaunchAssetBuilder<'a, S>
where
S: launch_asset_state::State,
S::ContentType: launch_asset_state::IsUnset,
{
pub fn content_type(
mut self,
value: impl Into<jacquard_common::CowStr<'a>>,
) -> LaunchAssetBuilder<'a, launch_asset_state::SetContentType<S>> {
self.__unsafe_private_named.0 = ::core::option::Option::Some(value.into());
LaunchAssetBuilder {
_phantom_state: ::core::marker::PhantomData,
__unsafe_private_named: self.__unsafe_private_named,
_phantom: ::core::marker::PhantomData,
}
}
}
impl<'a, S> LaunchAssetBuilder<'a, S>
where
S: launch_asset_state::State,
S::Key: launch_asset_state::IsUnset,
{
pub fn key(
mut self,
value: impl Into<jacquard_common::CowStr<'a>>,
) -> LaunchAssetBuilder<'a, launch_asset_state::SetKey<S>> {
self.__unsafe_private_named.1 = ::core::option::Option::Some(value.into());
LaunchAssetBuilder {
_phantom_state: ::core::marker::PhantomData,
__unsafe_private_named: self.__unsafe_private_named,
_phantom: ::core::marker::PhantomData,
}
}
}
impl<'a, S> LaunchAssetBuilder<'a, S>
where
S: launch_asset_state::State,
S::Url: launch_asset_state::IsUnset,
{
pub fn url(
mut self,
value: impl Into<jacquard_common::types::string::UriValue<'a>>,
) -> LaunchAssetBuilder<'a, launch_asset_state::SetUrl<S>> {
self.__unsafe_private_named.2 = ::core::option::Option::Some(value.into());
LaunchAssetBuilder {
_phantom_state: ::core::marker::PhantomData,
__unsafe_private_named: self.__unsafe_private_named,
_phantom: ::core::marker::PhantomData,
}
}
}
impl<'a, S> LaunchAssetBuilder<'a, S>
where
S: launch_asset_state::State,
S::Url: launch_asset_state::IsSet,
S::Key: launch_asset_state::IsSet,
S::ContentType: launch_asset_state::IsSet,
{
pub fn build(self) -> LaunchAsset<'a> {
LaunchAsset {
content_type: self.__unsafe_private_named.0.unwrap(),
key: self.__unsafe_private_named.1.unwrap(),
url: self.__unsafe_private_named.2.unwrap(),
extra_data: Default::default(),
}
}
pub fn build_with_data(
self,
extra_data: std::collections::BTreeMap<
jacquard_common::deps::smol_str::SmolStr,
jacquard_common::types::value::Data<'a>,
>,
) -> LaunchAsset<'a> {
LaunchAsset {
content_type: self.__unsafe_private_named.0.unwrap(),
key: self.__unsafe_private_named.1.unwrap(),
url: self.__unsafe_private_named.2.unwrap(),
extra_data: Some(extra_data),
}
}
}
impl<'a> ::jacquard_lexicon::schema::LexiconSchema for LaunchAsset<'a> {
fn nsid() -> &'static str {
"app.ocho.plugin.defs"
}
fn def_name() -> &'static str {
"launchAsset"
}
fn lexicon_doc() -> ::jacquard_lexicon::lexicon::LexiconDoc<'static> {
lexicon_doc_app_ocho_plugin_defs()
}
fn validate(
&self,
) -> ::core::result::Result<(), ::jacquard_lexicon::validation::ConstraintError> {
Ok(())
}
}
#[jacquard_derive::lexicon]
#[derive(
serde::Serialize,
serde::Deserialize,
Debug,
Clone,
PartialEq,
Eq,
jacquard_derive::IntoStatic
)]
#[serde(rename_all = "camelCase")]
pub struct Manifest<'a> {
pub created_at: jacquard_common::types::string::Datetime,
#[serde(borrow)]
pub extra: crate::app_ocho::plugin::ManifestExtra<'a>,
#[serde(borrow)]
pub id: jacquard_common::CowStr<'a>,
#[serde(borrow)]
pub launch_asset: crate::app_ocho::plugin::LaunchAsset<'a>,
#[serde(borrow)]
pub metadata: jacquard_common::types::value::Data<'a>,
#[serde(borrow)]
pub runtime_version: jacquard_common::CowStr<'a>,
}
pub mod manifest_state {
pub use crate::builder_types::{Set, Unset, IsSet, IsUnset};
#[allow(unused)]
use ::core::marker::PhantomData;
mod sealed {
pub trait Sealed {}
}
pub trait State: sealed::Sealed {
type RuntimeVersion;
type Extra;
type LaunchAsset;
type Id;
type Metadata;
type CreatedAt;
}
pub struct Empty(());
impl sealed::Sealed for Empty {}
impl State for Empty {
type RuntimeVersion = Unset;
type Extra = Unset;
type LaunchAsset = Unset;
type Id = Unset;
type Metadata = Unset;
type CreatedAt = Unset;
}
pub struct SetRuntimeVersion<S: State = Empty>(PhantomData<fn() -> S>);
impl<S: State> sealed::Sealed for SetRuntimeVersion<S> {}
impl<S: State> State for SetRuntimeVersion<S> {
type RuntimeVersion = Set<members::runtime_version>;
type Extra = S::Extra;
type LaunchAsset = S::LaunchAsset;
type Id = S::Id;
type Metadata = S::Metadata;
type CreatedAt = S::CreatedAt;
}
pub struct SetExtra<S: State = Empty>(PhantomData<fn() -> S>);
impl<S: State> sealed::Sealed for SetExtra<S> {}
impl<S: State> State for SetExtra<S> {
type RuntimeVersion = S::RuntimeVersion;
type Extra = Set<members::extra>;
type LaunchAsset = S::LaunchAsset;
type Id = S::Id;
type Metadata = S::Metadata;
type CreatedAt = S::CreatedAt;
}
pub struct SetLaunchAsset<S: State = Empty>(PhantomData<fn() -> S>);
impl<S: State> sealed::Sealed for SetLaunchAsset<S> {}
impl<S: State> State for SetLaunchAsset<S> {
type RuntimeVersion = S::RuntimeVersion;
type Extra = S::Extra;
type LaunchAsset = Set<members::launch_asset>;
type Id = S::Id;
type Metadata = S::Metadata;
type CreatedAt = S::CreatedAt;
}
pub struct SetId<S: State = Empty>(PhantomData<fn() -> S>);
impl<S: State> sealed::Sealed for SetId<S> {}
impl<S: State> State for SetId<S> {
type RuntimeVersion = S::RuntimeVersion;
type Extra = S::Extra;
type LaunchAsset = S::LaunchAsset;
type Id = Set<members::id>;
type Metadata = S::Metadata;
type CreatedAt = S::CreatedAt;
}
pub struct SetMetadata<S: State = Empty>(PhantomData<fn() -> S>);
impl<S: State> sealed::Sealed for SetMetadata<S> {}
impl<S: State> State for SetMetadata<S> {
type RuntimeVersion = S::RuntimeVersion;
type Extra = S::Extra;
type LaunchAsset = S::LaunchAsset;
type Id = S::Id;
type Metadata = Set<members::metadata>;
type CreatedAt = S::CreatedAt;
}
pub struct SetCreatedAt<S: State = Empty>(PhantomData<fn() -> S>);
impl<S: State> sealed::Sealed for SetCreatedAt<S> {}
impl<S: State> State for SetCreatedAt<S> {
type RuntimeVersion = S::RuntimeVersion;
type Extra = S::Extra;
type LaunchAsset = S::LaunchAsset;
type Id = S::Id;
type Metadata = S::Metadata;
type CreatedAt = Set<members::created_at>;
}
#[allow(non_camel_case_types)]
pub mod members {
pub struct runtime_version(());
pub struct extra(());
pub struct launch_asset(());
pub struct id(());
pub struct metadata(());
pub struct created_at(());
}
}
pub struct ManifestBuilder<'a, S: manifest_state::State> {
_phantom_state: ::core::marker::PhantomData<fn() -> S>,
__unsafe_private_named: (
::core::option::Option<jacquard_common::types::string::Datetime>,
::core::option::Option<crate::app_ocho::plugin::ManifestExtra<'a>>,
::core::option::Option<jacquard_common::CowStr<'a>>,
::core::option::Option<crate::app_ocho::plugin::LaunchAsset<'a>>,
::core::option::Option<jacquard_common::types::value::Data<'a>>,
::core::option::Option<jacquard_common::CowStr<'a>>,
),
_phantom: ::core::marker::PhantomData<&'a ()>,
}
impl<'a> Manifest<'a> {
pub fn new() -> ManifestBuilder<'a, manifest_state::Empty> {
ManifestBuilder::new()
}
}
impl<'a> ManifestBuilder<'a, manifest_state::Empty> {
pub fn new() -> Self {
ManifestBuilder {
_phantom_state: ::core::marker::PhantomData,
__unsafe_private_named: (None, None, None, None, None, None),
_phantom: ::core::marker::PhantomData,
}
}
}
impl<'a, S> ManifestBuilder<'a, S>
where
S: manifest_state::State,
S::CreatedAt: manifest_state::IsUnset,
{
pub fn created_at(
mut self,
value: impl Into<jacquard_common::types::string::Datetime>,
) -> ManifestBuilder<'a, manifest_state::SetCreatedAt<S>> {
self.__unsafe_private_named.0 = ::core::option::Option::Some(value.into());
ManifestBuilder {
_phantom_state: ::core::marker::PhantomData,
__unsafe_private_named: self.__unsafe_private_named,
_phantom: ::core::marker::PhantomData,
}
}
}
impl<'a, S> ManifestBuilder<'a, S>
where
S: manifest_state::State,
S::Extra: manifest_state::IsUnset,
{
pub fn extra(
mut self,
value: impl Into<crate::app_ocho::plugin::ManifestExtra<'a>>,
) -> ManifestBuilder<'a, manifest_state::SetExtra<S>> {
self.__unsafe_private_named.1 = ::core::option::Option::Some(value.into());
ManifestBuilder {
_phantom_state: ::core::marker::PhantomData,
__unsafe_private_named: self.__unsafe_private_named,
_phantom: ::core::marker::PhantomData,
}
}
}
impl<'a, S> ManifestBuilder<'a, S>
where
S: manifest_state::State,
S::Id: manifest_state::IsUnset,
{
pub fn id(
mut self,
value: impl Into<jacquard_common::CowStr<'a>>,
) -> ManifestBuilder<'a, manifest_state::SetId<S>> {
self.__unsafe_private_named.2 = ::core::option::Option::Some(value.into());
ManifestBuilder {
_phantom_state: ::core::marker::PhantomData,
__unsafe_private_named: self.__unsafe_private_named,
_phantom: ::core::marker::PhantomData,
}
}
}
impl<'a, S> ManifestBuilder<'a, S>
where
S: manifest_state::State,
S::LaunchAsset: manifest_state::IsUnset,
{
pub fn launch_asset(
mut self,
value: impl Into<crate::app_ocho::plugin::LaunchAsset<'a>>,
) -> ManifestBuilder<'a, manifest_state::SetLaunchAsset<S>> {
self.__unsafe_private_named.3 = ::core::option::Option::Some(value.into());
ManifestBuilder {
_phantom_state: ::core::marker::PhantomData,
__unsafe_private_named: self.__unsafe_private_named,
_phantom: ::core::marker::PhantomData,
}
}
}
impl<'a, S> ManifestBuilder<'a, S>
where
S: manifest_state::State,
S::Metadata: manifest_state::IsUnset,
{
pub fn metadata(
mut self,
value: impl Into<jacquard_common::types::value::Data<'a>>,
) -> ManifestBuilder<'a, manifest_state::SetMetadata<S>> {
self.__unsafe_private_named.4 = ::core::option::Option::Some(value.into());
ManifestBuilder {
_phantom_state: ::core::marker::PhantomData,
__unsafe_private_named: self.__unsafe_private_named,
_phantom: ::core::marker::PhantomData,
}
}
}
impl<'a, S> ManifestBuilder<'a, S>
where
S: manifest_state::State,
S::RuntimeVersion: manifest_state::IsUnset,
{
pub fn runtime_version(
mut self,
value: impl Into<jacquard_common::CowStr<'a>>,
) -> ManifestBuilder<'a, manifest_state::SetRuntimeVersion<S>> {
self.__unsafe_private_named.5 = ::core::option::Option::Some(value.into());
ManifestBuilder {
_phantom_state: ::core::marker::PhantomData,
__unsafe_private_named: self.__unsafe_private_named,
_phantom: ::core::marker::PhantomData,
}
}
}
impl<'a, S> ManifestBuilder<'a, S>
where
S: manifest_state::State,
S::RuntimeVersion: manifest_state::IsSet,
S::Extra: manifest_state::IsSet,
S::LaunchAsset: manifest_state::IsSet,
S::Id: manifest_state::IsSet,
S::Metadata: manifest_state::IsSet,
S::CreatedAt: manifest_state::IsSet,
{
pub fn build(self) -> Manifest<'a> {
Manifest {
created_at: self.__unsafe_private_named.0.unwrap(),
extra: self.__unsafe_private_named.1.unwrap(),
id: self.__unsafe_private_named.2.unwrap(),
launch_asset: self.__unsafe_private_named.3.unwrap(),
metadata: self.__unsafe_private_named.4.unwrap(),
runtime_version: self.__unsafe_private_named.5.unwrap(),
extra_data: Default::default(),
}
}
pub fn build_with_data(
self,
extra_data: std::collections::BTreeMap<
jacquard_common::deps::smol_str::SmolStr,
jacquard_common::types::value::Data<'a>,
>,
) -> Manifest<'a> {
Manifest {
created_at: self.__unsafe_private_named.0.unwrap(),
extra: self.__unsafe_private_named.1.unwrap(),
id: self.__unsafe_private_named.2.unwrap(),
launch_asset: self.__unsafe_private_named.3.unwrap(),
metadata: self.__unsafe_private_named.4.unwrap(),
runtime_version: self.__unsafe_private_named.5.unwrap(),
extra_data: Some(extra_data),
}
}
}
impl<'a> ::jacquard_lexicon::schema::LexiconSchema for Manifest<'a> {
fn nsid() -> &'static str {
"app.ocho.plugin.defs"
}
fn def_name() -> &'static str {
"manifest"
}
fn lexicon_doc() -> ::jacquard_lexicon::lexicon::LexiconDoc<'static> {
lexicon_doc_app_ocho_plugin_defs()
}
fn validate(
&self,
) -> ::core::result::Result<(), ::jacquard_lexicon::validation::ConstraintError> {
Ok(())
}
}
#[jacquard_derive::lexicon]
#[derive(
serde::Serialize,
serde::Deserialize,
Debug,
Clone,
PartialEq,
Eq,
jacquard_derive::IntoStatic
)]
#[serde(rename_all = "camelCase")]
pub struct ManifestExtra<'a> {
#[serde(borrow)]
pub expo_client: crate::app_ocho::plugin::ExpoClient<'a>,
#[serde(borrow)]
pub expo_go: crate::app_ocho::plugin::ExpoGo<'a>,
}
pub mod manifest_extra_state {
pub use crate::builder_types::{Set, Unset, IsSet, IsUnset};
#[allow(unused)]
use ::core::marker::PhantomData;
mod sealed {
pub trait Sealed {}
}
pub trait State: sealed::Sealed {
type ExpoClient;
type ExpoGo;
}
pub struct Empty(());
impl sealed::Sealed for Empty {}
impl State for Empty {
type ExpoClient = Unset;
type ExpoGo = Unset;
}
pub struct SetExpoClient<S: State = Empty>(PhantomData<fn() -> S>);
impl<S: State> sealed::Sealed for SetExpoClient<S> {}
impl<S: State> State for SetExpoClient<S> {
type ExpoClient = Set<members::expo_client>;
type ExpoGo = S::ExpoGo;
}
pub struct SetExpoGo<S: State = Empty>(PhantomData<fn() -> S>);
impl<S: State> sealed::Sealed for SetExpoGo<S> {}
impl<S: State> State for SetExpoGo<S> {
type ExpoClient = S::ExpoClient;
type ExpoGo = Set<members::expo_go>;
}
#[allow(non_camel_case_types)]
pub mod members {
pub struct expo_client(());
pub struct expo_go(());
}
}
pub struct ManifestExtraBuilder<'a, S: manifest_extra_state::State> {
_phantom_state: ::core::marker::PhantomData<fn() -> S>,
__unsafe_private_named: (
::core::option::Option<crate::app_ocho::plugin::ExpoClient<'a>>,
::core::option::Option<crate::app_ocho::plugin::ExpoGo<'a>>,
),
_phantom: ::core::marker::PhantomData<&'a ()>,
}
impl<'a> ManifestExtra<'a> {
pub fn new() -> ManifestExtraBuilder<'a, manifest_extra_state::Empty> {
ManifestExtraBuilder::new()
}
}
impl<'a> ManifestExtraBuilder<'a, manifest_extra_state::Empty> {
pub fn new() -> Self {
ManifestExtraBuilder {
_phantom_state: ::core::marker::PhantomData,
__unsafe_private_named: (None, None),
_phantom: ::core::marker::PhantomData,
}
}
}
impl<'a, S> ManifestExtraBuilder<'a, S>
where
S: manifest_extra_state::State,
S::ExpoClient: manifest_extra_state::IsUnset,
{
pub fn expo_client(
mut self,
value: impl Into<crate::app_ocho::plugin::ExpoClient<'a>>,
) -> ManifestExtraBuilder<'a, manifest_extra_state::SetExpoClient<S>> {
self.__unsafe_private_named.0 = ::core::option::Option::Some(value.into());
ManifestExtraBuilder {
_phantom_state: ::core::marker::PhantomData,
__unsafe_private_named: self.__unsafe_private_named,
_phantom: ::core::marker::PhantomData,
}
}
}
impl<'a, S> ManifestExtraBuilder<'a, S>
where
S: manifest_extra_state::State,
S::ExpoGo: manifest_extra_state::IsUnset,
{
pub fn expo_go(
mut self,
value: impl Into<crate::app_ocho::plugin::ExpoGo<'a>>,
) -> ManifestExtraBuilder<'a, manifest_extra_state::SetExpoGo<S>> {
self.__unsafe_private_named.1 = ::core::option::Option::Some(value.into());
ManifestExtraBuilder {
_phantom_state: ::core::marker::PhantomData,
__unsafe_private_named: self.__unsafe_private_named,
_phantom: ::core::marker::PhantomData,
}
}
}
impl<'a, S> ManifestExtraBuilder<'a, S>
where
S: manifest_extra_state::State,
S::ExpoClient: manifest_extra_state::IsSet,
S::ExpoGo: manifest_extra_state::IsSet,
{
pub fn build(self) -> ManifestExtra<'a> {
ManifestExtra {
expo_client: self.__unsafe_private_named.0.unwrap(),
expo_go: self.__unsafe_private_named.1.unwrap(),
extra_data: Default::default(),
}
}
pub fn build_with_data(
self,
extra_data: std::collections::BTreeMap<
jacquard_common::deps::smol_str::SmolStr,
jacquard_common::types::value::Data<'a>,
>,
) -> ManifestExtra<'a> {
ManifestExtra {
expo_client: self.__unsafe_private_named.0.unwrap(),
expo_go: self.__unsafe_private_named.1.unwrap(),
extra_data: Some(extra_data),
}
}
}
impl<'a> ::jacquard_lexicon::schema::LexiconSchema for ManifestExtra<'a> {
fn nsid() -> &'static str {
"app.ocho.plugin.defs"
}
fn def_name() -> &'static str {
"manifestExtra"
}
fn lexicon_doc() -> ::jacquard_lexicon::lexicon::LexiconDoc<'static> {
lexicon_doc_app_ocho_plugin_defs()
}
fn validate(
&self,
) -> ::core::result::Result<(), ::jacquard_lexicon::validation::ConstraintError> {
Ok(())
}
}
#[jacquard_derive::open_union]
#[derive(
serde::Serialize,
serde::Deserialize,
Debug,
Clone,
PartialEq,
Eq,
jacquard_derive::IntoStatic
)]
#[serde(tag = "$type")]
#[serde(bound(deserialize = "'de: 'a"))]
pub enum PluginItem<'a> {
#[serde(rename = "app.ocho.plugin.defs#stringId")]
StringId(Box<crate::app_ocho::plugin::StringId<'a>>),
#[serde(rename = "app.ocho.plugin.defs#pluginConfig")]
PluginConfig(Box<crate::app_ocho::plugin::PluginConfig<'a>>),
}
pub type Plugin<'a> = Vec<PluginItem<'a>>;
pub type PluginConfig<'a> = jacquard_common::types::value::Data<'a>;
pub type StringId<'a> = jacquard_common::CowStr<'a>;
#[jacquard_derive::lexicon]
#[derive(
serde::Serialize,
serde::Deserialize,
Debug,
Clone,
PartialEq,
Eq,
jacquard_derive::IntoStatic,
Default
)]
#[serde(rename_all = "camelCase")]
pub struct Web<'a> {
#[serde(skip_serializing_if = "std::option::Option::is_none")]
#[serde(borrow)]
pub bundler: std::option::Option<jacquard_common::CowStr<'a>>,
#[serde(skip_serializing_if = "std::option::Option::is_none")]
#[serde(borrow)]
pub favicon: std::option::Option<jacquard_common::CowStr<'a>>,
#[serde(skip_serializing_if = "std::option::Option::is_none")]
#[serde(borrow)]
pub favicon_blob: std::option::Option<jacquard_common::types::blob::BlobRef<'a>>,
#[serde(skip_serializing_if = "std::option::Option::is_none")]
#[serde(borrow)]
pub output: std::option::Option<jacquard_common::CowStr<'a>>,
}
impl<'a> ::jacquard_lexicon::schema::LexiconSchema for Web<'a> {
fn nsid() -> &'static str {
"app.ocho.plugin.defs"
}
fn def_name() -> &'static str {
"web"
}
fn lexicon_doc() -> ::jacquard_lexicon::lexicon::LexiconDoc<'static> {
lexicon_doc_app_ocho_plugin_defs()
}
fn validate(
&self,
) -> ::core::result::Result<(), ::jacquard_lexicon::validation::ConstraintError> {
Ok(())
}
}