-
Notifications
You must be signed in to change notification settings - Fork 13
/
Copy pathmercearia-eng.sh
executable file
·368 lines (316 loc) · 10.7 KB
/
mercearia-eng.sh
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
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
#!/bin/bash
#####################################################################
# Author: Slackjeff
# Description: A little point of sale software for grocery stores
# It has the following functionalities:
#
# * Add products database
# * Sell
# * Remove sell
# * Give a subtotal
# * Show monthly sells.
#
# Dependency:
# sqlite
#####################################################################
# Cores para formatação de texto
cor_vermelha=$(tput setaf 1)
cor_verde=$(tput setaf 2)
cor_amarela=$(tput setaf 3)
cor_reset=$(tput sgr0)
logo() {
cat << 'EOF'
__ __ _
| \/ | (_)
| \ / | ___ _ __ ___ ___ __ _ _ __ _ __ _
| |\/| |/ _ \ '__/ __/ _ \/ _` | '__| |/ _` |
| | | | __/ | | (_| __/ (_| | | | | (_| |
|_| |_|\___|_| \___\___|\__,_|_| |_|\__,_|
EOF
echo " Today is $(date "+%m/%d/%Y")"
echo
}
# Função para criar a tabela de produtos se não existir
criar_tabela_produtos() {
sqlite3 estoque.db <<EOF
CREATE TABLE IF NOT EXISTS produtos (
id INTEGER PRIMARY KEY,
nome TEXT,
quantidade INTEGER,
preco REAL
);
EOF
}
# Criar a tabela de vendas
criar_tabela_vendas() {
sqlite3 estoque.db <<EOF
CREATE TABLE IF NOT EXISTS vendas (
id INTEGER PRIMARY KEY,
data DATE,
total REAL
);
EOF
}
# Função para adicionar um novo produto ao banco de dados ou atualizar a quantidade se o produto já existir
adicionar_produto() {
clear
echo "==================== REGISTERING PRODUCT ===================="
read -p "Name: " nome
nome=${nome,,}
read -p "Amount: " quantidade
read -p "Price: " preco
sqlite3 estoque.db <<EOF
INSERT OR REPLACE INTO produtos (id, nome, quantidade, preco)
VALUES ((SELECT id FROM produtos WHERE nome="$nome"), "$nome", COALESCE((SELECT quantidade FROM produtos WHERE nome="$nome"), 0) + $quantidade, $preco);
EOF
echo "${cor_verde}Product registered/updated successfully!${cor_reset}"
pressione_para_continuar
}
# Função para remover um produto do banco de dados
remover_produto() {
clear
echo "==================== REMOVING PRODUCT ====================="
read -p "Type the ID or name of the product you want to remove: " identificador
identificado=${identificador,,}
# Verifica se o identificador é um número (ID) ou uma string (nome)
if [[ $identificador =~ ^[0-9]+$ ]]; then
sqlite3 estoque.db <<EOF
DELETE FROM produtos WHERE id=$identificador;
EOF
else
sqlite3 estoque.db <<EOF
DELETE FROM produtos WHERE nome="$identificador";
EOF
fi
echo "${cor_verde}Product removed successfully!${cor_reset}"
pressione_para_continuar
}
# Função para realizar uma venda de múltiplos produtos
realizar_venda() {
# Reinicia o valor total da venda
total_venda=0
lista_produtos=()
while true; do
clear
echo "============================ SALE ==========================="
echo "Products on sale:"
for produto in "${lista_produtos[@]}"; do
IFS=',' read -r produto_nome quantidade subtotal <<< "$produto"
echo "${cor_amarela}$produto_nome - Amount: $quantidade - Subtotal:$$subtotal${cor_reset}"
done
echo
echo "------------------------------------------------------------"
echo "========> SUBTOTAL: $ $total_venda"
echo "------------------------------------------------------------"
echo
read -p "Type the ID or name of the product you want to sell (or let it blank to complete the sale)" identificador
identificador=${identificador,,}
if [ -z "$identificador" ]; then
break
fi
read -p "Amount: " quantidade
# Verifica se o identificador é um número (ID) ou uma string (nome)
if [[ $identificador =~ ^[0-9]+$ ]]; then
# Busca o produto pelo ID
produto_nome=$(sqlite3 estoque.db "SELECT nome FROM produtos WHERE id=$identificador;")
else
# Busca o produto pelo nome
produto_nome=$identificador
fi
# Verifica se o produto existe e se há quantidade suficiente no estoque
quantidade_disponivel=$(sqlite3 estoque.db "SELECT quantidade FROM produtos WHERE nome='$produto_nome';")
if [ -z "$quantidade_disponivel" ]; then
echo "${cor_vermelha}Product '$produto_nome' not found in stock.${cor_reset}"
pressione_para_continuar
continue
fi
if [ "$quantidade_disponivel" -lt "$quantidade" ]; then
echo "${cor_vermelha}Insuficient amount of '$produto_nome' in stock.${cor_reset}"
pressione_para_continuar
continue
fi
# Calcula o valor total da venda para esse produto
preco_unitario=$(sqlite3 estoque.db "SELECT preco FROM produtos WHERE nome='$produto_nome';")
subtotal=$(echo "$preco_unitario * $quantidade" | bc)
# Atualiza a quantidade no estoque
sqlite3 estoque.db "UPDATE produtos SET quantidade = quantidade - $quantidade WHERE nome='$produto_nome';"
# Verifica se o produto já existe na lista de produtos vendidos
produto_encontrado=0
for i in "${!lista_produtos[@]}"; do
IFS=',' read -r lista_produto_nome lista_quantidade lista_subtotal <<< "${lista_produtos[$i]}"
if [ "$lista_produto_nome" == "$produto_nome" ]; then
lista_quantidade=$((lista_quantidade + quantidade))
lista_subtotal=$(echo "$preco_unitario * $lista_quantidade" | bc)
lista_produtos[$i]="$produto_nome,$lista_quantidade,$lista_subtotal"
produto_encontrado=1
break
fi
done
if [ "$produto_encontrado" -eq 0 ]; then
lista_produtos+=("$produto_nome,$quantidade,$subtotal")
fi
total_venda=$(echo "$total_venda + $subtotal" | bc)
done
echo "Sales Total: $ $total_venda"
# Registra a venda no banco de dados
registrar_venda "$total_venda"
# Pergunta se deseja remover unidades de venda
while true; do
clear
echo "================= REMOVE UNITS ON SALE ==================="
echo "Products on sale list:"
for i in "${!lista_produtos[@]}"; do
IFS=',' read -r produto_nome quantidade subtotal <<< "${lista_produtos[$i]}"
echo "${cor_amarela}$i - $produto_nome - Amount: $quantidade - Subtotal: $ $subtotal${cor_reset}"
done
echo
echo "------------------------------------------------------------"
echo "SUBTOTAL: $ $total_venda"
echo "------------------------------------------------------------"
echo
read -p "Type the number of the product you want to remove from sales (or let it blank to quit): " escolha
if [ -z "$escolha" ]; then
break
fi
if [[ ! "$escolha" =~ ^[0-9]+$ ]] || [ "$escolha" -ge "${#lista_produtos[@]}" ]; then
echo "${cor_vermelha}Invalid Option. Try Again.${cor_reset}"
pressione_para_continuar
continue
fi
IFS=',' read -r produto_nome quantidade subtotal <<< "${lista_produtos[$escolha]}"
if [ "$quantidade" -gt 1 ]; then
# Se houver mais de uma unidade do produto, apenas diminua a quantidade
lista_quantidade=$((quantidade - 1))
lista_subtotal=$(echo "$preco_unitario * $lista_quantidade" | bc)
lista_produtos[$escolha]="$produto_nome,$lista_quantidade,$lista_subtotal"
else
# Se houver apenas uma unidade do produto, remova-o da lista
unset lista_produtos[$escolha]
lista_produtos=("${lista_produtos[@]}") # Remove o elemento vazio
fi
total_venda=$(echo "$total_venda - $preco_unitario" | bc)
echo "${cor_verde}A unity of '$produto_nome' removed from sales.${cor_reset}"
pressione_para_continuar
done
echo "UPDATED SALES AMOUNT: $ $total_venda"
pressione_para_continuar
}
# Função para exibir as vendas diarias
exibir_vendas_diarias() {
clear
echo "==================== DAILY SALES AMOUNT ====================="
sqlite3 -column -header estoque.db "SELECT date(data), SUM(total) AS subtotal FROM vendas GROUP BY date(data) ORDER BY date(data) DESC"
pressione_para_continuar
}
# Função para registrar uma venda no banco de dados
registrar_venda() {
data=$(date +%Y-%m-%d)
total=$1
sqlite3 estoque.db <<EOF
INSERT INTO vendas (data, total) VALUES ("$data", $total);
EOF
}
# Função para visualizar todos os produtos cadastrados em formato de tabela
visualizar_produtos() {
clear
echo "================== REGISTERED PRODUCTS LIST ================="
echo "Search options:"
echo "1. Search by ID"
echo "2. Search by Name"
echo "3. Search all products"
read -p "Choose a search option: " busca_opcao
case $busca_opcao in
1)
read -p "Type the product ID you want to search: " produto_id
sqlite3 -column -header -separator " | " estoque.db <<EOF
SELECT id, nome, quantidade, preco FROM produtos WHERE id=$produto_id;
EOF
;;
2)
read -p "Type the product name you want to search: " produto_nome
produto_nome=${produto_nome,,}
sqlite3 -column -header -separator " | " estoque.db <<EOF
SELECT id, nome, quantidade, preco FROM produtos WHERE nome LIKE '%$produto_nome%';
EOF
;;
3)
sqlite3 -column -header -separator " | " estoque.db <<EOF
SELECT id, nome, quantidade, preco FROM produtos;
EOF
;;
*)
echo "${cor_vermelha}Invalid Option.${cor_reset}"
# sqlite3 -separator " | " estoque.db <<EOF
# SELECT id, nome, quantidade, preco FROM produtos;
#EOF
;;
esac
pressione_para_continuar
}
pesquisar_produto() {
clear
read -p "Type the name of the product you want to search: " produto
# Consulta SQL para pesquisar o produto pelo nome
QUERY_SEARCH_PRODUCT="SELECT id, nome, quantidade, preco FROM produtos WHERE nome LIKE '%$produto%'"
echo "Search results:"
echo "-------------------------------------------------------------------"
sqlite3 -column -header -separator "|" "estoque.db" "$QUERY_SEARCH_PRODUCT"
pressione_para_continuar
}
# Função para pausar a execução e aguardar um pressionamento de tecla
pressione_para_continuar() {
echo ""
read -n 1 -s -p "========> Press any key to continue..."
}
# Função principal
main() {
if [ -f $(which sqlite3) ]; then
criar_tabela_produtos
criar_tabela_vendas
while true; do
clear
logo
echo "Choose an option:"
echo " (1) Add new product"
echo " (2) Remove Product"
echo " (3) Sell"
echo " (4) Show all products"
echo " (5) Show daily sells"
echo " (6) Search for products"
echo " (7) Quit"
echo ""
read -p "Option: " opcao
case $opcao in
1)
adicionar_produto
;;
2)
remover_produto
;;
3)
realizar_venda
;;
4)
visualizar_produtos
;;
5)
exibir_vendas_diarias
;;
6)
pesquisar_produto
;;
7)
echo "Quitting."
exit 0
;;
*)
echo "${cor_vermelha}Invalid option. Try again..${cor_reset}"
pressione_para_continuar
;;
esac
done
else
echo "You need to install sqlite3";
fi
}
main