Edit Variables
< Debug Variables | Variables | I18n Variables >
To set many of the variables below specify them in config.php.
- $EnableReadOnly
- Set to 1 to disable editing. Note this doesn't automatically prevent changes to the wiki by recipes, unless they use the core Lock() function correctly.
-  $EnableReadOnly= 1; # disable editing
- $EnableNotSavedWarning
- This warns the editors if they are about to leave the edit form without saving their changes. By default this is enabled, set to 0 to disable it.
-  $EnableNotSavedWarning= 0; # disable warning, default 1 (enabled, since 2.3.0)
- $EnableEditAutoText
- Set to 1 to enable basic predictive editing like automatically inserted list bullets, see Cookbook:EditHelp. By default this is disabled. If you enable it, please disable any addons that may provide a similar feature, notably an older version of Cookbook:EditHelp.
-  $EnableEditAutoText= 1; # enable for the edit form
-  $EnableEditAutoText= 2; # enable for any textarea with the class name 'autotext'
- $EditAutoBrackets
-  An array of key-value pairs defining brackets, parentheses, or quotes. When the user types any key in the editor, both the opening (key) and closing (value) characters will be inserted, with the cursor positioned between them. If text is selected, the characters will wrap around the selection. $EnableEditAutoTextneeds to also be enabled.
-  $EditAutoBrackets= array( '('=>')', '['=>']', '{'=>'}', '"'=>'"');
-  This is enabled with $EnableCommonEnhancements, set$EditAutoBrackets= false;
- The opening (key) character needs to be a single character. The closing (value) may be longer.
- $EnableMinorEditKeepMeta
- When enabled, a "minor" edit will report some page attributes from the previous edit, for example the last modified time and author which appear in footers, pagelists, RSS feeds and are used by some recipes:
-  $EnableMinorEditKeepMeta= ['time', 'author', 'csum']; # report the last modified time, author and edit summary on minor edits
- This reports the previous page attributes, but Recent Changes pages and page histories are recorded as usual to allow review.
- Note, if the array is enabled, the 'time' attribute is reported even if not defined above, but for readability and future compatibility it is recommended to define it.
- $EnableMergeLastMinorEdit
- When set to 1, and an author has checked the "This is a minor edit" checkbox, and the previous edit was by the same author (same name, IP address, browser version), then the previous and current edits will be merged into a single page history entry. This way an author can make many small changes one after another without creating multiple separate history entries.
-  $EnableMergeLastMinorEdit= 1;
- To only allow this for a limited time between edits, set this variable to the number of seconds. If a longer time has passed, a separate history entry will be added as usual:
-  $EnableMergeLastMinorEdit= 2*3600; # at most 2 hours between merged edits
-  See also $EnableDraftAtomicDiff.
- $AutoCreate
- Used in conjunction with the AutoCreateTargets edit function, this array records any sets of pages which should be created automatically if they don't exist.  The syntax is $AutoCreate[REGEXP] = PAGE_PARAMETERS;whereREGEXPis a regular expression which will identify the pages to be autocreated, andPAGE_PARAMETERSis an array of attributes for the page to be created. For example$AutoCreate['/^Category\\./'] = array('ctime' => $Now);will create a blank page with a current creation time for any missing Category page.
- $DefaultPageTextFmt
- The text that should be displayed when browsing non-existent pages. As default PmWiki uses the contents of Site.PageNotFound: $DefaultPageTextFmt = '(:include $[{$SiteGroup}.PageNotFound]:)';
- $DeleteKeyPattern
- The pattern used to determine if a page should be deleted.  The default is to remove pages that contain only the single word "delete" (and optional spaces). ## Change delete word to "remove": $DeleteKeyPattern = "^\\s*remove\\s*$"; ## Delete any page with no visible text, i.e., empty: $DeleteKeyPattern = "^\\s*$"; 
- $DiffKeepDays
- The $DiffKeepDaysvariable sets the minimum length of time that a page's revision history is kept. By default it is set to 3650 days, or a little less than ten years. You can change this value in a customization file to be something smaller, e.g.:$DiffKeepDays = 30; # keep revisions at least 30 daysIf you want to suppress a page's revision history, you can insert into a customization file$DiffKeepDays = $DiffKeepNum = -1; # suppress revision historyNote that a specific page revision isn't removed from the page until the first edit after the time specified by$DiffKeepDayshas elapsed. Thus, it's still possible for some pages to have revisions older than$DiffKeepDays-- such revisions will be removed the next time those pages are edited.
- $DiffKeepNum
- This variable contains the minimum number of changes to be kept in the page history, even if some of them are older than the limit defined by $DiffKeepDays. It prevents lost history of pages that are older, but have few changes.$DiffKeepNum = 50; # keep at least 50 revisions (default is 20)To suppress page's revision history with$DiffKeepNum = -1see$DiffKeepDaysabove.
- $DraftActionsPattern
- The actions which allow full loading of the draft.php functionality for custom actions. Default is 'edit'. You can enable drafts for other actions like: $DraftActionsPattern = 'edit|pmform|translate'; # Enable drafts for actions 'edit', 'pmform' and 'translate'.
- $DraftSuffix
- The suffix to use for draft versions of pages (default "-Draft").
- $EditFunctions
-  This array contains the sequence of functions that are called when a page is edited.  It can be customized to provide additional functions to be called as part of the editing process.  The standard setting is: $EditFunctions = array('EditTemplate', 'RestorePage', 'ReplaceOnSave', 'SaveAttributes', 'PostPage', 'PostRecentChanges', 'AutoCreateTargets', 'PreviewPage');Many recipes manipulate this array, so it is recommended, instead of redefining the complete array to add your custom functions, to call InsertEditFunction() with your function name. See also UpdatePage().
- $EditRedirectFmt
-  The page to which an author is sent after pressing "Save" or "Cancel" from an edit form.  Defaults to "$FullName", which sends the author to the page just edited, but can be changed to specify another page. ## Redirect to Main.HomePage: $EditRedirectFmt = 'Main.HomePage'; ## Redirect to HomePage of current group: $EditRedirectFmt = '{$Group}.HomePage';
- $EditTemplatesFmt
- Name of the page (or an array of names) to be used as the default text for any newly created pages. ## Use 'Main.NewPageTemplate' as default text of all new pages: $EditTemplatesFmt = 'Main.NewPageTemplate'; ## Use 'Template' in the current group for new pages: $EditTemplatesFmt = '$Group.Template'; ## Use 'Template' in the current group if it exists, otherwise ## use 'Main.NewPageTemplate': $EditTemplatesFmt = array('$Group.Template', 'Main.NewPageTemplate');
See Cookbook:EditTemplates for more information.
- $EnableDrafts
- When set to '1', enables the "Save draft" button and built-in handling of "draft" versions of pages, where: 
- Initial "Save draft" of an existing page ("PageName") saves changes to a new name ("PageName-Draft").
- Subsequent attempts to edit PageName causes PageName-Draft to be edited.
- Subsequent selections of "Save draft" cause PageName-Draft to be saved.
- Pressing "Publish" causes PageName-Draft to be posted to PageName, and deleted.
 
