summaryrefslogtreecommitdiff
path: root/src/functions.php
blob: e7c2e5b27dee6c24df1fa7355babb299f3f2f9fc (plain)
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
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
<?php
// src/functions.php
//
// utilisées par main.php et les fonctions de la boucle principale


// commande pour lancer une application graphique en ouvrant un fichier
function windowAppCommand(string $app, string $path = ''): string
{
    // attention, ne supporte que la syntaxe la plus simple avec un seul paramètre:"app fichier"
    // fonctionne avec choisis: gimp, scribus, sqlite, "l'explorateur de fichiers par défaut"

    $command = 'nohup ' . $app; // détache l'appli du script PHP
    if($path !== '')
    {
	    $command .= ' ' . $path;
    }
    $command .= ' > /dev/null 2>&1 &';
    // stdout > /dev/null et & permettent de rendre la main à PHP
    // stderr > stdout pour cacher un message inutile
    return $command;
}

function enterCustomer($Client): bool
{
    // fenêtre
    $NouveauClient = new ZenityForms(ZenitySetup::$nouveau_client['text'], ZenitySetup::$nouveau_client['entrees']);
    
    $input = exec($NouveauClient->get());
    if($input == '')
    {
        echo "debug: annulation lors de l'enregistrement d'un nouveau client\n";
        return false;
    }
    if(!$Client->hydrateFromForm($input))
    {
        // messages d'erreur dans hydrateFromForm()
        return false;
    }
    unset($input);
    
    $Client->create(); // écrire dans la base
    $Client->setID(); // sans paramètre, exécute un $this->db->lastInsertId()
    
    return true;
}

function makeObjectClient()
{
    // fenêtres
    $RechercheClient = new zenityEntry(ZenitySetup::$recherche_client_text);
    $ResultatsRechercheClient = new ZenityList(ZenitySetup::$resultats_recherche_client_text, []);
    
    $Client = new Clients;
    
    $input = exec($RechercheClient->get());
    if($input == '')
    {
	echo "debug: recherche annulée ou saisie vide\n";
	return 0;
    }
    
    echo "debug: recherche effectuée\n";
    $ResultatsRechercheClient->setListRows(
	searchCustomer($input, $Client),
	count(StructTablesDB::$structureOfTables[$Client->getTable()])); // 2è paramètre = nombre de colonnes
    
    // sélection parmi les résultats
    $input = exec($ResultatsRechercheClient->get()); // renvoie l'ID de la table 'clients'
    $ResultatsRechercheClient->cleanCommand();
    
    if($input == '')
    {
	echo "debug: client pas trouvé ou pas sélectionné\n";
	return 0;
    }
    
    echo "debug: client sélectionné\n";
    $Client->setID($input);
    $Client->hydrate($Client->findById());
    
    return $Client;
}

// NOTE 1: en PHP les objets sont passés aux fonctions par référence par défaut, toutefois ce n'est pas entièrement vrai
// NOTE 2: PHP n'a pas de pointeur mais des références, une référence est un alias qui ne contient pas l'objet lui-même
// NOTE 3: la variable créée lors d'un "new" est elle-même une référence contenant un identifiant (= le pointeur?)
// NOTE 4: l'objet est détruit lorsque la dernière référence est supprimée

function searchCustomer(string $input, Clients $Client): array
{
    $input_array = explode(' ', $input); // si plusieurs mot, on les recherche tous l'un après l'autre
    $result = $Client->findByKeywords($input_array, 'prenom_nom'); // on obtient un tableau à deux dimensions avec les entrées trouvées
    //var_dump($result);
    return($result);
}


function getServices(Clients $Client, string $type = '')
{
    echo "debug: recherche d'une prestation\n";

    // on recherche les ID des prestas dans la table 'prestations' avec 'ID_client'
    $Presta = new Prestations($Client->getID()); 
    $Presta->setTypePresta($type);
    $IDs = $Presta->getIDsByIdClient(); // comportement différent si le type est connu
    unset($Presta);

    // mettres toutes les données dans un tableau
    $PrestaList = [];
    foreach($IDs as $id)
    {
	$PrestaList[$id] = new Prestations($Client->getID()); // renseigne 'ID_client'
	$PrestaList[$id]->setID($id); // ID de la prestation = clé du tableau
	$PrestaList[$id]->hydrate($PrestaList[$id]->findById()); // données copiés de la table à l'objet
    }

    // fenêtre
    $entrees = [];
    foreach($PrestaList as $Presta)
    {
	$id = $Presta->getID();
	$entrees[$id][] = $id;
	$Date = new Dates((int)$Presta->getDate()); // envoi du timestamp, (int) est là par sécurité
	$entrees[$id][] = $Date->getDate();
	$entrees[$id][] = $Presta->getTypePresta();
	$entrees[$id][] = $Presta->getCodePresta();
    }
    $ResultatsRecherchePresta = new ZenityList(ZenitySetup::$resultats_recherche_presta_text, []);
    $ResultatsRecherchePresta->setListRows($entrees, 4);

    // choix de l'utilisateur
    $input = exec($ResultatsRecherchePresta->get()); // $input est l'ID de la prestation
    if($input == '')
    {
	echo "debug: recherche annulée ou saisie vide\n";
	return 0;
    }
    else
    {
	return $PrestaList[$input];
    }
}