HoTMetal中使用javascript
5.怎样编写脚本来检查上次修改的日期
在本节教程中你将可以学到怎样编写一个宏来检查是否有任何的程序已经利用HoTMetaL中修改过一个文件。这个宏包括了以下几个检查的更新特性:On_Document_Open_Complete、On_Document_Activate和 On_Application_Activate。在前面的教程中,这些宏的名字已经被预定义了,所以这里不能对它们进行修改。这些名字指定了事件来触发宏。这个event-macro关联是隐含的,所以不能通过任何手段来对它进行改写。当我们打开一个文档的时候,比如On_Document_Open_Complete,它总是在完成文件打开的时候被调用的。以下是具体的定义:
var name = ActiveDocument.LocalFullName;
if (Application.ReadableFileExists(name)) { // if document has never been saved, do nothing
Application.Run("On_Document_Save");
}
]]>
我们首先提取当前文件夹的文件名:name = ActiveDocument.LocalFullName,然后检查可读的文件是否存在;接着我们运行宏On_Document_Save,这个宏On_Document_Save示范了微软的FileSystemObject作为ActiveX控件的使用方法,这是一个在JavaScript中。这个宏的主要思想是更新文档的LastMod属性以反应磁盘上文档的当前事件:
var fso = new ActiveXObject("Scripting.FileSystemObject");
var f = fso.GetFile(ActiveDocument.LocalFullName);
var mod = Date.parse(f.DateLastModified);
var props = ActiveDocument.CustomDocumentProperties;
if (props.count != 0) {
props.Add("LastMod", mod);
}
]]>
这个宏从FileSystemObject创建了一个ActiveX控件,它包括了微软的脚本库: var fso = new ActiveXObject("Scripting.FileSystemObject");
我们可以通过以下的语句来从磁盘得到文件的属性:f = fso.GetFile(name),然后提取出文件最后一次修改的事件:mod = Date.parse(f.DateLastModified)。我们通过调用ActiveDocument的CustomDocumentProperties 属性来创建了一个用户定义的属性集:props。然后我们利用mod属性来对这个集进行初始化,这时它的数值为"LastMode"。
Using Javascript in HoTMetal
5. How to write a script to check the last modified date
This On_Document_Activate macro checks whether the file on the disk is the same as the current document edited using HoTMetaL The date of last modification. It prompts the user what to do in case the dates do not match. The following is the specific code of this macro:
desc="Runs Macro: Hide_On_Document_Activate ">
// Do this for local documents only
if (ActiveDocument.FullName == ActiveDocument.LocalFullName) {
var name = ActiveDocument.LocalFullName;
if (Application.ReadableFileExists(name)) { // if document has never been saved, do nothing
var fso = new ActiveXObject("Scripting.FileSystemObject");
var f = fso.GetFile(name);
var newMod = Date.parse(f.DateLastModified);
var props = ActiveDocument.CustomDocumentProperties;
if (props.count != 0) {
oldMod = props.Item("LastMod").value;
if (oldMod != newMod) {
var Yes = 6;
var No = 7;
var msg = "The disk version of this document has changed from then";
msg = "version in memory. Do you want to re-open the document?";
var ret = Application.MessageBox(msg, 36, "Document Changed");
if (ret == Yes ) {
ActiveDocument.Reload();
}
// Reset the timestamp regardless of the user's response
// This will prevent the dialog from always showing
Application.Run("On_Document_Open_Complete");
}
}
}
}
]]>
Let’s check whether the file is loaded: ActiveDocument.FullName == ActiveDocument.LocalFullName. Then we verify whether the file is saved to disk: Application.ReadableFileExists(name). Similar to the previous On_Document_Open_Complete macro, we create an ActiveX control and extract the last modified date of the file. The code is as follows:
var fso = new ActiveXObject("Scripting.FileSystemObject");
var f = fso.GetFile(name);
var newMod = Date.parse(f.DateLastModified);
Using Javascript in HoTMetal
5. How to write a script to check the last modified date
Next, we call the custom property set of the current document: props = ActiveDocument.CustomDocumentProperties and check this property Whether the number is not equal to zero. We have saved it in the previous On_Document_Open_Complete macro and assigned it to oldMod:
oldMod = props.Item("LastMod").value
When we find oldMod (from open documentation) and newMod (from disk), we should tell the user whether the file was copied from disk:
var Yes = 6;
var No = 7 ;
var msg = "The disk version of this document has changed from then";
msg = "version in memory. Do you want to re-open the document?";
var ret = Application.MessageBox(msg, 36, "Document Changed");
if (ret == Yes) {
ActiveDocument.Reload();
}
Finally, we reset the date of the current document by mimicking an open action:
Application.Run("On_Document_Open_Complete");
We want to extend This update feature is checked and triggered regardless of when the document is current or when the application is current. At this time we can define the On_Application_Activate macro, which just calls the above macro:
Application .Run("On_Document_Activate");
]]>
Now we need to copy the On_Document_Save function to the On_Document_SaveAs macro:
Application.Run("On_Document_Save");
]]>
Finally, let’s test it. First open a document in HotMetaL PRO 6.0. and open the same document in your favorite editor. and insert a space character anywhere before saving it to disk. When you switch to the HoTMetaL application, you will get the information shown in Figure 1.
(Picture 1)