Turn on draft edits: 
    $EnableDrafts = 1;
A related variable, 
$EnablePublishAttr, adds a new "publish" authorization level to distinguish editing of drafts from publishing them.
- $EnableDraftAtomicDiff
- When set to 1, "publishing" a draft version will clear the "draft" history, leaving a single "diff" between the latest and the previous "published" versions. Note that this will delete the author names, dates and contributions of the intermediate, unpublished versions. (Drafts need to be enabled, see $EnableDrafts.) See also$EnableMergeLastMinorEdit.
- $EnableGUIButtons
- When set to '1', turns on the graphical buttons in the "Edit Page" form. ## Turn on graphical edit buttons: $EnableGUIButtons = 1; 
- $EnableGuiEditFixUrl
-  Enables an icon "%2" that can help encoding special characters in URL links, see Cookbook:FixURL. $EnableGUIButtonsneed to be enabled.
-  $EnableGuiEditFixUrl= 2000; # place the button near the end of the Edit toolbar
- $EnablePreviewChanges
- When set to '1', the "Preview" function will show the highlighted changes in the wiki markup before the rendered page preview. See Cookbook:PreviewChanges. $EnablePreviewChanges = 1; 
- $EnableListIncludedPages
-  When set to '1', inserts in the edit form a list with pages included in the currently edited page either via the include markup, or via page text variables (and any nested pages and variables). The list appears in a collapsed <details>element between the text area and the summary field.
- $EnablePostAuthorRequired
- When set to '1', posting of pages (and uploading files since 2.2.117) requires the author to provide an author name.  Otherwise, authors can post without a name. ## Require authors to provide a name: $EnablePostAuthorRequired = 1; 
- $EnableUploadAuthorRequired
- Whether uploading files requires the name of the uploader to be entered (added in 2.2.117). If unset, will use the value of $EnablePostAuthorRequired.
- $EnableRevUserAgent
- When set to '1', the page history will store the "User agent" string from the browser of the writer (by default this feature is disabled). This can be useful for tracking bugs in custom applications, by examining the disk files in wiki.d. ## Store browser user agent with page diffs: $EnableRevUserAgent = 1; 
- $GUIButtons
- Allows the configuration of the buttons which appear at the top of the text area when editing a page.  See scripts/guiedit.phpfor the default definition. Note that the 5th element can be HTML code rather than just the url of a gif - this allows more flexibility in defining the related JavaScript.
- $HandleEditFmt
-  Like $HandleBrowseFmt, this specifies the entire output format for ?action=editfor a page.
- $IsPagePosted
- Set to a true value if the page is actually saved (e.g., this is used to tell the RecentChanges handlers if they need to update).
- $PageEditFmt
- By default, this is the HTML to be displayed for an edit form.
- $PageEditForm
-  Specifies the edit form for ?action=edit. Defaults to '$SiteGroup.EditForm
- $ROSPatterns
- ("Replace on Save patterns") With this array you can add patterns as key and set a text value which will replace it when the edited page is saved (as signaled by $EnablePost). See Cookbook:ROSPatterns for examples.
- $ROEPatterns
-  ("Replace on Edit patterns") This behaves similarly to $ROSPatternsbut also when the page is loaded into the edit form, and when a preview is done.
- $TROEPatterns
-  ("Template Replace on Edit patterns") This behaves similarly to $ROEPatternsbut only when an empty page is opened for editing and an "edit template" is loaded into the edit form, see$EditTemplatesFmt.
- $EnableROSEscape
-  If set to 1, the $ROEPatterns,$ROSPatterns, and$TROEPatternsreplacements will skip escaped text (surrounded by[=...=]or[@...@]). If not set, or if set to 0, the replacements will happen even inside escaped text.
Categories: PmWiki Developer
< Debug Variables | Variables | I18n Variables >
This page may have a more recent version on pmwiki.org: PmWiki:EditVariables, and a talk page: PmWiki:EditVariables-Talk.