notedeck

One damus client to rule them all
git clone git://jb55.com/notedeck
Log | Files | Refs | README | LICENSE

preview.rs (3013B)


      1 use notedeck::{DataPath, Notedeck};
      2 use notedeck_chrome::setup::{generate_native_options, setup_chrome};
      3 use notedeck_columns::ui::configure_deck::ConfigureDeckView;
      4 use notedeck_columns::ui::edit_deck::EditDeckView;
      5 use notedeck_columns::ui::profile::EditProfileView;
      6 use notedeck_columns::ui::{
      7     account_login_view::AccountLoginView, PostView, Preview, PreviewApp, PreviewConfig, ProfilePic,
      8     ProfilePreview, RelayView,
      9 };
     10 use std::env;
     11 
     12 struct PreviewRunner {}
     13 
     14 impl PreviewRunner {
     15     fn new() -> Self {
     16         PreviewRunner {}
     17     }
     18 
     19     async fn run<P>(self, preview: P)
     20     where
     21         P: notedeck::App + 'static,
     22     {
     23         tracing_subscriber::fmt::init();
     24 
     25         let base_path = DataPath::default_base_or_cwd();
     26         let path = DataPath::new(&base_path);
     27 
     28         let _res = eframe::run_native(
     29             "Notedeck Preview",
     30             generate_native_options(path),
     31             Box::new(|cc| {
     32                 let args: Vec<String> = std::env::args().collect();
     33                 let ctx = &cc.egui_ctx;
     34 
     35                 let mut notedeck = Notedeck::new(ctx, &base_path, &args);
     36                 assert!(
     37                     notedeck.unrecognized_args().is_empty(),
     38                     "unrecognized args: {:?}",
     39                     notedeck.unrecognized_args()
     40                 );
     41                 setup_chrome(ctx, notedeck.args(), notedeck.theme());
     42 
     43                 notedeck.set_app(PreviewApp::new(preview));
     44 
     45                 Ok(Box::new(notedeck))
     46             }),
     47         );
     48     }
     49 }
     50 
     51 macro_rules! previews {
     52     // Accept a runner and name variable, followed by one or more identifiers for the views
     53     ($runner:expr, $name:expr, $is_mobile:expr, $($view:ident),* $(,)?) => {
     54         match $name.as_ref() {
     55             $(
     56                 stringify!($view) => {
     57                     $runner.run($view::preview(PreviewConfig { is_mobile: $is_mobile })).await;
     58                 }
     59             )*
     60             _ => println!("Component not found."),
     61         }
     62     };
     63 }
     64 
     65 #[tokio::main]
     66 async fn main() {
     67     let mut name: Option<String> = None;
     68     let mut is_mobile: Option<bool> = None;
     69     let mut light_mode: bool = false;
     70 
     71     for arg in env::args() {
     72         if arg == "--mobile" {
     73             is_mobile = Some(true);
     74         } else if arg == "--light" {
     75             light_mode = true;
     76         } else {
     77             name = Some(arg);
     78         }
     79     }
     80 
     81     let name = if let Some(name) = name {
     82         name
     83     } else {
     84         println!("Please specify a component to test");
     85         return;
     86     };
     87 
     88     println!(
     89         "light mode previews: {}",
     90         if light_mode { "enabled" } else { "disabled" }
     91     );
     92     let is_mobile = is_mobile.unwrap_or(notedeck::ui::is_compiled_as_mobile());
     93     let runner = PreviewRunner::new();
     94 
     95     previews!(
     96         runner,
     97         name,
     98         is_mobile,
     99         RelayView,
    100         AccountLoginView,
    101         ProfilePreview,
    102         ProfilePic,
    103         PostView,
    104         ConfigureDeckView,
    105         EditDeckView,
    106         EditProfileView,
    107     );
    108 }