Welcome to TiddlyWiki created by Jeremy Ruston, Copyright © 2007 UnaMesa Association
<!--{{{-->
<link rel='alternate' type='application/rss+xml' title='RSS' href='index.xml' />
<!--}}}-->
 
Background: #fff
Foreground: #000
PrimaryPale: #8cf
PrimaryLight: #18f
PrimaryMid: #04b
PrimaryDark: #014
SecondaryPale: #ffc
SecondaryLight: #fe8
SecondaryMid: #db4
SecondaryDark: #841
TertiaryPale: #eee
TertiaryLight: #ccc
TertiaryMid: #999
TertiaryDark: #666
Error: #f88
 
/*{{{*/
body {background:[[ColorPalette::Background]]; color:[[ColorPalette::Foreground]];}
a {color:[[ColorPalette::PrimaryMid]];}
a:hover {background-color:[[ColorPalette::PrimaryMid]]; color:[[ColorPalette::Background]];}
a img {border:0;}
h1,h2,h3,h4,h5,h6 {color:[[ColorPalette::SecondaryDark]]; background:transparent;}
h1 {border-bottom:2px solid [[ColorPalette::TertiaryLight]];}
h2,h3 {border-bottom:1px solid [[ColorPalette::TertiaryLight]];}
.button {color:[[ColorPalette::PrimaryDark]]; border:1px solid [[ColorPalette::Background]];}
.button:hover {color:[[ColorPalette::PrimaryDark]]; background:[[ColorPalette::SecondaryLight]]; border-color:[[ColorPalette::SecondaryMid]];}
.button:active {color:[[ColorPalette::Background]]; background:[[ColorPalette::SecondaryMid]]; border:1px solid [[ColorPalette::SecondaryDark]];}
.header {background:[[ColorPalette::PrimaryMid]];}
.headerShadow {color:[[ColorPalette::Foreground]];}
.headerShadow a {font-weight:normal; color:[[ColorPalette::Foreground]];}
.headerForeground {color:[[ColorPalette::Background]];}
.headerForeground a {font-weight:normal; color:[[ColorPalette::PrimaryPale]];}
.tabSelected{color:[[ColorPalette::PrimaryDark]];
	background:[[ColorPalette::TertiaryPale]];
	border-left:1px solid [[ColorPalette::TertiaryLight]];
	border-top:1px solid [[ColorPalette::TertiaryLight]];
	border-right:1px solid [[ColorPalette::TertiaryLight]];
}
.tabUnselected {color:[[ColorPalette::Background]]; background:[[ColorPalette::TertiaryMid]];}
.tabContents {color:[[ColorPalette::PrimaryDark]]; background:[[ColorPalette::TertiaryPale]]; border:1px solid [[ColorPalette::TertiaryLight]];}
.tabContents .button {border:0;}
#sidebar {}
#sidebarOptions input {border:1px solid [[ColorPalette::PrimaryMid]];}
#sidebarOptions .sliderPanel {background:[[ColorPalette::PrimaryPale]];}
#sidebarOptions .sliderPanel a {border:none;color:[[ColorPalette::PrimaryMid]];}
#sidebarOptions .sliderPanel a:hover {color:[[ColorPalette::Background]]; background:[[ColorPalette::PrimaryMid]];}
#sidebarOptions .sliderPanel a:active {color:[[ColorPalette::PrimaryMid]]; background:[[ColorPalette::Background]];}
.wizard {background:[[ColorPalette::PrimaryPale]]; border:1px solid [[ColorPalette::PrimaryMid]];}
.wizard h1 {color:[[ColorPalette::PrimaryDark]]; border:none;}
.wizard h2 {color:[[ColorPalette::Foreground]]; border:none;}
.wizardStep {background:[[ColorPalette::Background]]; color:[[ColorPalette::Foreground]];
	border:1px solid [[ColorPalette::PrimaryMid]];}
.wizardStep.wizardStepDone {background:[[ColorPalette::TertiaryLight]];}
.wizardFooter {background:[[ColorPalette::PrimaryPale]];}
.wizardFooter .status {background:[[ColorPalette::PrimaryDark]]; color:[[ColorPalette::Background]];}
.wizard .button {color:[[ColorPalette::Foreground]]; background:[[ColorPalette::SecondaryLight]]; border: 1px solid;
	border-color:[[ColorPalette::SecondaryPale]] [[ColorPalette::SecondaryDark]] [[ColorPalette::SecondaryDark]] [[ColorPalette::SecondaryPale]];}
.wizard .button:hover {color:[[ColorPalette::Foreground]]; background:[[ColorPalette::Background]];}
.wizard .button:active {color:[[ColorPalette::Background]]; background:[[ColorPalette::Foreground]]; border: 1px solid;
	border-color:[[ColorPalette::PrimaryDark]] [[ColorPalette::PrimaryPale]] [[ColorPalette::PrimaryPale]] [[ColorPalette::PrimaryDark]];}
