|
94 | 94 |
|
95 | 95 | flash()->info(tr('Listino aggiornato correttamente!')); |
96 | 96 |
|
| 97 | + break; |
| 98 | + |
| 99 | + case 'export_newsletter_csv': |
| 100 | + $tipo_esportazione = post('tipo_esportazione'); |
| 101 | + $id_records_list = implode(',', array_map('intval', $id_records)); |
| 102 | + |
| 103 | + if ($tipo_esportazione == 'anagrafiche') { |
| 104 | + // Esportazione email e ragione sociale dalle anagrafiche selezionate |
| 105 | + $query = "SELECT DISTINCT email, ragione_sociale, 'Anagrafica' as fonte, '' as sede_referente FROM an_anagrafiche |
| 106 | + WHERE idanagrafica IN ($id_records_list) |
| 107 | + AND email != '' |
| 108 | + AND email IS NOT NULL |
| 109 | + AND enable_newsletter = 1 |
| 110 | + AND deleted_at IS NULL"; |
| 111 | + } elseif ($tipo_esportazione == 'sedi') { |
| 112 | + // Esportazione email, ragione sociale e nome sede dalle sedi delle anagrafiche selezionate |
| 113 | + $query = "SELECT DISTINCT s.email, a.ragione_sociale, 'Sede' as fonte, s.nomesede as sede_referente |
| 114 | + FROM an_sedi s |
| 115 | + LEFT JOIN an_anagrafiche a ON s.idanagrafica = a.idanagrafica |
| 116 | + WHERE s.idanagrafica IN ($id_records_list) |
| 117 | + AND s.email != '' |
| 118 | + AND s.email IS NOT NULL |
| 119 | + AND s.enable_newsletter = 1"; |
| 120 | + } elseif ($tipo_esportazione == 'referenti') { |
| 121 | + // Esportazione email, ragione sociale e nome referente dai referenti delle anagrafiche selezionate |
| 122 | + $query = "SELECT DISTINCT r.email, a.ragione_sociale, 'Referente' as fonte, r.nome as sede_referente |
| 123 | + FROM an_referenti r |
| 124 | + LEFT JOIN an_anagrafiche a ON r.idanagrafica = a.idanagrafica |
| 125 | + WHERE r.idanagrafica IN ($id_records_list) |
| 126 | + AND r.email != '' |
| 127 | + AND r.email IS NOT NULL |
| 128 | + AND r.enable_newsletter = 1"; |
| 129 | + } else { |
| 130 | + // Esportazione email, ragione sociale e nomi da tutte e tre le fonti delle anagrafiche selezionate |
| 131 | + $query = "SELECT DISTINCT email, ragione_sociale, fonte, sede_referente FROM ( |
| 132 | + SELECT email, ragione_sociale, 'Anagrafica' as fonte, '' as sede_referente FROM an_anagrafiche |
| 133 | + WHERE idanagrafica IN ($id_records_list) |
| 134 | + AND email != '' |
| 135 | + AND email IS NOT NULL |
| 136 | + AND enable_newsletter = 1 |
| 137 | + AND deleted_at IS NULL |
| 138 | + UNION |
| 139 | + SELECT s.email, a.ragione_sociale, 'Sede' as fonte, s.nomesede as sede_referente |
| 140 | + FROM an_sedi s |
| 141 | + LEFT JOIN an_anagrafiche a ON s.idanagrafica = a.idanagrafica |
| 142 | + WHERE s.idanagrafica IN ($id_records_list) |
| 143 | + AND s.email != '' |
| 144 | + AND s.email IS NOT NULL |
| 145 | + AND s.enable_newsletter = 1 |
| 146 | + UNION |
| 147 | + SELECT r.email, a.ragione_sociale, 'Referente' as fonte, r.nome as sede_referente |
| 148 | + FROM an_referenti r |
| 149 | + LEFT JOIN an_anagrafiche a ON r.idanagrafica = a.idanagrafica |
| 150 | + WHERE r.idanagrafica IN ($id_records_list) |
| 151 | + AND r.email != '' |
| 152 | + AND r.email IS NOT NULL |
| 153 | + AND r.enable_newsletter = 1 |
| 154 | + ) AS all_emails"; |
| 155 | + } |
| 156 | + $results = $dbo->fetchArray($query); |
| 157 | + |
| 158 | + // Creazione del file CSV |
| 159 | + $file = temp_file(); |
| 160 | + $handle = fopen($file, 'w'); |
| 161 | + |
| 162 | + // Scrittura dell'intestazione |
| 163 | + fputcsv($handle, ['email', 'ragione_sociale', 'fonte', 'sede_referente'], ';'); |
| 164 | + |
| 165 | + // Scrittura dei dati |
| 166 | + foreach ($results as $row) { |
| 167 | + fputcsv($handle, [ |
| 168 | + $row['email'], |
| 169 | + $row['ragione_sociale'], |
| 170 | + $row['fonte'], |
| 171 | + $row['sede_referente'] |
| 172 | + ], ';'); |
| 173 | + } |
| 174 | + fclose($handle); |
| 175 | + |
| 176 | + // Nome del file basato sul tipo di esportazione |
| 177 | + $filename_map = [ |
| 178 | + 'anagrafiche' => 'newsletter_anagrafiche.csv', |
| 179 | + 'sedi' => 'newsletter_sedi.csv', |
| 180 | + 'referenti' => 'newsletter_referenti.csv', |
| 181 | + 'tutti' => 'newsletter_tutti.csv' |
| 182 | + ]; |
| 183 | + $filename = $filename_map[$tipo_esportazione] ?? 'newsletter_export.csv'; |
| 184 | + |
| 185 | + // Download del file |
| 186 | + download($file, $filename); |
| 187 | + |
97 | 188 | break; |
98 | 189 | } |
99 | 190 |
|
|
145 | 236 | ], |
146 | 237 | ]; |
147 | 238 |
|
| 239 | +$operations['export_newsletter_csv'] = [ |
| 240 | + 'text' => '<span><i class="fa fa-envelope"></i> '.tr('Esporta email newsletter').'</span>', |
| 241 | + 'data' => [ |
| 242 | + 'msg' => tr('Seleziona il tipo di email da esportare per la newsletter:').'<br><br>{[ "type": "select", "label": "'.tr('Tipo esportazione').'", "name": "tipo_esportazione", "required": 1, "values": "list=\"anagrafiche\":\"Anagrafiche\",\"sedi\":\"Sedi\",\"referenti\":\"Referenti\",\"tutti\":\"Tutti (Anagrafiche, Sedi, Referenti)\"", "value": "tutti" ]}', |
| 243 | + 'button' => tr('Esporta CSV'), |
| 244 | + 'class' => 'btn btn-lg btn-warning', |
| 245 | + 'blank' => true, |
| 246 | + ], |
| 247 | +]; |
| 248 | + |
148 | 249 | return $operations; |
0 commit comments