File: userprops.html.html

package info (click to toggle)
jwchat 1.0beta2-13
  • links: PTS
  • area: main
  • in suites: etch, etch-m68k
  • size: 5,200 kB
  • ctags: 405
  • sloc: xml: 462; sh: 80; makefile: 6
file content (151 lines) | stat: -rw-r--r-- 4,755 bytes parent folder | download | duplicates (5)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
    <title>JWChat - User Properties</title>
    <meta http-equiv="content-type" content="text/html; charset=utf-8">
    <script src="shared.js"></script>
    <script src="switchStyle.js"></script>
    <script src="xmlextras.js"></script>
    <script src="JSJaCPacket.js"></script>
    <script>
      <!--
var jid; 
var srcW;
var user; 
var allgrpbox; 
var curgrpbox;

function submitClicked() {
	var iq = new JSJaCIQ();
	iq.setType('set');
	var query = iq.setQuery('jabber:iq:roster');

	var aItem = query.appendChild(iq.getDoc().createElement('item'));
	aItem.setAttribute('jid',jid);
	aItem.setAttribute('name',document.userprops.nickname.value);

  if (curgrpbox.length > 0) {
    for (var i=0; i<curgrpbox.length; i++)
			aItem.appendChild(iq.getDoc().createElement('group')).appendChild(iq.getDoc().createTextNode(curgrpbox.options[i].value));
  }

	srcW.con.syncSend(iq);
  window.close();
}

function addgroup() {
  if (document.userprops.newgrp.value != '') {
    for (var i=0; i<curgrpbox.length; i++) {
      if (curgrpbox.options[i].value == document.userprops.newgrp.value)
        return false; // nothin to do
    }
    curgrpbox.options[curgrpbox.length] = new Option(document.userprops.newgrp.value,document.userprops.newgrp.value);
  }
  return false;
}

function remgroup() {
  if(curgrpbox.selectedIndex < 0)
    return false;
  curgrpbox.options[curgrpbox.selectedIndex] = null;
  return false;
}

function setNewGrp(idx) {
  document.userprops.newgrp.value = allgrpbox.options[idx].value;
}

function init() {
  // determine source window
  if (opener.roster)
    srcW = opener.top;
  else
    srcW = opener.opener.top;
  
  getArgs();
  jid = passedArgs['jid'];
  document.title = "Edit properties for "+jid;
  document.getElementById('nickjid').innerHTML = jid;
  document.getElementById('groupjid').innerHTML = jid;
  user = srcW.roster.getUserByJID(jid);
  curgrpbox = document.userprops.curgrps;
  allgrpbox = document.userprops.allgrps
    for (var i in user.groups) {
      if (user.groups[i] != '') {
        curgrpbox.options[curgrpbox.length] = new Option(user.groups[i],user.groups[i]);
      }
    }
  
  for (var i in srcW.roster.groups) {
    if (srcW.roster.groups[i].name != "Unfiled") {
      allgrpbox.options[allgrpbox.length] = new Option(srcW.roster.groups[i].name,srcW.roster.groups[i].name);
    }
  }

  document.userprops.nickname.value = user.name;
}

function keyPressed(e) {
  if (e.ctrlKey && e.keyCode == 13)
    submitClicked();
  else if (e.keyCode == 27)
    window.close();
}
onkeydown = keyPressed;
onload = init;
      //-->
    </script>
    <script for="document" event="onkeydown()" language="JScript">
      <!--
      if (window.event.ctrlKey && window.event.keyCode == 13)
      submitClicked();
      if (window.event.keyCode == 27)
      window.close();
      //-->
    </script>
  </head>

  <body style="margin: 8px;">
    <form name="userprops">
      <fieldset>
        <legend>Edit nickname for <span id="nickjid"></span></legend>
        <table border=0 cellspacing=0 cellpadding=0 width="100%">
            <tr>
              <td nowrap>Nickname:&nbsp;</td><td width="100%"><input type="text" name="nickname" style="width:100%"></td></tr>
        </table>
      </fieldset>
      <br>
      <fieldset>
        <legend>Edit groups for <span id="groupjid"></span></legend>
        <table>
            <tr>
              <td>
                <fieldset>
                  <legend>Available groups</legend>
                  <table border=0 cellspacing=0 cellpadding=0 width="100%">
                      <tr>
                        <tr><td>Group:&nbsp;</td><td width="100%"><input type="text" name="newgrp"></td></tr>
                        <tr><td colspan=2 height=10></td></tr>
                        <tr>
                          <td colspan=2 width="100%;"><select size="9" name="allgrps" style="width:100%" onChange="setNewGrp(this.selectedIndex);"></select></td></tr>
                  </table>
                </fieldset>
              </td>
              <td><button onClick="return addgroup();">&gt;</button><br><button onClick="return remgroup();">&lt;</button></td>
              <td>
                <fieldset>
                  <legend>Current groups</legend>
                  <select size="11" name="curgrps" style="width:165px"></select>
                </fieldset>
              </td>
            </tr>
        </table>
      </fieldset>
      
      <hr noshade size="1" size="100%">
      <div align="right" id="buttonbox">
        <button onClick="window.close();">Cancel</button>&nbsp;<button onClick="return submitClicked();">OK</button>
      </div>
    </form>
  </body>
</html>