|
81 | 81 |
|
82 | 82 | $excel->setActiveSheetIndex(0) ;
|
83 | 83 |
|
84 |
| - $tableName = $importType->getDetail('table'); |
85 |
| - $primaryKey = $importType->getPrimaryKey(); |
| 84 | + $count = 0; |
86 | 85 |
|
| 86 | + $rowData = []; |
87 | 87 | $queryFields = [];
|
88 |
| - $columnFields = []; |
89 |
| - |
90 |
| - foreach ($importType->getTableFields() as $fieldName) { |
91 |
| - if ($importType->isFieldHidden($fieldName)) { |
92 |
| - continue; // Skip hidden fields |
93 |
| - } |
94 |
| - |
95 |
| - $columnFields[] = $fieldName; |
96 |
| - |
97 |
| - if ($importType->isFieldReadOnly($fieldName) && $dataExport == true) { |
98 |
| - continue; // Skip readonly fields when exporting data |
99 |
| - } |
100 |
| - |
101 |
| - $queryFields[] = $fieldName; |
102 |
| - } |
103 |
| - |
104 |
| - if ($dataExport && !empty($primaryKey)) { |
105 |
| - $queryFields = array_merge(array($primaryKey), $queryFields); |
106 |
| - $columnFields = array_merge(array($primaryKey), $columnFields); |
107 |
| - } |
| 88 | + $columnFields = $importType->getAllFields(); |
108 | 89 |
|
109 | 90 | // Create the header row
|
110 |
| - $count = 0; |
111 | 91 | foreach ($columnFields as $fieldName) {
|
112 | 92 | $excel->getActiveSheet()->setCellValue(num2alpha($count).'1', $importType->getField($fieldName, 'name', $fieldName));
|
113 | 93 | $excel->getActiveSheet()->getStyle(num2alpha($count).'1')->applyFromArray($style_head_fill);
|
|
131 | 111 | $count++;
|
132 | 112 | }
|
133 | 113 |
|
134 |
| - |
135 |
| - if ($dataExport) { |
136 |
| - // Get the data |
137 |
| - $data = []; |
138 |
| - $sql = "SELECT ".implode(', ', $queryFields)." FROM `{$tableName}`" ; |
| 114 | + foreach ($importType->getTables() as $index => $tableName) { |
| 115 | + |
| 116 | + $importType->switchTable($tableName); |
| 117 | + $primaryKey = $importType->getPrimaryKey(); |
139 | 118 |
|
140 |
| - if ($dataExportAll == false) { |
141 |
| - // Optionally limit all exports to the current school year by default, to avoid massive files |
142 |
| - $gibbonSchoolYearID = $importType->getField('gibbonSchoolYearID', 'name', null); |
| 119 | + foreach ($importType->getTableFields() as $fieldName) { |
| 120 | + if ($importType->isFieldHidden($fieldName)) { |
| 121 | + continue; // Skip hidden fields |
| 122 | + } |
143 | 123 |
|
144 |
| - if ($gibbonSchoolYearID != null && $importType->isFieldReadOnly('gibbonSchoolYearID') == false) { |
145 |
| - $data['gibbonSchoolYearID'] = $_SESSION[$guid]['gibbonSchoolYearID']; |
146 |
| - $sql .= " WHERE gibbonSchoolYearID=:gibbonSchoolYearID "; |
| 124 | + if ($importType->isFieldReadOnly($fieldName) && $dataExport == true) { |
| 125 | + continue; // Skip readonly fields when exporting data |
147 | 126 | }
|
| 127 | + |
| 128 | + $queryFields[$tableName][] = $fieldName; |
148 | 129 | }
|
149 | 130 |
|
150 |
| - $sql.= " ORDER BY $primaryKey ASC"; |
151 |
| - $result = $pdo->executeQuery($data, $sql); |
| 131 | + if ($dataExport && !empty($primaryKey)) { |
| 132 | + $queryFields[$tableName] = array_merge(array($primaryKey), $queryFields[$tableName]); |
| 133 | + // $columnFields = array_merge(array($primaryKey), $columnFields); |
| 134 | + } |
| 135 | + |
| 136 | + if ($dataExport) { |
| 137 | + // Get the data |
| 138 | + $data = []; |
| 139 | + $sql = "SELECT ".implode(', ', $queryFields[$tableName])." FROM `{$tableName}`" ; |
| 140 | + |
| 141 | + if ($dataExportAll == false) { |
| 142 | + // Optionally limit all exports to the current school year by default, to avoid massive files |
| 143 | + $gibbonSchoolYearID = $importType->getField('gibbonSchoolYearID', 'name', null); |
| 144 | + |
| 145 | + if ($gibbonSchoolYearID != null && $importType->isFieldReadOnly('gibbonSchoolYearID') == false) { |
| 146 | + $data['gibbonSchoolYearID'] = $_SESSION[$guid]['gibbonSchoolYearID']; |
| 147 | + $sql .= " WHERE gibbonSchoolYearID=:gibbonSchoolYearID "; |
| 148 | + } |
| 149 | + } |
| 150 | + |
| 151 | + $sql.= " ORDER BY $primaryKey ASC"; |
| 152 | + $result = $pdo->executeQuery($data, $sql); |
152 | 153 |
|
153 |
| - // Continue if there's data |
154 |
| - if ($result && $result->rowCount() > 0) { |
| 154 | + // Continue if there's data |
| 155 | + if ($result && $result->rowCount() > 0) { |
155 | 156 |
|
156 |
| - // Build some relational data arrays, if needed (do this first to avoid duplicate queries per-row) |
157 |
| - $relationalData = []; |
| 157 | + // Build some relational data arrays, if needed (do this first to avoid duplicate queries per-row) |
| 158 | + $relationalData = []; |
158 | 159 |
|
159 |
| - foreach ($columnFields as $fieldName) { |
160 |
| - if ($importType->isFieldRelational($fieldName)) { |
161 |
| - $join = $on = ''; |
162 |
| - extract($importType->getField($fieldName, 'relationship')); |
163 |
| - $queryFields = (is_array($field))? implode(',', $field) : $field; |
| 160 | + foreach ($importType->getTableFields() as $fieldName) { |
| 161 | + if ($importType->isFieldRelational($fieldName)) { |
| 162 | + $join = $on = ''; |
| 163 | + extract($importType->getField($fieldName, 'relationship')); |
| 164 | + $queryFieldsRelational = (is_array($field))? implode(',', $field) : $field; |
164 | 165 |
|
165 |
| - // Build a query to grab data from relational tables |
166 |
| - $relationalSQL = "SELECT `{$table}`.`{$key}` id, {$queryFields} FROM `{$table}`"; |
| 166 | + // Build a query to grab data from relational tables |
| 167 | + $relationalSQL = "SELECT `{$table}`.`{$key}` id, {$queryFieldsRelational} FROM `{$table}`"; |
167 | 168 |
|
168 |
| - if (!empty($join) && !empty($on)) { |
169 |
| - if (is_array($on) && count($on) == 2) { |
170 |
| - $relationalSQL .= " JOIN {$join} ON ({$join}.{$on[0]}={$table}.{$on[1]})"; |
| 169 | + if (!empty($join) && !empty($on)) { |
| 170 | + if (is_array($on) && count($on) == 2) { |
| 171 | + $relationalSQL .= " JOIN {$join} ON ({$join}.{$on[0]}={$table}.{$on[1]})"; |
| 172 | + } |
171 | 173 | }
|
172 |
| - } |
173 | 174 |
|
174 |
| - $resultRelation = $pdo->executeQuery([], $relationalSQL); |
| 175 | + $resultRelation = $pdo->executeQuery([], $relationalSQL); |
175 | 176 |
|
176 |
| - if ($resultRelation->rowCount() > 0) { |
| 177 | + if ($resultRelation->rowCount() > 0) { |
177 | 178 |
|
178 |
| - // Fetch into an array as: id => array( field => value, field => value, ... ) |
179 |
| - $relationalData[$fieldName] = $resultRelation->fetchAll(\PDO::FETCH_GROUP|\PDO::FETCH_UNIQUE); |
| 179 | + // Fetch into an array as: id => array( field => value, field => value, ... ) |
| 180 | + $relationalData[$fieldName] = $resultRelation->fetchAll(\PDO::FETCH_GROUP|\PDO::FETCH_UNIQUE); |
| 181 | + } |
180 | 182 | }
|
181 | 183 | }
|
182 |
| - } |
183 |
| - |
184 |
| - $rowCount = 2; |
185 |
| - while ($row = $result->fetch()) { |
186 |
| - |
187 |
| - // Work backwards, so we can potentially fill in any relational read-only fields |
188 |
| - for ($i=count($columnFields)-1; $i >= 0; $i--) { |
189 |
| - $fieldName = $columnFields[$i]; |
190 |
| - |
191 |
| - $value = (isset($row[ $fieldName ]))? $row[ $fieldName ] : null; |
192 | 184 |
|
193 |
| - // Handle relational fields |
194 |
| - if ($importType->isFieldRelational($fieldName)) { |
195 |
| - extract($importType->getField($fieldName, 'relationship')); |
196 |
| - $filter = $importType->getField($fieldName, 'filter'); |
197 |
| - |
198 |
| - $values = $filter == 'csv' ? array_map('trim', explode(',', $value)) : [$value]; |
199 |
| - $relationalValue = []; |
200 |
| - |
201 |
| - foreach ($values as $value) { |
202 |
| - // Single key relational field -- value is the ID from other table |
203 |
| - $relationalField = (is_array($field))? $field[0] : $field; |
204 |
| - $relationalValue[] = @$relationalData[$fieldName][$value][$relationalField]; |
205 |
| - |
206 |
| - // Multi-key relational field (fill in backwards, slightly hacky but works) |
207 |
| - if (is_array($field) && count($field) > 1) { |
208 |
| - for ($n=1; $n < count($field); $n++) { |
209 |
| - $relationalField = $field[$n]; |
210 |
| - |
211 |
| - // Does the field exist in the import definition but not in the current table? |
212 |
| - // Add the value to the row to fill-in the link between read-only relational fields |
213 |
| - if ($importType->isFieldReadOnly($relationalField)) { |
214 |
| - $row[ $relationalField ] = @$relationalData[$fieldName][$value][$relationalField]; |
| 185 | + $rowCount = 2; |
| 186 | + while ($row = $result->fetch()) { |
| 187 | + |
| 188 | + // Work backwards, so we can potentially fill in any relational read-only fields |
| 189 | + for ($i=count($columnFields)-1; $i >= 0; $i--) { |
| 190 | + $fieldName = $columnFields[$i]; |
| 191 | + |
| 192 | + $value = (isset($row[ $fieldName ]))? $row[ $fieldName ] : null; |
| 193 | + |
| 194 | + // Handle relational fields |
| 195 | + if ($importType->isFieldRelational($fieldName)) { |
| 196 | + extract($importType->getField($fieldName, 'relationship')); |
| 197 | + $filter = $importType->getField($fieldName, 'filter'); |
| 198 | + |
| 199 | + $values = $filter == 'csv' ? array_map('trim', explode(',', $value)) : [$value]; |
| 200 | + $relationalValue = []; |
| 201 | + |
| 202 | + foreach ($values as $value) { |
| 203 | + // Single key relational field -- value is the ID from other table |
| 204 | + $relationalField = (is_array($field))? $field[0] : $field; |
| 205 | + $relationalValue[] = @$relationalData[$fieldName][$value][$relationalField]; |
| 206 | + |
| 207 | + // Multi-key relational field (fill in backwards, slightly hacky but works) |
| 208 | + if (is_array($field) && count($field) > 1) { |
| 209 | + for ($n=1; $n < count($field); $n++) { |
| 210 | + $relationalField = $field[$n]; |
| 211 | + |
| 212 | + // Does the field exist in the import definition but not in the current table? |
| 213 | + // Add the value to the row to fill-in the link between read-only relational fields |
| 214 | + if ($importType->isFieldReadOnly($relationalField)) { |
| 215 | + $row[ $relationalField ] = @$relationalData[$fieldName][$value][$relationalField]; |
| 216 | + } |
215 | 217 | }
|
216 | 218 | }
|
217 | 219 | }
|
| 220 | + |
| 221 | + // Replace the relational ID value with the actual value |
| 222 | + $value = implode(',', $relationalValue); |
| 223 | + } |
| 224 | + |
| 225 | + if (!empty($value)) { |
| 226 | + // Set the cell value |
| 227 | + $excel->getActiveSheet()->setCellValue(num2alpha($i).$rowCount, (string)$value); |
218 | 228 | }
|
219 |
| - |
220 |
| - // Replace the relational ID value with the actual value |
221 |
| - $value = implode(',', $relationalValue); |
222 | 229 | }
|
223 | 230 |
|
224 |
| - // Set the cell value |
225 |
| - $excel->getActiveSheet()->setCellValue(num2alpha($i).$rowCount, $value); |
| 231 | + $rowCount++; |
226 | 232 | }
|
227 |
| - |
228 |
| - $rowCount++; |
229 | 233 | }
|
230 | 234 | }
|
231 | 235 | }
|
232 | 236 |
|
233 |
| - $filename = ($dataExport)? __("DataExport", 'Data Admin').'-'.$tableName : __("DataStructure", 'Data Admin').'-'.$type; |
| 237 | + $filename = ($dataExport) ? 'DataExport'.'-'.$type : 'DataStructure'.'-'.$type; |
234 | 238 |
|
235 | 239 | $exportFileType = getSettingByScope($connection2, 'Data Admin', 'exportDefaultFileType');
|
236 | 240 | if (empty($exportFileType)) {
|
|
0 commit comments