Rework publication theme system to use flat files, it makes things easier

master
Skylar Ittner 6 years ago
parent c5f234bb11
commit a91209a420

@ -50,8 +50,8 @@ switch ($VARS['action']) {
if (!is_numeric($VARS['columns'])) {
returnToSender('invalid_parameters');
}
if (!$database->has('pub_styles', ["styleid" => $VARS['style']])) {
returnToSender('invalid_parameters');
if (!preg_match("/([A-Za-z0-9_])+/", $VARS['style'])) {
$VARS['style'] = "";
}
if (!$database->has('pub_permissions', ["permid" => $VARS['perm']])) {
returnToSender('invalid_parameters');
@ -77,7 +77,7 @@ switch ($VARS['action']) {
$data = [
'pubname' => $VARS['name'],
'pubdate' => date("Y-m-d H:i:s"),
'styleid' => $VARS['style'],
'style' => $VARS['style'],
'columns' => $VARS['columns'],
'permid' => $permission,
'pwd' => $password,

Binary file not shown.

File diff suppressed because one or more lines are too long

@ -83,5 +83,6 @@ define("STRINGS", [
"adding list" => "Adding mailing list",
"cloning list" => "Copying {olist} <i class=\"fa fa-angle-right\"></i> {nlist}",
"editing list" => "Editing {list}",
"addresses" => "Addresses"
"addresses" => "Addresses",
"theme" => "Theme"
]);

@ -9,7 +9,7 @@ if (!defined("IN_NEWSPEN")) {
if (is_numeric($VARS['pubid'])) {
if ($database->has('publications', ['pubid' => $VARS['pubid']])) {
$pub = $VARS['pubid'];
$pubdata = $database->get("publications", ["[>]pub_permissions" => ["permid" => "permid"]], ["pubname", "uid", "pubdate", "styleid", "columns", "page_size", "landscape", "publications.permid", "permname", "pwd"], ["pubid" => $pub]);
$pubdata = $database->get("publications", ["[>]pub_permissions" => ["permid" => "permid"]], ["pubname", "uid", "pubdate", "style", "columns", "page_size", "landscape", "publications.permid", "permname", "pwd"], ["pubid" => $pub]);
if ($pubdata["permname"] != "LINK") {
dieifnotloggedin();
}
@ -84,32 +84,27 @@ if (defined("EDIT_MODE") && EDIT_MODE == true) {
}
?>
<style nonce="<?php echo $SECURE_NONCE; ?>">
<?php $pubcss = $database->get("pub_styles", ["css", "cssvars", "cssextra", "background"], ["styleid" => $pubdata["styleid"]]); ?>
<?php $pubcss = file_get_contents(__DIR__ . "/../themes/" . $pubdata['style'] . "/pub.css"); ?>
.pub-content {
<?php
$pubvars = json_decode($pubcss["cssvars"], TRUE);
$pubvars = json_decode(file_get_contents(__DIR__ . "/../themes/" . $pubdata['style'] . "/vars.json"), TRUE);
foreach ($pubvars as $name => $val) {
echo "--$name: $val;\n";
echo "\t--$name: $val;\n";
}
?>
}
.pub-content {
<?php echo $pubcss["css"]; ?>
}
<?php echo $pubcss["cssextra"]; ?>
echo $pubcss;
.pub-content {
background-image: url('data:image/png;base64,<?php echo $pubcss["background"]; ?>');
}
if (file_exists(__DIR__ . "/../themes/" . $pubdata['style'] . "/background.png")) {
echo "\n\tbackground-image: url('data:image/png;base64," . base64_encode(file_get_contents(__DIR__ . "/../themes/" . $pubdata['style'] . "/background.png")) . "');";
}
<?php $pagesize = $database->get("page_sizes", ["sizewidth (width)", "sizeheight (height)"], ["sizeid" => $pubdata["page_size"]]); ?>
.pub-content {
$pagesize = $database->get("page_sizes", ["sizewidth (width)", "sizeheight (height)"], ["sizeid" => $pubdata["page_size"]]);
?>
max-width: <?php echo ($pubdata["landscape"] == 0 ? $pagesize["width"] : $pagesize["height"]); ?>;
height: <?php echo ($pubdata["landscape"] == 0 ? $pagesize["height"] : $pagesize["width"]); ?>;
}
<?php echo file_get_contents(__DIR__ . "/../themes/" . $pubdata['style'] . "/extra.css"); ?>
@media (max-width: 900px) {
.pub-content {
height: auto;

@ -34,7 +34,7 @@ switch ($VARS['order'][0]['column']) {
$order = ["pubdate" => $sortby];
break;
case 5:
$order = ["stylename" => $sortby];
$order = ["style" => $sortby];
break;
case 6:
$order = ["columns" => $sortby];
@ -54,7 +54,7 @@ if (!is_empty($VARS['search']['value'])) {
$wherenolimit["AND"]["OR"] = [
"pubname[~]" => $VARS['search']['value'],
"pubdate[~]" => $VARS['search']['value'],
"stylename[~]" => $VARS['search']['value'],
"style[~]" => $VARS['search']['value'],
"sizename[~]" => $VARS['search']['value'],
"permname[~]" => $VARS['search']['value']
];
@ -76,7 +76,6 @@ $where["OR #perms"] = [
//var_dump($where);
$pubs = $database->select('publications', [
'[>]pub_styles' => ['styleid' => 'styleid'],
'[>]pub_permissions' => ['permid' => 'permid'],
'[>]page_sizes' => ['page_size' => 'sizeid']
], [
@ -84,7 +83,7 @@ $pubs = $database->select('publications', [
'pubname',
'uid',
'pubdate',
'stylename',
'style',
'columns',
'permname',
'pwd',
@ -98,7 +97,6 @@ $pubs = $database->select('publications', [
$out['status'] = "OK";
if ($filter) {
$recordsFiltered = $database->count('publications', [
'[>]pub_styles' => ['styleid' => 'styleid'],
'[>]pub_permissions' => ['permid' => 'permid']
], 'pubid', $wherenolimit);
} else {

@ -17,7 +17,7 @@ $edit = false;
if (is_numeric($VARS['pubid'])) {
if ($database->has('publications', ['pubid' => $VARS['pubid']])) {
$pub = $VARS['pubid'];
$pubdata = $database->get("publications", ["[>]pub_permissions" => ["permid" => "permid"]], ["pubname", "uid", "pubdate", "styleid", "columns", "page_size", "landscape", "publications.permid", "permname"], ["pubid" => $pub]);
$pubdata = $database->get("publications", ["[>]pub_permissions" => ["permid" => "permid"]], ["pubname", "uid", "pubdate", "style", "columns", "page_size", "landscape", "publications.permid", "permname"], ["pubid" => $pub]);
if ($pubdata["uid"] == $_SESSION['uid']) {
$edit = true;
} else {

@ -11,7 +11,7 @@ redirectifnotloggedin();
$pubdata = [
'name' => '',
'pubdate' => '',
'styleid' => '',
'style' => '',
'columns' => '',
'permid' => '',
'page_size' => 1,
@ -31,7 +31,7 @@ if (!is_empty($VARS['id'])) {
'publications', [
'pubname (name)',
'pubdate',
'styleid',
'style',
'columns',
'permid',
'page_size',
@ -78,15 +78,18 @@ if (!is_empty($VARS['id'])) {
<div class="row">
<div class="col-12 col-sm-6 col-md-4">
<div class="form-group">
<label for="style"><i class="fas fa-star"></i> <?php lang('style'); ?></label>
<label for="style"><i class="fas fa-star"></i> <?php lang('theme'); ?></label>
<select name="style" class="form-control" required>
<?php
$styles = $database->select("pub_styles", ['styleid', 'stylename']);
$themedir = __DIR__ . "/../themes/";
$styles = array_diff(scandir($themedir), array('..', '.'));//$database->select("pub_styles", ['styleid', 'stylename']);
foreach ($styles as $s) {
$si = $s['styleid'];
$sn = $s['stylename'];
$ss = $pubdata["styleid"] == $si ? " selected" : "";
echo "<option value=\"$si\"$ss>$sn</option>\n";
if (!file_exists($themedir . "$s/info.json")) {
continue;
}
$info = json_decode(file_get_contents($themedir . "$s/info.json"), TRUE);
$ss = $pubdata["style"] == $s ? " selected" : "";
echo "<option value=\"$s\"$ss>" . $info['name'] . "</option>\n";
}
?>
</select>

@ -21,7 +21,7 @@ redirectifnotloggedin();
<th data-priority="1"><i class="fas fa-fw fa-font d-none d-md-inline"></i> <?php lang('name'); ?></th>
<th data-priority="2"><i class="fas fa-fw fa-calendar d-none d-md-inline"></i> <?php lang('date'); ?></th>
<th data-priority="2"><i class="fas fa-fw fa-user d-none d-md-inline"></i> <?php lang('author'); ?></th>
<th data-priority="4"><i class="fas fa-fw fa-star d-none d-md-inline"></i> <?php lang('style'); ?></th>
<th data-priority="4"><i class="fas fa-fw fa-star d-none d-md-inline"></i> <?php lang('theme'); ?></th>
<th data-priority="4"><i class="fas fa-fw fa-columns d-none d-md-inline"></i> <?php lang('columns'); ?></th>
<th data-priority="3"><i class="fas fa-fw fa-file d-none d-md-inline"></i> <?php lang('page size'); ?></th>
<th data-priority="2"><i class="fas fa-fw fa-eye d-none d-md-inline"></i> <?php lang('visibility'); ?></th>
@ -36,7 +36,7 @@ redirectifnotloggedin();
<th data-priority="1"><i class="fas fa-fw fa-font d-none d-md-inline"></i> <?php lang('name'); ?></th>
<th data-priority="2"><i class="fas fa-fw fa-calendar d-none d-md-inline"></i> <?php lang('date'); ?></th>
<th data-priority="2"><i class="fas fa-fw fa-user d-none d-md-inline"></i> <?php lang('author'); ?></th>
<th data-priority="4"><i class="fas fa-fw fa-star d-none d-md-inline"></i> <?php lang('style'); ?></th>
<th data-priority="4"><i class="fas fa-fw fa-star d-none d-md-inline"></i> <?php lang('theme'); ?></th>
<th data-priority="4"><i class="fas fa-fw fa-columns d-none d-md-inline"></i> <?php lang('columns'); ?></th>
<th data-priority="3"><i class="fas fa-fw fa-file d-none d-md-inline"></i> <?php lang('page size'); ?></th>
<th data-priority="2"><i class="fas fa-fw fa-eye d-none d-md-inline"></i> <?php lang('visibility'); ?></th>

@ -44,7 +44,7 @@ var pubtable = $('#pubtable').DataTable({
row.pubname,
row.pubdate,
row.username,
row.stylename,
row.style,
row.columns,
row.pagesize,
row.visibility

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

Binary file not shown.

After

Width:  |  Height:  |  Size: 42 KiB

@ -0,0 +1,25 @@
.tile-html h1,h2,h3,h4,h5,h6 {
color: var(--text);
}
.tile-html pre {
background-color: var(--light-alpha);
border-left: 3px solid var(--medium);
padding: 5px 10px;
display: inline-block;
border-radius: 8px;
}
.tile-html blockquote {
background-color: var(--secondary-alpha);
border: 1px solid var(--primary);
border-left: 3px solid var(--primary);
padding: 5px 10px;
display: inline-block;
border-radius: 8px;
}
.tile-html ul li {
padding-top: 3px;
list-style-image: url('');
}

@ -0,0 +1,4 @@
{
"name": "Flowers",
"colors": ["#ffd5d5", "#fc8a5b", "#77ff77", "#008000"]
}

@ -0,0 +1,2 @@
background-position: right bottom;
background-repeat: no-repeat;

@ -0,0 +1,9 @@
{
"primary": "#008000",
"secondary": "#77ff77",
"secondary-alpha": "rgba(119,255,119,.25)",
"text": "#008000",
"light": "#ffd5d5",
"light-alpha": "rgba(255,213,213,.25)",
"medium": "#fc8a5b"
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 38 KiB

@ -0,0 +1,18 @@
.tile-html h1,h2,h3,h4,h5,h6 {
color: var(--text);
}
.tile-html blockquote {
background-color: var(--light-alpha);
border-left: 3px solid var(--secondary);
padding: 5px 10px;
display: inline-block;
}
.tile-html pre {
background-color: var(--light-alpha);
border: 1px solid var(--secondary);
border-left: 3px solid var(--secondary);
padding: 5px 10px;
display: inline-block;
}

@ -0,0 +1,4 @@
{
"name": "Harvest",
"colors": ["#973b01", "#bc525b", "#ffe46f", "#ff9e01"]
}

@ -0,0 +1,2 @@
background-position: right bottom;
background-repeat: no-repeat;

@ -0,0 +1,8 @@
{
"primary": "#973b01",
"secondary": "#bc525b",
"text": "#2f0701",
"light": "#ffe46f",
"light-alpha": "rgba(255,228,111,.25)",
"medium": "#ff9e01"
}

@ -0,0 +1,4 @@
{
"name": "Plain",
"colors": ["#ffffff", "#000000", "#2196F3"]
}
Loading…
Cancel
Save