Managing Topics
Browser-based rename, move, copy, and delete for individual topicsOn this page:
Overview
You can use browser-based controls to change a name of a topic, move it to another web or delete it to a hiddenTrash
web.
How to rename or move a topic
- Select the
[More actions]
link (normally located in an action toolbar at the top or bottom of page) on the topic to be changed. Then, in the new screen, click[Rename or move topic...]
or[Delete topic...]
. You can now rename and/or move in one operation:- Move: Select the target web if other than the current web
- Rename: Enter the new topic name - default is current name
You'll be warned if any of the topics to be affected are locked (being edited), or if there is a name conflict.
- Prevent updates by unchecking individual items on the list of referring links - these topics will NOT to be updated with the new name (by default, only links in the same web will be updated).
- Click on
[Rename]
: the topic will be renamed and links to the topic updated as requested.- If any of the referring pages are locked then they will be listed: you can correct these later by again pressing
[Rename]
.There is a Put back feature that allows you to undo a
rename/move/delete
action - an instruction line and an undo link will appear at the bottom of the modified topic. This allows you to revert from the last modification only.
- If any of the referring pages are locked then they will be listed: you can correct these later by again pressing
How to delete a topic
Foswiki deletes topics by moving them to the hiddenTrash
web. - Select the
[More actions]
link (normally located in an action toolbar at the top or bottom of page) on the topic to be changed. Then, in the new screen, click[Delete topic...]
. That will bring up the "rename" form prepopulated with theTrash
web and a suitable topic name. - Click on
[Delete]
: the topic will be renamed and moved to theTrash
web as requested.
How to copy a topic
- Select the
[More actions]
link (normally located in an action toolbar at the top or bottom of page) on the topic to be changed. - On the "More actions" page, scroll down to the "Copy topic" section. In the "Name of copy" text box, enter in the new topic name. To copy the topic to another web, fully qualify the topic name with the web name, separating the two with a period (for example,
Web.TopicName
). - Select the
[Copy topic]
button. You will be directed to an edit page for the newly-created topic. You can save the new copy immediately, or make some changes and then save it.
Deleted topics: How to clear the trash
Deleted topics are moved to a specialTrash
web - they are NOT physically erased from the server. All webs share the same Trash
- in case of a name conflict with a topic already existing in the Trash
web, the user is alerted and asked to choose a new name.
The Trash
web should be be cleared periodically, by archiving (saving) the text and RCS files if required (recommended), then deleting them from the Trash
directory.
This can only be done from on the server, not through the browser.
Since simple FTP access to the
Trash
directory is all that is required for maintenance, it is possible to grantTrash
admin privileges to multiple users, while strictly limiting server access.
Redirecting from an old topic
The default "new topic" screen tells the user when a topic being created used to exist, but was moved. So if anyone follows a link to a moved topic, they will be able to click through to the new name.How rename/move works
- %SEARCH%, with a special template, finds and displays all occurrences of the topic name in other topics, either web- or site-wide. These referring links are by default automatically changed to the new topic and/or web name. This includes relevant MetaData definitions.
- User can omit one or more topics from the update list by unchecking them.
-
<pre>
and<verbatim>
are honoured - no changes are made to text within these areas.
Foswiki will therefore not change any references in macros defined in
<pre>
and<verbatim>
blocks
- The topic is moved (if locks allow).
- References are changed (locks and permissions permitting).
- Any referring topics that cannot be changed due to locks are listed - user can take note and change them at another time.
How referring topics are found
First, matching topics in the current web are listed - matches are totopic
. Next, all webs (including the current one) are listed that match web.topic
. All webs will be searched during rename, even if NOSEARCHALL
is defined on a web, though access permissions will of course be honoured.
Changed references are kept as short as possible, for example: topic
is used in preference to web.topic
.
Effect of user access settings
User permissions affect the 'rename' functions in various ways. To rename a topic, you need all ofVIEW
, CHANGE
and RENAME
access to that topic. To alter referring topics, you need CHANGE
access. See AccessControl for information on setting up access permissions.
Special considerations
Consider carefully whether to make browser-based rename/move/delete widely available, or to restrict it to an administrator/moderator group. Allowing all users to easily manipulate topics can be extremely useful in refactoring a busy web or site. However, there are at least two significant potential drawbacks to take into account:- When referring links are updated, the modified topics appear in WebChanges, creating the impression that editorial changes were made. This can undermine the usefulness of WebChanges.
- Due to current limitations, fairly heavy use of rename/move/delete functions can lead to an accumulation of minor technical problems (such as broken links) and usability issues (e.g. user confusion). If rename... is used heavily, these negatives will obviously increase, in number and effect.
Known issues
Rename/move is fairly complicated due to the dynamic generation of links. Ideally, it would be possible to run the required part of rendering in a way that would allow identification of the text to be changed. Unfortunately, these hooks don't exist at present. Instead, %SEARCH% is used with a special template to show the text to be changed, and the selected topics are then altered. One drawback is thatsearch
can show matches that will not be updated due to case differences. Other mismatches with actual rendered output are also possible as the approaches are so different.
The following shows some limitations of square bracket processing.
[[Old Topic]] => [[NewTopic][Old Topic]] [[old topic]] => [[NewTopic][old topic]] [[old t opic]] => not changed [[OldTopic]] => [[NewTopic]]
Reviewing and Reverting
Foswiki's revision control saves all topic changes. To view earlier versions of a topic, click on theHistory
link in topic actions. If you would like to revert to an earlier version or reclaim part of an earlier version, just copy from the old topic revision to the current topic revision as follows: - In the
History
view, click the revision number you want to reclaim from - Select and copy to clipboard either the portion of that version you want to reclaim or the entire text of the topic if you want to revert completely to that version.
- Edit the topic and paste in the portion you wish to reclaim or replace the entire text with the text you copied from the earlier version.
- Save the topic.
Related Topics: UserDocumentationCategory, AdminDocumentationCategory