Commit | Line | Data |
---|---|---|
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 |