update
This commit is contained in:
parent
0427e0bf8f
commit
729b7b552b
@ -2,42 +2,42 @@
|
||||
<?xml-stylesheet href="chrome://linktargetfinder/skin/skin.css" type="text/css"?>
|
||||
<!DOCTYPE firerecord SYSTEM "chrome://firerecord/locale/translations.dtd">
|
||||
<overlay id="sample" xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul">
|
||||
<script src="firerecord.js" />
|
||||
<script src="firerecord.js" />
|
||||
|
||||
<menupopup id="menu_ToolsPopup">
|
||||
<menuitem label="&runlinktargetfinder;" key="link-target-finder-run-key" oncommand="firerecord.run()"/>
|
||||
</menupopup>
|
||||
<toolbox>
|
||||
<menubar id="xulschoolhello-menubar">
|
||||
<menu id="xulschoolhello-greeting-menu" label="testing">
|
||||
<menupopup>
|
||||
<menuitem label="Nothing Yet"
|
||||
oncommand ="firerecord.file()"/>
|
||||
<menupopup id="menu_ToolsPopup">
|
||||
<menuitem label="&runlinktargetfinder;" key="link-target-finder-run-key" oncommand="firerecord.running()"/>
|
||||
</menupopup>
|
||||
<toolbox>
|
||||
<menubar id="xulschoolhello-menubar">
|
||||
<menu id="xulschoolhello-greeting-menu" label="testing">
|
||||
<menupopup>
|
||||
<menuitem label="Choose Text File"
|
||||
oncommand ="firerecord.file()"/>
|
||||
|
||||
</menupopup>
|
||||
</menupopup>
|
||||
|
||||
|
||||
|
||||
</menu>
|
||||
</menubar>
|
||||
</toolbox>
|
||||
<keyset>
|
||||
<key id="link-target-finder-run-key" modifiers="accel alt shift" key="L" oncommand="firerecord.run()"/>
|
||||
</keyset>
|
||||
</menu>
|
||||
</menubar>
|
||||
</toolbox>
|
||||
<keyset>
|
||||
<key id="link-target-finder-run-key" modifiers="accel alt shift" key="L" oncommand="firerecord.running()"/>
|
||||
</keyset>
|
||||
|
||||
<toolbar id="status-bar">
|
||||
<statusbarpanel id="link-target-finder-status-bar-icon" label="Record" class="statusbarpanel-iconic" src="chrome://firerecord/skin/toolbar-large.png" tooltiptext="&runlinktargetfinder;" onclick="firerecord.run()" />
|
||||
<toolbar id="status-bar">
|
||||
<statusbarpanel id="link-target-finder-status-bar-icon" label="Record" class="statusbarpanel-iconic" src="chrome://firerecord/skin/toolbar-large.png" tooltiptext="&runlinktargetfinder;" onclick="firerecord.running()" />
|
||||
|
||||
</toolbar>
|
||||
<toolbar id="status-bar">
|
||||
<statusbarpanel id="Recording" type="menu" role="button" label="Record" class="statusbarpanel-iconic" src="chrome://firerecord/skin/toolbar-large.png" tooltiptext="Page to Page Recording" onclick="firerecord.running()" />
|
||||
</toolbar>
|
||||
<toolbar id="status-bar">
|
||||
<statusbarpanel id="Recording" type="menu" role="button" label="Record" class="statusbarpanel-iconic" src="chrome://firerecord/skin/toolbar-large.png" tooltiptext="Page to Page Recording" onclick="firerecord.running()" />
|
||||
|
||||
</toolbar>
|
||||
</toolbar>
|
||||
|
||||
<toolbarpalette id="BrowserToolbarPalette">
|
||||
<toolbarbutton id="link-target-finder-toolbar-button" label="firerecord:" class="statusbarpanel-iconic" src="chrome://firerecord/skin/toolbar-large.png" tooltiptext="&runlinktargetfinder;" oncommand="firerecord.running()"/>
|
||||
</toolbarpalette>
|
||||
|
||||
<toolbarpalette id="BrowserToolbarPalette">
|
||||
<toolbarbutton id="link-target-finder-toolbar-button" label="firerecord:" class="statusbarpanel-iconic" src="chrome://firerecord/skin/toolbar-large.png" tooltiptext="&runlinktargetfinder;" oncommand="firerecord.run()"/>
|
||||
</toolbarpalette>
|
||||
|
||||
<input type="file" id="upload" name="upload"/>
|
||||
|
||||
</overlay>
|
@ -1,4 +1,6 @@
|
||||
var recordingx = false;
|
||||
var path = null;
|
||||
|
||||
|
||||
window.addEventListener("load", function load(event) {
|
||||
window.removeEventListener("load", load, false); //remove listener, no longer needed
|
||||
@ -14,25 +16,41 @@ var firerecord = function () {
|
||||
appcontent.addEventListener("DOMContentLoaded", firerecord.run, true);
|
||||
}
|
||||
},
|
||||
running: function () {
|
||||
if (recordingx) {
|
||||
recordingx = false;
|
||||
alert("Stop Listen");
|
||||
//document.location.reload();
|
||||
//closes all tabs on firefox.
|
||||
}
|
||||
else {
|
||||
recordingx = true;
|
||||
alert("Start Listen");
|
||||
firerecord.run();
|
||||
}
|
||||
running: function (){
|
||||
if(recordingx){
|
||||
recordingx = false;
|
||||
alert("Stop Listen");
|
||||
|
||||
},
|
||||
file: function () {
|
||||
//document.location.reload();
|
||||
//closes all tabs on firefox.
|
||||
}
|
||||
else{
|
||||
recordingx = true;
|
||||
alert("Start Listen");
|
||||
//createFile("Initialize New Test File");
|
||||
firerecord.run();
|
||||
}
|
||||
|
||||
},
|
||||
file: function(){
|
||||
const nsIFilePicker = Components.interfaces.nsIFilePicker;
|
||||
|
||||
},
|
||||
run: function () {
|
||||
var fp = Components.classes["@mozilla.org/filepicker;1"]
|
||||
.createInstance(nsIFilePicker);
|
||||
fp.init(window, "Dialog Title", nsIFilePicker.modeOpen);
|
||||
fp.appendFilters(nsIFilePicker.filterAll | nsIFilePicker.filterText);
|
||||
|
||||
var rv = fp.show();
|
||||
if (rv == nsIFilePicker.returnOK || rv == nsIFilePicker.returnReplace) {
|
||||
var file = fp.file;
|
||||
// Get the path as string. Note that you usually won't
|
||||
// need to work with the string paths.
|
||||
path = fp.file.path;
|
||||
// work with returned nsILocalFile...
|
||||
|
||||
}
|
||||
},
|
||||
run : function () {
|
||||
var head = content.document.getElementsByTagName("head")[0],
|
||||
style = content.document.getElementById("link-target-finder-style"),
|
||||
all = content.document.getElementsByTagName("*"),
|
||||
@ -64,67 +82,67 @@ var firerecord = function () {
|
||||
info[0] = all[i].tagName;
|
||||
|
||||
//Feel free to change this to a for each...
|
||||
if (recordingx) {
|
||||
switch (info[0]) {
|
||||
//All of these cases need null checks for each attribute.
|
||||
case "INPUT":
|
||||
if(recordingx){
|
||||
switch (info[0]) {
|
||||
//All of these cases need null checks for each attribute.
|
||||
case "INPUT":
|
||||
|
||||
elm.className += ((elm.className.length > 0) ? " " : "") + "link-target-finder-selected";
|
||||
elm.addEventListener("click", handleType, false);
|
||||
break;
|
||||
case "A":
|
||||
elm.className += ((elm.className.length > 0) ? " " : "") + "link-target-finder-selected";
|
||||
elm.addEventListener("click", handleType, false);
|
||||
break;
|
||||
case "A":
|
||||
|
||||
elm.addEventListener("click", handleEvent);
|
||||
elm.className += ((elm.className.length > 0) ? " " : "") + "link-target-finder-selected";
|
||||
elm.addEventListener("click", handleEvent, false);
|
||||
break;
|
||||
case "BUTTON":
|
||||
elm.addEventListener("click", handleEvent);
|
||||
elm.className += ((elm.className.length > 0) ? " " : "") + "link-target-finder-selected";
|
||||
elm.addEventListener("click", handleEvent, false);
|
||||
break;
|
||||
case "BUTTON":
|
||||
|
||||
elm.className += ((elm.className.length > 0) ? " " : "") + "link-target-finder-selected";
|
||||
elm.addEventListener("click", handleEvent, false);
|
||||
break;
|
||||
case "FORM":
|
||||
elm.className += ((elm.className.length > 0) ? " " : "") + "link-target-finder-selected";
|
||||
elm.addEventListener("click", handleEvent, false);
|
||||
break;
|
||||
case "FORM":
|
||||
|
||||
elm.className += ((elm.className.length > 0) ? " " : "") + "link-target-finder-selected";
|
||||
elm.addEventListener("click", handleEvent, false);
|
||||
break;
|
||||
case "IMG":
|
||||
elm.className += ((elm.className.length > 0) ? " " : "") + "link-target-finder-selected";
|
||||
elm.addEventListener("click", handleEvent, false);
|
||||
break;
|
||||
case "IMG":
|
||||
|
||||
elm.className += ((elm.className.length > 0) ? " " : "") + "link-target-finder-selected";
|
||||
elm.addEventListener("click", handleEvent, false);
|
||||
break;
|
||||
case "INPUT":
|
||||
elm.className += ((elm.className.length > 0) ? " " : "") + "link-target-finder-selected";
|
||||
elm.addEventListener("click", handleEvent, false);
|
||||
break;
|
||||
case "INPUT":
|
||||
|
||||
elm.className += ((elm.className.length > 0) ? " " : "") + "link-target-finder-selected";
|
||||
elm.addEventListener("click", handleEvent, false);
|
||||
break;
|
||||
case "LINK":
|
||||
elm.className += ((elm.className.length > 0) ? " " : "") + "link-target-finder-selected";
|
||||
elm.addEventListener("click", handleEvent, false);
|
||||
break;
|
||||
case "LINK":
|
||||
|
||||
elm.className += ((elm.className.length > 0) ? " " : "") + "link-target-finder-selected";
|
||||
elm.addEventListener("click", handleEvent, false);
|
||||
break;
|
||||
case "OPTION":
|
||||
elm.className += ((elm.className.length > 0) ? " " : "") + "link-target-finder-selected";
|
||||
elm.addEventListener("click", handleEvent, false);
|
||||
break;
|
||||
case "OPTION":
|
||||
|
||||
elm.className += ((elm.className.length > 0) ? " " : "") + "link-target-finder-selected";
|
||||
elm.addEventListener("click", handleEvent, false);
|
||||
break;
|
||||
case "SELECT":
|
||||
elm.className += ((elm.className.length > 0) ? " " : "") + "link-target-finder-selected";
|
||||
elm.addEventListener("click", handleEvent, false);
|
||||
break;
|
||||
case "SELECT":
|
||||
|
||||
elm.className += ((elm.className.length > 0) ? " " : "") + "link-target-finder-selected";
|
||||
elm.addEventListener("click", handleEvent, false);
|
||||
break;
|
||||
case "TABLE":
|
||||
info[1] = all[i].getAttribute("summmary");
|
||||
info[2] = all[i].getAttribute("caption");
|
||||
elm.className += ((elm.className.length > 0) ? " " : "") + "link-target-finder-selected";
|
||||
elm.addEventListener("click", handleEvent, false);
|
||||
break;
|
||||
case "TEXTAREA":
|
||||
elm.className += ((elm.className.length > 0) ? " " : "") + "link-target-finder-selected";
|
||||
elm.addEventListener("click", handleEvent, false);
|
||||
break;
|
||||
elm.className += ((elm.className.length > 0) ? " " : "") + "link-target-finder-selected";
|
||||
elm.addEventListener("click", handleEvent, false);
|
||||
break;
|
||||
case "TABLE":
|
||||
info[1] = all[i].getAttribute("summmary");
|
||||
info[2] = all[i].getAttribute("caption");
|
||||
elm.className += ((elm.className.length > 0) ? " " : "") + "link-target-finder-selected";
|
||||
elm.addEventListener("click", handleEvent, false);
|
||||
break;
|
||||
case "TEXTAREA":
|
||||
elm.className += ((elm.className.length > 0) ? " " : "") + "link-target-finder-selected";
|
||||
elm.addEventListener("click", handleEvent, false);
|
||||
break;
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
@ -136,7 +154,7 @@ var firerecord = function () {
|
||||
};
|
||||
|
||||
//Need to add author to this part...
|
||||
//Need to add author to this part...
|
||||
//Need to add author to this part...
|
||||
function handleEvent(e) {
|
||||
var targ;
|
||||
if (!e) {
|
||||
@ -151,6 +169,10 @@ var firerecord = function () {
|
||||
|
||||
//---------------------------------------------------------------------
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
//_____________________________________________________________________
|
||||
var tname;
|
||||
var taginfo = new Array();
|
||||
@ -223,25 +245,58 @@ var firerecord = function () {
|
||||
}
|
||||
|
||||
alert(window.content.location.href);
|
||||
if (!taginfo[1]) {
|
||||
taginfo[1] = "null";
|
||||
if(!taginfo[1]){
|
||||
//taginfo[1]= "null";
|
||||
}
|
||||
if (!taginfo[2]) {
|
||||
taginfo[2] = "null";
|
||||
if(!taginfo[2]){
|
||||
//taginfo[2]= "null";
|
||||
}
|
||||
if (!taginfo[3]) {
|
||||
taginfo[3] = "null";
|
||||
if(!taginfo[3]){
|
||||
//taginfo[3]= "null";
|
||||
}
|
||||
if (!taginfo[4]) {
|
||||
taginfo[4] = "null";
|
||||
if(!taginfo[4]){
|
||||
//taginfo[4]= "null";
|
||||
}
|
||||
alert("You clicked on a " + tname + " with info \n " + taginfo[1] + "\n" + taginfo[2] + "\n" + taginfo[3] + "\n" + " saving... " + taginfo.join('::'));
|
||||
var contents = "You clicked on a " + tname + " with info \n "+ taginfo.join(' :: ')+"\n";
|
||||
|
||||
appendFile(contents);
|
||||
e.cancelBubble = true;
|
||||
|
||||
};
|
||||
|
||||
}();
|
||||
function createFile(contents) {
|
||||
|
||||
alert("created File");
|
||||
var file1 = Components.classes["@mozilla.org/file/local;1"].createInstance(Components.interfaces.nsILocalFile);
|
||||
file1.initWithPath("C:\\test\\" + "test.txt");
|
||||
//alert("create file nullcheck" +file1.toString());
|
||||
var foStream = Components.classes["@mozilla.org/network/file-output-stream;1"].createInstance(Components.interfaces.nsIFileOutputStream);
|
||||
// use 0x02 | 0x10 to open file for appending.
|
||||
foStream.init(file1, 0x02 | 0x08 | 0x20, 438, 0);
|
||||
var converter = Components.classes["@mozilla.org/intl/converter-output-stream;1"].
|
||||
createInstance(Components.interfaces.nsIConverterOutputStream);
|
||||
converter.init(foStream, "UTF-8", 0, 0);
|
||||
converter.writeString(contents.toString());
|
||||
converter.close(); // this closes foStream
|
||||
}
|
||||
|
||||
function appendFile(contents) {
|
||||
|
||||
alert("appended File");
|
||||
var file1 = Components.classes["@mozilla.org/file/local;1"].createInstance(Components.interfaces.nsILocalFile);
|
||||
file1.initWithPath(path);
|
||||
//alert("append file nullcheck: "+file1.toString());
|
||||
var foStream = Components.classes["@mozilla.org/network/file-output-stream;1"].createInstance(Components.interfaces.nsIFileOutputStream);
|
||||
// use 0x02 | 0x10 to open file for appending.
|
||||
foStream.init(file1, 0x02 | 0x10, 438, 0);
|
||||
var converter = Components.classes["@mozilla.org/intl/converter-output-stream;1"].
|
||||
createInstance(Components.interfaces.nsIConverterOutputStream);
|
||||
converter.init(foStream, "UTF-8", 0, 0);
|
||||
|
||||
converter.writeString(contents);
|
||||
converter.close();
|
||||
}
|
||||
function handleType(e) {
|
||||
var targ;
|
||||
if (!e) {
|
||||
|
@ -5,27 +5,27 @@
|
||||
title="FireRecord Preferences"
|
||||
xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul">
|
||||
|
||||
<prefpane label="FireRecord Preferences">
|
||||
<preferences>
|
||||
<preference id="link-target-finder-autorun" name="extensions.firerecord.autorun" type="bool"/>
|
||||
</preferences>
|
||||
<prefpane label="FireRecord Preferences">
|
||||
<preferences>
|
||||
<preference id="link-target-finder-autorun" name="extensions.firerecord.autorun" type="bool"/>
|
||||
</preferences>
|
||||
|
||||
<groupbox>
|
||||
<caption label="Settings"/>
|
||||
<grid>
|
||||
<columns>
|
||||
<column flex="4"/>
|
||||
<column flex="1"/>
|
||||
</columns>
|
||||
<rows>
|
||||
<row>
|
||||
<label control="autorun" value="Autorun"/>
|
||||
<checkbox id="autorun" preference="link-target-finder-autorun"/>
|
||||
</row>
|
||||
</rows>
|
||||
</grid>
|
||||
</groupbox>
|
||||
<groupbox>
|
||||
<caption label="Settings"/>
|
||||
<grid>
|
||||
<columns>
|
||||
<column flex="4"/>
|
||||
<column flex="1"/>
|
||||
</columns>
|
||||
<rows>
|
||||
<row>
|
||||
<label control="autorun" value="Autorun"/>
|
||||
<checkbox id="autorun" preference="link-target-finder-autorun"/>
|
||||
</row>
|
||||
</rows>
|
||||
</grid>
|
||||
</groupbox>
|
||||
|
||||
</prefpane>
|
||||
</prefpane>
|
||||
|
||||
</prefwindow>
|
Reference in New Issue
Block a user