Consistent use of view.$; Don't hide notification checkbox when Notification is on...
[KiwiIRC.git] / client / src / applets / settings.js
CommitLineData
4baeda09 1(function () {\r
1b48d21e
VC
2 var View = Backbone.View.extend({\r
3 events: {\r
4 'change [data-setting]': 'saveSettings',\r
ed5b9cd6 5 'click [data-setting="theme"]': 'selectTheme',\r
d70c63d4 6 'click .register_protocol': 'registerProtocol',\r
159e6756 7 'click .enable_notifications': 'enableNotifications'\r
1b48d21e
VC
8 },\r
9\r
10 initialize: function (options) {\r
13e912d8
NF
11 function t(key, vars) {\r
12 var trans = _kiwi.global.i18n.translate(key);\r
13 return trans.fetch.apply(trans, Array.prototype.slice.call(arguments, 1));\r
14 }\r
0d29c21f 15 var text = {\r
13e912d8
NF
16 tabs : t('client_applets_settings_channelview_tabs'),\r
17 list : t('client_applets_settings_channelview_list'),\r
18 large_amounts_of_chans: t('client_applets_settings_channelview_list_notice'),\r
19 join_part : t('client_applets_settings_notification_joinpart'),\r
20 count_all_activity : t('client_applets_settings_notification_count_all_activity'),\r
21 timestamps : t('client_applets_settings_timestamp'),\r
22 timestamp_24 : t('client_applets_settings_timestamp_24_hour'),\r
23 mute : t('client_applets_settings_notification_sound'),\r
24 emoticons : t('client_applets_settings_emoticons'),\r
25 scroll_history : t('client_applets_settings_history_length'),\r
26 languages : _kiwi.app.translations,\r
27 default_client : t('client_applets_settings_default_client'),\r
28 make_default : t('client_applets_settings_default_client_enable'),\r
29 locale_restart_needed : t('client_applets_settings_locale_restart_needed'),\r
30 default_note : t('client_applets_settings_default_client_notice', '<a href="chrome://settings/handlers">chrome://settings/handlers</a>'),\r
31 html5_notifications : t('client_applets_settings_html5_notifications'),\r
32 enable_notifications : t('client_applets_settings_enable_notifications'),\r
83dc56c5
D
33 theme_thumbnails: _.map(_kiwi.app.themes, function (theme) {\r
34 return _.template($('#tmpl_theme_thumbnail').html().trim(), theme);\r
35 })\r
0d29c21f
JA
36 };\r
37 this.$el = $(_.template($('#tmpl_applet_settings').html().trim(), text));\r
1b48d21e 38\r
ed5b9cd6 39 if (!navigator.registerProtocolHandler) {\r
aca5a9c9 40 this.$('.protocol_handler').remove();\r
ed5b9cd6 41 }\r
ee2f0962 42\r
aca5a9c9
NF
43 if (!(window.Notification || window.webkitNotifications || window.mozNotification)) {\r
44 this.$('notification_enabler').remove();\r
ee2f0962
D
45 }\r
46\r
1b48d21e
VC
47 // Incase any settings change while we have this open, update them\r
48 _kiwi.global.settings.on('change', this.loadSettings, this);\r
49\r
50 // Now actually show the current settings\r
51 this.loadSettings();\r
52\r
53 },\r
54\r
55 loadSettings: function () {\r
56\r
57 var that = this;\r
58\r
59 $.each(_kiwi.global.settings.attributes, function(key, value) {\r
60\r
aca5a9c9 61 var $el = that.$('[data-setting="' + key + '"]');\r
ad6e3f2b
VC
62\r
63 // Only deal with settings we have a UI element for\r
08701d92 64 if (!$el.length)\r
134071ac 65 return;\r
ad6e3f2b
VC
66\r
67 switch ($el.prop('type')) {\r
1b48d21e 68 case 'checkbox':\r
ad6e3f2b 69 $el.prop('checked', value);\r
1b48d21e
VC
70 break;\r
71 case 'radio':\r
72 $('[data-setting="' + key + '"][value="' + value + '"]', that.$el).prop('checked', true);\r
73 break;\r
74 case 'text':\r
ad6e3f2b 75 $el.val(value);\r
1b48d21e 76 break;\r
0fa2ca42
JA
77 case 'select-one':\r
78 $('[value="' + value + '"]', that.$el).prop('selected', true);\r
79 break;\r
1b48d21e
VC
80 default:\r
81 $('[data-setting="' + key + '"][data-value="' + value + '"]', that.$el).addClass('active');\r
82 break;\r
83 }\r
84 });\r
85 },\r
86\r
87 saveSettings: function (event) {\r
88 var value,\r
89 settings = _kiwi.global.settings,\r
aca5a9c9 90 $setting = this.$(event.currentTarget);\r
1b48d21e
VC
91\r
92 switch (event.currentTarget.type) {\r
93 case 'checkbox':\r
94 value = $setting.is(':checked');\r
95 break;\r
96 case 'radio':\r
97 case 'text':\r
98 value = $setting.val();\r
99 break;\r
0fa2ca42
JA
100 case 'select-one':\r
101 value = $(event.currentTarget[$setting.prop('selectedIndex')]).val();\r
102 break;\r
1b48d21e
VC
103 default:\r
104 value = $setting.data('value');\r
105 break;\r
106 }\r
107\r
108 // Stop settings being updated while we're saving one by one\r
109 _kiwi.global.settings.off('change', this.loadSettings, this);\r
110 settings.set($setting.data('setting'), value);\r
111 settings.save();\r
112\r
113 // Continue listening for setting changes\r
114 _kiwi.global.settings.on('change', this.loadSettings, this);\r
115 },\r
116\r
117 selectTheme: function(event) {\r
22ffa51a
D
118 event.preventDefault();\r
119\r
aca5a9c9 120 this.$('[data-setting="theme"].active').removeClass('active');\r
1b48d21e 121 $(event.currentTarget).addClass('active').trigger('change');\r
ed5b9cd6
JA
122 },\r
123\r
124 registerProtocol: function (event) {\r
22ffa51a
D
125 event.preventDefault();\r
126\r
ed5b9cd6
JA
127 navigator.registerProtocolHandler('irc', document.location.origin + _kiwi.app.get('base_path') + '/%s', 'Kiwi IRC');\r
128 navigator.registerProtocolHandler('ircs', document.location.origin + _kiwi.app.get('base_path') + '/%s', 'Kiwi IRC');\r
d70c63d4
K
129 },\r
130\r
aca5a9c9 131 enableNotifications: function(event) {\r
98bc1a84 132 event.preventDefault();\r
aca5a9c9 133 var Notify = window.Notification || window.webkitNotifications;\r
98bc1a84 134\r
aca5a9c9
NF
135 if (Notify) {\r
136 Notify.requestPermission();\r
98bc1a84 137 }\r
ee2f0962 138 }\r
d70c63d4 139\r
1b48d21e
VC
140 });\r
141\r
142\r
143 var Applet = Backbone.Model.extend({\r
144 initialize: function () {\r
247dd7ac 145 this.set('title', _kiwi.global.i18n.translate('client_applets_settings_title').fetch());\r
1b48d21e
VC
146 this.view = new View();\r
147 }\r
148 });\r
149\r
150\r
151 _kiwi.model.Applet.register('kiwi_settings', Applet);\r
d70c63d4 152})();\r