1 <?php 2 // This file is part of Moodle - http://moodle.org/ 3 // 4 // Moodle is free software: you can redistribute it and/or modify 5 // it under the terms of the GNU General Public License as published by 6 // the Free Software Foundation, either version 3 of the License, or 7 // (at your option) any later version. 8 // 9 // Moodle is distributed in the hope that it will be useful, 10 // but WITHOUT ANY WARRANTY; without even the implied warranty of 11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 12 // GNU General Public License for more details. 13 // 14 // You should have received a copy of the GNU General Public License 15 // along with Moodle. If not, see <http://www.gnu.org/licenses/>. 16 17 /** 18 * This script produces sample Excel and ODF spreadsheets. 19 * 20 * @package core 21 * @copyright 2013 Petr Skoda {@link http://skodak.org} 22 * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later 23 */ 24 25 require(__DIR__ . '/../../../config.php'); 26 require_once($CFG->libdir . '/excellib.class.php'); 27 require_once($CFG->libdir . '/odslib.class.php'); 28 29 $context = context_system::instance(); 30 $PAGE->set_url('/lib/tests/other/spreadsheettestpage.php'); 31 $PAGE->set_context($context); 32 33 require_login(); 34 require_capability('moodle/site:config', $context); 35 36 $type = optional_param('type', '', PARAM_ALPHANUM); 37 38 if (!in_array($type, array('xslx', 'ods'))) { 39 $type = ''; 40 } 41 42 if (!$type) { 43 $PAGE->set_title('Moodle spreadsheet export test'); 44 $PAGE->set_heading('Moodle spreadsheet export test'); 45 46 echo $OUTPUT->header(); 47 echo $OUTPUT->box_start(); 48 49 $notes = ' 50 Tested with: 51 52 * MS Excel Viewer 2003 (with Compatibility Pack), 2010 53 * LibreOffice 6.0 54 * NeoOffice 3.3 55 * Apple Numbers \'09 (2.3) and Preview 56 * Google Drive spreadsheet import 57 * IBM Lotus Symphony 3.0.1 58 * Gnumeric 1.11 59 * Calligra Suite 2.4, 2.5 60 61 Known problems: 62 63 * Excel 2007 can not be opened in Calligra Suite 64 '; 65 66 echo markdown_to_html($notes); 67 echo $OUTPUT->box_end(); 68 echo $OUTPUT->single_button(new moodle_url($PAGE->url, array('type' => 'xslx')), 'Test Excel format'); 69 echo $OUTPUT->single_button(new moodle_url($PAGE->url, array('type' => 'ods')), 'Test ODS format'); 70 echo $OUTPUT->footer(); 71 die; 72 } 73 74 if ($type === 'xslx') { 75 $workbook = new MoodleExcelWorkbook('moodletest.xlsx', 'Xslx'); 76 } else if ($type === 'ods') { 77 $workbook = new MoodleODSWorkbook('moodletest.ods'); 78 } 79 80 $worksheet = array(); 81 82 $worksheet = $workbook->add_worksheet('Supported'); 83 84 $worksheet->hide_screen_gridlines(); 85 86 $worksheet->write_string(0, 0, 'Moodle worksheet export test', 87 $workbook->add_format(array('color' => 'red', 'size' => 20, 'bold' => 1, 'italic' => 1))); 88 $worksheet->set_row(0, 25); 89 $worksheet->write(1, 0, 'Moodle release: '.$CFG->release, $workbook->add_format(array('size' => 8, 'italic' => 1))); 90 91 $worksheet->set_column(0, 0, 20); 92 $worksheet->set_column(1, 1, 30); 93 $worksheet->set_column(2, 2, 5); 94 $worksheet->set_column(3, 3, 30); 95 $worksheet->set_column(4, 4, 20); 96 97 $miniheading = $workbook->add_format(array('size' => 15, 'bold' => 1, 'italic' => 1, 'underline' => 1)); 98 99 100 $worksheet->write(2, 0, 'Cell types', $miniheading); 101 $worksheet->set_row(2, 20); 102 $worksheet->set_row(3, 5); 103 104 $worksheet->write(4, 0, 'String'); 105 $worksheet->write_string(4, 1, 'Žluťoučký koníček'); 106 107 $worksheet->write(5, 0, 'Number as string'); 108 $worksheet->write_string(5, 1, 3.14159); 109 110 $worksheet->write(6, 0, 'Integer'); 111 $worksheet->write_number(6, 1, 666); 112 113 $worksheet->write(7, 0, 'Float'); 114 $worksheet->write_number(7, 1, 3.14159); 115 116 $worksheet->write(8, 0, 'URL'); 117 $worksheet->write_url(8, 1, 'http://moodle.org'); 118 119 $worksheet->write(9, 0, 'Date (now)'); 120 $worksheet->write_date(9, 1, time()); 121 122 $worksheet->write(10, 0, 'Formula'); 123 $worksheet->write(10, 1, '=1+2'); 124 125 $worksheet->write(11, 0, 'Blank'); 126 $worksheet->write_blank(11, 1, $workbook->add_format(array('bg_color' => 'silver'))); 127 128 129 $worksheet->write(14, 0, 'Text formats', $miniheading); 130 $worksheet->set_row(14, 20); 131 $worksheet->set_row(15, 5); 132 133 // Following writes use alternative format array. 134 $worksheet->write(16, 0, 'Bold', array('bold' => 1)); 135 $worksheet->write(17, 0, 'Italic', array('italic' => 1)); 136 $worksheet->write(18, 0, 'Single underline', array('underline' => 1)); 137 $worksheet->write(19, 0, 'Double underline', array('underline' => 2)); 138 $worksheet->write(20, 0, 'Strikeout', array('strikeout' => 1)); 139 $worksheet->write(21, 0, 'Superscript', array('script' => 1)); 140 $worksheet->write(22, 0, 'Subscript', array('script' => 2)); 141 $worksheet->write(23, 0, 'Red', array('color' => 'red')); 142 143 144 $worksheet->write(25, 0, 'Text align', $miniheading); 145 $worksheet->set_row(25, 20); 146 $worksheet->set_row(26, 5); 147 148 $worksheet->write(27, 0, 'Wrapped text - Žloťoučký koníček', 149 $workbook->add_format(array('text_wrap' => true, 'border' => 1))); 150 $worksheet->set_row(27, 30); 151 $worksheet->write(27, 1, 'All centered', 152 $workbook->add_format(array('v_align' => 'center', 'h_align' => 'center', 'border' => 1))); 153 $worksheet->write(28, 0, 'Top', $workbook->add_format(array('align' => 'top', 'border' => 1))); 154 $worksheet->set_row(28, 25); 155 $worksheet->write(29, 0, 'Vcenter', $workbook->add_format(array('align' => 'vcenter', 'border' => 1))); 156 $worksheet->set_row(29, 25); 157 $worksheet->write(30, 0, 'Bottom', $workbook->add_format(array('align' => 'bottom', 'border' => 1))); 158 $worksheet->set_row(30, 25); 159 $worksheet->write(28, 1, 'Left', $workbook->add_format(array('align' => 'left', 'border' => 1))); 160 $worksheet->write(29, 1, 'Center', $workbook->add_format(array('align' => 'center', 'border' => 1))); 161 $worksheet->write(30, 1, 'Right', $workbook->add_format(array('align' => 'right', 'border' => 1))); 162 163 $worksheet->write(32, 0, 'Number formats', $miniheading); 164 $worksheet->set_row(32, 20); 165 $worksheet->set_row(33, 5); 166 167 $worksheet->write_string(34, 0, '1: 0'); 168 $worksheet->write_number(34, 1, 1003.14159, array('num_format' => 1)); 169 $worksheet->write_string(35, 0, '2: 0.00'); 170 $worksheet->write_number(35, 1, 1003.14159, array('num_format' => 2)); 171 $worksheet->write_string(36, 0, '3: #,##0'); 172 $worksheet->write_number(36, 1, 1003.14159, array('num_format' => 3)); 173 $worksheet->write_string(37, 0, '3: #,##0.00'); 174 $worksheet->write_number(37, 1, 1003.14159, array('num_format' => 4)); 175 $worksheet->write_string(38, 0, '11: 0.00E+00'); 176 $worksheet->write_number(38, 1, 3.14159, array('num_format' => 11)); 177 $worksheet->write_string(39, 0, '12: # ?/?'); 178 $worksheet->write_number(39, 1, 3.14, array('num_format' => 12)); 179 $worksheet->write_string(40, 0, '13: # ??/??'); 180 $worksheet->write_number(40, 1, 3.14, array('num_format' => 13)); 181 $worksheet->write_string(41, 0, '15: d-mmm-yy'); 182 $worksheet->write_date(41, 1, time(), array('num_format' => 15)); 183 $worksheet->write_string(42, 0, '22: m/d/yy h:mm'); 184 $worksheet->write_date(42, 1, time(), array('num_format' => 22)); 185 186 187 188 $worksheet->write(2, 3, 'Borders', $miniheading); 189 190 $worksheet->write(4, 3, 'Left', $workbook->add_format(array('left' => '1'))); 191 $worksheet->write(6, 3, 'Bottom', $workbook->add_format(array('bottom' => '1'))); 192 $worksheet->write(8, 3, 'Right', $workbook->add_format(array('right' => '1'))); 193 $worksheet->write(10, 3, 'Top', $workbook->add_format(array('top' => '1'))); 194 $worksheet->write(12, 3, 'Thick borders', $workbook->add_format(array('border' => '2'))); 195 196 197 $worksheet->write(14, 3, 'Background colours', $miniheading); 198 199 $worksheet->write(16, 3, 'Yellow', $workbook->add_format(array('bg_color' => 'yellow'))); 200 $worksheet->write(17, 3, 'Red', $workbook->add_format(array('bg_color' => 'red'))); 201 $worksheet->write(18, 3, 'Green', $workbook->add_format(array('bg_color' => 'green'))); 202 $worksheet->write(19, 3, 'Blue', $workbook->add_format(array('bg_color' => 12))); 203 $worksheet->write(20, 3, 'Cyan', $workbook->add_format(array('bg_color' => '#00FFFF'))); 204 205 206 $worksheet->write(25, 3, 'Cell merging', $miniheading); 207 208 $worksheet->merge_cells(27, 3, 28, 3); 209 $worksheet->write(27, 3, 'Vertical merging of cells', $workbook->add_format(array('bg_color' => 'silver'))); 210 211 $worksheet->merge_cells(30, 3, 30, 4); 212 $worksheet->write(30, 3, 'Horizontal merging of cells', 213 $workbook->add_format(array('pattern' => 1, 'bg_color' => 'silver'))); 214 $worksheet->set_column(4, 4, 5); 215 216 $worksheet->set_row(44, null, null, true); 217 $worksheet->write(44, 0, 'Hidden row', array('bg_color' => 'yellow')); 218 219 $worksheet->set_column(5, 5, null, null, true); 220 $worksheet->write(0, 5, 'Hidden column', array('bg_color' => 'yellow')); 221 222 223 $worksheet->write(45, 0, 'Outline row 1'); 224 $worksheet->set_row(45, null, null, false, 1); 225 $worksheet->write(46, 0, 'Outline row 2'); 226 $worksheet->set_row(46, null, null, false, 2); 227 228 $worksheet->write(0, 6, 'Outline column 1'); 229 $worksheet->set_column(6, 6, 20, null, false, 1); 230 $worksheet->write(0, 7, 'Outline column 2'); 231 $worksheet->set_column(7, 7, 20, null, false, 2); 232 233 234 235 // Some unfinished stuff. 236 237 $worksheet2 = $workbook->add_worksheet('Unsupported'); 238 $worksheet2->write(0, 0, 'Incomplete and missing features', 239 $workbook->add_format(array('size' => 20, 'bold' => 1, 'italic' => 1))); 240 $worksheet2->set_row(0, 25); 241 $worksheet2->set_column(1, 1, 25); 242 243 $worksheet2->write(3, 1, 'Gray row - buggy'); 244 $worksheet2->set_row(3, null, array('bg_color' => 'silver')); 245 $worksheet2->write(2, 6, 'Gray column - buggy'); 246 $worksheet2->set_column(6, 6, 20, array('bg_color' => 'silver')); 247 248 $worksheet2->hide_gridlines(); 249 250 $worksheet2->write(5, 0, 'Outline text - not implemented', array('outline' => 1)); 251 $worksheet2->write(6, 0, 'Shadow text - not implemented', array('outline' => 1)); 252 253 $worksheet2->write(8, 0, 'Pattern 1'); 254 $worksheet2->write_blank(8, 1, array('pattern' => 1)); 255 $worksheet2->write(9, 0, 'Pattern 2'); 256 $worksheet2->write_blank(9, 1, array('pattern' => 2)); 257 $worksheet2->write(10, 0, 'Pattern 3'); 258 $worksheet2->write_blank(10, 1, array('pattern' => 3)); 259 260 261 // Other worksheet tests follow. 262 263 $worksheet3 = $workbook->add_worksheet('Žlutý:koníček?přeskočil mrňavoučký potůček'); 264 $worksheet3->write(1, 0, 'Test long Unicode worksheet name.'); 265 266 267 $worksheet4 = $workbook->add_worksheet(''); 268 $worksheet4->write(1, 0, 'Test missing worksheet name.'); 269 270 $workbook->close(); 271 die;
title
Description
Body
title
Description
Body
title
Description
Body
title
Body