aboutsummaryrefslogtreecommitdiff
path: root/lib/classes/exportdocument/ExportDocument.php
diff options
context:
space:
mode:
authorPhilipp Schüttlöffel <schuettloeffel@zqs.uni-hannover.de>2024-09-24 10:53:31 +0200
committerPhilipp Schüttlöffel <schuettloeffel@zqs.uni-hannover.de>2024-09-24 10:53:31 +0200
commit4459dd7917f4d1c34f40bb68f0e991e9c3d53e4c (patch)
tree5c07151ae61276d334e88f6309c30d439a85c12e /lib/classes/exportdocument/ExportDocument.php
parentda0022e5c1abbf9825ae76debaabdff7e8623bb4 (diff)
parent97a188592c679890a25c37ab78463add76a52ff7 (diff)
Merge branch 'main' into issue-3911issue-3911
Diffstat (limited to 'lib/classes/exportdocument/ExportDocument.php')
-rw-r--r--lib/classes/exportdocument/ExportDocument.php59
1 files changed, 59 insertions, 0 deletions
diff --git a/lib/classes/exportdocument/ExportDocument.php b/lib/classes/exportdocument/ExportDocument.php
new file mode 100644
index 0000000..27aaee2
--- /dev/null
+++ b/lib/classes/exportdocument/ExportDocument.php
@@ -0,0 +1,59 @@
+<?php
+# Lifter010: TODO
+
+/**
+ * ExportDocument.interface.php - create and export or save a pdf with simple HTML-Data
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation; either version 2 of
+ * the License, or (at your option) any later version.
+ *
+ * @author Rasmus Fuhse & Peter Thienel
+ * @license http://www.gnu.org/licenses/gpl-2.0.html GPL version 2
+ * @category Stud.IP
+ */
+
+/**
+ * This interface describes a basic structure for a class that exports content
+ * or many contents within a document. It is used in ExportPDF, but could be
+ * used for classes that export Excel or OpenDocument files as well. The main
+ * operation to get a document by stud.ip-formatted text is quite simple:
+ *
+ * $doc = new ExportPDF();
+ * $doc->addPage();
+ * $doc->addContent('Hallo, %%wir%% benutzen :studip: -Formatierung.');
+ * $doc->dispatch("test_pdf");
+ * //lines following dispatch won't be accessed anymor, because dispatch
+ * //cancels all other output.
+ *
+ */
+interface ExportDocument {
+
+ /**
+ * Adding a new page to write new content on it. Must be called at least once
+ * before any call of addContent($text).
+ */
+ public function addPage();
+
+ /**
+ * Adding an area of Stud.IP formatted content.
+ */
+ public function addContent($content);
+
+ /**
+ * Outputs the content as a file with MIME-type and aborts any other output.
+ * @param string $filename name of the future file without the extension.
+ */
+ public function dispatch($filename);
+
+ /**
+ * Saves the content as a file in the filesystem and returns a Stud.IP-document object.
+ * @param string $filename name of the future file without the extension.
+ * @param mixed $folder_id md5-id of a given folder in database or null for nothing
+ * @return StudipDocument of the exported file or false if creation of StudipDocument failed.
+ */
+ public function save($filename, $folder_id = null);
+
+}
+