put schemas in Comanche (this requires theme support (!))
This commit is contained in:
parent
d2bc7c606a
commit
102521844b
7
boot.php
7
boot.php
@ -1678,10 +1678,11 @@ function current_theme(){
|
|||||||
function current_theme_url($installing = false) {
|
function current_theme_url($installing = false) {
|
||||||
global $a;
|
global $a;
|
||||||
$t = current_theme();
|
$t = current_theme();
|
||||||
$uid = '';
|
$opts = '';
|
||||||
$uid = (($a->profile_uid) ? '?f=&puid=' . $a->profile_uid : '');
|
$opts = (($a->profile_uid) ? '?f=&puid=' . $a->profile_uid : '');
|
||||||
|
$opts .= ((x($a->layout,'schema')) ? '&schema=' . $a->layout['schema'] : '');
|
||||||
if(file_exists('view/theme/' . $t . '/php/style.php'))
|
if(file_exists('view/theme/' . $t . '/php/style.php'))
|
||||||
return('view/theme/' . $t . '/php/style.pcss' . $uid);
|
return('view/theme/' . $t . '/php/style.pcss' . $opts);
|
||||||
return('view/theme/' . $t . '/css/style.css');
|
return('view/theme/' . $t . '/css/style.css');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -6,7 +6,7 @@ Comanche is a markup language similar to bbcode with which to create elaborate a
|
|||||||
|
|
||||||
Comanche primarily chooses what content will appear in various regions of the page. The various regions have names and these names can change depending on what layout template you choose.
|
Comanche primarily chooses what content will appear in various regions of the page. The various regions have names and these names can change depending on what layout template you choose.
|
||||||
|
|
||||||
Currently there are two layout templates, unless your site provides additional layouts (TODO list all templates)
|
Currently there are two layout templates, unless your site provides additional layouts.
|
||||||
|
|
||||||
default
|
default
|
||||||
|
|
||||||
@ -42,6 +42,9 @@ To select a theme for your page, use the 'theme' tag.
|
|||||||
|
|
||||||
This will select the theme named "apw". By default your channel's preferred theme will be used.
|
This will select the theme named "apw". By default your channel's preferred theme will be used.
|
||||||
|
|
||||||
|
[theme=dark]redbasic[/theme]
|
||||||
|
|
||||||
|
This will select the theme named "redbasic" and load the "dark" theme schema for this theme.
|
||||||
|
|
||||||
**Regions**
|
**Regions**
|
||||||
|
|
||||||
@ -60,6 +63,11 @@ Your webpage creation tools allow you to create menus and blocks, in addition to
|
|||||||
|
|
||||||
This places the menu called "mymenu" at this location on the page, which must be inside a region.
|
This places the menu called "mymenu" at this location on the page, which must be inside a region.
|
||||||
|
|
||||||
|
[menu=horizontal-menu]mymenu[/menu]
|
||||||
|
|
||||||
|
This places the menu called "mymenu" at this location on the page, which must be inside a region. Additionally it adds the CSS class "horizontal-menu" to this menu. This *may* result in a menu that looks different than the default menu style, *if* the css for the current theme defines a "horizontal-menu" class.
|
||||||
|
|
||||||
|
|
||||||
[block]contributors[/block]
|
[block]contributors[/block]
|
||||||
|
|
||||||
This places a block named "contributors" in this region.
|
This places a block named "contributors" in this region.
|
||||||
@ -92,6 +100,8 @@ The 'comment' tag is used to delimit comments. These comments will not appear on
|
|||||||
|
|
||||||
**Complex Example**
|
**Complex Example**
|
||||||
|
|
||||||
|
Please note that pasting this example into a layout page is not likely to do anything useful as the chosen names (layout, theme, regions, etc.) may not correspond to any existing webpage components.
|
||||||
|
|
||||||
[comment]use an existing page template which provides a banner region plus 3 columns beneath it[/comment]
|
[comment]use an existing page template which provides a banner region plus 3 columns beneath it[/comment]
|
||||||
|
|
||||||
[layout]3-column-with-header[/layout]
|
[layout]3-column-with-header[/layout]
|
||||||
|
@ -57,6 +57,13 @@ function comanche_parser(&$a,$s) {
|
|||||||
if($cnt)
|
if($cnt)
|
||||||
$a->page['template'] = trim($matches[1]);
|
$a->page['template'] = trim($matches[1]);
|
||||||
|
|
||||||
|
|
||||||
|
$cnt = preg_match("/\[theme=(.*?)\](.*?)\[\/theme\]/ism", $s, $matches);
|
||||||
|
if($cnt) {
|
||||||
|
$a->layout['schema'] = trim($matches[1]);
|
||||||
|
$a->layout['theme'] = trim($matches[2]);
|
||||||
|
}
|
||||||
|
|
||||||
$cnt = preg_match("/\[theme\](.*?)\[\/theme\]/ism", $s, $matches);
|
$cnt = preg_match("/\[theme\](.*?)\[\/theme\]/ism", $s, $matches);
|
||||||
if($cnt)
|
if($cnt)
|
||||||
$a->layout['theme'] = trim($matches[1]);
|
$a->layout['theme'] = trim($matches[1]);
|
||||||
|
@ -613,7 +613,7 @@ function widget_suggestedchats($arr) {
|
|||||||
$h = get_observer_hash();
|
$h = get_observer_hash();
|
||||||
if(! $h)
|
if(! $h)
|
||||||
return;
|
return;
|
||||||
$r = q("select *, count(xchat_url) as total from xchat group by xchat_url order by total desc, xchat_desc");
|
$r = q("select *, count(xchat_url) as total from xchat group by xchat_url order by total desc, xchat_desc limit 24");
|
||||||
|
|
||||||
for($x = 0; $x < count($r); $x ++)
|
for($x = 0; $x < count($r); $x ++)
|
||||||
$r[$x]['xchat_url'] = zid($r[$x]['xchat_url']);
|
$r[$x]['xchat_url'] = zid($r[$x]['xchat_url']);
|
||||||
|
@ -28,9 +28,6 @@ function layouts_content(&$a) {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Get the observer, check their permissions
|
// Get the observer, check their permissions
|
||||||
|
|
||||||
$observer = $a->get_observer();
|
$observer = $a->get_observer();
|
||||||
@ -43,10 +40,6 @@ function layouts_content(&$a) {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// if(local_user() && local_user() == $owner) {
|
|
||||||
// $a->set_widget('design',design_tools());
|
|
||||||
// }
|
|
||||||
|
|
||||||
$tabs = array(
|
$tabs = array(
|
||||||
array(
|
array(
|
||||||
'label' => t('Layout Help'),
|
'label' => t('Layout Help'),
|
||||||
@ -62,7 +55,9 @@ function layouts_content(&$a) {
|
|||||||
|
|
||||||
// Create a status editor (for now - we'll need a WYSIWYG eventually) to create pages
|
// Create a status editor (for now - we'll need a WYSIWYG eventually) to create pages
|
||||||
// Nickname is set to the observers xchan, and profile_uid to the owners. This lets you post pages at other people's channels.
|
// Nickname is set to the observers xchan, and profile_uid to the owners. This lets you post pages at other people's channels.
|
||||||
|
|
||||||
require_once ('include/conversation.php');
|
require_once ('include/conversation.php');
|
||||||
|
|
||||||
$x = array(
|
$x = array(
|
||||||
'webpage' => ITEM_PDL,
|
'webpage' => ITEM_PDL,
|
||||||
'is_owner' => true,
|
'is_owner' => true,
|
||||||
@ -96,7 +91,7 @@ $r = q("select * from item_id where uid = %d and service = 'PDL' order by sid as
|
|||||||
|
|
||||||
//Build the base URL for edit links
|
//Build the base URL for edit links
|
||||||
$url = z_root() . "/editlayout/" . $which;
|
$url = z_root() . "/editlayout/" . $which;
|
||||||
// This isn't pretty, but it works. Until I figure out what to do with the UI, it's Good Enough(TM).
|
|
||||||
return $o . replace_macros(get_markup_template("webpagelist.tpl"), array(
|
return $o . replace_macros(get_markup_template("webpagelist.tpl"), array(
|
||||||
'$baseurl' => $url,
|
'$baseurl' => $url,
|
||||||
'$edit' => t('Edit'),
|
'$edit' => t('Edit'),
|
||||||
|
@ -39,9 +39,15 @@ if(! $a->install) {
|
|||||||
|
|
||||||
// Now load the scheme. If a value is changed above, we'll keep the settings
|
// Now load the scheme. If a value is changed above, we'll keep the settings
|
||||||
// If not, we'll keep those defined by the schema
|
// If not, we'll keep those defined by the schema
|
||||||
// Setting $scheme to '' wasn't working for some reason, so we'll check it's
|
// Setting $schema to '' wasn't working for some reason, so we'll check it's
|
||||||
// not --- like the mobile theme does instead.
|
// not --- like the mobile theme does instead.
|
||||||
|
|
||||||
|
|
||||||
|
// Allow layouts to over-ride the schema
|
||||||
|
|
||||||
|
if($_REQUEST['schema'])
|
||||||
|
$schema = $_REQUEST['schema'];
|
||||||
|
|
||||||
if (($schema) && ($schema != '---')) {
|
if (($schema) && ($schema != '---')) {
|
||||||
// Check it exists, because this setting gets distributed to clones
|
// Check it exists, because this setting gets distributed to clones
|
||||||
if(file_exists('view/theme/redbasic/schema/' . $schema . '.php')) {
|
if(file_exists('view/theme/redbasic/schema/' . $schema . '.php')) {
|
||||||
|
Reference in New Issue
Block a user