mirror of
https://github.com/mozilla/gecko-dev.git
synced 2025-02-14 20:22:00 +00:00
more changes for the new subscribe dialog.
This commit is contained in:
parent
a0b141afcc
commit
9e2b1200cd
@ -273,11 +273,16 @@ function SubscribeOKCallback(serverURI, changeTable)
|
||||
|
||||
for (var name in changeTable) {
|
||||
dump(name + " = " + changeTable[name] + "\n");
|
||||
if (changeTable[name] == 1) {
|
||||
if (changeTable[name] == true) {
|
||||
dump("subscribe to " + name +"\n");
|
||||
// should this be SubscribeFolder()?
|
||||
NewFolder(name,serverURI);
|
||||
}
|
||||
else if (changeTable[name] == -1) {
|
||||
dump("unsuscribe\n");
|
||||
else if (changeTable[name] == false) {
|
||||
dump("unsubscribe to " + name +"\n");
|
||||
}
|
||||
else {
|
||||
dump("no change to " + name + "\n");
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1,11 +1,9 @@
|
||||
var gSubscribeTree = null;
|
||||
var gCurrentServer = null;
|
||||
var okCallback = null;
|
||||
var gChangeTable = {};
|
||||
var gServerURI = null;
|
||||
var RDF = null;
|
||||
var SubscribeDS = null;
|
||||
var gCurrentServerURI = null;
|
||||
var gSubscribeDS = null;
|
||||
|
||||
function Stop()
|
||||
{
|
||||
@ -13,23 +11,45 @@ function Stop()
|
||||
dump("we need to stop the news url that is running.\n");
|
||||
}
|
||||
|
||||
function onServerClick(event)
|
||||
{
|
||||
var item = event.target;
|
||||
gServerURI = item.id;
|
||||
|
||||
SetUpTree();
|
||||
}
|
||||
|
||||
function SetUpServerMenu()
|
||||
{
|
||||
dump("SetUpServerMenu()\n");
|
||||
|
||||
var serverMenu = document.getElementById("serverMenu");
|
||||
var menuitems = serverMenu.getElementsByAttribute("id", gServerURI);
|
||||
|
||||
serverMenu.selectedItem = menuitems[0];
|
||||
}
|
||||
|
||||
function SetUpTree()
|
||||
{
|
||||
dump("SetUpTree()\n");
|
||||
|
||||
var folder = GetMsgFolderFromUri(gServerURI);
|
||||
var server = folder.server;
|
||||
|
||||
/* todo: this should be server.buildSubscribeDatasource() which does the right thing with its server. for imap */
|
||||
var nntpService = Components.classes['component://netscape/messenger/nntpservice'].getService(Components.interfaces.nsINntpService);
|
||||
nntpService = nntpService.QueryInterface(Components.interfaces.nsINntpService);
|
||||
nntpService.buildSubscribeDatasource(gCurrentServer);
|
||||
nntpService.buildSubscribeDatasource(server);
|
||||
|
||||
gCurrentServerURI = "news://" + gCurrentServer.hostName;
|
||||
dump("root subscribe tree at: "+gCurrentServerURI+"\n");
|
||||
gSubscribeTree.setAttribute('ref',gCurrentServerURI);
|
||||
dump("root subscribe tree at: "+ gServerURI +"\n");
|
||||
gSubscribeTree.setAttribute('ref',gServerURI);
|
||||
}
|
||||
|
||||
function SubscribeOnLoad()
|
||||
{
|
||||
dump("SubscribeOnLoad()\n");
|
||||
|
||||
gSubscribeTree = document.getElementById('subscribetree');
|
||||
gSubscribeTree = document.getElementById('subscribetree');
|
||||
|
||||
doSetOKCancel(subscribeOK,subscribeCancel);
|
||||
|
||||
@ -45,21 +65,25 @@ function SubscribeOnLoad()
|
||||
}
|
||||
|
||||
if (window.arguments[0].preselectedURI) {
|
||||
gServerURI = window.arguments[0].preselectedURI;
|
||||
dump("subscribe: got a uri," + gServerURI + "\n");
|
||||
folder = GetMsgFolderFromUri(window.arguments[0].preselectedURI);
|
||||
gCurrentServer = folder.server;
|
||||
|
||||
SetUpTree();
|
||||
|
||||
RDF = Components.classes["component://netscape/rdf/rdf-service"].getService();
|
||||
RDF = RDF.QueryInterface(Components.interfaces.nsIRDFService);
|
||||
|
||||
SubscribeDS = RDF.GetDataSource("rdf:subscribe");
|
||||
var uri = window.arguments[0].preselectedURI;
|
||||
dump("subscribe: got a uri," + uri + "\n");
|
||||
folder = GetMsgFolderFromUri(uri);
|
||||
gServerURI = folder.server.serverURI;
|
||||
}
|
||||
else {
|
||||
dump("subscribe: no uri\n");
|
||||
var serverMenu = document.getElementById("serverMenu");
|
||||
var menuitems = serverMenu.getElementsByTagName("menuitem");
|
||||
gServerURI = menuitems[1].id;
|
||||
}
|
||||
|
||||
SetUpServerMenu();
|
||||
SetUpTree();
|
||||
|
||||
RDF = Components.classes["component://netscape/rdf/rdf-service"].getService();
|
||||
RDF = RDF.QueryInterface(Components.interfaces.nsIRDFService);
|
||||
|
||||
gSubscribeDS = RDF.GetDataSource("rdf:subscribe");
|
||||
}
|
||||
|
||||
function subscribeOK()
|
||||
@ -78,24 +102,23 @@ function subscribeCancel()
|
||||
return true;
|
||||
}
|
||||
|
||||
function SetState(uri, state)
|
||||
function SetState(uri,state,stateStr)
|
||||
{
|
||||
dump("SetState(" + uri +"," + state + ")\n");
|
||||
if (!uri || !state) return;
|
||||
dump("SetState(" + uri +"," + state + "," + stateStr + ")\n");
|
||||
if (!uri || !stateStr) return;
|
||||
|
||||
try {
|
||||
var src = RDF.GetResource(uri, true);
|
||||
var prop = RDF.GetResource("http://home.netscape.com/NC-rdf#Subscribed", true);
|
||||
var oldLiteral = SubscribeDS.GetTarget(src, prop, true);
|
||||
var newLiteral = RDF.GetLiteral(state);
|
||||
var oldLiteral = gSubscribeDS.GetTarget(src, prop, true);
|
||||
dump("oldLiteral="+oldLiteral+"\n");
|
||||
|
||||
if (oldLiteral) {
|
||||
dump("oldLiteral.Value="+oldLiteral.Value+"\n");
|
||||
SubscribeDS.Change(src, prop, oldLiteral, newLiteral);
|
||||
}
|
||||
else {
|
||||
SubscribeDS.Assert(src,prop, newLiteral, true);
|
||||
oldValue = oldLiteral.QueryInterface(Components.interfaces.nsIRDFLiteral).Value;
|
||||
dump("oldLiteral.Value="+oldValue+"\n");
|
||||
if (oldValue != stateStr) {
|
||||
var newLiteral = RDF.GetLiteral(stateStr);
|
||||
gSubscribeDS.Change(src, prop, oldLiteral, newLiteral);
|
||||
StateChanged(name,state);
|
||||
}
|
||||
}
|
||||
catch (ex) {
|
||||
@ -106,26 +129,38 @@ function SetState(uri, state)
|
||||
function StateChanged(name,state)
|
||||
{
|
||||
dump("StateChanged(" + name + "," + state + ")\n");
|
||||
if (!gChangeTable[name]) {
|
||||
gChangeTable[name] = 0;
|
||||
}
|
||||
dump("start val=" +gChangeTable[name] + "\n");
|
||||
|
||||
if (state == 'true') {
|
||||
gChangeTable[name] = gChangeTable[name] + 1;
|
||||
if (gChangeTable[name] == undefined) {
|
||||
dump(name+" not in table yet\n");
|
||||
gChangeTable[name] = state;
|
||||
}
|
||||
else {
|
||||
gChangeTable[name] = gChangeTable[name] - 1;
|
||||
var oldValue = gChangeTable[name];
|
||||
dump(name+" already in table\n");
|
||||
if (oldValue != state) {
|
||||
gChangeTable[name] = undefined;
|
||||
}
|
||||
}
|
||||
dump(gChangeTable[name] + "\n");
|
||||
|
||||
dump("end val=" +gChangeTable[name] + "\n");
|
||||
}
|
||||
|
||||
function SetSubscribeState(state)
|
||||
{
|
||||
dump("SetSubscribedState()\n");
|
||||
|
||||
var stateStr;
|
||||
if (state) {
|
||||
stateStr = 'true';
|
||||
}
|
||||
else {
|
||||
stateStr = 'false';
|
||||
}
|
||||
|
||||
try {
|
||||
dump("subscribe button clicked\n");
|
||||
|
||||
|
||||
var groupList = gSubscribeTree.selectedItems;
|
||||
for (i=0;i<groupList.length;i++) {
|
||||
group = groupList[i];
|
||||
@ -133,8 +168,7 @@ function SetSubscribeState(state)
|
||||
dump(uri + "\n");
|
||||
name = group.getAttribute('name');
|
||||
dump(name + "\n");
|
||||
SetState(uri, state);
|
||||
StateChanged(name,state);
|
||||
SetState(uri,state,stateStr);
|
||||
}
|
||||
}
|
||||
catch (ex) {
|
||||
@ -142,10 +176,17 @@ function SetSubscribeState(state)
|
||||
}
|
||||
}
|
||||
|
||||
function ReverseState(uri)
|
||||
{
|
||||
dump("ReverseState("+uri+")\n");
|
||||
}
|
||||
|
||||
function SubscribeOnClick(event)
|
||||
{
|
||||
dump("subscribe tree clicked\n");
|
||||
dump(event.target.parentNode.parentNode.getAttribute("id") + "\n");
|
||||
if (event.clickCount == 2) {
|
||||
var uri = event.target.parentNode.parentNode.getAttribute("id");
|
||||
ReverseState(uri);
|
||||
}
|
||||
}
|
||||
|
||||
function RefreshList()
|
||||
|
@ -45,24 +45,18 @@ Rights Reserved.
|
||||
|
||||
<box orient="horizontal" flex="100%">
|
||||
<box orient="vertical" flex="100%">
|
||||
<box orient="horizontal" flex="100%">
|
||||
<text class="label" value="&server.label;" for="currentserver"/>
|
||||
<menulist id="currentserver" value="...">
|
||||
<menupopup>
|
||||
<menuitem value="news.mozilla.org" uri="news://news.mozilla.org" />
|
||||
<menuitem value="news.fresmeat.net" uri="news://news.freshmeat.net" />
|
||||
<menuitem value="news.mcom.com" uri="news://news.mcom.com" />
|
||||
<!--
|
||||
<menupopup datasources="rdf:msgaccountmanager" ref="msgaccounts:/">
|
||||
<template>
|
||||
<rule>
|
||||
<menuitem value="..."/>
|
||||
</rule>
|
||||
</template>
|
||||
-->
|
||||
</menupopup>
|
||||
</menulist>
|
||||
</box>
|
||||
<box orient="horizontal">
|
||||
<text value="&server.label;"/>
|
||||
<menulist oncommand="onServerClick(event);" id="serverMenu">
|
||||
<menupopup rdf:datasources="rdf:msgaccountmanager"
|
||||
rdf:containment="http://home.netscape.com/NC-rdf#child"
|
||||
ref="msgaccounts:/">
|
||||
<template>
|
||||
<menuitem uri="..." value="rdf:http://home.netscape.com/NC-rdf#Name"/>
|
||||
</template>
|
||||
</menupopup>
|
||||
</menulist>
|
||||
</box>
|
||||
<box orient="horizontal" flex="100%">
|
||||
<text class="label" value="&folders.label;" for="name"/>
|
||||
<textfield id="name"/>
|
||||
@ -109,8 +103,8 @@ Rights Reserved.
|
||||
</box>
|
||||
<box orient="vertical" flex="20%">
|
||||
<spring flex="100%"/>
|
||||
<titledbutton id="subscribe" class="push" value="&subscribeButton.label;" onclick="SetSubscribeState('true')"/>
|
||||
<titledbutton id="unsubscribe" class="push" value="&unsubscribeButton.label;" onclick="SetSubscribeState('false')"/>
|
||||
<titledbutton id="subscribe" class="push" value="&subscribeButton.label;" onclick="SetSubscribeState(true)"/>
|
||||
<titledbutton id="unsubscribe" class="push" value="&unsubscribeButton.label;" onclick="SetSubscribeState(false)"/>
|
||||
<titledbutton id="refresh" class="push" value="&refreshButton.label;" onclick="RefreshList()"/>
|
||||
<titledbutton id="stop" class="push" value="&stopButton.label;" onclick="Stop()"/>
|
||||
<spring flex="100%"/>
|
||||
|
Loading…
x
Reference in New Issue
Block a user