fix: Fix all examples
This commit is contained in:
		@@ -24,6 +24,7 @@ impl Account {
 | 
			
		||||
    /// Create a new account with auto-generated ID
 | 
			
		||||
    ///
 | 
			
		||||
    /// # Arguments
 | 
			
		||||
    /// * `id` - Optional ID for the account (use None for auto-generated ID)
 | 
			
		||||
    /// * `name` - Name of the account
 | 
			
		||||
    /// * `user_id` - ID of the user who owns the account
 | 
			
		||||
    /// * `description` - Description of the account
 | 
			
		||||
@@ -31,6 +32,7 @@ impl Account {
 | 
			
		||||
    /// * `address` - Address of the account on the blockchain
 | 
			
		||||
    /// * `pubkey` - Public key
 | 
			
		||||
    pub fn new(
 | 
			
		||||
        id: Option<u32>,
 | 
			
		||||
        name: impl ToString,
 | 
			
		||||
        user_id: u32,
 | 
			
		||||
        description: impl ToString,
 | 
			
		||||
@@ -38,8 +40,13 @@ impl Account {
 | 
			
		||||
        address: impl ToString,
 | 
			
		||||
        pubkey: impl ToString
 | 
			
		||||
    ) -> Self {
 | 
			
		||||
        let mut base_data = BaseModelData::new();
 | 
			
		||||
        if let Some(id) = id {
 | 
			
		||||
            base_data.update_id(id);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        Self {
 | 
			
		||||
            base_data: BaseModelData::new(),
 | 
			
		||||
            base_data,
 | 
			
		||||
            name: name.to_string(),
 | 
			
		||||
            user_id,
 | 
			
		||||
            description: description.to_string(),
 | 
			
		||||
 
 | 
			
		||||
@@ -34,7 +34,17 @@ pub struct Asset {
 | 
			
		||||
 | 
			
		||||
impl Asset {
 | 
			
		||||
    /// Create a new asset with auto-generated ID
 | 
			
		||||
    ///
 | 
			
		||||
    /// # Arguments
 | 
			
		||||
    /// * `id` - Optional ID for the asset (use None for auto-generated ID)
 | 
			
		||||
    /// * `name` - Name of the asset
 | 
			
		||||
    /// * `description` - Description of the asset
 | 
			
		||||
    /// * `amount` - Amount of the asset
 | 
			
		||||
    /// * `address` - Address of the asset on the blockchain or bank
 | 
			
		||||
    /// * `asset_type` - Type of the asset
 | 
			
		||||
    /// * `decimals` - Number of decimals of the asset
 | 
			
		||||
    pub fn new(
 | 
			
		||||
        id: Option<u32>,
 | 
			
		||||
        name: impl ToString,
 | 
			
		||||
        description: impl ToString,
 | 
			
		||||
        amount: f64,
 | 
			
		||||
@@ -42,8 +52,13 @@ impl Asset {
 | 
			
		||||
        asset_type: AssetType,
 | 
			
		||||
        decimals: u8,
 | 
			
		||||
    ) -> Self {
 | 
			
		||||
        let mut base_data = BaseModelData::new();
 | 
			
		||||
        if let Some(id) = id {
 | 
			
		||||
            base_data.update_id(id);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        Self {
 | 
			
		||||
            base_data: BaseModelData::new(),
 | 
			
		||||
            base_data,
 | 
			
		||||
            name: name.to_string(),
 | 
			
		||||
            description: description.to_string(),
 | 
			
		||||
            amount,
 | 
			
		||||
 
 | 
			
		||||
@@ -112,7 +112,22 @@ pub struct Listing {
 | 
			
		||||
 | 
			
		||||
impl Listing {
 | 
			
		||||
    /// Create a new listing with auto-generated ID
 | 
			
		||||
    ///
 | 
			
		||||
    /// # Arguments
 | 
			
		||||
    /// * `id` - Optional ID for the listing (use None for auto-generated ID)
 | 
			
		||||
    /// * `title` - Title of the listing
 | 
			
		||||
    /// * `description` - Description of the listing
 | 
			
		||||
    /// * `asset_id` - ID of the asset being listed
 | 
			
		||||
    /// * `asset_type` - Type of the asset
 | 
			
		||||
    /// * `seller_id` - ID of the seller
 | 
			
		||||
    /// * `price` - Initial price for fixed price, or starting price for auction
 | 
			
		||||
    /// * `currency` - Currency of the price
 | 
			
		||||
    /// * `listing_type` - Type of the listing
 | 
			
		||||
    /// * `expires_at` - Optional expiration date
 | 
			
		||||
    /// * `tags` - Tags for the listing
 | 
			
		||||
    /// * `image_url` - Optional image URL
 | 
			
		||||
    pub fn new(
 | 
			
		||||
        id: Option<u32>,
 | 
			
		||||
        title: impl ToString,
 | 
			
		||||
        description: impl ToString,
 | 
			
		||||
        asset_id: impl ToString,
 | 
			
		||||
@@ -125,8 +140,13 @@ impl Listing {
 | 
			
		||||
        tags: Vec<String>,
 | 
			
		||||
        image_url: Option<impl ToString>,
 | 
			
		||||
    ) -> Self {
 | 
			
		||||
        let mut base_data = BaseModelData::new();
 | 
			
		||||
        if let Some(id) = id {
 | 
			
		||||
            base_data.update_id(id);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        Self {
 | 
			
		||||
            base_data: BaseModelData::new(),
 | 
			
		||||
            base_data,
 | 
			
		||||
            title: title.to_string(),
 | 
			
		||||
            description: description.to_string(),
 | 
			
		||||
            asset_id: asset_id.to_string(),
 | 
			
		||||
 
 | 
			
		||||
@@ -78,12 +78,18 @@ impl Ballot {
 | 
			
		||||
    /// Create a new ballot with auto-generated ID
 | 
			
		||||
    ///
 | 
			
		||||
    /// # Arguments
 | 
			
		||||
    /// * `id` - Optional ID for the ballot (use None for auto-generated ID)
 | 
			
		||||
    /// * `user_id` - ID of the user who cast this ballot
 | 
			
		||||
    /// * `vote_option_id` - ID of the vote option chosen
 | 
			
		||||
    /// * `shares_count` - Number of shares/tokens/voting power
 | 
			
		||||
    pub fn new(user_id: u32, vote_option_id: u8, shares_count: i64) -> Self {
 | 
			
		||||
    pub fn new(id: Option<u32>, user_id: u32, vote_option_id: u8, shares_count: i64) -> Self {
 | 
			
		||||
        let mut base_data = BaseModelData::new();
 | 
			
		||||
        if let Some(id) = id {
 | 
			
		||||
            base_data.update_id(id);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        Self {
 | 
			
		||||
            base_data: BaseModelData::new(),
 | 
			
		||||
            base_data,
 | 
			
		||||
            user_id,
 | 
			
		||||
            vote_option_id,
 | 
			
		||||
            shares_count,
 | 
			
		||||
@@ -116,14 +122,20 @@ impl Proposal {
 | 
			
		||||
    /// Create a new proposal with auto-generated ID
 | 
			
		||||
    ///
 | 
			
		||||
    /// # Arguments
 | 
			
		||||
    /// * `id` - Optional ID for the proposal (use None for auto-generated ID)
 | 
			
		||||
    /// * `creator_id` - ID of the user who created the proposal
 | 
			
		||||
    /// * `title` - Title of the proposal
 | 
			
		||||
    /// * `description` - Description of the proposal
 | 
			
		||||
    /// * `vote_start_date` - Date when voting starts
 | 
			
		||||
    /// * `vote_end_date` - Date when voting ends
 | 
			
		||||
    pub fn new(creator_id: impl ToString, title: impl ToString, description: impl ToString, vote_start_date: DateTime<Utc>, vote_end_date: DateTime<Utc>) -> Self {
 | 
			
		||||
    pub fn new(id: Option<u32>, creator_id: impl ToString, title: impl ToString, description: impl ToString, vote_start_date: DateTime<Utc>, vote_end_date: DateTime<Utc>) -> Self {
 | 
			
		||||
        let mut base_data = BaseModelData::new();
 | 
			
		||||
        if let Some(id) = id {
 | 
			
		||||
            base_data.update_id(id);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        Self {
 | 
			
		||||
            base_data: BaseModelData::new(),
 | 
			
		||||
            base_data,
 | 
			
		||||
            creator_id: creator_id.to_string(),
 | 
			
		||||
            title: title.to_string(),
 | 
			
		||||
            description: description.to_string(),
 | 
			
		||||
@@ -143,7 +155,7 @@ impl Proposal {
 | 
			
		||||
        self
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    pub fn cast_vote(mut self, user_id: u32, chosen_option_id: u8, shares: i64) -> Self {
 | 
			
		||||
    pub fn cast_vote(mut self, ballot_id: Option<u32>, user_id: u32, chosen_option_id: u8, shares: i64) -> Self {
 | 
			
		||||
        if self.vote_status != VoteEventStatus::Open {
 | 
			
		||||
            eprintln!("Voting is not open for proposal '{}'", self.title);
 | 
			
		||||
            return self;
 | 
			
		||||
@@ -159,7 +171,7 @@ impl Proposal {
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        let new_ballot = Ballot::new(user_id, chosen_option_id, shares);
 | 
			
		||||
        let new_ballot = Ballot::new(ballot_id, user_id, chosen_option_id, shares);
 | 
			
		||||
        self.ballots.push(new_ballot);
 | 
			
		||||
 | 
			
		||||
        if let Some(option) = self.options.iter_mut().find(|opt| opt.id == chosen_option_id) {
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user