.wizard .notChanged {background:transparent;}
.wizard .changedLocally {background:#80ff80;}
.wizard .changedServer {background:#8080ff;}
.wizard .changedBoth {background:#ff8080;}
.wizard .notFound {background:#ffff80;}
.wizard .putToServer {background:#ff80ff;}
.wizard .gotFromServer {background:#80ffff;}
#messageArea {border:1px solid [[ColorPalette::SecondaryMid]]; background:[[ColorPalette::SecondaryLight]]; color:[[ColorPalette::Foreground]];}
#messageArea .button {color:[[ColorPalette::PrimaryMid]]; background:[[ColorPalette::SecondaryPale]]; border:none;}
.popupTiddler {background:[[ColorPalette::TertiaryPale]]; border:2px solid [[ColorPalette::TertiaryMid]];}
.popup {background:[[ColorPalette::TertiaryPale]]; color:[[ColorPalette::TertiaryDark]]; border-left:1px solid [[ColorPalette::TertiaryMid]]; border-top:1px solid [[ColorPalette::TertiaryMid]]; border-right:2px solid [[ColorPalette::TertiaryDark]]; border-bottom:2px solid [[ColorPalette::TertiaryDark]];}
.popup hr {color:[[ColorPalette::PrimaryDark]]; background:[[ColorPalette::PrimaryDark]]; border-bottom:1px;}
.popup li.disabled {color:[[ColorPalette::TertiaryMid]];}
.popup li a, .popup li a:visited {color:[[ColorPalette::Foreground]]; border: none;}
.popup li a:hover {background:[[ColorPalette::SecondaryLight]]; color:[[ColorPalette::Foreground]]; border: none;}
.popup li a:active {background:[[ColorPalette::SecondaryPale]]; color:[[ColorPalette::Foreground]]; border: none;}
.popupHighlight {background:[[ColorPalette::Background]]; color:[[ColorPalette::Foreground]];}
.listBreak div {border-bottom:1px solid [[ColorPalette::TertiaryDark]];}
.tiddler .defaultCommand {font-weight:bold;}
.shadow .title {color:[[ColorPalette::TertiaryDark]];}
.title {color:[[ColorPalette::SecondaryDark]];}
.subtitle {color:[[ColorPalette::TertiaryDark]];}
.toolbar {color:[[ColorPalette::PrimaryMid]];}
.toolbar a {color:[[ColorPalette::TertiaryLight]];}
.selected .toolbar a {color:[[ColorPalette::TertiaryMid]];}
.selected .toolbar a:hover {color:[[ColorPalette::Foreground]];}
.tagging, .tagged {border:1px solid [[ColorPalette::TertiaryPale]]; background-color:[[ColorPalette::TertiaryPale]];}
.selected .tagging, .selected .tagged {background-color:[[ColorPalette::TertiaryLight]]; border:1px solid [[ColorPalette::TertiaryMid]];}
.tagging .listTitle, .tagged .listTitle {color:[[ColorPalette::PrimaryDark]];}
.tagging .button, .tagged .button {border:none;}
.footer {color:[[ColorPalette::TertiaryLight]];}
.selected .footer {color:[[ColorPalette::TertiaryMid]];}
.sparkline {background:[[ColorPalette::PrimaryPale]]; border:0;}
.sparktick {background:[[ColorPalette::PrimaryDark]];}
.error, .errorButton {color:[[ColorPalette::Foreground]]; background:[[ColorPalette::Error]];}
.warning {color:[[ColorPalette::Foreground]]; background:[[ColorPalette::SecondaryPale]];}
.lowlight {background:[[ColorPalette::TertiaryLight]];}
.zoomer {background:none; color:[[ColorPalette::TertiaryMid]]; border:3px solid [[ColorPalette::TertiaryMid]];}
.imageLink, #displayArea .imageLink {background:transparent;}
.annotation {background:[[ColorPalette::SecondaryLight]]; color:[[ColorPalette::Foreground]]; border:2px solid [[ColorPalette::SecondaryMid]];}
.viewer .listTitle {list-style-type:none; margin-left:-2em;}
.viewer .button {border:1px solid [[ColorPalette::SecondaryMid]];}
.viewer blockquote {border-left:3px solid [[ColorPalette::TertiaryDark]];}
.viewer table, table.twtable {border:2px solid [[ColorPalette::TertiaryDark]];}
.viewer th, .viewer thead td, .twtable th, .twtable thead td {background:[[ColorPalette::SecondaryMid]]; border:1px solid [[ColorPalette::TertiaryDark]]; color:[[ColorPalette::Background]];}
.viewer td, .viewer tr, .twtable td, .twtable tr {border:1px solid [[ColorPalette::TertiaryDark]];}
.viewer pre {border:1px solid [[ColorPalette::SecondaryLight]]; background:[[ColorPalette::SecondaryPale]];}
.viewer code {color:[[ColorPalette::SecondaryDark]];}
.viewer hr {border:0; border-top:dashed 1px [[ColorPalette::TertiaryDark]]; color:[[ColorPalette::TertiaryDark]];}
.highlight, .marked {background:[[ColorPalette::SecondaryLight]];}
.editor input {border:1px solid [[ColorPalette::PrimaryMid]];}
.editor textarea {border:1px solid [[ColorPalette::PrimaryMid]]; width:100%;}
.editorFooter {color:[[ColorPalette::TertiaryMid]];}
.readOnly {background:[[ColorPalette::TertiaryPale]];}
#backstageArea {background:[[ColorPalette::Foreground]]; color:[[ColorPalette::TertiaryMid]];}
#backstageArea a {background:[[ColorPalette::Foreground]]; color:[[ColorPalette::Background]]; border:none;}
#backstageArea a:hover {background:[[ColorPalette::SecondaryLight]]; color:[[ColorPalette::Foreground]]; }
#backstageArea a.backstageSelTab {background:[[ColorPalette::Background]]; color:[[ColorPalette::Foreground]];}
#backstageButton a {background:none; color:[[ColorPalette::Background]]; border:none;}
#backstageButton a:hover {background:[[ColorPalette::Foreground]]; color:[[ColorPalette::Background]]; border:none;}
#backstagePanel {background:[[ColorPalette::Background]]; border-color: [[ColorPalette::Background]] [[ColorPalette::TertiaryDark]] [[ColorPalette::TertiaryDark]] [[ColorPalette::TertiaryDark]];}
.backstagePanelFooter .button {border:none; color:[[ColorPalette::Background]];}
.backstagePanelFooter .button:hover {color:[[ColorPalette::Foreground]];}
#backstageCloak {background:[[ColorPalette::Foreground]]; opacity:0.6; filter:'alpha(opacity=60)';}
/*}}}*/
 
/*{{{*/
* html .tiddler {height:1%;}
body {font-size:.75em; font-family:arial,helvetica; margin:0; padding:0;}
h1,h2,h3,h4,h5,h6 {font-weight:bold; text-decoration:none;}
h1,h2,h3 {padding-bottom:1px; margin-top:1.2em;margin-bottom:0.3em;}
h4,h5,h6 {margin-top:1em;}
h1 {font-size:1.35em;}
h2 {font-size:1.25em;}
h3 {font-size:1.1em;}
h4 {font-size:1em;}
h5 {font-size:.9em;}
hr {height:1px;}
a {text-decoration:none;}
dt {font-weight:bold;}
ol {list-style-type:decimal;}
ol ol {list-style-type:lower-alpha;}
ol ol ol {list-style-type:lower-roman;}
ol ol ol ol {list-style-type:decimal;}
ol ol ol ol ol {list-style-type:lower-alpha;}
ol ol ol ol ol ol {list-style-type:lower-roman;}
ol ol ol ol ol ol ol {list-style-type:decimal;}
.txtOptionInput {width:11em;}
#contentWrapper .chkOptionInput {border:0;}
.externalLink {text-decoration:underline;}
.indent {margin-left:3em;}
.outdent {margin-left:3em; text-indent:-3em;}
code.escaped {white-space:nowrap;}
.tiddlyLinkExisting {font-weight:bold;}
.tiddlyLinkNonExisting {font-style:italic;}
/* the 'a' is required for IE, otherwise it renders the whole tiddler in bold */
a.tiddlyLinkNonExisting.shadow {font-weight:bold;}
#mainMenu .tiddlyLinkExisting,
	#mainMenu .tiddlyLinkNonExisting,
	#sidebarTabs .tiddlyLinkNonExisting {font-weight:normal; font-style:normal;}
#sidebarTabs .tiddlyLinkExisting {font-weight:bold; font-style:normal;}
.header {position:relative;}
.header a:hover {background:transparent;}
.headerShadow {position:relative; padding:4.5em 0 1em 1em; left:-1px; top:-1px;}
.headerForeground {position:absolute; padding:4.5em 0 1em 1em; left:0px; top:0px;}
.siteTitle {font-size:3em;}
.siteSubtitle {font-size:1.2em;}
#mainMenu {position:absolute; left:0; width:10em; text-align:right; line-height:1.6em; padding:1.5em 0.5em 0.5em 0.5em; font-size:1.1em;}
#sidebar {position:absolute; right:3px; width:16em; font-size:.9em;}
#sidebarOptions {padding-top:0.3em;}
#sidebarOptions a {margin:0 0.2em; padding:0.2em 0.3em; display:block;}
#sidebarOptions input {margin:0.4em 0.5em;}
#sidebarOptions .sliderPanel {margin-left:1em; padding:0.5em; font-size:.85em;}
#sidebarOptions .sliderPanel a {font-weight:bold; display:inline; padding:0;}
#sidebarOptions .sliderPanel input {margin:0 0 0.3em 0;}
#sidebarTabs .tabContents {width:15em; overflow:hidden;}
.wizard {padding:0.1em 1em 0 2em;}
.wizard h1 {font-size:2em; font-weight:bold; background:none; padding:0; margin:0.4em 0 0.2em;}
.wizard h2 {font-size:1.2em; font-weight:bold; background:none; padding:0; margin:0.4em 0 0.2em;}
.wizardStep {padding:1em 1em 1em 1em;}
.wizard .button {margin:0.5em 0 0; font-size:1.2em;}
.wizardFooter {padding:0.8em 0.4em 0.8em 0;}
.wizardFooter .status {padding:0 0.4em; margin-left:1em;}
.wizard .button {padding:0.1em 0.2em;}
#messageArea {position:fixed; top:2em; right:0; margin:0.5em; padding:0.5em; z-index:2000; _position:absolute;}
.messageToolbar {display:block; text-align:right; padding:0.2em;}
#messageArea a {text-decoration:underline;}
.tiddlerPopupButton {padding:0.2em;}
.popupTiddler {position: absolute; z-index:300; padding:1em; margin:0;}
.popup {position:absolute; z-index:300; font-size:.9em; padding:0; list-style:none; margin:0;}
.popup .popupMessage {padding:0.4em;}
.popup hr {display:block; height:1px; width:auto; padding:0; margin:0.2em 0;}
.popup li.disabled {padding:0.4em;}
.popup li a {display:block; padding:0.4em; font-weight:normal; cursor:pointer;}
.listBreak {font-size:1px; line-height:1px;}
.listBreak div {margin:2px 0;}
.tabset {padding:1em 0 0 0.5em;}
.tab {margin:0 0 0 0.25em; padding:2px;}
.tabContents {padding:0.5em;}
.tabContents ul, .tabContents ol {margin:0; padding:0;}
.txtMainTab .tabContents li {list-style:none;}
.tabContents li.listLink { margin-left:.75em;}
#contentWrapper {display:block;}
#splashScreen {display:none;}
#displayArea {margin:1em 17em 0 14em;}
.toolbar {text-align:right; font-size:.9em;}
.tiddler {padding:1em 1em 0;}
.missing .viewer,.missing .title {font-style:italic;}
.title {font-size:1.6em; font-weight:bold;}
.missing .subtitle {display:none;}
.subtitle {font-size:1.1em;}
.tiddler .button {padding:0.2em 0.4em;}
.tagging {margin:0.5em 0.5em 0.5em 0; float:left; display:none;}
.isTag .tagging {display:block;}
.tagged {margin:0.5em; float:right;}
.tagging, .tagged {font-size:0.9em; padding:0.25em;}
.tagging ul, .tagged ul {list-style:none; margin:0.25em; padding:0;}
.tagClear {clear:both;}
.footer {font-size:.9em;}
.footer li {display:inline;}
.annotation {padding:0.5em; margin:0.5em;}
* html .viewer pre {width:99%; padding:0 0 1em 0;}
.viewer {line-height:1.4em; padding-top:0.5em;}
.viewer .button {margin:0 0.25em; padding:0 0.25em;}
.viewer blockquote {line-height:1.5em; padding-left:0.8em;margin-left:2.5em;}
.viewer ul, .viewer ol {margin-left:0.5em; padding-left:1.5em;}
.viewer table, table.twtable {border-collapse:collapse; margin:0.8em 1.0em;}
.viewer th, .viewer td, .viewer tr,.viewer caption,.twtable th, .twtable td, .twtable tr,.twtable caption {padding:3px;}
table.listView {font-size:0.85em; margin:0.8em 1.0em;}
table.listView th, table.listView td, table.listView tr {padding:0px 3px 0px 3px;}
.viewer pre {padding:0.5em; margin-left:0.5em; font-size:1.2em; line-height:1.4em; overflow:auto;}
.viewer code {font-size:1.2em; line-height:1.4em;}
.editor {font-size:1.1em;}
.editor input, .editor textarea {display:block; width:100%; font:inherit;}
.editorFooter {padding:0.25em 0; font-size:.9em;}
.editorFooter .button {padding-top:0px; padding-bottom:0px;}
.fieldsetFix {border:0; padding:0; margin:1px 0px;}
.sparkline {line-height:1em;}
.sparktick {outline:0;}
.zoomer {font-size:1.1em; position:absolute; overflow:hidden;}
.zoomer div {padding:1em;}
* html #backstage {width:99%;}
* html #backstageArea {width:99%;}
#backstageArea {display:none; position:relative; overflow: hidden; z-index:150; padding:0.3em 0.5em;}
#backstageToolbar {position:relative;}
#backstageArea a {font-weight:bold; margin-left:0.5em; padding:0.3em 0.5em;}
#backstageButton {display:none; position:absolute; z-index:175; top:0; right:0;}
#backstageButton a {padding:0.1em 0.4em; margin:0.1em;}
#backstage {position:relative; width:100%; z-index:50;}
#backstagePanel {display:none; z-index:100; position:absolute; width:90%; margin-left:3em; padding:1em;}
.backstagePanelFooter {padding-top:0.2em; float:right;}
.backstagePanelFooter a {padding:0.2em 0.4em;}
#backstageCloak {display:none; z-index:20; position:absolute; width:100%; height:100px;}
.whenBackstage {display:none;}
.backstageVisible .whenBackstage {display:block;}
/*}}}*/
 
/***
StyleSheet for use when a translation requires any css style changes.
This StyleSheet can be used directly by languages such as Chinese, Japanese and Korean which need larger font sizes.
***/
/*{{{*/
body {font-size:0.8em;}
#sidebarOptions {font-size:1.05em;}
#sidebarOptions a {font-style:normal;}
#sidebarOptions .sliderPanel {font-size:0.95em;}
.subtitle {font-size:0.8em;}
.viewer table.listView {font-size:0.95em;}
/*}}}*/
 
/*{{{*/
@media print {
#mainMenu, #sidebar, #messageArea, .toolbar, #backstageButton, #backstageArea {display: none !important;}
#displayArea {margin: 1em 1em 0em;}
noscript {display:none;} /* Fixes a feature in Firefox 1.5.0.2 where print preview displays the noscript content */
}
/*}}}*/
 
<!--{{{-->
<div class='header' macro='gradient vert [[ColorPalette::PrimaryLight]] [[ColorPalette::PrimaryMid]]'>
<div class='headerShadow'>
<span class='siteTitle' refresh='content' tiddler='SiteTitle'></span> 
<span class='siteSubtitle' refresh='content' tiddler='SiteSubtitle'></span>
</div>
<div class='headerForeground'>
<span class='siteTitle' refresh='content' tiddler='SiteTitle'></span> 
<span class='siteSubtitle' refresh='content' tiddler='SiteSubtitle'></span>
</div>
</div>
<div id='mainMenu' refresh='content' tiddler='MainMenu'></div>
<div id='sidebar'>
<div id='sidebarOptions' refresh='content' tiddler='SideBarOptions'></div>
<div id='sidebarTabs' refresh='content' force='true' tiddler='SideBarTabs'></div>
</div>
<div id='displayArea'>
<div id='messageArea'></div>
<div id='tiddlerDisplay'></div>
</div>
<!--}}}-->
 
<!--{{{-->
<div class='toolbar' macro='toolbar [[ToolbarCommands::ViewToolbar]]'></div>
<div class='title' macro='view title'></div>
<div class='subtitle'><span macro='view modifier link'></span>, <span macro='view modified date'></span> (<span macro='message views.wikified.createdPrompt'></span> <span macro='view created date'></span>)</div>
<div class='tagging' macro='tagging'></div>
<div class='tagged' macro='tags'></div>
<div class='viewer' macro='view text wikified'></div>
<div class='tagClear'></div>
<!--}}}-->
 
<!--{{{-->
<div class='toolbar' macro='toolbar [[ToolbarCommands::EditToolbar]]'></div>
<div class='title' macro='view title'></div>
<div class='editor' macro='edit title'></div>
<div macro='annotations'></div>
<div class='editor' macro='edit text'></div>
<div class='editor' macro='edit tags'></div><div class='editorFooter'><span macro='message views.editor.tagPrompt'></span><span macro='tagChooser excludeLists'></span></div>
<!--}}}-->
 
To get started with this blank [[TiddlyWiki]], you'll need to modify the following tiddlers:
* [[SiteTitle]] & [[SiteSubtitle]]: The title and subtitle of the site, as shown above (after saving, they will also appear in the browser title bar)
* [[MainMenu]]: The menu (usually on the left)
* [[DefaultTiddlers]]: Contains the names of the tiddlers that you want to appear when the TiddlyWiki is opened
You'll also need to enter your username for signing your edits: <<option txtUserName>>
 
These [[InterfaceOptions]] for customising [[TiddlyWiki]] are saved in your browser
Your username for signing your edits. Write it as a [[WikiWord]] (eg [[JoeBloggs]])
<<option txtUserName>>
<<option chkSaveBackups>> [[SaveBackups]]
<<option chkAutoSave>> [[AutoSave]]
<<option chkRegExpSearch>> [[RegExpSearch]]
<<option chkCaseSensitiveSearch>> [[CaseSensitiveSearch]]
<<option chkAnimate>> [[EnableAnimations]]
----
Also see [[AdvancedOptions]]
 
 
tout ce qui concerne Le Flash
 
On part du principe ou CLIENT est le nom du client
!Création du dossier client
* Créer un dossier "_CLIENT" à la racine ou CLIENT représente le nom du client (Majuscule et underscore pour séparer les mots)
!Création des fichiers de base du répertoire client
* Création de la classe Cmodule_CLIENT.class.php dans le dossier _CLIENT
Cette classe se doit d'étendre la classe CModule et d'implémenter l'interface ImoduleSite de cette manière
{{{
class Cmodule_CLIENT extends Cmodule implements ImoduleSite
}}}
* Dans un premier temps ont définit les propriétés de la classe
{{{
public $nom = "site CLIENT";
public $identifiant = "CLIENT" ;
public $modules_dependants = array("super_admin","fsadmin");
public $titre="CLIENT";
}}}
* Ensuite il faut créer les fichiers utilisés lors de la création ainsi que la modification des tables nécessaires au fonctionnement du client qui seront appelés lors d'un maj_bdd ou un maj_pages par exemple
{{{
/_CLIENT/install_CLIENT.inc.php
/_CLIENT/install_CLIENT.inc.php
}}}
!Création de la configuration du client
* Créer le fichier {{{/_CLIENT/includes/config_client.CLIENT.inc.php}}}
* Définir dans ce fichier les 4 constantes de connexion à la base de données
{{{
define("BDD_BASE","bdd");
define("BDD_HOST","localhost");
define("BDD_USER","root");
define("BDD_PASS","");
}}}
!Intégration du serveur dans le config du FSE
* Insertion dans le tableau des configs serveurs du fichier /includes/config.inc.php
{{{
array("masque"=>"^localclient$","serveur"=>"localhost","client"=>"CLIENT"),
}}}
Rajouter localclient dans le fichier HOSTS (voir [[Installation FSE3]])
!Création de la configuration du serveur
Créer le fichier {{{/includes/serveurs/config_serveur.CASTELAS.inc.php}}} qui contiendra les commandes personnalisé au serveur (ex : si site en prod)
 
!Prérequis
Votre site doit être en haut a gauche, en mode noscale
{{{
	stage.align = StageAlign.TOP_LEFT;
	stage.scaleMode = StageScaleMode.NO_SCALE;
}}}
pour utiliser les MessageBox sur votre site, il suffit de définir une classe graphique dans la bibliothèque :
- efrogg.affichage.messagebox.BoiteMessage
- efrogg.affichage.messagebox.BoutonMsgBox
! boite par défaut
Il est possible de définir la boite de message par défaut, et créant une nouvelle boite, et en la définissant par défaut :
{{{
	var ma_msg : CMsgBox = CMsgBox.newMsgBox(stage, MsgBoxFondFlou);
	ma_msg.setDefault();
}}}
 
La classe CPageHTML permet de gérer une page HTML. Lorsque l'on veut gérer une page par une classe, on crée une nouvelle classe dérivée de CPageHTML (placée dans le dossier ''classes'' du Module_CLIENT).
Elle sera utilisée pour générer une page si dans la liste ''site_pages'' (table ''"""site__pages_liste"""'') le champ ''classe_php'' contient cette classe (ne pas oublier de mettre l'identifiant du Module_CLIENT dans le champ ''id_module'').
Lorsque l'on crée la classe qui étend CPageHTML, il faut étendre (ou plutôt créer car ces méthodes sont vides) les méthodes suivantes :
* Le constructeur. Les paramètres du constructeur sont ceux définis dans le champ ''parametres'' de la liste ''site_pages''. On peut passer les $1, $2, etc... détectés par le champ ''masque'' de cette même liste (voir aussi [[site_definit_page]]).
* La fonction getContenu(). Elle renverra le contenu texte de la page.
* La fonction getTitre(). Elle renverra le titre de la page.
* La fonction getMotsCles(). Elle renverra les mots clés (meta) de la page.
* La fonction getDescription(). Elle renverra la description (meta) de la page.
* La fonction getCSS(). Elle renverra le css __spécifique__ (supplémentaire par rapport à celui du modèle de page) à la page.
 
/***
|Name|CheckboxPlugin|
|Source|http://www.TiddlyTools.com/#CheckboxPlugin|
|Documentation|http://www.TiddlyTools.com/#CheckboxPluginInfo|
|Version|2.4.0|
|Author|Eric Shulman|
|License|http://www.TiddlyTools.com/#LegalStatements|
|~CoreVersion|2.1|
|Type|plugin|
|Description|Add checkboxes to your tiddler content|
This plugin extends the TiddlyWiki syntax to allow definition of checkboxes that can be embedded directly in tiddler content.  Checkbox states are preserved by:
* by setting/removing tags on specified tiddlers,
* or, by setting custom field values on specified tiddlers,
* or, by saving to a locally-stored cookie ID,
* or, automatically modifying the tiddler content (deprecated)
When an ID is assigned to the checkbox, it enables direct programmatic access to the checkbox DOM element, as well as creating an entry in TiddlyWiki's config.options[ID] internal data.  In addition to tracking the checkbox state, you can also specify custom javascript for programmatic initialization and onClick event handling for any checkbox, so you can provide specialized side-effects in response to state changes.
!!!!!Documentation
>see [[CheckboxPluginInfo]]
!!!!!Revisions
<<<
2008.01.08 [*.*.*] plugin size reduction: documentation moved to [[CheckboxPluginInfo]]
2008.01.05 [2.4.0] set global "window.place" to current checkbox element when processing checkbox clicks.  This allows init/beforeClick/afterClick handlers to reference RELATIVE elements, including using "story.findContainingTiddler(place)".  Also, wrap handlers in "function()" so "return" can be used within handler code.
|please see [[CheckboxPluginInfo]] for additional revision details|
2005.12.07 [0.9.0] initial BETA release
<<<
!!!!!Code
***/
//{{{
version.extensions.CheckboxPlugin = {major: 2, minor: 4, revision:0 , date: new Date(2008,1,5)};
//}}}
//{{{
config.checkbox = { refresh: { tagged:true, tagging:true, container:true } };
config.formatters.push( {
	name: "checkbox",
	match: "\\[[xX_ ][\\]\\=\\(\\{]",
	lookahead: "\\[([xX_ ])(=[^\\s\\(\\]{]+)?(\\([^\\)]*\\))?({[^}]*})?({[^}]*})?({[^}]*})?\\]",
	handler: function(w) {
		var lookaheadRegExp = new RegExp(this.lookahead,"mg");
		lookaheadRegExp.lastIndex = w.matchStart;
		var lookaheadMatch = lookaheadRegExp.exec(w.source)
		if(lookaheadMatch && lookaheadMatch.index == w.matchStart) {
			// get params
			var checked=(lookaheadMatch[1].toUpperCase()=="X");
			var id=lookaheadMatch[2];
			var target=lookaheadMatch[3];
			if (target) target=target.substr(1,target.length-2).trim(); // trim off parentheses
			var fn_init=lookaheadMatch[4];
			var fn_clickBefore=lookaheadMatch[5];
			var fn_clickAfter=lookaheadMatch[6];
			var tid=story.findContainingTiddler(w.output);  if (tid) tid=tid.getAttribute("tiddler");
			var srctid=w.tiddler?w.tiddler.title:null;
			config.macros.checkbox.create(w.output,tid,srctid,w.matchStart+1,checked,id,target,config.checkbox.refresh,fn_init,fn_clickBefore,fn_clickAfter);
			w.nextMatch = lookaheadMatch.index + lookaheadMatch[0].length;
		}
	}
} );
config.macros.checkbox = {
	handler: function(place,macroName,params,wikifier,paramString,tiddler) {
		if(!(tiddler instanceof Tiddler)) { // if no tiddler passed in try to find one
			var here=story.findContainingTiddler(place);
			if (here) tiddler=store.getTiddler(here.getAttribute("tiddler"))
		}
		var srcpos=0; // "inline X" not applicable to macro syntax
		var target=params.shift(); if (!target) target="";
		var defaultState=params[0]=="checked"; if (defaultState) params.shift();
		var id=params.shift(); if (id && !id.length) id=null;
		var fn_init=params.shift(); if (fn_init && !fn_init.length) fn_init=null;
		var fn_clickBefore=params.shift();
		if (fn_clickBefore && !fn_clickBefore.length) fn_clickBefore=null;
		var fn_clickAfter=params.shift();
		if (fn_clickAfter && !fn_clickAfter.length) fn_clickAfter=null;
		var refresh={ tagged:true, tagging:true, container:false };
		this.create(place,tiddler.title,tiddler.title,0,defaultState,id,target,refresh,fn_init,fn_clickBefore,fn_clickAfter);
	},
	create: function(place,tid,srctid,srcpos,defaultState,id,target,refresh,fn_init,fn_clickBefore,fn_clickAfter) {
		// create checkbox element
		var c = document.createElement("input");
		c.setAttribute("type","checkbox");
		c.onclick=this.onClickCheckbox;
		c.srctid=srctid; // remember source tiddler
		c.srcpos=srcpos; // remember location of "X"
		c.container=tid; // containing tiddler (may be null if not in a tiddler)
		c.tiddler=tid; // default target tiddler 
		c.refresh = {};
		c.refresh.container = refresh.container;
		c.refresh.tagged = refresh.tagged;
		c.refresh.tagging = refresh.tagging;
		place.appendChild(c);
		// set default state
		c.checked=defaultState;
		// track state in config.options.ID
		if (id) {
			c.id=id.substr(1); // trim off leading "="
			if (config.options[c.id]!=undefined)
				c.checked=config.options[c.id];
			else
				config.options[c.id]=c.checked;
		}
		// track state in (tiddlername|tagname) or (fieldname@tiddlername)
		if (target) {
			var pos=target.indexOf("@");
			if (pos!=-1) {
				c.field=pos?target.substr(0,pos):"checked"; // get fieldname (or use default "checked")
				c.tiddler=target.substr(pos+1); // get specified tiddler name (if any)
				if (!c.tiddler || !c.tiddler.length) c.tiddler=tid; // if tiddler not specified, default == container
				if (store.getValue(c.tiddler,c.field)!=undefined)
					c.checked=(store.getValue(c.tiddler,c.field)=="true"); // set checkbox from saved state
			} else {
				var pos=target.indexOf("|"); if (pos==-1) var pos=target.indexOf(":");
				c.tag=target;
				if (pos==0) c.tag=target.substr(1); // trim leading "|" or ":"
				if (pos>0) { c.tiddler=target.substr(0,pos); c.tag=target.substr(pos+1); }
				if (!c.tag.length) c.tag="checked";
				var t=store.getTiddler(c.tiddler);
				if (t && t.tags)
					c.checked=t.isTagged(c.tag); // set checkbox from saved state
			}
		}
		// trim off surrounding { and } delimiters from init/click handlers
		if (fn_init) c.fn_init="(function(){"+fn_init.trim().substr(1,fn_init.length-2)+"})()";
		if (fn_clickBefore) c.fn_clickBefore="(function(){"+fn_clickBefore.trim().substr(1,fn_clickBefore.length-2)+"})()";
		if (fn_clickAfter) c.fn_clickAfter="(function(){"+fn_clickAfter.trim().substr(1,fn_clickAfter.length-2)+"})()";
		c.init=true; c.onclick(); c.init=false; // compute initial state and save in tiddler/config/cookie
	},
	onClickCheckbox: function(event) {
		window.place=this;
		if (this.init && this.fn_init) // custom function hook to set initial state (run only once)
			{ try { eval(this.fn_init); } catch(e) { displayMessage("Checkbox init error: "+e.toString()); } }
		if (!this.init && this.fn_clickBefore) // custom function hook to override changes in checkbox state
			{ try { eval(this.fn_clickBefore) } catch(e) { displayMessage("Checkbox onClickBefore error: "+e.toString()); } }
		if (this.id)
			// save state in config AND cookie (only when ID starts with 'chk')
			{ config.options[this.id]=this.checked; if (this.id.substr(0,3)=="chk") saveOptionCookie(this.id); }
		if (this.srctid && this.srcpos>0 && (!this.id || this.id.substr(0,3)!="chk") && !this.tag && !this.field) {
			// save state in tiddler content only if not using cookie, tag or field tracking
			var t=store.getTiddler(this.srctid); // put X in original source tiddler (if any)
			if (t && this.checked!=(t.text.substr(this.srcpos,1).toUpperCase()=="X")) { // if changed
				t.set(null,t.text.substr(0,this.srcpos)+(this.checked?"X":"_")+t.text.substr(this.srcpos+1),null,null,t.tags);
				if (!story.isDirty(t.title)) story.refreshTiddler(t.title,null,true);
				store.setDirty(true);
			}
		}
		if (this.field) {
			if (this.checked && !store.tiddlerExists(this.tiddler))
				store.saveTiddler(this.tiddler,this.tiddler,"",config.options.txtUserName,new Date());
			// set the field value in the target tiddler
			store.setValue(this.tiddler,this.field,this.checked?"true":"false");
			// DEBUG: displayMessage(this.field+"@"+this.tiddler+" is "+this.checked);
		}
		if (this.tag) {
			if (this.checked && !store.tiddlerExists(this.tiddler))
				store.saveTiddler(this.tiddler,this.tiddler,"",config.options.txtUserName,new Date());
			var t=store.getTiddler(this.tiddler);
			if (t) {
				var tagged=(t.tags && t.tags.indexOf(this.tag)!=-1);
				if (this.checked && !tagged) { t.tags.push(this.tag); store.setDirty(true); }
				if (!this.checked && tagged) { t.tags.splice(t.tags.indexOf(this.tag),1); store.setDirty(true); }
			}
			// if tag state has been changed, update display of corresponding tiddlers (unless they are in edit mode...)
			if (this.checked!=tagged) {
				if (this.refresh.tagged) {
					if (!story.isDirty(this.tiddler)) // the TAGGED tiddler in view mode
						story.refreshTiddler(this.tiddler,null,true); 
					else // the TAGGED tiddler in edit mode (with tags field)
						config.macros.checkbox.refreshEditorTagField(this.tiddler,this.tag,this.checked);
				}
				if (this.refresh.tagging)
					if (!story.isDirty(this.tag)) story.refreshTiddler(this.tag,null,true); // the TAGGING tiddler
			}
		}
		if (!this.init && this.fn_clickAfter) // custom function hook to react to changes in checkbox state
			{ try { eval(this.fn_clickAfter) } catch(e) { displayMessage("Checkbox onClickAfter error: "+e.toString()); } }
		// refresh containing tiddler (but not during initial rendering, or we get an infinite loop!) (and not when editing container)
		if (!this.init && this.refresh.container && this.container!=this.tiddler)
			if (!story.isDirty(this.container)) story.refreshTiddler(this.container,null,true); // the tiddler CONTAINING the checkbox
		return true;
	},
	refreshEditorTagField: function(title,tag,set) {
		var tagfield=story.getTiddlerField(title,"tags");
		if (!tagfield||tagfield.getAttribute("edit")!="tags") return; // if no tags field in editor (i.e., custom template)
		var tags=tagfield.value.readBracketedList();
		if (tags.contains(tag)==set) return; // if no change needed
		if (set) tags.push(tag); // add tag
		else tags.splice(tags.indexOf(tag),1); // remove tag
		for (var t=0;t<tags.length;t++) tags[t]=String.encodeTiddlyLink(tags[t]);
		tagfield.value=tags.join(" "); // reassemble tag string (with brackets as needed)
		return;
	}
}
//}}}
 
|Name|CheckboxPluginInfo|
|Source|http://www.TiddlyTools.com/#CheckboxPlugin|
|Documentation|http://www.TiddlyTools.com/#CheckboxPluginInfo|
|Version|2.4.0|
|Author|Eric Shulman|
|License|http://www.TiddlyTools.com/#LegalStatements|
|~CoreVersion|2.1|
|Type|documentation|
|Description|documentation for CheckboxPlugin|
This plugin extends the TiddlyWiki syntax to allow definition of checkboxes that can be embedded directly in tiddler content.  Checkbox states are preserved by:
* setting/removing tags on specified tiddlers,
* or, setting custom field values on specified tiddlers,
* or, saving to a locally-stored cookie ID,
* or, automatically modifying the tiddler source content (deprecated).
When an ID is assigned to the checkbox, it enables direct programmatic access to the checkbox DOM element, as well as creating an entry in TiddlyWiki's config.options[ID] internal data.  In addition to tracking the checkbox state, you can also specify custom javascript for programmatic initialization and onClick event handling for any checkbox, so you can provide specialized side-effects in response to state changes.
!!!!!Inline (wiki syntax) Usage
<<<
//{{{
[ ]or[_] and [x]or[X]
//}}}
Simple checkboxes using 'Inline X' storage.  The current unchecked/checked state is indicated by the character between the {{{[}}} and {{{]}}} brackets ("_" means unchecked, "X" means checked).  When you click on a checkbox, the current state is retained by directly modifying the tiddler content to place the corresponding "_" or "X" character in between the brackets.
>//''NOTE: 'Inline X' syntax has been deprecated...''  This storage format only works properly for checkboxes that are directly embedded and accessed from content in a single tiddler.  However, if that tiddler is 'transcluded' into another (by using the {{{<<tiddler TiddlerName>>}}} macro), the 'Inline X' will be ''erroneously stored in the containing tiddler's source content, resulting in corrupted content in that tiddler.''  For anything but the most simple of "to do list" uses, you should select from the various alternative storage methods described below...//
//{{{
[x=id]
//}}}
Assign an optional ID to the checkbox so you can use {{{document.getElementByID("id")}}} to manipulate the checkbox DOM element, as well as tracking the current checkbox state in {{{config.options["id"]}}}.  If the ID starts with "chk" the checkbox state will also be saved in a cookie, so it can be automatically restored whenever the checkbox is re-rendered (overrides any default {{{[x]}}} or {{{[_]}}} value).  If a cookie value is kept, the "_" or "X" character in the tiddler content remains unchanged, and is only applied as the default when a cookie-based value is not currently defined.
//{{{
[x(title|tag)] or [x(title:tag)]
//}}}
Initializes and tracks the current checkbox state by setting or removing a particular tag value from a specified tiddler.  If you omit the tiddler title (and the | or : separator), the specified tag is assigned to the current tiddler.  If you omit the tag value, as in {{{(title|)}}}, the default tag, {{{checked}}}, is assumed.  Omitting both the title and tag, {{{()}}}, tracks the checkbox state by setting the "checked" tag on the current tiddler.  When tag tracking is used, the "_" or "X" character in the tiddler content remains unchanged, and is not used to set or track the checkbox state.  If a tiddler title named in the tag does not exist, the checkbox state defaults to the "inline X" value.  If this value is //checked//, or is subsequently changed to //checked//, it will automatically create the missing tiddler and then add the tag to it.  //''NOTE: beginning with version 2.1.2 of this plugin, the "|" separator is the preferred separator between the title and tag name, as it avoids syntactic ambiguity when ":" is used within tiddler titles or tag names.''//
//{{{
[x(field@tiddler)]
//}}}
Initializes and tracks the current checkbox state by setting a particular custom field value from a specified tiddler.  If you omit the tiddler title (but not the "@" separator), the specified field on the current tiddler is used.  If you omit the field name, as in {{{(@tiddler)}}}, a default fieldname of {{{checked}}} is assumed.  Omitting both the field and the tiddler title, {{{(@)}}}, defaults to setting the "checked" field on the current tiddler.  When field tracking is used, the "_" or "X" character in the tiddler content remains unchanged, and is not used to set or track the checkbox state.  If the tiddler title named in the parameter does not exist, the checkbox state defaults to the "inline X" value.  If this value is //checked// or is subsequently changed to //checked//, it will automatically create the missing tiddler and then add the field to it.
//{{{
[x{javascript}{javascript}{javascript}]
//}}}
You can define optional javascript code segments to add custom initialization and/or 'onClick' handlers to a checkbox.  The current checkbox state (and it's other DOM attributes) can be set or read from within these code segments by reference to a globally-defined context object, "place" (which can also be referenced as "window.place").
The first code segment will be executed when the checkbox is initially displayed, so that you can programmatically determine it's starting checked/unchecked state.  The second code segment (if present) is executed whenever the checkbox is clicked, but //before the regular checkbox processing in performed// ("onClickBefore"), so that you can apply programmed responses or intercept and override the checkbox state based on custom logic.  The third code segment (if present) is executed whenver the checkbox is clicked, //after the regular checkbox processing has completed// ("onClickAfter"), so that you can include "side-effect" processing based on the checkbox state just applied.
>Note: if you want to use the default checkbox initialization processing with a custom onClickBefore/After function, use this syntax:
>{{{[x(tag){}{javascript}]}}} or {{{[x(tag){}{}{javascript}]}}}
<<<
!!!!!Macro usage
<<<
In addition to embedded checkboxes using the wiki syntax described above, a ''macro-based syntax'' is also provided, for use in templates where wiki syntax cannot be directly used.  This macro syntax can also be used in tiddler content, as an alternative to the wiki syntax.  When embedded in [[PageTemplate]], [[ViewTemplate]], or [[EditTemplate]] (or custom alternative templates), use the following macro syntax:
//{{{
<span macro="checkbox target checked id onInit onClickBefore onClickAfter"></span>
//}}}
or, when embedded in tiddler content, use the following macro syntax:
//{{{
<<checkbox target checked id onInit onClickBefore onClickAfter>>
//}}}
where:
''target''
>is either a tag reference (e.g., ''tagname|tiddlername'') or a field reference (e.g. ''fieldname@tiddlername''), as described above.
''checked'' (optional)
>is a keyword that sets the initial state of the checkbox to "checked".  When omitted, the default checkbox state is "unchecked".
''id'' (optional)
>specifies an internal config.options.* ID, as described above.  If the ID begins with "chk", a cookie-based persistent value will be created to track the checkbox state in between sessions.
''onInit'' (optional)
>contains a javascript event handler to be performed when the checkbox is initially rendered (see details above).
''onClickBefore'' and/or ''onClickAfter'' (optional)
>contains a javascript event handler to be performed each time the checkbox is clicked (see details above).  //note: to use the default onInit handler with a custom onClickBefore/After handler, use "" (empty quotes) or {} (empty function) as a placeholder for the onInit and/or onClickBefore parameters//
<<<
!!!!!Examples
<<<
''checked and unchecked static default ("inline X") values:''
//{{{
[X] label
[_] label
//}}}
>[X] label
>[_] label
''document-based value (id='demo', no cookie):''
//{{{
[_=demo] label
//}}}
>[_=demo] label
''cookie-based value  (id='chkDemo'):''
//{{{
[_=chkDemo] label
//}}}
>[_=chkDemo] label
''tag-based value (TogglyTagging):''
//{{{
[_(CheckboxPluginInfo|demotag)]
[_(CheckboxPluginInfo|demotag){place.refresh.tagged=place.refresh.container=false}]
//}}}
>[_(CheckboxPluginInfo|demotag)] toggle 'demotag' (and refresh tiddler display)
>[_(CheckboxPluginInfo|demotag){place.refresh.tagged=place.refresh.container=false}] toggle 'demotag' (no refresh)
''field-based values:''
//{{{
[_(demofield@CheckboxPluginInfo)] demofield@CheckboxPluginInfo
[_(demofield@)] demofield@ (equivalent to demonfield@ current tiddler)
[_(checked@CheckboxPluginInfo)] checked@CheckboxPluginInfo
[_(@CheckboxPluginInfo)] @CheckboxPluginInfo
[_(@)] @ (equivalent to checked@ current tiddler)
//}}}
>[_(demofield@CheckboxPluginInfo)] demofield@CheckboxPluginInfo
>[_(demofield@)] demofield@ (current tiddler)
>[_(checked@CheckboxPluginInfo)] checked@CheckboxPluginInfo
>[_(@CheckboxPluginInfo)] @CheckboxPluginInfo
>[_(@)] toggle field: @ (defaults to "checked@here")
>click to view current: <<toolbar fields>>
''custom init and onClick functions:''
//{{{
[X{place.checked=true}{alert(place.checked?"on":"off")}] message box with checkbox state
//}}}
>[X{place.checked=true}{alert(place.checked?"on":"off")}] message box with checkbox state
''retrieving option values:''
>config.options['demo']=<script>return config.options['demo']?"true":"false";</script>
>config.options['chkDemo']=<script>return config.options['chkDemo']?"true":"false";</script>
<<<
!!!!!Configuration
<<<
Normally, when a checkbox state is changed, the affected tiddlers are automatically re-rendered, so that any checkbox-dependent dynamic content can be updated.  There are three possible tiddlers to be re-rendered, depending upon where the checkbox is placed, and what kind of storage method it is using.
*''container'': the tiddler in which the checkbox is displayed. (e.g., this tiddler)
*''tagged'': the tiddler that is being tagged (e.g., "~MyTask" when tagging "~MyTask:done")
*''tagging'': the "tag tiddler" (e.g., "~done" when tagging "~MyTask:done")
You can set the default refresh handling for all checkboxes in your document by using the following javascript syntax either in a systemConfig plugin, or as an inline script.  (Substitute true/false values as desired):
{{{config.checkbox.refresh = { tagged:true, tagging:true, container:true };}}}
You can also override these defaults for any given checkbox by using an initialization function to set one or more of the refresh options.  For example:
{{{[_{place.refresh.container=false}]}}}
<<<
!!!!!Revisions
<<<
2008.01.08 [*.*.*] plugin size reduction: documentation moved to [[CheckboxPluginInfo]]
2008.01.05 2.4.0 set global "window.place" to current checkbox element when processing checkbox clicks.  This allows init/beforeClick/afterClick handlers to reference RELATIVE elements, including using "story.findContainingTiddler(place)".  Also, wrap handlers in "function()" so "return" can be used within handler code.
2008.01.02 2.3.0 split optional custom onClick handling into separate onClickBefore and onClickAfter handlers.  The onClickBefore handler permits interception of the click BEFORE the checkbox is set.  onClickAfter allows follow-on 'side-effect' processing to occur AFTER the checkbox is set.
2007.12.04 [*.*.*] update for TW2.3.0: replaced deprecated core functions, regexps, and macros
2007.08.06 2.2.5 supress automatic refresh of any tiddler that is currently being edited.  Ensures that current tiddler edit sessions are not prematurely discarded (losing any changes).  However, if checkbox changes a tag on a tiddler being edited, update the "tags" input field (if any) so that saving the edited tiddler correctly reflects any changes due to checkbox activity... see refreshEditorTagField().
2007.07.13 - 2.2.4 in handler(), fix srctid reference (was "w.tiddler", should have been "w.tiddler.title").  This fixes broken 'inline X' plus fatal macro error when using PartTiddlerPlugin.  Thanks to cmari for reporting the problem and UdoBorkowski for finding the code error.
2007.06.21 - 2.2.3 suppress automatic refresh of tiddler when using macro-syntax to prevent premature end of tiddler editing session.
2007.06.20 - 2.2.2 fixed handling for 'inline X' when checkboxes are contained in a 'trancluded' tiddler.  Now, regardless of where an inline X checkbox appears, the X will be placed in the originating source tiddler, rather than the tiddler in which the checkbox appears.
2007.06.17 - 2.2.1 Refactored code to add checkbox //macro// syntax for use in templates (e.g., {{{macro="checkbox ..."}}}. Also, code cleanup of existing tag handling.
2007.06.16 - 2.2.0 added support for tracking checkbox states using tiddler fields via "(fieldname@tiddlername)" syntax.
2006.05.04 - 2.1.3 fix use of findContainingTiddler() to check for a non-null return value, so that checkboxes won't crash when used outside of tiddler display context (such as in header, sidebar or mainmenu)
2006.03.11 - 2.1.2 added "|" as delimiter to tag-based storage syntax (e.g. "tiddler|tag") to avoid parsing ambiguity when tiddler titles or tag names contain ":".   Using ":" as a delimiter is still supported but is deprecated in favor of the new "|" usage.  Based on a problem reported by JeffMason.
2006.02.25 - 2.1.0 added configuration options to enable/disable forced refresh of tiddlers when toggling tags
2006.02.23 - 2.0.4 when toggling tags, force refresh of the tiddler containing the checkbox.
2006.02.23 - 2.0.3 when toggling tags, force refresh of the 'tagged tiddler' so that tag-related tiddler content (such as "to-do" lists) can be re-rendered.
2006.02.23 - 2.0.2 when using tag-based storage, allow use [[ and ]] to quote tiddler or tag names that contain spaces:
{{{[x([[Tiddler with spaces]]:[[tag with spaces]])]}}}
2006.01.10 - 2.0.1 when toggling tags, force refresh of the 'tagging tiddler'.  For example, if you toggle the "systemConfig" tag on a plugin, the corresponding "systemConfig" TIDDLER will be automatically refreshed (if currently displayed), so that the 'tagged' list in that tiddler will remain up-to-date.
2006.01.04 - 2.0.0 update for ~TW2.0
2005.12.27 - 1.1.2 Fix lookAhead regExp handling for {{{[x=id]}}}, which had been including the "]" in the extracted ID.  
Added check for "chk" prefix on ID before calling saveOptionCookie()
2005.12.26 - 1.1.2 Corrected use of toUpperCase() in tiddler re-write code when comparing {{{[X]}}} in tiddler content with checkbox state. Fixes a problem where simple checkboxes could be set, but never cleared.
2005.12.26 - 1.1.0 Revise syntax so all optional parameters are included INSIDE the [ and ] brackets.  Backward compatibility with older syntax is supported, so content changes are not required when upgrading to the current version of this plugin.   Based on a suggestion by GeoffSlocock
2005.12.25 - 1.0.0 added support for tracking checkbox state using tags ("TogglyTagging")
Revised version number for official post-beta release.
2005.12.08 - 0.9.3 support separate 'init' and 'onclick' function definitions.
2005.12.08 - 0.9.2 clean up lookahead pattern
2005.12.07 - 0.9.1 only update tiddler source content if checkbox state is actually different.  Eliminates unnecessary tiddler changes (and 'unsaved changes' warnings)
2005.12.07 - 0.9.0 initial BETA release
<<<
 
Les listes se créent en PHP avec la fonction ''"""CListes::add_liste2"""''
{{{
include_once 'modules/listes/classes/CListes.class.php';
CListes::add_liste2($identifiant, $table_sql, $titre, $description, $nom_element, $classement, $dossier);
}}}
; Paramètres :
: $identifiant : un nom unique désignant la liste
: $table_sql : nom de la table de BDD qui va contenir la liste
: $titre : un titre lisible pour la liste (défaut = "")
: $description : description expliquant le contenu de la liste (défaut = "")
: $nom_element : comment se nomme un élément de la liste (ex : "article") (défaut = "")
: $classement: désigne dans quel "dossier virtuel" placer la liste dans la gestion des listes (ex : "monSite.contenu", "monSite.admin") (défaut = NULL)
: $dossier : le dossier où seront stockées les fichiers uploadés pour cette liste (ex : "imagesarticles/") (défaut = NULL)
!Paramètres d'une liste
...
!Création d'un champ
...
 
Plusieurs façons de créer des pages :
*des pages HTML simples écrites à la main dans des dossiers identiques entre le workspace et leur url (ex : www/module_CLIENT/page1 = http:localhost/page1)
**simplement créer des pages et dossiers dans le dossier www du Module_CLIENT. Le chemin des images est relatif à l'emplacement des fichiers.
**dans la liste ''site_pages'', il faut forcément __vider le champ__ ''page_html'', mettre __"site"__ pour ''id_module'' et __""""site.CSite.pages_html_basic""""__ pour ''fonction''
**ne pas oublier dans cette même liste de renseigner ''masque'' (et souvent ''modele'' aussi), ainsi que ''actif'' = 1
*des pages HTML simples créées avec le Module_Arborescence
**il faut avoir activer le Module_Arborescence dans le Module_CLIENT du site
**une fois fait, se rendre sur http://localhost/super_admin/arborescence/ pour créer les arborescences, pages et dossiers
* en utilisant la fonction [[site_definit_page]] (qui ne fait qu'insérer un enregistrement dans la liste ''site_pages'')
* en créant un nouveau CReferencement
 
DataListAffichageEditable < DataListAffichateNonEditable < DataListAffichage < DataList
Un DLAE (DataListAffichageEditable) permet d'afficher des éléments d'une [[Liste]], et de les éditer directement en ligne
!prérequis
*Le site doit contenir : 
** une CMsgBox
** un [[Gestionnaire_modules]]
** une InfoBulle
* associer le stage 
{{{
DataListAffichageEditable.STAGE = stage;
}}}
* associer le gestionnaire de modules au gestionnaire de listes [[CListes]]
{{{
CListes.gestionnaire_modules = mon_gestionnaire;
}}}
!utilisation
créer un DLAE , avec un identifiant de [[Liste]].
{{{
le_dlae = new DataListAffichageEditable("album");
}}}
définir le type d'affichage ([[CAffichage]]), et l'associer au DLAE
{{{
var aff : CAffichage = new AffichageHorizontal();
aff.largeurConteneur = 550;
le_dlae.affichage = aff;
}}}
!ajouter des actions
!activer des actions
Il est possible d'activer ou désactiver des actions définies dans le DLAE.
!!!activation globale 
{{{
le_dlae.editable = true;
}}}
!!!activation globale par action
Chaque action peut être activée séparément : 
{{{
le_dlae.autorise_ajouter = true;
le_dlae.autorise_modifier = true;
le_dlae.autorise_supprimer = true;
le_dlae.autoriseAction("activer",true);
}}}
!!!activation par action et par élément
permet de définir une fonction qui renvoie un Boolean pour chaque DataSprite différent.
{{{
le_dlae.fnAutoriseAction("toggle", function(d:Object) :Boolean{
	return (d.titre as String).charAt(0) == "A";
});
}}}
Attention, génère une exception si l'action n'est pas définie au préalable.
!Boutons d'actions
Chaque action est associée à un [[Bouton]], placé dans le DataSprite.
Si ce bouton existe dans le DataSprite, il est utilisé ( /!\ Attention, il doit être de la classe Bouton)
Si ce bouton n'existe pas, il sera créé dynamiquement d'après la classe d'affichage définie dans l'action
Les actions editer et supprimer ont déjà leur classe d'affichage définie par défaut.
afin que les boutons editer et supprimer soient visibles, il faut implémenter dans la bibliothèque les classe graphiques suivantes : 
* efrogg.affichageDonnees.boutons.BoutonListeModification
* efrogg.affichageDonnees.boutons.BoutonListeAjouter
* efrogg.affichageDonnees.boutons.BoutonListeSuppression
Pour redéfinir les classes d'une action existante, 
{{{
le_dlae.classe_bt_modifier = MonBtModifier;
setClasseGraphiqueAction("modifier", MonBtModifier);
}}}
Le bouton ajouter étant seul, il est possible de définir sa Classe graphique de la même manière que ci-dessus, mais il est aussi possible de définir directement le bouton à utiliser pour ajouter.
{{{
le_dlae.bt_ajouter = mon_bouton;
}}}
Cette instruction est à utiliser AVANT de passer le DLAE.editable = true
!alignement des boutons
la propriété forceAlignBoutons sert a aligner tous les boutons en fonction du placement, même si celui-ci est placé dans le DataSprite, et non créé dynamiquement:
{{{
le_dlae.forceAlignBoutons = true;
}}}
!personnalisation des boutons en fonction des données
il est possible de faire en sorte qu'un bouton change en fonction des données. PAr exemple, un bouton activer/désactiver pourra prendre successivement la couleur rouge, ou vert, selon l'état de la variable actif.
Pour cela, le [[Bouton]] devra implémenter IDataSprite (ou être un BoutonDataSprite). Il suffira alors d'implémenter la fonction set donnees, et faire le traitement des différents cas
 
[[Installation FSE3]]
[[Création de pages]]
 
Voici le Wiki de la société, fortement conseillé de le remplir ! =)
Consulter la page http://tiddlywiki.org/wiki/TiddlyWiki_Markup pour le formatage du texte.
Pour l'insertion d'images et pour tout le reste, fouiller http://www.tiddlywiki.com.
Petite info, on fait du gras en entourant ce que l'on veut par 2 quotes simples, donc pour les chaines vides, merci d'utiliser les guillemets !
Seconde info, pour empêcher tout formatage, entourer une bloc par 3 guillemets.
 
Le FSE3 est la structure de travail pour créer des sites en Flash (as3) ou HTML (PHP).
 
Le FSE3 est constitué de modules. Chaque module dans son fichier associé (''"""CModule_NOM.class.php"""'') définit les autres modules nécessaires à son fonctionnement.
Chaque site créé utilise un Module_CLIENT spécifique, et utilise les autres selon les besoins.
!Liste des modules communs
|!nom module |!description |h
|Module_Arborescence|utilisé pour créer des pages simplement, le client peut y avoir accès par exemple|
|Module_Listes|gère les listes présentes sur le site|
|Module_Site|gère la navigation, détection et génération des pages, les redirections...|
Lors de la création d'un nouveau module, on peut se servir d'un modèle vide. Dans ''"""/modules/__nouveau__/"""'', il y a tout le nécessaire pour créer le module. Penser à bien tout remplacer.
Attention ! Ne jamais copier de dossier dans Eclipse, sinon Svn va crier ! Copier __les fichiers__ du dossier ''"""__nouveau__"""'' seulement.
 
{{{
	gest = new Gestionnaire_modules();
	gest.racine = "http://localhost/";
}}}
 
Les listes peuvent contenir des champs image. Une liste appelée __images_defaut__ (table __"""lis__images_defaut"""__) permet de définir le comportement à adopter quand l'élément de la liste ne contient pas d'image. Cette liste contient 2 champs à renseigner : image et identifiant (de la liste concernée par l'enregistrement).
2 possibilités de comportement :
* en passant par le SuperAdmin (http://monsite/super_admin) et en éditant cette liste, on ajoute une image (upload) et on renseigne l'identifiant de la liste concernée. Si un élément n'a pas d'image, elle sera remplacée par cette image par défaut.
* en inscrivant "no_image" dans le champ __image__ de cette liste (passer par la base de données). Si un élément n'a pas d'image, rien ne sera inséré pour éviter d'avoir une "image introuvable" et d'afficher l'attribut "alt".
 
Pour créer une infobulle : 
#créer dans la librairie un classe {{{MonInfoBulle}}} extends {{{efrogg.affichage.infobulle.InfoBullePlacementRedim}}}
# définir cette InfoBulle comme bulle par défaut
{{{
InfoBulle.classe_infobulle_defaut = infobulle_simple;
InfoBulle.stage_bulle = stage;
}}}
!!!Ajouter une InfoBulle a un bouton
{{{
InfoBulle.addInfoBulle(bt, texteInfoBulle);
}}}
!!!ouvrir une InfoBulle manuellement : 
{{{
InfoBulle.ouvreInfoBulle("coucou");
}}}
!!! différents types d'infoBulles
Il est possible d'ouvrir différentes InfoBulle dans une même site, en passant la Classe de l'InfoBulle en paramètre
{{{
InfoBulle.ouvreInfoBulle("coucou",ClasseInfoBulle);
}}}
!!!Manipuler une InfoBulle
Il est possible de créer une instance d'une InfoBulle, et de l'afficher, cacher,changer, etc...
{{{
}}}
 
!Première étape
* dans le fichiers __hosts__ de Windows, définir un alias ''localsiteencours'' qui redirige vers 127.0.0.1
*dans __/includes/config_serveur.inc.php__, ajouter une ligne au tableau ''$serveurs_config'' du type:
{{{
array("masque"=>"^localsiteencours$","serveur"=>"localhost","client"=>"IDENTIFIANT_MODULE_CLIENT")
}}}
*bien, entendu, créer le Module_CLIENT
!Mise à jour et installation
* mise à jour de la base de données : http://localhost?maj_bdd
* installation des pages : http://localhost?maj_pages
* installation des listes (à faire sur chaque page ou il y a des listes) : http://localhost?maj_listes
* installation des classes : http://localhost?maj_classes
* installation/maj du ht_access : http://localhost?maj_ht
Le refaire tant qu'il y a du rouge dans le rapport (à cause de l'ordre de faisabilité des opérations).
 
[[démarrer un site]]
[[Installation FSE3]]
[[Création de pages]]
[[plugins]]
 
Création d'une msgBox ....
[X] marche pas encore
[X] marche
 
Le Module_CLIENT est le module spécifique au site développé. Il se place à la racine du workspace. Le dossier s'écrit avec un underscore : ''_NOMCLIENT''.
Toutes les créations de listes , tables, etc... spécifiques au site sont à placer dans ses fichiers ''install_NOMCLIENT.inc.php'' et ''modifs_NOMCLIENT.inc.php''.
Consulter FSE3_Module pour plus d'infos sur l'installation et sur les modules en général.
 
Le Module_Listes gère les listes. Les listes sont une façon générique de gérer le contenu.
On ne crée pas une table article, une table gallerie_photo et une table news, on crée une liste article, une liste gallerie_photo et une liste news.
La liste et chaque champ la formant possèdent beaucoup de paramètres.
En savoir plus en consultant [[Création de listes]].
 
!flash : 
{{{
package krax {
    import flash.display.StageAlign;
    import efrogg.debugg.Debugger;
    import efrogg.sites.swfaddress.SWFAddressEvent;
    import efrogg.sites.swfaddress.SWFAddress;
    import flash.display.MovieClip;
    /**
     * @author Leo
     */
    public class MainKrax extends MovieClip {
        public function MainKrax() {
            stage.align = StageAlign.TOP_LEFT;
            SWFAddress.addEventListener(SWFAddressEvent.INIT, swfadressInited);
            SWFAddress.addEventListener(SWFAddressEvent.CHANGE, changeAdressListener);
            Debugger.init(stage, this);
        }
        private function swfadressInited(event : SWFAddressEvent) : void {
            Debugger.trace(event.toString());            
            Debugger.trace(event.path);            
            SWFAddress.setValue("/truc/chose");
        }
        private function changeAdressListener(event : SWFAddressEvent) : void {
            Debugger.trace(event.toString());            
            Debugger.trace(event.path);            
        }
    }
}
}}}
!html : 
{{{
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="fr" xml:lang="fr">
	<head>
		<title>main</title>
		<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
		<style type="text/css" media="screen">
		html, body { height:100%; background-color: #ffffff;}
		body { margin:0; padding:0; overflow:hidden; }
		#flashContent { width:100%; height:100%; }
		</style>
		<script type="text/javascript" src="/flash/swfobject.js"></script>
<script type="text/javascript" src="/flash/swfaddress.js"></script>
	</head>
	<body>
		<div id="flashContent">
			vous n'avez pas flash !
		</div>
		<script type="text/javascript">
        // <![CDATA[
        	var swf = new SWFObject('/flash/main.swf', 'main', '550', '400', '10', '#FFFFFF', 'high');
        	swf.addParam("menu", "false");
        	swf.useExpressInstall('/flash/expressinstall.swf');
        	swf.addParam("allowFullScreen", "false");
        	swf.write('flashContent');
        // ]]>
        </script> 
	</body>
</html>
}}}
 
Pour faire un site AS3 "simple" : 
{{{
//pour les pages où l'on ne précise pas, celle-ci sera utilisée. par défaut (sans cette ligne, c'est la transition Fade)
CSite.transitionDefaut = Volet;
			
op = new OptionsPage();
op.transition = Volet;
			
site = new CSite();
CSite.mainSite = site;
site.conteneur = this;
pageAccueil = site.ajoutePageClip('accueil', page_accueil,op); //ici on donne "op", on utilise donc ici la transition Volet
site.ajoutePageClip('galerie', page_galerie); //ici on ne donne pas le 3eme param, les options (dont la transition) par défaut sont utilisées
site.pageDefaut = "accueil"; //page qui s'ouvre au lancement
			
site.initialise();
}}}
pour ouvrir une page :
{{{
ot = new OptionTransition();
ot.duree = 3;
CSite.ouvrePageParNom('accueil',ot); //si on ne précise pas le 2eme param, on utilise les options par défaut
}}}
 
pour créer une version mobile d'un site du FSE3 :
*ajouter le module "mobile" dans les modules dépendants dans Cmodule_CLIENT
*ajouter dans le Cmodule_CLIENT :
{{{
if(Cmodule::module_existe('mobile'))
{
	Cmodule_mobile::definitSousDomaine('m');
	Cmodule_mobile::definitCheminFichiersMobile('m');
}
}}}
organisation du dossier www :
* un dossier 'm' est placé dans www. il contient les ''pages'' version mobile et les ''modeles'' (à placer dans un dossier "modeles"). Si le fichier n'est pas trouvé dans le dossier 'm', on regarde dans www selon la même arborescence. Dossiers contenu dans www/m :
** modeles
** html, et dedans blocs
** les dossiers contenant des pages du site, comme dans www
* les css et js sont gérés manuellement. si on veut créer un fichier css pour mobile, on créé un dossier 'm' dans le dossier 'css' et on place le fichier dedans.
La table site_pages_modeles contient un champ "type_site", il permet de déterminer si l'enregistrement est utilisé pour le site mobile ou le site standard. Dans le cas d'un site mobile, le root_modele n'est pas pris en compte, un root_modele "universel" est utilisé, placé dans le module "mobile". Si on est mobile mais que le modèle version mobile n'existe pas, on prend celui version standard.
La table lis_type_affichage contient un champ "type_site", il permet de déterminer si l'enregistrement est utilisé pour le site mobile ou le site standard. Si on est mobile mais que le type affichage version mobile n'existe pas, on prend celui version standard.
''ATTENTION'' : pour les pages blogables, il ne faut pas avoir de listes dans le modèle ou la page contenu (liste automatiques """{{{liste}{...}...}}""") (cette remarque n'est pas spéciale mobile, c'est aussi le cas pour un site normal)
Pour un site simple avec ses pages en html directement dans www/ (ou m/) (exemple : GOLF), on gère de façon minimum la barre mobile ainsi :
*dans le modèle : à mettre tout en haut (pour qu'elle soit en haut du site) :
{{{
{#mobile.CMobile.mobileBar(iddudivmenu,iddudivcontenu)#}
}}}
*dans les pages :
{{{
{#mobile.CMobile.mobileBarLienParent(/urlparent.htm,Textedulienversparent)#}
{#mobile.CMobile.mobileBarTitre(Titredelapage,identifiantpage)#}
}}}
** comme la barre pointe par défaut vers l'accueil, il suffit pour une page juste "sous" l'accueil :
{{{
{#mobile.CMobile.mobileBarTitre(Titredelapage,identifiantpage)#}
}}}
** enfin pour l'accueil ('acc' est l'identifiant par défaut de l'accueil dans le fonctionnement de la barre)
{{{
{#mobile.CMobile.mobileBarTitre(Bienvenue,acc)#}
}}}
 
/*{{{*/
.title {font-size:2em; font-weight:bold;}
.tiddler {background-color:#F8F8F8;border:solid 1px #CCC;margin-bottom:50px;}
#contentWrapper {background-color:white;}
#mainMenu {position:relative; float:left;}
/*}}}*/
 
Editeur WYSIWYG qui remplace les textarea classiques.
Utilisé dans l'admin PHP du site, pour les champs qui ont un type_formulaire = ''tinyeditor'' (plus d'infos dans Module_Listes).
 
Les variables de config sont stockées dans la table ''"""site__variables_config"""''.
Des fonctions permettent de travailler avec ces variables :
{{{
include_once 'modules/site/fonctions_config.inc.php';
cree_config($nom_variable, $type_variable, $valeur_variable = '', $description_variable = '');
get_config($nom_variable);
set_config($nom_variable, $nouvelle_valeur);
config_exists($nom_variable);
}}}
Pour l'instant, seuls les types "string" et "bool" sont bien gérés par get_config. mettre 1 ou 0 lors de la création d'une variable type "bool".
!Liste des variables
|!nom variable |!type variable |!description |h
|"""CONTENT_CSS_TINYMCE"""|string|contient le chemin vers  le css du site pour l'utiliser dans TinyMCE dans l'admin|
 
[[Ajouter un site]]
Flash :
Ajouter une MessageBox
utiliser [[SWFAddress]]
ajouter un [[Formulaire]]
faire un GestionnaireModule
utiliser un DataListAffichageEditable
 
{{{http://www.TiddlyTools.com/#CheckboxPlugin}}}
 
Pour utiliser la fonction :
{{{
include_once 'modules/site/fonctions_site.inc.php';
}}}
; Paramètres :
: $identifiant : un nom unique désignant la page
: $str_masque : masque (expression régulière possible) pour accéder à cette page
: $id_module : identifiant du [[FSE3_Module]] contenant la page
: $fichier : fichier définissant la page (défaut = NULL)
: $id_modele : identifiant du modèle de page (défaut = NULL)
: $fonction : la fonction déclenchée créant la page (défaut = NULL)
: $str_params : les paramètres (possibilité de passer les $1, $2, etc... détectés par $str_masque) à passer à la fonction ou à la classe php (défaut = NULL)
: $identifiant_droit (défaut = NULL)
: $redirige_NOK (défaut = NULL)
: $redirige_OK (défaut = NULL)
: $priorite (défaut = NULL)
: $continue (défaut = NULL)
: $commentaires (défaut = "")
: $id_parent (défaut = NULL)
: $actif (défaut = NULL)
: $date_debut (défaut = NULL)
: $date_fin (défaut = NULL)
: $classe_php : classe (dérivant de CPageHTML) se trouvant dans le dossier pages du module $id_module créant la page (défaut = "")
: $robots (défaut = "")
: $is_flash (défaut = 0)