Forked mumble-django project from https://bitbucket.org/Svedrin/mumble-django
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

352 lines
12 KiB

16 years ago
16 years ago
16 years ago
16 years ago
16 years ago
16 years ago
16 years ago
16 years ago
16 years ago
16 years ago
16 years ago
  1. {% extends "index.htm" %}
  2. {% load mumble_extras %}
  3. {% load i18n %}
  4. {% block Headline %}
  5. {{ DBaseObject.name }}
  6. {% endblock %}
  7. {% block LeftColumn %}
  8. {{ DBaseObject|chanview:MumbleAccount }}
  9. {% endblock %}
  10. {% block Content %}
  11. <noscript>
  12. <p>
  13. {% blocktrans %}
  14. <b>Hint:</b><br />
  15. This area is used to display additional information for each channel and player, but requires JavaScript to be
  16. displayed correctly. You will not see the detail pages, but you can use all links and forms
  17. that are displayed.
  18. {% endblocktrans %}
  19. </p>
  20. </noscript>
  21. <div id="mumble_ext_container"></div>
  22. <div id="mumble_motd" class="mumble-ext x-hide-display">
  23. <ul>
  24. <li>{% trans "Server Address" %}: <a href="{{ DBaseObject.connecturl }}">{{ DBaseObject.connecturl }}</a></li>
  25. {% if DBaseObject.url %}
  26. <li>{% trans "Website" %}: {{ DBaseObject.url|urlize }}</li>
  27. {% endif %}
  28. <li>{% trans "Server version" %}: {{ DBaseObject.version.0 }}.{{ DBaseObject.version.1 }}.{{ DBaseObject.version.2 }}</li>
  29. </ul>
  30. <fieldset>
  31. <legend>{% trans "Welcome message" %}</legend>
  32. {{ DBaseObject.motd|safe }}
  33. </fieldset>
  34. </div>
  35. <div id="mumble_registration" class="mumble-ext">
  36. {% if user.is_authenticated %}
  37. <h2>{% trans "Server registration" %}</h2>
  38. <form action="{% url mumble.views.show DBaseObject.id %}" method="post">
  39. {% if Registered %}
  40. {% trans "You are registered on this server" %}.<br />
  41. {% else %}
  42. {% trans "You do not have an account on this server" %}.<br />
  43. {% endif %}
  44. <table>
  45. {{ RegForm }}
  46. </table>
  47. <input type="hidden" name="mode" value="reg" />
  48. <input type="submit" />
  49. </form>
  50. {% else %}
  51. {% blocktrans %}
  52. <p>You need to be <a href="{{ login_url }}">logged in</a> to be able to register an account on this Mumble server.</p>
  53. {% endblocktrans %}
  54. {% endif %}
  55. </div>
  56. {% if Registered %}
  57. <div id="mumble_texture" class="mumble-ext">
  58. <h2>{% trans "User Texture" %}</h2>
  59. <p>
  60. {% blocktrans with DBaseObject.id as serverid %}
  61. You can upload an image that you would like to use as your user texture here.
  62. {% endblocktrans %}<br />
  63. <br />
  64. {% if MumbleAccount.hasTexture %}
  65. {% trans "Your current texture is" %}:<br />
  66. <img src="{% url mumble.views.showTexture DBaseObject.id MumbleAccount.id %}" alt="user texture" /><br />
  67. {% else %}
  68. {% trans "You don't currently have a texture set" %}.<br />
  69. {% endif %}
  70. <br />
  71. {% blocktrans with DBaseObject.id as serverid %}
  72. Hint: The texture image <b>needs</b> to be 600x60 in size. If you upload an image with
  73. a different size, it will be resized accordingly.<br />
  74. {% endblocktrans %}
  75. </p>
  76. <form action="{% url mumble.views.show DBaseObject.id %}" method="post" enctype="multipart/form-data">
  77. <table>
  78. {{ TextureForm }}
  79. </table>
  80. <input type="hidden" name="mode" value="texture" />
  81. <input type="submit" />
  82. </form>
  83. </div>
  84. {% endif %}
  85. {% if CurrentUserIsAdmin %}
  86. <div id="mumble_admin" class="mumble-ext">
  87. <h2>{% trans "Server administration" %}</h2>
  88. <form action="{% url mumble.views.show DBaseObject.id %}" method="post">
  89. <table>
  90. {{ AdminForm }}
  91. </table>
  92. <input type="hidden" name="mode" value="admin" />
  93. <input type="submit" />
  94. </form>
  95. </div>
  96. {% endif %}
  97. {% for item in ChannelTable %}
  98. {% if item.is_player %}
  99. <div id="mumble_{{ item.id }}" class="mumble-ext x-hide-display">
  100. <h2>{% trans "Player" %} {{ item.name }}</h2>
  101. <ul>
  102. <li>{% trans "Online since" %} {{ item.onlinesince|time }}</li>
  103. <li>{% blocktrans with item.isAuthed|yesno as authed %}Authenticated: {{ authed }}{% endblocktrans %}</li>
  104. <li>{% blocktrans with item.isAdmin|yesno as admin %}Admin: {{ admin }}{% endblocktrans %}</li>
  105. <li>{% blocktrans with item.muted|yesno as muted %}Muted: {{ muted }}{% endblocktrans %}</li>
  106. <li>{% blocktrans with item.deafened|yesno as deafened %}Deafened: {{ deafened }}{% endblocktrans %}</li>
  107. <li>{% blocktrans with item.selfmuted|yesno as selfmuted %}Muted by self: {{ selfmuted }}{% endblocktrans %}</li>
  108. <li>{% blocktrans with item.selfdeafened|yesno as selfdeafened %}Deafened by self: {{ selfdeafened }}{% endblocktrans %}</li>
  109. </ul>
  110. {% if item.mumbleuser and item.mumbleuser.owner %}
  111. <h2>{% trans "User" %} {{ item.mumbleuser.owner.username|capfirst }}</h2>
  112. <ul>
  113. {% if item.mumbleuser.owner.first_name and item.mumbleuser.owner.last_name %}
  114. <li>{% trans "Full Name" %}: {{ item.mumbleuser.owner.first_name }} {{ item.mumbleuser.owner.last_name }}</li>
  115. {% endif %}
  116. <li>{% trans "Admin" %}: {{ item.mumbleuser.owner.is_staff|yesno }}</li>
  117. <li>{% trans "Sign-up date" %}: {{ item.mumbleuser.owner.date_joined|date }}</li>
  118. </ul>
  119. {% endif %}
  120. {% if item.mumbleuser and item.mumbleuser.comment %}
  121. <fieldset>
  122. <legend>{% trans "User Comment" %}</legend>
  123. {{ item.mumbleuser.comment|safe }}
  124. </fieldset>
  125. {% endif %}
  126. {% if item.mumbleuser and item.mumbleuser.hasTexture %}
  127. <fieldset>
  128. <legend>{% trans "User Texture" %}</legend>
  129. <img src="{% url mumble.views.showTexture DBaseObject.id item.mumbleuser.id %}" alt="user texture" />
  130. </fieldset>
  131. {% endif %}
  132. </div>
  133. {% else %}
  134. <div id="mumble_{{ item.id }}" class="mumble-ext x-hide-display">
  135. <h2>{% trans "Channel" %} {{ item.name }}</h2>
  136. {% if CurrentUserIsAdmin or user.is_staff %}
  137. {% trans "Channel ID" %}: {{ item.chanid }}<br />
  138. {% endif %}
  139. <a href="{{ item|chanurl:MumbleAccount }}" class="mumble">{% trans "Connect" %}</a>
  140. {% if item.description %}
  141. <fieldset>
  142. <legend>{% trans "Channel description" %}</legend>
  143. {{ item.description|safe }}
  144. </fieldset>
  145. {% endif %}
  146. </div>
  147. {% endif %}
  148. {% endfor %}
  149. {% endblock %}
  150. {% block HeadTag %}
  151. <script type="text/javascript">
  152. Ext.onReady( function(){
  153. Ext.get( 'mumble_registration' ).addClass( 'x-hide-display' );
  154. {% if Registered %}
  155. Ext.get( 'mumble_texture' ).addClass( 'x-hide-display' );
  156. {% endif %}
  157. {% if CurrentUserIsAdmin %}
  158. Ext.get( 'mumble_admin' ).addClass( 'x-hide-display' );
  159. {% endif %}
  160. {% if CurrentUserIsAdmin %}
  161. userRecord = Ext.data.Record.create([
  162. { name: 'id', type: 'int' },
  163. { name: 'name', type: 'string' },
  164. { name: 'password', type: 'string' },
  165. { name: 'owner', type: 'int' },
  166. { name: 'admin', type: 'bool' },
  167. { name: 'delete', type: 'bool' },
  168. ]);
  169. userAdminStore = new Ext.data.Store({
  170. url: '{% url mumble.views.users DBaseObject.id %}',
  171. reader: new Ext.data.JsonReader({
  172. root: 'objects',
  173. fields: userRecord,
  174. }),
  175. autoLoad: true,
  176. remoteSort: false,
  177. });
  178. adminColumn = new Ext.grid.CheckColumn({
  179. header: '{% trans "Admin on root channel" %}',
  180. dataIndex: 'admin',
  181. width: 50,
  182. });
  183. deleteColumn = new Ext.grid.CheckColumn({
  184. header: '{% trans "Delete" %}',
  185. dataIndex: 'delete',
  186. width: 50,
  187. });
  188. ownerCombo = new Ext.form.ComboBox({
  189. name: 'owner',
  190. hiddenName: 'owner_id',
  191. forceSelection: true,
  192. triggerAction: 'all',
  193. valueField: 'uid',
  194. displayField: 'uname',
  195. store: new Ext.data.Store({
  196. url: '{% url mumble.views.djangousers %}',
  197. reader: new Ext.data.JsonReader({
  198. fields: [ 'uid', 'uname' ],
  199. root: 'objects',
  200. }),
  201. autoLoad: true,
  202. }),
  203. });
  204. {% endif %}
  205. var cardpanel = new Ext.Panel({
  206. renderTo: 'mumble_ext_container',
  207. layout: 'card',
  208. id: 'mumble_container',
  209. height: 570,
  210. activeItem: 0,
  211. border: false,
  212. items: [ {
  213. id: 'mumble_tabpanel',
  214. xtype: 'tabpanel',
  215. defaults: { autoheight: true },
  216. activeTab: {{ DisplayTab }},
  217. items: [
  218. { contentEl: 'mumble_motd', title: '{% trans "Server Info" %}', autoScroll: true },
  219. { contentEl: 'mumble_registration',
  220. title: '{% trans "Registration" %}',
  221. autoScroll: true,
  222. {% if user.is_authenticated %}
  223. listeners: {
  224. activate: function(){ Ext.fly("id_name").focus() },
  225. },
  226. {% endif %}
  227. },
  228. {% if CurrentUserIsAdmin %}
  229. { contentEl: 'mumble_admin', title: '{% trans "Administration" %}', autoScroll: true },
  230. {% endif %}
  231. {% if Registered %}
  232. { contentEl: 'mumble_texture',title: '{% trans "User Texture" %}', autoScroll: true },
  233. {% endif %}
  234. {% if CurrentUserIsAdmin %}
  235. {
  236. title: '{% trans "User List" %}',
  237. xtype: 'editorgrid',
  238. store: userAdminStore,
  239. cm: new Ext.grid.ColumnModel( [ {
  240. header: '{% trans "name" %}',
  241. dataIndex: 'name',
  242. sortable: true,
  243. editor: new Ext.form.TextField({
  244. allowBlank: false,
  245. }),
  246. }, {
  247. header: '{% trans "Account owner" %}',
  248. dataIndex: 'owner',
  249. editor: ownerCombo,
  250. sortable: true,
  251. renderer: function( value ){
  252. if( value == '' ) return '';
  253. items = ownerCombo.store.data.items;
  254. for( i = 0; i < items.length; i++ )
  255. if( items[i].data.uid == value )
  256. return items[i].data.uname;
  257. },
  258. }, adminColumn, {
  259. header: '{% trans "Change password" %}',
  260. dataIndex: 'password',
  261. editor: new Ext.form.TextField({
  262. inputType: 'password',
  263. }),
  264. renderer: function( value ){
  265. ret = '';
  266. for( i = 0; i < value.length; i++ )
  267. ret += '*';
  268. return ret;
  269. },
  270. }, deleteColumn ] ),
  271. tbar: [{
  272. text: '{% trans "Add" %}',
  273. handler : function(){
  274. userAdminStore.add( new userRecord( {
  275. id: -1,
  276. name: 'New User',
  277. admin: false,
  278. owner: '',
  279. password: '',
  280. 'delete': false,
  281. } ) );
  282. }
  283. }, {
  284. text: '{% trans "Save" %}',
  285. handler : function(){
  286. data = [];
  287. for( i = 0; i < userAdminStore.data.items.length; i++ ){
  288. rec = userAdminStore.data.items[i];
  289. if( rec.dirty ){
  290. data.push(rec.data);
  291. }
  292. }
  293. var conn = new Ext.data.Connection();
  294. conn.request( {
  295. url: userAdminStore.url,
  296. params: { data: Ext.encode( data ), },
  297. success: function(){
  298. for( i = 0; i < userAdminStore.data.items.length; i++ ){
  299. rec = userAdminStore.data.items[i];
  300. if( rec.data['delete'] == true )
  301. userAdminStore.remove( rec );
  302. else if( rec.dirty ){
  303. rec.commit();
  304. }
  305. }
  306. },
  307. } );
  308. }
  309. }, {
  310. text: '{% trans "Resync with Murmur" %}',
  311. handler: function(){
  312. userAdminStore.reload({
  313. params: { 'resync': 'true' },
  314. });
  315. },
  316. }],
  317. plugins: [ adminColumn, deleteColumn ],
  318. },
  319. {% endif %}
  320. ]
  321. },
  322. {% for item in ChannelTable %}
  323. { contentEl: 'mumble_{{ item.id }}', id: 'carditem_{{ item.id }}' },
  324. {% endfor %}
  325. ],
  326. });
  327. Ext.get( 'link_server' ).on( 'click', function( event, target ){
  328. cardpanel.layout.setActiveItem( 'mumble_tabpanel' );
  329. event.preventDefault();
  330. });
  331. {% for item in ChannelTable %}
  332. Ext.get( 'link_{{ item.id }}' ).on( 'click', function( event, target ){
  333. cardpanel.layout.setActiveItem( 'carditem_{{ item.id }}' );
  334. event.preventDefault();
  335. });
  336. {% endfor %}
  337. } );
  338. </script>
  339. <meta http-equiv="refresh" content="300" />
  340. {% endblock %}