saimod documentation proto, workin markdown viewer
This commit is contained in:
parent
819e3b21c7
commit
7c3a80d9cf
@ -35,3 +35,7 @@ spl_autoload_register('__autoload_system');
|
|||||||
\SYSTEM\autoload::registerFolder(dirname(__FILE__).'/cache','SYSTEM\CACHE');
|
\SYSTEM\autoload::registerFolder(dirname(__FILE__).'/cache','SYSTEM\CACHE');
|
||||||
|
|
||||||
\SYSTEM\autoload::registerFolder(dirname(__FILE__).'/sai','SYSTEM\SAI');
|
\SYSTEM\autoload::registerFolder(dirname(__FILE__).'/sai','SYSTEM\SAI');
|
||||||
|
\SYSTEM\autoload::registerFolder(dirname(__FILE__).'/docu','SYSTEM\DOCU');
|
||||||
|
|
||||||
|
require_once dirname(__FILE__).'/lib/autoload.inc.php';
|
||||||
|
require_once dirname(__FILE__).'/docu/register_sys_docu.php';
|
||||||
25
docu/docu.php
Normal file
25
docu/docu.php
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
<?php
|
||||||
|
namespace SYSTEM\DOCU;
|
||||||
|
|
||||||
|
class docu {
|
||||||
|
private static $documents = array(); //only strings!
|
||||||
|
|
||||||
|
public static function registerFolder($folder,$category){
|
||||||
|
if(!is_dir($folder)){
|
||||||
|
throw new \SYSTEM\LOG\ERROR('Docu Folder does not exist: '.$folder);}
|
||||||
|
|
||||||
|
foreach (glob($folder."/*.md") as $filename) {
|
||||||
|
self::register($filename, $category);}
|
||||||
|
}
|
||||||
|
public static function register($document,$category){
|
||||||
|
if(!file_exists($document)){
|
||||||
|
throw new \SYSTEM\LOG\ERROR("Could not find registered documentation: ".$document);}
|
||||||
|
if(!isset(self::$documents[$category])){
|
||||||
|
self::$documents[$category] = array();}
|
||||||
|
array_push(self::$documents[$category],$document);}
|
||||||
|
|
||||||
|
public static function getDocuments(){
|
||||||
|
return self::$documents;}
|
||||||
|
public static function getCategory($category){
|
||||||
|
return self::$documents[$category];}
|
||||||
|
}
|
||||||
6
docu/docu_categories.php
Normal file
6
docu/docu_categories.php
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
<?php
|
||||||
|
namespace SYSTEM\DOCU;
|
||||||
|
|
||||||
|
class docu_categories {
|
||||||
|
const DOCU_CAT_SYS = 'System';
|
||||||
|
}
|
||||||
2
docu/register_sys_docu.php
Normal file
2
docu/register_sys_docu.php
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
<?php
|
||||||
|
\SYSTEM\DOCU\docu::registerFolder(dirname(__FILE__).'/system',\SYSTEM\DOCU\docu_categories::DOCU_CAT_SYS);
|
||||||
3
docu/system/1.system.md
Normal file
3
docu/system/1.system.md
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
system
|
||||||
|
======
|
||||||
|
System - PHP Framework
|
||||||
21
docu/system/2.license.md
Normal file
21
docu/system/2.license.md
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
License
|
||||||
|
=======
|
||||||
|
Copyright (c) 2013 TU-Darmstadt, Ulf Gebhardt
|
||||||
|
|
||||||
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
in the Software without restriction, including without limitation the rights
|
||||||
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
copies of the Software, and to permit persons to whom the Software is
|
||||||
|
furnished to do so, subject to the following conditions:
|
||||||
|
|
||||||
|
The above copyright notice and this permission notice shall be included in
|
||||||
|
all copies or substantial portions of the Software.
|
||||||
|
|
||||||
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||||
|
THE SOFTWARE.
|
||||||
0
docu/system/3.getting started.md
Normal file
0
docu/system/3.getting started.md
Normal file
0
docu/system/system.api.md
Normal file
0
docu/system/system.api.md
Normal file
0
docu/system/system.cache.md
Normal file
0
docu/system/system.cache.md
Normal file
0
docu/system/system.config.md
Normal file
0
docu/system/system.config.md
Normal file
0
docu/system/system.db.md
Normal file
0
docu/system/system.db.md
Normal file
0
docu/system/system.docu.md
Normal file
0
docu/system/system.docu.md
Normal file
0
docu/system/system.log.md
Normal file
0
docu/system/system.log.md
Normal file
0
docu/system/system.page.md
Normal file
0
docu/system/system.page.md
Normal file
0
docu/system/system.sai.md
Normal file
0
docu/system/system.sai.md
Normal file
0
docu/system/system.security.md
Normal file
0
docu/system/system.security.md
Normal file
0
docu/system/system.system.md
Normal file
0
docu/system/system.system.md
Normal file
16
img/img.php
Normal file
16
img/img.php
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
<?php
|
||||||
|
namespace SYSTEM;
|
||||||
|
|
||||||
|
class img {
|
||||||
|
protected static function folder_path(){
|
||||||
|
throw new \RuntimeException("Not implemeted");}
|
||||||
|
|
||||||
|
public static function get($hash){
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function put($file){
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
2899
lib/EpicEditor/js/epiceditor.js
Normal file
2899
lib/EpicEditor/js/epiceditor.js
Normal file
File diff suppressed because it is too large
Load Diff
5
lib/EpicEditor/js/epiceditor.min.js
vendored
Normal file
5
lib/EpicEditor/js/epiceditor.min.js
vendored
Normal file
File diff suppressed because one or more lines are too long
70
lib/EpicEditor/themes/base/epiceditor.css
Normal file
70
lib/EpicEditor/themes/base/epiceditor.css
Normal file
@ -0,0 +1,70 @@
|
|||||||
|
html, body, iframe, div {
|
||||||
|
margin:0;
|
||||||
|
padding:0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-utilbar {
|
||||||
|
position:fixed;
|
||||||
|
bottom:10px;
|
||||||
|
right:10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-utilbar button {
|
||||||
|
display:block;
|
||||||
|
float:left;
|
||||||
|
width:30px;
|
||||||
|
height:30px;
|
||||||
|
border:none;
|
||||||
|
background:none;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-utilbar button.epiceditor-toggle-preview-btn {
|
||||||
|
background-image:url();
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-utilbar button.epiceditor-toggle-edit-btn {
|
||||||
|
background-image:url();
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-utilbar button.epiceditor-fullscreen-btn {
|
||||||
|
background-image:url();
|
||||||
|
}
|
||||||
|
|
||||||
|
@media
|
||||||
|
only screen and (-webkit-min-device-pixel-ratio: 2),
|
||||||
|
only screen and ( min--moz-device-pixel-ratio: 2),
|
||||||
|
only screen and ( -o-min-device-pixel-ratio: 2/1),
|
||||||
|
only screen and ( min-device-pixel-ratio: 2),
|
||||||
|
only screen and ( min-resolution: 192dpi),
|
||||||
|
only screen and ( min-resolution: 2dppx) {
|
||||||
|
#epiceditor-utilbar button.epiceditor-toggle-preview-btn {
|
||||||
|
background:url();
|
||||||
|
background-size: 30px 30px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-utilbar button.epiceditor-toggle-edit-btn {
|
||||||
|
background:url();
|
||||||
|
background-size: 30px 30px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-utilbar button.epiceditor-fullscreen-btn {
|
||||||
|
background:url();
|
||||||
|
background-size: 30px 30px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-utilbar button:last-child {
|
||||||
|
margin-left:15px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-utilbar button:hover {
|
||||||
|
cursor:pointer;
|
||||||
|
}
|
||||||
|
|
||||||
|
.epiceditor-edit-mode #epiceditor-utilbar button.epiceditor-toggle-edit-btn {
|
||||||
|
display:none;
|
||||||
|
}
|
||||||
|
|
||||||
|
.epiceditor-preview-mode #epiceditor-utilbar button.epiceditor-toggle-preview-btn {
|
||||||
|
display:none;
|
||||||
|
}
|
||||||
13
lib/EpicEditor/themes/editor/epic-dark.css
Normal file
13
lib/EpicEditor/themes/editor/epic-dark.css
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
html { padding:10px; }
|
||||||
|
|
||||||
|
body {
|
||||||
|
border:0;
|
||||||
|
background:rgb(41,41,41);
|
||||||
|
font-family:monospace;
|
||||||
|
font-size:14px;
|
||||||
|
padding:10px;
|
||||||
|
color:#ddd;
|
||||||
|
line-height:1.35em;
|
||||||
|
margin:0;
|
||||||
|
padding:0;
|
||||||
|
}
|
||||||
12
lib/EpicEditor/themes/editor/epic-light.css
Normal file
12
lib/EpicEditor/themes/editor/epic-light.css
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
html { padding:10px; }
|
||||||
|
|
||||||
|
body {
|
||||||
|
border:0;
|
||||||
|
background:#fcfcfc;
|
||||||
|
font-family:monospace;
|
||||||
|
font-size:14px;
|
||||||
|
padding:10px;
|
||||||
|
line-height:1.35em;
|
||||||
|
margin:0;
|
||||||
|
padding:0;
|
||||||
|
}
|
||||||
167
lib/EpicEditor/themes/preview/bartik.css
Normal file
167
lib/EpicEditor/themes/preview/bartik.css
Normal file
@ -0,0 +1,167 @@
|
|||||||
|
body {
|
||||||
|
font-family: Georgia, "Times New Roman", Times, serif;
|
||||||
|
line-height: 1.5;
|
||||||
|
font-size: 87.5%;
|
||||||
|
word-wrap: break-word;
|
||||||
|
margin: 2em;
|
||||||
|
padding: 0;
|
||||||
|
border: 0;
|
||||||
|
outline: 0;
|
||||||
|
background: #fff;
|
||||||
|
}
|
||||||
|
|
||||||
|
h1,
|
||||||
|
h2,
|
||||||
|
h3,
|
||||||
|
h4,
|
||||||
|
h5,
|
||||||
|
h6 {
|
||||||
|
margin: 1.0em 0 0.5em;
|
||||||
|
font-weight: inherit;
|
||||||
|
}
|
||||||
|
|
||||||
|
h1 {
|
||||||
|
font-size: 1.357em;
|
||||||
|
color: #000;
|
||||||
|
}
|
||||||
|
|
||||||
|
h2 {
|
||||||
|
font-size: 1.143em;
|
||||||
|
}
|
||||||
|
|
||||||
|
p {
|
||||||
|
margin: 0 0 1.2em;
|
||||||
|
}
|
||||||
|
|
||||||
|
del {
|
||||||
|
text-decoration: line-through;
|
||||||
|
}
|
||||||
|
|
||||||
|
tr:nth-child(odd) {
|
||||||
|
background-color: #dddddd;
|
||||||
|
}
|
||||||
|
|
||||||
|
img {
|
||||||
|
outline: 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
code {
|
||||||
|
background-color: #f2f2f2;
|
||||||
|
background-color: rgba(40, 40, 0, 0.06);
|
||||||
|
}
|
||||||
|
|
||||||
|
pre {
|
||||||
|
background-color: #f2f2f2;
|
||||||
|
background-color: rgba(40, 40, 0, 0.06);
|
||||||
|
margin: 10px 0;
|
||||||
|
overflow: hidden;
|
||||||
|
padding: 15px;
|
||||||
|
white-space: pre-wrap;
|
||||||
|
}
|
||||||
|
|
||||||
|
pre code {
|
||||||
|
font-size: 100%;
|
||||||
|
background-color: transparent;
|
||||||
|
}
|
||||||
|
|
||||||
|
blockquote {
|
||||||
|
background: #f7f7f7;
|
||||||
|
border-left: 1px solid #bbb;
|
||||||
|
font-style: italic;
|
||||||
|
margin: 1.5em 10px;
|
||||||
|
padding: 0.5em 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
blockquote:before {
|
||||||
|
color: #bbb;
|
||||||
|
content: "\201C";
|
||||||
|
font-size: 3em;
|
||||||
|
line-height: 0.1em;
|
||||||
|
margin-right: 0.2em;
|
||||||
|
vertical-align: -.4em;
|
||||||
|
}
|
||||||
|
|
||||||
|
blockquote:after {
|
||||||
|
color: #bbb;
|
||||||
|
content: "\201D";
|
||||||
|
font-size: 3em;
|
||||||
|
line-height: 0.1em;
|
||||||
|
vertical-align: -.45em;
|
||||||
|
}
|
||||||
|
|
||||||
|
blockquote > p:first-child {
|
||||||
|
display: inline;
|
||||||
|
}
|
||||||
|
|
||||||
|
table {
|
||||||
|
font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
|
||||||
|
border: 0;
|
||||||
|
border-spacing: 0;
|
||||||
|
font-size: 0.857em;
|
||||||
|
margin: 10px 0;
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
table table {
|
||||||
|
font-size: 1em;
|
||||||
|
}
|
||||||
|
|
||||||
|
table tr th {
|
||||||
|
background: #757575;
|
||||||
|
background: rgba(0, 0, 0, 0.51);
|
||||||
|
border-bottom-style: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
table tr th,
|
||||||
|
table tr th a,
|
||||||
|
table tr th a:hover {
|
||||||
|
color: #FFF;
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
table tbody tr th {
|
||||||
|
vertical-align: top;
|
||||||
|
}
|
||||||
|
|
||||||
|
tr td,
|
||||||
|
tr th {
|
||||||
|
padding: 4px 9px;
|
||||||
|
border: 1px solid #fff;
|
||||||
|
text-align: left; /* LTR */
|
||||||
|
}
|
||||||
|
|
||||||
|
tr:nth-child(odd) {
|
||||||
|
background: #e4e4e4;
|
||||||
|
background: rgba(0, 0, 0, 0.105);
|
||||||
|
}
|
||||||
|
|
||||||
|
tr,
|
||||||
|
tr:nth-child(even) {
|
||||||
|
background: #efefef;
|
||||||
|
background: rgba(0, 0, 0, 0.063);
|
||||||
|
}
|
||||||
|
|
||||||
|
a {
|
||||||
|
color: #0071B3;
|
||||||
|
}
|
||||||
|
|
||||||
|
a:hover,
|
||||||
|
a:focus {
|
||||||
|
color: #018fe2;
|
||||||
|
}
|
||||||
|
|
||||||
|
a:active {
|
||||||
|
color: #23aeff;
|
||||||
|
}
|
||||||
|
|
||||||
|
a:link,
|
||||||
|
a:visited {
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
|
||||||
|
a:hover,
|
||||||
|
a:active,
|
||||||
|
a:focus {
|
||||||
|
text-decoration: underline;
|
||||||
|
}
|
||||||
|
|
||||||
368
lib/EpicEditor/themes/preview/github.css
Normal file
368
lib/EpicEditor/themes/preview/github.css
Normal file
@ -0,0 +1,368 @@
|
|||||||
|
html { padding:0 10px; }
|
||||||
|
|
||||||
|
body {
|
||||||
|
margin:0;
|
||||||
|
padding:0;
|
||||||
|
background:#fff;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-wrapper{
|
||||||
|
background:white;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview{
|
||||||
|
padding-top:10px;
|
||||||
|
padding-bottom:10px;
|
||||||
|
font-family: Helvetica,arial,freesans,clean,sans-serif;
|
||||||
|
font-size:13px;
|
||||||
|
line-height:1.6;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview>*:first-child{
|
||||||
|
margin-top:0!important;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview>*:last-child{
|
||||||
|
margin-bottom:0!important;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview a{
|
||||||
|
color:#4183C4;
|
||||||
|
text-decoration:none;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview a:hover{
|
||||||
|
text-decoration:underline;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview h1,
|
||||||
|
#epiceditor-preview h2,
|
||||||
|
#epiceditor-preview h3,
|
||||||
|
#epiceditor-preview h4,
|
||||||
|
#epiceditor-preview h5,
|
||||||
|
#epiceditor-preview h6{
|
||||||
|
margin:20px 0 10px;
|
||||||
|
padding:0;
|
||||||
|
font-weight:bold;
|
||||||
|
-webkit-font-smoothing:antialiased;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview h1 tt,
|
||||||
|
#epiceditor-preview h1 code,
|
||||||
|
#epiceditor-preview h2 tt,
|
||||||
|
#epiceditor-preview h2 code,
|
||||||
|
#epiceditor-preview h3 tt,
|
||||||
|
#epiceditor-preview h3 code,
|
||||||
|
#epiceditor-preview h4 tt,
|
||||||
|
#epiceditor-preview h4 code,
|
||||||
|
#epiceditor-preview h5 tt,
|
||||||
|
#epiceditor-preview h5 code,
|
||||||
|
#epiceditor-preview h6 tt,
|
||||||
|
#epiceditor-preview h6 code{
|
||||||
|
font-size:inherit;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview h1{
|
||||||
|
font-size:28px;
|
||||||
|
color:#000;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview h2{
|
||||||
|
font-size:24px;
|
||||||
|
border-bottom:1px solid #ccc;
|
||||||
|
color:#000;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview h3{
|
||||||
|
font-size:18px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview h4{
|
||||||
|
font-size:16px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview h5{
|
||||||
|
font-size:14px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview h6{
|
||||||
|
color:#777;
|
||||||
|
font-size:14px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview p,
|
||||||
|
#epiceditor-preview blockquote,
|
||||||
|
#epiceditor-preview ul,
|
||||||
|
#epiceditor-preview ol,
|
||||||
|
#epiceditor-preview dl,
|
||||||
|
#epiceditor-preview li,
|
||||||
|
#epiceditor-preview table,
|
||||||
|
#epiceditor-preview pre{
|
||||||
|
margin:15px 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview hr{
|
||||||
|
background:transparent url('../../images/modules/pulls/dirty-shade.png') repeat-x 0 0;
|
||||||
|
border:0 none;
|
||||||
|
color:#ccc;
|
||||||
|
height:4px;
|
||||||
|
padding:0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview>h2:first-child,
|
||||||
|
#epiceditor-preview>h1:first-child,
|
||||||
|
#epiceditor-preview>h1:first-child+h2,
|
||||||
|
#epiceditor-preview>h3:first-child,
|
||||||
|
#epiceditor-preview>h4:first-child,
|
||||||
|
#epiceditor-preview>h5:first-child,
|
||||||
|
#epiceditor-preview>h6:first-child{
|
||||||
|
margin-top:0;
|
||||||
|
padding-top:0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview h1+p,
|
||||||
|
#epiceditor-preview h2+p,
|
||||||
|
#epiceditor-preview h3+p,
|
||||||
|
#epiceditor-preview h4+p,
|
||||||
|
#epiceditor-preview h5+p,
|
||||||
|
#epiceditor-preview h6+p{
|
||||||
|
margin-top:0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview li p.first{
|
||||||
|
display:inline-block;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview ul,
|
||||||
|
#epiceditor-preview ol{
|
||||||
|
padding-left:30px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview ul li>:first-child,
|
||||||
|
#epiceditor-preview ol li>:first-child{
|
||||||
|
margin-top:0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview ul li>:last-child,
|
||||||
|
#epiceditor-preview ol li>:last-child{
|
||||||
|
margin-bottom:0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview dl{
|
||||||
|
padding:0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview dl dt{
|
||||||
|
font-size:14px;
|
||||||
|
font-weight:bold;
|
||||||
|
font-style:italic;
|
||||||
|
padding:0;
|
||||||
|
margin:15px 0 5px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview dl dt:first-child{
|
||||||
|
padding:0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview dl dt>:first-child{
|
||||||
|
margin-top:0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview dl dt>:last-child{
|
||||||
|
margin-bottom:0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview dl dd{
|
||||||
|
margin:0 0 15px;
|
||||||
|
padding:0 15px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview dl dd>:first-child{
|
||||||
|
margin-top:0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview dl dd>:last-child{
|
||||||
|
margin-bottom:0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview blockquote{
|
||||||
|
border-left:4px solid #DDD;
|
||||||
|
padding:0 15px;
|
||||||
|
color:#777;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview blockquote>:first-child{
|
||||||
|
margin-top:0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview blockquote>:last-child{
|
||||||
|
margin-bottom:0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview table{
|
||||||
|
padding:0;
|
||||||
|
border-collapse: collapse;
|
||||||
|
border-spacing: 0;
|
||||||
|
font-size: 100%;
|
||||||
|
font: inherit;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview table tr{
|
||||||
|
border-top:1px solid #ccc;
|
||||||
|
background-color:#fff;
|
||||||
|
margin:0;
|
||||||
|
padding:0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview table tr:nth-child(2n){
|
||||||
|
background-color:#f8f8f8;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview table tr th{
|
||||||
|
font-weight:bold;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview table tr th,
|
||||||
|
#epiceditor-preview table tr td{
|
||||||
|
border:1px solid #ccc;
|
||||||
|
text-align:left;
|
||||||
|
margin:0;
|
||||||
|
padding:6px 13px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview table tr th>:first-child,
|
||||||
|
#epiceditor-preview table tr td>:first-child{
|
||||||
|
margin-top:0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview table tr th>:last-child,
|
||||||
|
#epiceditor-preview table tr td>:last-child{
|
||||||
|
margin-bottom:0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview img{
|
||||||
|
max-width:100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview span.frame{
|
||||||
|
display:block;
|
||||||
|
overflow:hidden;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview span.frame>span{
|
||||||
|
border:1px solid #ddd;
|
||||||
|
display:block;
|
||||||
|
float:left;
|
||||||
|
overflow:hidden;
|
||||||
|
margin:13px 0 0;
|
||||||
|
padding:7px;
|
||||||
|
width:auto;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview span.frame span img{
|
||||||
|
display:block;
|
||||||
|
float:left;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview span.frame span span{
|
||||||
|
clear:both;
|
||||||
|
color:#333;
|
||||||
|
display:block;
|
||||||
|
padding:5px 0 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview span.align-center{
|
||||||
|
display:block;
|
||||||
|
overflow:hidden;
|
||||||
|
clear:both;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview span.align-center>span{
|
||||||
|
display:block;
|
||||||
|
overflow:hidden;
|
||||||
|
margin:13px auto 0;
|
||||||
|
text-align:center;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview span.align-center span img{
|
||||||
|
margin:0 auto;
|
||||||
|
text-align:center;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview span.align-right{
|
||||||
|
display:block;
|
||||||
|
overflow:hidden;
|
||||||
|
clear:both;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview span.align-right>span{
|
||||||
|
display:block;
|
||||||
|
overflow:hidden;
|
||||||
|
margin:13px 0 0;
|
||||||
|
text-align:right;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview span.align-right span img{
|
||||||
|
margin:0;
|
||||||
|
text-align:right;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview span.float-left{
|
||||||
|
display:block;
|
||||||
|
margin-right:13px;
|
||||||
|
overflow:hidden;
|
||||||
|
float:left;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview span.float-left span{
|
||||||
|
margin:13px 0 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview span.float-right{
|
||||||
|
display:block;
|
||||||
|
margin-left:13px;
|
||||||
|
overflow:hidden;
|
||||||
|
float:right;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview span.float-right>span{
|
||||||
|
display:block;
|
||||||
|
overflow:hidden;
|
||||||
|
margin:13px auto 0;
|
||||||
|
text-align:right;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview code,
|
||||||
|
#epiceditor-preview tt{
|
||||||
|
margin:0 2px;
|
||||||
|
padding:0 5px;
|
||||||
|
white-space:nowrap;
|
||||||
|
border:1px solid #eaeaea;
|
||||||
|
background-color:#f8f8f8;
|
||||||
|
border-radius:3px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview pre>code{
|
||||||
|
margin:0;
|
||||||
|
padding:0;
|
||||||
|
white-space:pre;
|
||||||
|
border:none;
|
||||||
|
background:transparent;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview .highlight pre,
|
||||||
|
#epiceditor-preview pre{
|
||||||
|
background-color:#f8f8f8;
|
||||||
|
border:1px solid #ccc;
|
||||||
|
font-size:13px;
|
||||||
|
line-height:19px;
|
||||||
|
overflow:auto;
|
||||||
|
padding:6px 10px;
|
||||||
|
border-radius:3px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview pre code,
|
||||||
|
#epiceditor-preview pre tt{
|
||||||
|
background-color:transparent;
|
||||||
|
border:none;
|
||||||
|
}
|
||||||
121
lib/EpicEditor/themes/preview/preview-dark.css
Normal file
121
lib/EpicEditor/themes/preview/preview-dark.css
Normal file
@ -0,0 +1,121 @@
|
|||||||
|
html { padding:0 10px; }
|
||||||
|
|
||||||
|
body {
|
||||||
|
margin:0;
|
||||||
|
padding:10px 0;
|
||||||
|
background:#000;
|
||||||
|
}
|
||||||
|
|
||||||
|
#epiceditor-preview h1,
|
||||||
|
#epiceditor-preview h2,
|
||||||
|
#epiceditor-preview h3,
|
||||||
|
#epiceditor-preview h4,
|
||||||
|
#epiceditor-preview h5,
|
||||||
|
#epiceditor-preview h6,
|
||||||
|
#epiceditor-preview p,
|
||||||
|
#epiceditor-preview blockquote {
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
|
#epiceditor-preview {
|
||||||
|
background:#000;
|
||||||
|
font-family: "Helvetica Neue", Helvetica, "Hiragino Sans GB", Arial, sans-serif;
|
||||||
|
font-size: 13px;
|
||||||
|
line-height: 18px;
|
||||||
|
color: #ccc;
|
||||||
|
}
|
||||||
|
#epiceditor-preview a {
|
||||||
|
color: #fff;
|
||||||
|
}
|
||||||
|
#epiceditor-preview a:hover {
|
||||||
|
color: #00ff00;
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
#epiceditor-preview a img {
|
||||||
|
border: none;
|
||||||
|
}
|
||||||
|
#epiceditor-preview p {
|
||||||
|
margin-bottom: 9px;
|
||||||
|
}
|
||||||
|
#epiceditor-preview h1,
|
||||||
|
#epiceditor-preview h2,
|
||||||
|
#epiceditor-preview h3,
|
||||||
|
#epiceditor-preview h4,
|
||||||
|
#epiceditor-preview h5,
|
||||||
|
#epiceditor-preview h6 {
|
||||||
|
color: #cdcdcd;
|
||||||
|
line-height: 36px;
|
||||||
|
}
|
||||||
|
#epiceditor-preview h1 {
|
||||||
|
margin-bottom: 18px;
|
||||||
|
font-size: 30px;
|
||||||
|
}
|
||||||
|
#epiceditor-preview h2 {
|
||||||
|
font-size: 24px;
|
||||||
|
}
|
||||||
|
#epiceditor-preview h3 {
|
||||||
|
font-size: 18px;
|
||||||
|
}
|
||||||
|
#epiceditor-preview h4 {
|
||||||
|
font-size: 16px;
|
||||||
|
}
|
||||||
|
#epiceditor-preview h5 {
|
||||||
|
font-size: 14px;
|
||||||
|
}
|
||||||
|
#epiceditor-preview h6 {
|
||||||
|
font-size: 13px;
|
||||||
|
}
|
||||||
|
#epiceditor-preview hr {
|
||||||
|
margin: 0 0 19px;
|
||||||
|
border: 0;
|
||||||
|
border-bottom: 1px solid #ccc;
|
||||||
|
}
|
||||||
|
#epiceditor-preview blockquote {
|
||||||
|
padding: 13px 13px 21px 15px;
|
||||||
|
margin-bottom: 18px;
|
||||||
|
font-family:georgia,serif;
|
||||||
|
font-style: italic;
|
||||||
|
}
|
||||||
|
#epiceditor-preview blockquote:before {
|
||||||
|
content:"\201C";
|
||||||
|
font-size:40px;
|
||||||
|
margin-left:-10px;
|
||||||
|
font-family:georgia,serif;
|
||||||
|
color:#eee;
|
||||||
|
}
|
||||||
|
#epiceditor-preview blockquote p {
|
||||||
|
font-size: 14px;
|
||||||
|
font-weight: 300;
|
||||||
|
line-height: 18px;
|
||||||
|
margin-bottom: 0;
|
||||||
|
font-style: italic;
|
||||||
|
}
|
||||||
|
#epiceditor-preview code, #epiceditor-preview pre {
|
||||||
|
font-family: Monaco, Andale Mono, Courier New, monospace;
|
||||||
|
}
|
||||||
|
#epiceditor-preview code {
|
||||||
|
background-color: #000;
|
||||||
|
color: #f92672;
|
||||||
|
padding: 1px 3px;
|
||||||
|
font-size: 12px;
|
||||||
|
-webkit-border-radius: 3px;
|
||||||
|
-moz-border-radius: 3px;
|
||||||
|
border-radius: 3px;
|
||||||
|
}
|
||||||
|
#epiceditor-preview pre {
|
||||||
|
display: block;
|
||||||
|
padding: 14px;
|
||||||
|
color:#66d9ef;
|
||||||
|
margin: 0 0 18px;
|
||||||
|
line-height: 16px;
|
||||||
|
font-size: 11px;
|
||||||
|
border: 1px solid #d9d9d9;
|
||||||
|
white-space: pre-wrap;
|
||||||
|
word-wrap: break-word;
|
||||||
|
}
|
||||||
|
#epiceditor-preview pre code {
|
||||||
|
background-color: #000;
|
||||||
|
color:#ccc;
|
||||||
|
font-size: 11px;
|
||||||
|
padding: 0;
|
||||||
|
}
|
||||||
3096
lib/Michelf/Markdown.php
Normal file
3096
lib/Michelf/Markdown.php
Normal file
File diff suppressed because it is too large
Load Diff
40
lib/Michelf/MarkdownExtra.php
Normal file
40
lib/Michelf/MarkdownExtra.php
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
<?php
|
||||||
|
#
|
||||||
|
# Markdown Extra - A text-to-HTML conversion tool for web writers
|
||||||
|
#
|
||||||
|
# PHP Markdown Extra
|
||||||
|
# Copyright (c) 2004-2013 Michel Fortin
|
||||||
|
# <http://michelf.com/projects/php-markdown/>
|
||||||
|
#
|
||||||
|
# Original Markdown
|
||||||
|
# Copyright (c) 2004-2006 John Gruber
|
||||||
|
# <http://daringfireball.net/projects/markdown/>
|
||||||
|
#
|
||||||
|
namespace Michelf;
|
||||||
|
|
||||||
|
|
||||||
|
# Just force Michelf/Markdown.php to load. This is needed to load
|
||||||
|
# the temporary implementation class. See below for details.
|
||||||
|
\Michelf\Markdown::MARKDOWNLIB_VERSION;
|
||||||
|
|
||||||
|
#
|
||||||
|
# Markdown Extra Parser Class
|
||||||
|
#
|
||||||
|
# Note: Currently the implementation resides in the temporary class
|
||||||
|
# \Michelf\MarkdownExtra_TmpImpl (in the same file as \Michelf\Markdown).
|
||||||
|
# This makes it easier to propagate the changes between the three different
|
||||||
|
# packaging styles of PHP Markdown. Once this issue is resolved, the
|
||||||
|
# _MarkdownExtra_TmpImpl will disappear and this one will contain the code.
|
||||||
|
#
|
||||||
|
|
||||||
|
class MarkdownExtra extends \Michelf\_MarkdownExtra_TmpImpl {
|
||||||
|
|
||||||
|
### Parser Implementation ###
|
||||||
|
|
||||||
|
# Temporarily, the implemenation is in the _MarkdownExtra_TmpImpl class.
|
||||||
|
# See note above.
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
?>
|
||||||
36
lib/Michelf/extra/License.md
Normal file
36
lib/Michelf/extra/License.md
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
PHP Markdown Lib
|
||||||
|
Copyright (c) 2004-2013 Michel Fortin
|
||||||
|
<http://michelf.ca/>
|
||||||
|
All rights reserved.
|
||||||
|
|
||||||
|
Based on Markdown
|
||||||
|
Copyright (c) 2003-2006 John Gruber
|
||||||
|
<http://daringfireball.net/>
|
||||||
|
All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are
|
||||||
|
met:
|
||||||
|
|
||||||
|
* Redistributions of source code must retain the above copyright notice,
|
||||||
|
this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
* Redistributions in binary form must reproduce the above copyright
|
||||||
|
notice, this list of conditions and the following disclaimer in the
|
||||||
|
documentation and/or other materials provided with the distribution.
|
||||||
|
|
||||||
|
* Neither the name "Markdown" nor the names of its contributors may
|
||||||
|
be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
This software is provided by the copyright holders and contributors "as
|
||||||
|
is" and any express or implied warranties, including, but not limited
|
||||||
|
to, the implied warranties of merchantability and fitness for a
|
||||||
|
particular purpose are disclaimed. In no event shall the copyright owner
|
||||||
|
or contributors be liable for any direct, indirect, incidental, special,
|
||||||
|
exemplary, or consequential damages (including, but not limited to,
|
||||||
|
procurement of substitute goods or services; loss of use, data, or
|
||||||
|
profits; or business interruption) however caused and on any theory of
|
||||||
|
liability, whether in contract, strict liability, or tort (including
|
||||||
|
negligence or otherwise) arising in any way out of the use of this
|
||||||
|
software, even if advised of the possibility of such damage.
|
||||||
259
lib/Michelf/extra/Readme.md
Normal file
259
lib/Michelf/extra/Readme.md
Normal file
@ -0,0 +1,259 @@
|
|||||||
|
PHP Markdown
|
||||||
|
============
|
||||||
|
|
||||||
|
PHP Markdown Lib 1.3 - 11 Apr 2013
|
||||||
|
|
||||||
|
by Michel Fortin
|
||||||
|
<http://michelf.ca/>
|
||||||
|
|
||||||
|
based on Markdown by John Gruber
|
||||||
|
<http://daringfireball.net/>
|
||||||
|
|
||||||
|
|
||||||
|
Introduction
|
||||||
|
------------
|
||||||
|
|
||||||
|
This is a library package that includes the PHP Markdown parser and its
|
||||||
|
sibling PHP Markdown Extra which additional features.
|
||||||
|
|
||||||
|
Markdown is a text-to-HTML conversion tool for web writers. Markdown
|
||||||
|
allows you to write using an easy-to-read, easy-to-write plain text
|
||||||
|
format, then convert it to structurally valid XHTML (or HTML).
|
||||||
|
|
||||||
|
"Markdown" is two things: a plain text markup syntax, and a software
|
||||||
|
tool, written in Perl, that converts the plain text markup to HTML.
|
||||||
|
PHP Markdown is a port to PHP of the original Markdown program by
|
||||||
|
John Gruber.
|
||||||
|
|
||||||
|
PHP Markdown can work as a plug-in for WordPress, as a modifier for
|
||||||
|
the Smarty templating engine, or as a replacement for Textile
|
||||||
|
formatting in any software that supports Textile.
|
||||||
|
|
||||||
|
Full documentation of Markdown's syntax is available on John's
|
||||||
|
Markdown page: <http://daringfireball.net/projects/markdown/>
|
||||||
|
|
||||||
|
|
||||||
|
Requirement
|
||||||
|
-----------
|
||||||
|
|
||||||
|
This library package requires PHP 5.3 or later.
|
||||||
|
|
||||||
|
Note: The older plugin/library hybrid package for PHP Markdown and
|
||||||
|
PHP Markdown Extra is still maintained and will work with PHP 4.0.5 and later.
|
||||||
|
|
||||||
|
Before PHP 5.3.7, pcre.backtrack_limit defaults to 100 000, which is too small
|
||||||
|
in many situations. You might need to set it to higher values. Later PHP
|
||||||
|
releases defaults to 1 000 000, which is usually fine.
|
||||||
|
|
||||||
|
|
||||||
|
Usage
|
||||||
|
-----
|
||||||
|
|
||||||
|
This library package is meant to be used with class autoloading. For autoloading
|
||||||
|
to work, your project needs have setup a PSR-0-compatible autoloader. See the
|
||||||
|
included Readme.php file for a minimal autoloader setup. (If you don't want to
|
||||||
|
use autoloading you can do a classic `require_once` to manually include the
|
||||||
|
files prior use instead.)
|
||||||
|
|
||||||
|
With class autoloading in place, putting the 'Michelf' folder in your
|
||||||
|
include path should be enough for this to work:
|
||||||
|
|
||||||
|
use \Michelf\Markdown;
|
||||||
|
$my_html = Markdown::defaultTransform($my_text);
|
||||||
|
|
||||||
|
Markdown Extra syntax is also available the same way:
|
||||||
|
|
||||||
|
use \Michelf\MarkdownExtra;
|
||||||
|
$my_html = MarkdownExtra::defaultTransform($my_text);
|
||||||
|
|
||||||
|
If you wish to use PHP Markdown with another text filter function
|
||||||
|
built to parse HTML, you should filter the text *after* the `transform`
|
||||||
|
function call. This is an example with [PHP SmartyPants][psp]:
|
||||||
|
|
||||||
|
use \Michelf\Markdown, \Michelf\SmartyPants;
|
||||||
|
$my_html = Markdown::defaultTransform($my_text);
|
||||||
|
$my_html = SmartyPants::defaultTransform($my_html);
|
||||||
|
|
||||||
|
All these examples are using the static `defaultTransform` static function
|
||||||
|
found inside the parser class. If you want to customize the parser
|
||||||
|
configuration, you can also instantiate it directly and change some
|
||||||
|
configuration variables:
|
||||||
|
|
||||||
|
use \Michelf\MarkdownExtra;
|
||||||
|
$parser = new MarkdownExtra;
|
||||||
|
$parser->fn_id_prefix = "post22-";
|
||||||
|
$my_html = $parser->transform($my_text);
|
||||||
|
|
||||||
|
|
||||||
|
Usage
|
||||||
|
-----
|
||||||
|
|
||||||
|
This library package is meant to be used with class autoloading. For autoloading
|
||||||
|
to work, your project needs have setup a PSR-0-compatible autoloader. See the
|
||||||
|
included Readme.php file for a minimal autoloader setup. (If you don't want to
|
||||||
|
use autoloading you can do a classic `require_once` to manually include the
|
||||||
|
files prior use instead.)
|
||||||
|
|
||||||
|
With class autoloading in place, putting the 'Michelf' folder in your
|
||||||
|
include path should be enough for this to work:
|
||||||
|
|
||||||
|
use \Michelf\Markdown;
|
||||||
|
$my_html = Markdown::defaultTransform($my_text);
|
||||||
|
|
||||||
|
Markdown Extra syntax is also available the same way:
|
||||||
|
|
||||||
|
use \Michelf\MarkdownExtra;
|
||||||
|
$my_html = MarkdownExtra::defaultTransform($my_text);
|
||||||
|
|
||||||
|
If you wish to use PHP Markdown with another text filter function
|
||||||
|
built to parse HTML, you should filter the text *after* the `transform`
|
||||||
|
function call. This is an example with [PHP SmartyPants][psp]:
|
||||||
|
|
||||||
|
use \Michelf\Markdown, \Michelf\SmartyPants;
|
||||||
|
$my_html = Markdown::defaultTransform($my_text);
|
||||||
|
$my_html = SmartyPants::defaultTransform($my_html);
|
||||||
|
|
||||||
|
All these examples are using the static `defaultTransform` static function
|
||||||
|
found inside the parser class. If you want to customize the parser
|
||||||
|
configuration, you can also instantiate it directly and change some
|
||||||
|
configuration variables:
|
||||||
|
|
||||||
|
use \Michelf\MarkdownExtra;
|
||||||
|
$parser = new MarkdownExtra;
|
||||||
|
$parser->fn_id_prefix = "post22-";
|
||||||
|
$my_html = $parser->transform($my_text);
|
||||||
|
|
||||||
|
To learn more, see the full list of [configuration variables].
|
||||||
|
|
||||||
|
[configuration variables]: http://michelf.ca/project/php-markdown/configuration/
|
||||||
|
|
||||||
|
|
||||||
|
Public API and Versionning Policy
|
||||||
|
---------------------------------
|
||||||
|
|
||||||
|
Version numbers are of the form *major*.*minor*.*patch*.
|
||||||
|
|
||||||
|
The public API of PHP Markdown consist of the two parser classes `Markdown`
|
||||||
|
and `MarkdownExtra`, their constructors, the `transform` and `defaultTransform`
|
||||||
|
functions and their configuration variables. The public API is stable for
|
||||||
|
a given major version number. It might get additions when the minor version
|
||||||
|
number increments.
|
||||||
|
|
||||||
|
**Protected members are not considered public API.** This is unconventionnal
|
||||||
|
and deserves an explanation. Incrementing the major version number every time
|
||||||
|
the underlying implementation of something changes is going to give nonsential
|
||||||
|
version numbers for the vast majority of people who just use the parser.
|
||||||
|
Protected members are meant to create parser subclasses that behave in
|
||||||
|
different ways. Very few people create parser subclasses. I don't want to
|
||||||
|
discourage it by making everything private, but at the same time I can't
|
||||||
|
guarenty any stable hook between versions if you use protected members.
|
||||||
|
|
||||||
|
**Syntax changes** will increment the minor number for new features, and the
|
||||||
|
patch number for small corrections. A *new feature* is something that needs a
|
||||||
|
change in the syntax documentation. Note that since PHP Markdown Lib includes
|
||||||
|
two parsers, a syntax change for either of them will increment the minor
|
||||||
|
number. Also note that there is nothigng perfectly backward-compatible with the
|
||||||
|
Markdown syntax: all inputs are always valid, so new features always replace
|
||||||
|
something that was previously legal, although generally non-sensial to do.
|
||||||
|
|
||||||
|
|
||||||
|
Bugs
|
||||||
|
----
|
||||||
|
|
||||||
|
To file bug reports please send email to:
|
||||||
|
<michel.fortin@michelf.ca>
|
||||||
|
|
||||||
|
Please include with your report: (1) the example input; (2) the output you
|
||||||
|
expected; (3) the output PHP Markdown actually produced.
|
||||||
|
|
||||||
|
If you have a problem where Markdown gives you an empty result, first check
|
||||||
|
that the backtrack limit is not too low by running `php --info | grep pcre`.
|
||||||
|
See Installation and Requirement above for details.
|
||||||
|
|
||||||
|
|
||||||
|
Version History
|
||||||
|
---------------
|
||||||
|
|
||||||
|
PHP Markdown Lib 1.3 (11 Apr 2013):
|
||||||
|
|
||||||
|
This is the first release of PHP Markdown Lib. This package requires PHP
|
||||||
|
version 4.3 or later and is designed to work with PSR-0 autoloading and,
|
||||||
|
optionally with Composer. Here is a list of the changes since
|
||||||
|
PHP Markdown Extra 1.2.6:
|
||||||
|
|
||||||
|
* Plugin interface for Wordpress and other systems is no longer present in
|
||||||
|
the Lib package. The classic package is still available if you need it:
|
||||||
|
<http://michelf.ca/projects/php-markdown/classic/>
|
||||||
|
|
||||||
|
* Added `public` and `protected` protection attributes, plus a section about
|
||||||
|
what is "public API" and what isn't in the Readme file.
|
||||||
|
|
||||||
|
* Changed HTML output for footnotes: now instead of adding `rel` and `rev`
|
||||||
|
attributes, footnotes links have the class name `footnote-ref` and
|
||||||
|
backlinks `footnote-backref`.
|
||||||
|
|
||||||
|
* Fixed some regular expressions to make PCRE not shout warnings about POSIX
|
||||||
|
collation classes (dependent on your version of PCRE).
|
||||||
|
|
||||||
|
* Added optional class and id attributes to images and links using the same
|
||||||
|
syntax as for headers:
|
||||||
|
|
||||||
|
[link](url){#id .class}
|
||||||
|
{#id .class}
|
||||||
|
|
||||||
|
It work too for reference-style links and images. In this case you need
|
||||||
|
to put those attributes at the reference definition:
|
||||||
|
|
||||||
|
[link][linkref] or [linkref]
|
||||||
|
![img][linkref]
|
||||||
|
|
||||||
|
[linkref]: url "optional title" {#id .class}
|
||||||
|
|
||||||
|
* Fixed a PHP notice message triggered when some table column separator
|
||||||
|
markers are missing on the separator line below column headers.
|
||||||
|
|
||||||
|
* Fixed a small mistake that could cause the parser to retain an invalid
|
||||||
|
state related to parsing links across multiple runs. This was never
|
||||||
|
observed (that I know of), but it's still worth fixing.
|
||||||
|
|
||||||
|
|
||||||
|
Copyright and License
|
||||||
|
---------------------
|
||||||
|
|
||||||
|
PHP Markdown Lib
|
||||||
|
Copyright (c) 2004-2013 Michel Fortin
|
||||||
|
<http://michelf.ca/>
|
||||||
|
All rights reserved.
|
||||||
|
|
||||||
|
Based on Markdown
|
||||||
|
Copyright (c) 2003-2005 John Gruber
|
||||||
|
<http://daringfireball.net/>
|
||||||
|
All rights reserved.
|
||||||
|
|
||||||
|
Redistribution and use in source and binary forms, with or without
|
||||||
|
modification, are permitted provided that the following conditions are
|
||||||
|
met:
|
||||||
|
|
||||||
|
* Redistributions of source code must retain the above copyright
|
||||||
|
notice, this list of conditions and the following disclaimer.
|
||||||
|
|
||||||
|
* Redistributions in binary form must reproduce the above copyright
|
||||||
|
notice, this list of conditions and the following disclaimer in the
|
||||||
|
documentation and/or other materials provided with the
|
||||||
|
distribution.
|
||||||
|
|
||||||
|
* Neither the name "Markdown" nor the names of its contributors may
|
||||||
|
be used to endorse or promote products derived from this software
|
||||||
|
without specific prior written permission.
|
||||||
|
|
||||||
|
This software is provided by the copyright holders and contributors "as
|
||||||
|
is" and any express or implied warranties, including, but not limited
|
||||||
|
to, the implied warranties of merchantability and fitness for a
|
||||||
|
particular purpose are disclaimed. In no event shall the copyright owner
|
||||||
|
or contributors be liable for any direct, indirect, incidental, special,
|
||||||
|
exemplary, or consequential damages (including, but not limited to,
|
||||||
|
procurement of substitute goods or services; loss of use, data, or
|
||||||
|
profits; or business interruption) however caused and on any theory of
|
||||||
|
liability, whether in contract, strict liability, or tort (including
|
||||||
|
negligence or otherwise) arising in any way out of the use of this
|
||||||
|
software, even if advised of the possibility of such damage.
|
||||||
31
lib/Michelf/extra/Readme.php
Normal file
31
lib/Michelf/extra/Readme.php
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
# This file passes the content of the Readme.md file in the same directory
|
||||||
|
# through the Markdown filter. You can adapt this sample code in any way
|
||||||
|
# you like.
|
||||||
|
|
||||||
|
# Install PSR-0-compatible class autoloader
|
||||||
|
spl_autoload_register(function($class){
|
||||||
|
require preg_replace('{\\\\|_(?!.*\\\\)}', DIRECTORY_SEPARATOR, ltrim($class, '\\')).'.php';
|
||||||
|
});
|
||||||
|
|
||||||
|
# Get Markdown class
|
||||||
|
use \Michelf\Markdown;
|
||||||
|
|
||||||
|
# Read file and pass content through the Markdown praser
|
||||||
|
$text = file_get_contents('Readme.md');
|
||||||
|
$html = Markdown::defaultTransform($text);
|
||||||
|
|
||||||
|
?>
|
||||||
|
<!DOCTYPE html>
|
||||||
|
<html>
|
||||||
|
<head>
|
||||||
|
<title>PHP Markdown Lib - Readme</title>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<?php
|
||||||
|
# Put HTML content in the document
|
||||||
|
echo $html;
|
||||||
|
?>
|
||||||
|
</body>
|
||||||
|
</html>
|
||||||
31
lib/Michelf/extra/composer.json
Normal file
31
lib/Michelf/extra/composer.json
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
{
|
||||||
|
"name": "michelf/php-markdown",
|
||||||
|
"type": "library",
|
||||||
|
"description": "PHP Markdown",
|
||||||
|
"homepage": "http://michelf.ca/projects/php-markdown/",
|
||||||
|
"keywords": ["markdown"],
|
||||||
|
"license": "BSD-3-Clause",
|
||||||
|
"authors": [
|
||||||
|
{
|
||||||
|
"name": "Michel Fortin",
|
||||||
|
"email": "michel.fortin@michelf.ca",
|
||||||
|
"homepage": "http://michelf.ca/",
|
||||||
|
"role": "Developer"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "John Gruber",
|
||||||
|
"homepage": "http://daringfireball.net/"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"require": {
|
||||||
|
"php": ">=5.3.0"
|
||||||
|
},
|
||||||
|
"autoload": {
|
||||||
|
"psr-0": { "Michelf": "" }
|
||||||
|
},
|
||||||
|
"extra": {
|
||||||
|
"branch-alias": {
|
||||||
|
"dev-lib": "1.3.x-dev"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
2
lib/autoload.inc.php
Normal file
2
lib/autoload.inc.php
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
<?php
|
||||||
|
\SYSTEM\autoload::registerFolder(dirname(__FILE__).'/Michelf','Michelf');
|
||||||
16
sai/modules/saimod_sys_docu/saimod_sys_docu.js
Normal file
16
sai/modules/saimod_sys_docu/saimod_sys_docu.js
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
var editor = null;
|
||||||
|
|
||||||
|
function init__SYSTEM_SAI_saimod_sys_docu() {
|
||||||
|
$('#documaintab a, .subtabs a').click(function (e) {
|
||||||
|
e.preventDefault();
|
||||||
|
$(this).tab('show');
|
||||||
|
if(editor != null){
|
||||||
|
editor.unload();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
$('.docuedit').click(function (){
|
||||||
|
var opts = {basePath: '../system/lib/EpicEditor'};
|
||||||
|
editor = new EpicEditor(opts).load();
|
||||||
|
});
|
||||||
|
};
|
||||||
@ -3,7 +3,42 @@ namespace SYSTEM\SAI;
|
|||||||
|
|
||||||
class saimod_sys_docu extends \SYSTEM\SAI\SaiModule {
|
class saimod_sys_docu extends \SYSTEM\SAI\SaiModule {
|
||||||
public static function sai_mod__SYSTEM_SAI_saimod_sys_docu(){
|
public static function sai_mod__SYSTEM_SAI_saimod_sys_docu(){
|
||||||
return "todo";
|
$documents = \SYSTEM\DOCU\docu::getDocuments();
|
||||||
|
|
||||||
|
$vars['tabopts'] = '';
|
||||||
|
$first = true;
|
||||||
|
foreach($documents as $cat => $docs){
|
||||||
|
$vars2 = array( 'active' => ($first ? 'active' : ''),
|
||||||
|
'tab_id' => str_replace(' ', '_', $cat),
|
||||||
|
'tab_id_pretty' => $cat);
|
||||||
|
$first = false;
|
||||||
|
$vars['tabopts'] .= \SYSTEM\PAGE\replace::replaceFile(\SYSTEM\SERVERPATH(new \SYSTEM\PSAI(),'modules/saimod_sys_docu/tabopt.tpl'), $vars2);
|
||||||
|
|
||||||
|
$first2 = true;
|
||||||
|
foreach($docs as $doc){
|
||||||
|
$tabs[$cat]['tab_id'] = str_replace(' ', '_', $cat);
|
||||||
|
$tabs[$cat]['content'] = isset($tabs[$cat]['content']) ? $tabs[$cat]['content'] : '';
|
||||||
|
$tabs[$cat]['menu'] = isset($tabs[$cat]['menu']) ? $tabs[$cat]['menu'] : '';
|
||||||
|
//$tabs[$cat]['content'] .= \Michelf\Markdown::defaultTransform(file_get_contents($doc));
|
||||||
|
$vars3 = array( 'active' => ($first2 ? 'active' : ''),
|
||||||
|
'content' => \Michelf\Markdown::defaultTransform(file_get_contents($doc)),
|
||||||
|
'tab_id' => str_replace(array('.',' '), '_', basename($doc)));
|
||||||
|
$tabs[$cat]['content'] .= \SYSTEM\PAGE\replace::replaceFile(\SYSTEM\SERVERPATH(new \SYSTEM\PSAI(),'modules/saimod_sys_docu/tab2.tpl'), $vars3);
|
||||||
|
$vars3 = array( 'active' => ($first2 ? 'active' : ''),
|
||||||
|
'tab_id' => str_replace(array('.',' '), '_', basename($doc)),
|
||||||
|
'tab_id_pretty' => basename($doc));
|
||||||
|
$tabs[$cat]['menu'] .= \SYSTEM\PAGE\replace::replaceFile(\SYSTEM\SERVERPATH(new \SYSTEM\PSAI(),'modules/saimod_sys_docu/tabopt.tpl'), $vars3);
|
||||||
|
$first2 = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
$vars['tabs'] = '';
|
||||||
|
$first = true;
|
||||||
|
foreach($tabs as $tab){
|
||||||
|
$tab['active'] = ($first ? 'active' : '');
|
||||||
|
$first = false;
|
||||||
|
$vars['tabs'] .= \SYSTEM\PAGE\replace::replaceFile(\SYSTEM\SERVERPATH(new \SYSTEM\PSAI(),'modules/saimod_sys_docu/tab.tpl'), $tab);}
|
||||||
|
}
|
||||||
|
return \SYSTEM\PAGE\replace::replaceFile(\SYSTEM\SERVERPATH(new \SYSTEM\PSAI(),'modules/saimod_sys_docu/tabs.tpl'), $vars);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function html_li_menu(){return '<li><a href="#" saimenu=".SYSTEM.SAI.saimod_sys_docu">Docu</a></li>';}
|
public static function html_li_menu(){return '<li><a href="#" saimenu=".SYSTEM.SAI.saimod_sys_docu">Docu</a></li>';}
|
||||||
@ -11,5 +46,8 @@ class saimod_sys_docu extends \SYSTEM\SAI\SaiModule {
|
|||||||
public static function right_right(){return \SYSTEM\SECURITY\Security::check(\SYSTEM\SECURITY\RIGHTS::SYS_SAI);}
|
public static function right_right(){return \SYSTEM\SECURITY\Security::check(\SYSTEM\SECURITY\RIGHTS::SYS_SAI);}
|
||||||
|
|
||||||
public static function sai_mod__SYSTEM_SAI_saimod_sys_docu_flag_css(){}
|
public static function sai_mod__SYSTEM_SAI_saimod_sys_docu_flag_css(){}
|
||||||
public static function sai_mod__SYSTEM_SAI_saimod_sys_docu_flag_js(){}
|
public static function sai_mod__SYSTEM_SAI_saimod_sys_docu_flag_js(){
|
||||||
|
return \SYSTEM\LOG\JsonResult::toString(
|
||||||
|
array( \SYSTEM\WEBPATH(new \SYSTEM\PSYSTEM(),'lib/EpicEditor/js/epiceditor.min.js'),
|
||||||
|
\SYSTEM\WEBPATH(new \SYSTEM\PSAI(),'modules/saimod_sys_docu/saimod_sys_docu.js')));}
|
||||||
}
|
}
|
||||||
12
sai/modules/saimod_sys_docu/tab.tpl
Normal file
12
sai/modules/saimod_sys_docu/tab.tpl
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
<div class="tab-pane ${active}" id="tab_${tab_id}">
|
||||||
|
<div class="tabbable tabs-left subtabs">
|
||||||
|
<ul class="nav nav-tabs">
|
||||||
|
${menu}
|
||||||
|
</ul>
|
||||||
|
<div class="tab-content">
|
||||||
|
${content}
|
||||||
|
</br>
|
||||||
|
<div id="epiceditor"></div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
8
sai/modules/saimod_sys_docu/tab2.tpl
Normal file
8
sai/modules/saimod_sys_docu/tab2.tpl
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
<div class="tab-pane ${active}" id="tab_${tab_id}">
|
||||||
|
<div class="tabbable tabs-left">
|
||||||
|
<div class="tab-content">
|
||||||
|
${content}
|
||||||
|
<button class="btn docuedit" tabid="${tab_id}">Edit</button>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
1
sai/modules/saimod_sys_docu/tabopt.tpl
Normal file
1
sai/modules/saimod_sys_docu/tabopt.tpl
Normal file
@ -0,0 +1 @@
|
|||||||
|
<li class="${active}"><a href="#tab_${tab_id}">${tab_id_pretty}</a></li>
|
||||||
10
sai/modules/saimod_sys_docu/tabs.tpl
Normal file
10
sai/modules/saimod_sys_docu/tabs.tpl
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
<h3>Documentation</h3>
|
||||||
|
<br>
|
||||||
|
<div class="tabbable">
|
||||||
|
<ul class="nav nav-tabs" id="documaintab">
|
||||||
|
${tabopts}
|
||||||
|
</ul>
|
||||||
|
<div class="tab-content">
|
||||||
|
${tabs}
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
Loading…
x
Reference in New Issue
Block a user