forked from emaijala/MLInvoice
-
Notifications
You must be signed in to change notification settings - Fork 0
/
open_invoices.php
executable file
·106 lines (91 loc) · 3.13 KB
/
open_invoices.php
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
<?php
/*******************************************************************************
MLInvoice: web-based invoicing application.
Copyright (C) 2010-2017 Ere Maijala
Portions based on:
PkLasku : web-based invoicing software.
Copyright (C) 2004-2008 Samu Reinikainen
This program is free software. See attached LICENSE.
*******************************************************************************/
/*******************************************************************************
MLInvoice: web-pohjainen laskutusohjelma.
Copyright (C) 2010-2017 Ere Maijala
Perustuu osittain sovellukseen:
PkLasku : web-pohjainen laskutusohjelmisto.
Copyright (C) 2004-2008 Samu Reinikainen
Tämä ohjelma on vapaa. Lue oheinen LICENSE.
*******************************************************************************/
require_once 'htmlfuncs.php';
require_once 'sqlfuncs.php';
require_once 'miscfuncs.php';
require_once 'datefuncs.php';
require_once 'translator.php';
require_once 'list.php';
require_once 'settings.php';
function createOpenInvoiceList()
{
$currentDate = date('Ymd');
$res = mysqli_query_check(
"select count(*) as cnt from {prefix}invoice i where i.deleted = 0 AND i.interval_type > 0 AND i.next_interval_date <= $currentDate AND i.archived = 0"
);
$row = mysqli_fetch_assoc($res);
if ($row['cnt'] > 0) {
createList(
'open_invoices', 'invoice', 'resultlist_repeating_invoices',
Translator::translate('LabelInvoicesWithIntervalDue'),
"i.interval_type > 0 AND i.next_interval_date <= $currentDate AND i.archived = 0",
true
);
}
$open = '';
$res = mysqli_query_check(
'SELECT id FROM {prefix}invoice_state WHERE invoice_open=1 AND invoice_offer=0'
);
while ($id = mysqli_fetch_value($res)) {
if ($open) {
$open .= ', ';
}
$open .= $id;
}
$unpaid = '';
$res = mysqli_query_check(
'SELECT id FROM {prefix}invoice_state WHERE invoice_open=0 AND invoice_unpaid=1 AND invoice_offer=0'
);
while ($id = mysqli_fetch_value($res)) {
if ($unpaid) {
$unpaid .= ', ';
}
$unpaid .= $id;
}
$offers = '';
$res = mysqli_query_check(
'SELECT id FROM {prefix}invoice_state WHERE invoice_offer=1'
);
while ($id = mysqli_fetch_value($res)) {
if ($offers) {
$offers .= ', ';
}
$offers .= $id;
}
if ($open) {
createList(
'open_invoices', 'invoice', 'resultlist_open_invoices',
Translator::translate('LabelOpenInvoices'),
"i.state_id IN ($open) AND i.archived=0", true
);
}
if ($unpaid) {
createList(
'open_invoices', 'invoice', 'resultlist_unpaid_invoices',
Translator::translate('LabelUnpaidInvoices'),
"i.state_id IN ($unpaid) AND i.archived=0", true, true
);
}
if ($offers) {
createList(
'open_invoices', 'offer', 'resultlist_offers',
Translator::translate('LabelOffers'),
"i.state_id IN ($offers) AND i.archived=0", true
);
}
}