]> git.sur5r.net Git - c128-kasse/blob - src/credit_manager.c
delete edit hint from credit manager (#33)
[c128-kasse] / src / credit_manager.c
1 /*
2  * RGB2R-C128-Kassenprogramm
3  * © 2007-2009 phil_fry, sECuRE, sur5r
4  * See LICENSE for license information
5  *
6  */
7 #include <conio.h>
8 #include <stdio.h>
9 #include <stdlib.h>
10 #include <string.h>
11
12 #include "config.h"
13 #include "general.h"
14 #include "kasse.h"
15 #include "c128time.h"
16 #include "print.h"
17 #include "version.h"
18 #include "vdc_patch_charset.h"
19
20 static char *filter = NULL;
21 static BYTE filter_len;
22
23 static BYTE current_credits_page = 0;
24
25 static void credit_print_screen(void) {
26   BYTE i, pages;
27   char buffer[EUR_FORMAT_MINLEN + 1];
28
29   clrscr();
30   cprintf("credit_manager (phil_fry, sECuRE, sur5r) v:" GV "\r\n\r\n");
31   pages = (credits.num_items / CREDITS_PER_PAGE);
32   if (current_credits_page > pages)
33     current_credits_page = pages;
34   cprintf("Datei: CREDITS (Seite %d von %d)\r\n\r\n", current_credits_page,
35           pages);
36   for (i = (current_credits_page * CREDITS_PER_PAGE);
37        i < credits.num_items &&
38        i < ((current_credits_page + 1) * CREDITS_PER_PAGE);
39        i++) {
40     if (filter == NULL ||
41         strncmp(credits.credits[i].nickname, filter, filter_len) == 0) {
42       if (format_euro(buffer, sizeof(buffer), credits.credits[i].credit) !=
43           buffer) {
44         cprintf("Error: Could not format credit %d\r\n",
45                 credits.credits[i].credit);
46         exit(1);
47       }
48
49       cprintf("%d: %s: %s\r\n", i, credits.credits[i].nickname, buffer);
50     }
51   }
52   cprintf("\r\nn) Neu d) L" oUML "schen p) Einzahlen b) Seite hoch "
53           "f) Seite runter\r\ng) Filtern s) Speichern z) Zur" uUML "ck\r\n");
54 }
55
56 static int8_t find_credit_idx(char *name) {
57   int8_t i;
58   for (i = 0; i < credits.num_items; ++i) {
59     if (strncmp(name, credits.credits[i].nickname, NICKNAME_MAX_LEN + 1) == 0) {
60       return i;
61     }
62   }
63   return -1;
64 }
65
66 struct credits_t *find_credit(char *name) {
67   int i;
68   if ((i = find_credit_idx(name)) >= 0) {
69     return &credits.credits[i];
70   }
71   return NULL;
72 }
73
74 void deposit_credit(char *nickname) {
75   char *time = get_time();
76   struct credits_t *credit;
77   unsigned int deposit;
78
79   if ((credit = find_credit(nickname)) == NULL)
80     return; // cannot find named credit
81
82   cprintf("\r\nEinzahlung in Cent:\r\n");
83   if ((deposit = cget_number(0)) == 0)
84     return;
85
86   credit->credit += deposit;
87
88   print_the_buffer();
89   cprintf("\r\nEinzahlung durchgef" uUML "hrt, dr" uUML "cke RETURN...\r\n");
90   cget_return();
91 }
92
93 static void new_credit(void) {
94   char name[NICKNAME_MAX_LEN + 1];
95   char *time;
96   int credit;
97
98   if (credits.num_items == MAX_CREDIT_ITEMS) {
99     cprintf("\rEs ist bereits die maximale Anzahl an Eintr" aUML
100             "gen erreicht, dr" uUML "cke RETURN...\r\n");
101     cget_return();
102     return;
103   }
104
105   clrscr();
106   cprintf("\rNickname (max. 10 Zeichen):\r\n");
107   if (cgetn_input(name, sizeof(name)) == 0)
108     return;
109
110   if (find_credit_idx(name) >= 0) {
111     cprintf("\rNickname existiert bereits, dr" uUML "cke RETURN...\r\n");
112     cget_return();
113     return;
114   }
115
116   cprintf("\r\nGuthaben in Cents:\r\n");
117   if ((credit = cget_number(0)) == 0)
118     return;
119   strncpy(credits.credits[credits.num_items].nickname, name, NICKNAME_MAX_LEN);
120   credits.credits[credits.num_items].credit = credit;
121
122   time = get_time();
123   sprintf(print_buffer, "%c%s - Guthaben mit %d Cent f" uUML "r %s angelegt\r",
124           17, time, credit, name);
125   print_the_buffer();
126
127   credits.num_items++;
128 }
129
130 static void delete_credit(char *nickname) {
131   int8_t i;
132   if ((i = find_credit_idx(nickname)) < 0) {
133     cprintf("\r Nick existiert nicht\r\n");
134     return;
135   }
136   --credits.num_items;
137   if (i != credits.num_items) {
138     credits.credits[i] = credits.credits[credits.num_items];
139   }
140   memset(credits.credits[credits.num_items].nickname, '\0',
141          NICKNAME_MAX_LEN + 1);
142   credits.credits[credits.num_items].credit = 0;
143   return;
144 }
145
146 void credit_manager() {
147   char nickname[NICKNAME_MAX_LEN + 1];
148   char *c;
149   while (1) {
150     credit_print_screen();
151     c = get_input();
152     switch (*c) {
153     case 'n':
154       new_credit();
155       break;
156     case 'd':
157       cputs("\rName?\r\n");
158       if (cget_nickname(nickname, sizeof(nickname))) {
159         delete_credit(nickname);
160       }
161       break;
162     case 's':
163       save_credits();
164       break;
165     case 'f':
166       if (current_credits_page < (credits.num_items / CREDITS_PER_PAGE))
167         current_credits_page++;
168       break;
169     case 'b':
170       if (current_credits_page > 0)
171         current_credits_page--;
172       break;
173     case 'p':
174       cputs("\rName?\r\n");
175       if (cget_nickname(nickname, sizeof(nickname))) {
176         deposit_credit(nickname);
177       }
178       break;
179     case 'g':
180       cprintf("Filter eingeben:\r\n");
181       filter = get_input();
182       if (filter == NULL || *filter == PETSCII_SP ||
183           (filter_len = strlen(filter)) == 0)
184         filter = NULL;
185       break;
186     case 'z':
187       save_credits();
188       return;
189     default:
190       cprintf("Unbekannter Befehl, dr" uUML "cke RETURN...\r\n");
191       cget_return();
192     }
193   }
194 }