1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
use crate::com::{SafeDispatch, SafeVariant};
use crate::errors::SageResult;
use windows::Win32::System::Com::IDispatch;
/// Wrapper pour un document générique (IBODocument)
///
/// Représente un document commercial générique qui peut être de vente, achat, stock ou interne.
/// Cette classe est une abstraction commune pour tous les types de documents.
///
/// ⚠️ IMPLÉMENTATION MINIMALE - Version Phase 1
///
/// Pour un accès typé par type de document, utilisez les wrappers spécifiques:
/// - `DocumentVente` pour les devis, commandes, BL, factures de vente
/// - `DocumentAchat` pour les documents fournisseurs
/// - `DocumentStock` pour les mouvements de stock
/// - `DocumentInterne` pour les documents internes
///
/// # Exemple
/// ```no_run
/// use objets_metier_rs::wrappers::cial::CialApplication;
///
/// let cial_app = CialApplication::new("Objets100c.CIAL")?;
/// let factory = cial_app.factory_document()?;
/// // Accès générique à tous types de documents
/// # Ok::<(), Box<dyn std::error::Error>>(())
/// ```
pub struct Document {
pub(crate) dispatch: IDispatch,
}
impl Document {
/// Crée un SafeDispatch temporaire pour les appels
fn dispatch(&self) -> SafeDispatch<'_> {
SafeDispatch::new(&self.dispatch)
}
// ==================== PROPRIÉTÉS PRINCIPALES ====================
/// Numéro de pièce du document
pub fn do_piece(&self) -> SageResult<String> {
self.dispatch()
.call_method_by_name("DO_Piece", &[])?
.to_string()
}
pub fn set_do_piece(&self, value: &str) -> SageResult<()> {
let param = SafeVariant::from_string(value);
self.dispatch().call_property_put("DO_Piece", &[param])?;
Ok(())
}
/// Type de document (enum DocumentType)
pub fn do_type(&self) -> SageResult<i32> {
self.dispatch()
.call_method_by_name("DO_Type", &[])?
.to_i32()
}
/// cbMarq - Identifiant unique du document
pub fn cbmarq(&self) -> SageResult<i32> {
self.dispatch().call_method_by_name("cbMarq", &[])?.to_i32()
}
// ==================== MÉTHODES D'ÉCRITURE ====================
/// Écrit le document dans la base de données
pub fn write(&self) -> SageResult<()> {
self.dispatch().call_method_by_name("Write", &[])?;
Ok(())
}
/// Supprime le document de la base de données
/// ⚠️ ATTENTION : Cette opération est irréversible
pub fn remove(&self) -> SageResult<()> {
self.dispatch().call_method_by_name("Remove", &[])?;
Ok(())
}
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn test_document_creation_needs_factory() {
// Les documents sont créés via FactoryDocument
// Ce test documente le pattern d'utilisation
}
}