activity_notification 2.0.0 → 2.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (195) hide show
  1. checksums.yaml +4 -4
  2. data/.github/ISSUE_TEMPLATE/bug_report.md +22 -0
  3. data/.github/ISSUE_TEMPLATE/feature_request.md +17 -0
  4. data/.github/pull_request_template.md +13 -0
  5. data/.gitignore +10 -3
  6. data/.travis.yml +6 -5
  7. data/CHANGELOG.md +22 -0
  8. data/Gemfile +8 -2
  9. data/Procfile +1 -1
  10. data/README.md +153 -1510
  11. data/activity_notification.gemspec +4 -1
  12. data/app/channels/activity_notification/notification_api_channel.rb +12 -0
  13. data/app/channels/activity_notification/notification_api_with_devise_channel.rb +46 -0
  14. data/app/channels/activity_notification/notification_channel.rb +1 -1
  15. data/app/channels/activity_notification/notification_with_devise_channel.rb +1 -1
  16. data/app/controllers/activity_notification/apidocs_controller.rb +75 -0
  17. data/app/controllers/activity_notification/notifications_api_controller.rb +143 -0
  18. data/app/controllers/activity_notification/notifications_api_with_devise_controller.rb +7 -0
  19. data/app/controllers/activity_notification/notifications_controller.rb +79 -53
  20. data/app/controllers/activity_notification/subscriptions_api_controller.rb +197 -0
  21. data/app/controllers/activity_notification/subscriptions_api_with_devise_controller.rb +7 -0
  22. data/app/controllers/activity_notification/subscriptions_controller.rb +78 -69
  23. data/app/views/activity_notification/notifications/default/_default.html.erb +18 -18
  24. data/app/views/activity_notification/notifications/default/_default_without_grouping.html.erb +14 -14
  25. data/app/views/activity_notification/notifications/default/index.html.erb +6 -6
  26. data/app/views/activity_notification/optional_targets/default/action_cable_channel/_default.html.erb +176 -0
  27. data/app/views/activity_notification/subscriptions/default/_form.html.erb +1 -1
  28. data/app/views/activity_notification/subscriptions/default/_notification_keys.html.erb +3 -31
  29. data/app/views/activity_notification/subscriptions/default/_subscription.html.erb +7 -7
  30. data/app/views/activity_notification/subscriptions/default/index.html.erb +11 -7
  31. data/bin/deploy_on_heroku.sh +3 -1
  32. data/docs/CODE_OF_CONDUCT.md +76 -0
  33. data/docs/CONTRIBUTING.md +36 -0
  34. data/docs/Functions.md +1130 -0
  35. data/docs/Setup.md +674 -0
  36. data/docs/Testing.md +148 -0
  37. data/gemfiles/Gemfile.rails-4.2 +3 -0
  38. data/gemfiles/Gemfile.rails-5.0 +3 -0
  39. data/gemfiles/Gemfile.rails-5.1 +3 -0
  40. data/gemfiles/Gemfile.rails-5.2 +3 -0
  41. data/gemfiles/{Gemfile.rails-6.0.rc → Gemfile.rails-6.0} +5 -3
  42. data/lib/activity_notification.rb +13 -1
  43. data/lib/activity_notification/apis/notification_api.rb +29 -92
  44. data/lib/activity_notification/apis/subscription_api.rb +20 -8
  45. data/lib/activity_notification/apis/swagger.rb +6 -0
  46. data/lib/activity_notification/config.rb +41 -21
  47. data/lib/activity_notification/controllers/common_api_controller.rb +30 -0
  48. data/lib/activity_notification/controllers/common_controller.rb +44 -20
  49. data/lib/activity_notification/controllers/concerns/swagger/error_responses.rb +55 -0
  50. data/lib/activity_notification/controllers/concerns/swagger/notifications_api.rb +273 -0
  51. data/lib/activity_notification/controllers/concerns/swagger/notifications_parameters.rb +92 -0
  52. data/lib/activity_notification/controllers/concerns/swagger/subscriptions_api.rb +405 -0
  53. data/lib/activity_notification/controllers/concerns/swagger/subscriptions_parameters.rb +50 -0
  54. data/lib/activity_notification/controllers/devise_authentication_controller.rb +7 -6
  55. data/lib/activity_notification/gem_version.rb +14 -0
  56. data/lib/activity_notification/helpers/errors.rb +2 -0
  57. data/lib/activity_notification/helpers/view_helpers.rb +4 -0
  58. data/lib/activity_notification/mailers/helpers.rb +17 -10
  59. data/lib/activity_notification/models/concerns/notifiable.rb +26 -10
  60. data/lib/activity_notification/models/concerns/subscriber.rb +12 -1
  61. data/lib/activity_notification/models/concerns/swagger/error_schema.rb +36 -0
  62. data/lib/activity_notification/models/concerns/swagger/notification_schema.rb +209 -0
  63. data/lib/activity_notification/models/concerns/swagger/subscription_schema.rb +162 -0
  64. data/lib/activity_notification/models/concerns/target.rb +36 -10
  65. data/lib/activity_notification/models/notification.rb +1 -0
  66. data/lib/activity_notification/models/subscription.rb +1 -0
  67. data/lib/activity_notification/optional_targets/action_cable_api_channel.rb +69 -0
  68. data/lib/activity_notification/optional_targets/action_cable_channel.rb +68 -0
  69. data/lib/activity_notification/optional_targets/base.rb +7 -13
  70. data/lib/activity_notification/orm/active_record/notification.rb +17 -1
  71. data/lib/activity_notification/orm/active_record/subscription.rb +1 -1
  72. data/lib/activity_notification/orm/dynamoid.rb +28 -0
  73. data/lib/activity_notification/orm/dynamoid/extension.rb +79 -1
  74. data/lib/activity_notification/orm/dynamoid/notification.rb +1 -1
  75. data/lib/activity_notification/orm/dynamoid/subscription.rb +1 -1
  76. data/lib/activity_notification/orm/mongoid.rb +22 -0
  77. data/lib/activity_notification/orm/mongoid/notification.rb +17 -1
  78. data/lib/activity_notification/orm/mongoid/subscription.rb +1 -1
  79. data/lib/activity_notification/rails/routes.rb +132 -48
  80. data/lib/activity_notification/renderable.rb +13 -2
  81. data/lib/activity_notification/roles/acts_as_notifiable.rb +38 -20
  82. data/lib/activity_notification/version.rb +1 -1
  83. data/lib/generators/activity_notification/controllers_generator.rb +2 -1
  84. data/lib/generators/templates/activity_notification.rb +8 -0
  85. data/lib/generators/templates/controllers/notifications_api_controller.rb +31 -0
  86. data/lib/generators/templates/controllers/notifications_api_with_devise_controller.rb +31 -0
  87. data/lib/generators/templates/controllers/notifications_controller.rb +1 -37
  88. data/lib/generators/templates/controllers/notifications_with_devise_controller.rb +1 -45
  89. data/lib/generators/templates/controllers/subscriptions_api_controller.rb +61 -0
  90. data/lib/generators/templates/controllers/subscriptions_api_with_devise_controller.rb +61 -0
  91. data/lib/generators/templates/controllers/subscriptions_controller.rb +14 -37
  92. data/lib/generators/templates/controllers/subscriptions_with_devise_controller.rb +14 -45
  93. data/lib/generators/templates/models/README +8 -4
  94. data/lib/generators/templates/models/notification.rb +1 -1
  95. data/lib/generators/templates/models/subscription.rb +1 -1
  96. data/package.json +8 -0
  97. data/spec/channels/notification_api_channel_shared_examples.rb +59 -0
  98. data/spec/channels/notification_api_channel_spec.rb +51 -0
  99. data/spec/channels/notification_api_with_devise_channel_spec.rb +78 -0
  100. data/spec/concerns/apis/notification_api_spec.rb +37 -2
  101. data/spec/concerns/models/notifiable_spec.rb +64 -0
  102. data/spec/concerns/models/subscriber_spec.rb +13 -16
  103. data/spec/concerns/models/target_spec.rb +32 -0
  104. data/spec/concerns/renderable_spec.rb +2 -2
  105. data/spec/controllers/controller_spec_utility.rb +136 -0
  106. data/spec/controllers/notifications_api_controller_shared_examples.rb +506 -0
  107. data/spec/controllers/notifications_api_controller_spec.rb +19 -0
  108. data/spec/controllers/notifications_api_with_devise_controller_spec.rb +60 -0
  109. data/spec/controllers/notifications_controller_shared_examples.rb +54 -79
  110. data/spec/controllers/notifications_controller_spec.rb +1 -2
  111. data/spec/controllers/notifications_with_devise_controller_spec.rb +3 -12
  112. data/spec/controllers/subscriptions_api_controller_shared_examples.rb +750 -0
  113. data/spec/controllers/subscriptions_api_controller_spec.rb +19 -0
  114. data/spec/controllers/subscriptions_api_with_devise_controller_spec.rb +60 -0
  115. data/spec/controllers/subscriptions_controller_shared_examples.rb +94 -121
  116. data/spec/controllers/subscriptions_controller_spec.rb +1 -2
  117. data/spec/controllers/subscriptions_with_devise_controller_spec.rb +3 -12
  118. data/spec/helpers/view_helpers_spec.rb +4 -11
  119. data/spec/mailers/mailer_spec.rb +41 -0
  120. data/spec/models/notification_spec.rb +17 -0
  121. data/spec/models/subscription_spec.rb +0 -13
  122. data/spec/optional_targets/action_cable_api_channel_spec.rb +37 -0
  123. data/spec/optional_targets/action_cable_channel_spec.rb +44 -0
  124. data/spec/optional_targets/amazon_sns_spec.rb +0 -2
  125. data/spec/optional_targets/slack_spec.rb +0 -2
  126. data/spec/rails_app/Rakefile +9 -0
  127. data/spec/rails_app/app/assets/config/manifest.js +3 -0
  128. data/spec/rails_app/app/assets/images/.keep +0 -0
  129. data/spec/rails_app/app/controllers/admins_controller.rb +21 -0
  130. data/spec/rails_app/app/controllers/application_controller.rb +1 -1
  131. data/spec/rails_app/app/controllers/articles_controller.rb +6 -3
  132. data/spec/rails_app/app/controllers/spa_controller.rb +7 -0
  133. data/spec/rails_app/app/controllers/users/notifications_controller.rb +0 -65
  134. data/spec/rails_app/app/controllers/users/notifications_with_devise_controller.rb +0 -73
  135. data/spec/rails_app/app/controllers/users/subscriptions_controller.rb +0 -77
  136. data/spec/rails_app/app/controllers/users/subscriptions_with_devise_controller.rb +0 -85
  137. data/spec/rails_app/app/controllers/users_controller.rb +21 -0
  138. data/spec/rails_app/app/javascript/App.vue +104 -0
  139. data/spec/rails_app/app/javascript/components/DeviseTokenAuth.vue +83 -0
  140. data/spec/rails_app/app/javascript/components/Top.vue +99 -0
  141. data/spec/rails_app/app/javascript/components/notifications/Index.vue +200 -0
  142. data/spec/rails_app/app/javascript/components/notifications/Notification.vue +133 -0
  143. data/spec/rails_app/app/javascript/components/notifications/NotificationContent.vue +122 -0
  144. data/spec/rails_app/app/javascript/components/subscriptions/Index.vue +279 -0
  145. data/spec/rails_app/app/javascript/components/subscriptions/NewSubscription.vue +112 -0
  146. data/spec/rails_app/app/javascript/components/subscriptions/NotificationKey.vue +141 -0
  147. data/spec/rails_app/app/javascript/components/subscriptions/Subscription.vue +226 -0
  148. data/spec/rails_app/app/javascript/config/development.js +5 -0
  149. data/spec/rails_app/app/javascript/config/environment.js +7 -0
  150. data/spec/rails_app/app/javascript/config/production.js +5 -0
  151. data/spec/rails_app/app/javascript/config/test.js +5 -0
  152. data/spec/rails_app/app/javascript/packs/application.js +18 -0
  153. data/spec/rails_app/app/javascript/packs/spa.js +11 -0
  154. data/spec/rails_app/app/javascript/store/auth.js +37 -0
  155. data/spec/rails_app/app/models/admin.rb +16 -15
  156. data/spec/rails_app/app/models/article.rb +26 -21
  157. data/spec/rails_app/app/models/comment.rb +24 -71
  158. data/spec/rails_app/app/models/user.rb +43 -20
  159. data/spec/rails_app/app/views/activity_notification/notifications/default/article/_update.html.erb +146 -0
  160. data/spec/rails_app/app/views/articles/index.html.erb +51 -7
  161. data/spec/rails_app/app/views/articles/show.html.erb +1 -1
  162. data/spec/rails_app/app/views/layouts/_header.html.erb +8 -10
  163. data/spec/rails_app/app/views/spa/index.html.erb +2 -0
  164. data/spec/rails_app/babel.config.js +72 -0
  165. data/spec/rails_app/bin/webpack +18 -0
  166. data/spec/rails_app/bin/webpack-dev-server +18 -0
  167. data/spec/rails_app/config/application.rb +15 -2
  168. data/spec/rails_app/config/environment.rb +2 -1
  169. data/spec/rails_app/config/environments/development.rb +5 -0
  170. data/spec/rails_app/config/environments/production.rb +3 -0
  171. data/spec/rails_app/config/environments/test.rb +5 -0
  172. data/spec/rails_app/config/initializers/activity_notification.rb +8 -0
  173. data/spec/rails_app/config/initializers/devise_token_auth.rb +55 -0
  174. data/spec/rails_app/config/initializers/mysql.rb +9 -0
  175. data/spec/rails_app/config/locales/activity_notification.en.yml +2 -2
  176. data/spec/rails_app/config/routes.rb +33 -1
  177. data/spec/rails_app/config/webpack/development.js +5 -0
  178. data/spec/rails_app/config/webpack/environment.js +7 -0
  179. data/spec/rails_app/config/webpack/loaders/vue.js +6 -0
  180. data/spec/rails_app/config/webpack/production.js +5 -0
  181. data/spec/rails_app/config/webpack/test.js +5 -0
  182. data/spec/rails_app/config/webpacker.yml +97 -0
  183. data/spec/rails_app/db/migrate/20191201000000_add_tokens_to_users.rb +10 -0
  184. data/spec/rails_app/db/schema.rb +4 -1
  185. data/spec/rails_app/db/seeds.rb +1 -0
  186. data/spec/rails_app/lib/custom_optional_targets/raise_error.rb +14 -0
  187. data/spec/rails_app/package.json +23 -0
  188. data/spec/rails_app/postcss.config.js +12 -0
  189. data/spec/roles/acts_as_group_spec.rb +0 -2
  190. data/spec/roles/acts_as_notifiable_spec.rb +1 -3
  191. data/spec/roles/acts_as_notifier_spec.rb +0 -2
  192. data/spec/roles/acts_as_target_spec.rb +0 -4
  193. data/spec/spec_helper.rb +7 -15
  194. data/spec/version_spec.rb +31 -0
  195. metadata +187 -13
@@ -0,0 +1,279 @@
1
+ <template>
2
+ <div class="subscription_wrapper">
3
+ <div class="subscription_header">
4
+ <h1>Subscriptions for {{ currentTarget.printable_target_name }}</h1>
5
+ </div>
6
+
7
+ <div v-if="subscriptions">
8
+ <div class="subscription_header">
9
+ <h2>Configured subscriptions</h2>
10
+ </div>
11
+ <div class="subscriptions" id="subscriptions">
12
+ <div v-if="subscriptions.length" class="fields_area">
13
+ <div v-for="subscription in subscriptions" :key="`${subscription.id}_${subscription.updated_at}`">
14
+ <subscription :targetSubscription="subscription" :targetApiPath="targetApiPath" @getSubscriptions="getSubscriptions" />
15
+ </div>
16
+ </div>
17
+ <div v-else class="fields_area">
18
+ <div class="fields_wrapper">
19
+ No subscriptions are available.
20
+ </div>
21
+ </div>
22
+ </div>
23
+ </div>
24
+
25
+ <div v-if="notificationKeys">
26
+ <div class="subscription_header">
27
+ <h2>Unconfigured notification keys</h2>
28
+ </div>
29
+ <div class="notification_keys" id="notification_keys">
30
+ <div v-if="notificationKeys.length" class="fields_area">
31
+ <div v-for="notificationKey in notificationKeys" :key="notificationKey">
32
+ <notification-key :notificationKey="notificationKey" :targetApiPath="targetApiPath" @getSubscriptions="getSubscriptions" />
33
+ </div>
34
+ </div>
35
+ <div v-else class="fields_area">
36
+ <div class="fields_wrapper">
37
+ No notification keys are available.
38
+ </div>
39
+ </div>
40
+ </div>
41
+ </div>
42
+
43
+ <div class="subscription_header">
44
+ <h2>Create a new subscription</h2>
45
+ </div>
46
+ <div class="subscription_form" id="subscription_form">
47
+ <div class="fields_area">
48
+ <new-subscription :targetApiPath="targetApiPath" @getSubscriptions="getSubscriptions" />
49
+ </div>
50
+ </div>
51
+ </div>
52
+ </template>
53
+
54
+ <script>
55
+ import axios from 'axios'
56
+ import Subscription from './Subscription.vue'
57
+ import NotificationKey from './NotificationKey.vue'
58
+ import NewSubscription from './NewSubscription.vue'
59
+
60
+ export default {
61
+ name: 'SubscriptionsIndex',
62
+ components: {
63
+ Subscription,
64
+ NotificationKey,
65
+ NewSubscription
66
+ },
67
+ props: {
68
+ target_type: {
69
+ type: String
70
+ },
71
+ target_id: {
72
+ type: [String, Number]
73
+ },
74
+ targetApiPath: {
75
+ type: String,
76
+ default: function () {
77
+ if (this.target_type && this.target_id) {
78
+ return '/' + this.target_type + '/' + this.target_id;
79
+ } else {
80
+ return '';
81
+ }
82
+ }
83
+ },
84
+ target: {
85
+ type: Object
86
+ }
87
+ },
88
+ data () {
89
+ return {
90
+ currentTarget: { printable_target_name: '' },
91
+ subscriptions: [],
92
+ notificationKeys: []
93
+ }
94
+ },
95
+ mounted () {
96
+ if (this.target) {
97
+ this.currentTarget = this.target;
98
+ } else {
99
+ this.getCurrentTarget();
100
+ }
101
+ this.getSubscriptions();
102
+ },
103
+ methods: {
104
+ getCurrentTarget () {
105
+ axios
106
+ .get(this.targetApiPath)
107
+ .then(response => (this.currentTarget = response.data))
108
+ },
109
+ getSubscriptions () {
110
+ axios
111
+ .get(this.targetApiPath + '/subscriptions')
112
+ .then(response => {
113
+ this.subscriptions = response.data.subscriptions;
114
+ this.notificationKeys = response.data.unconfigured_notification_keys;
115
+ })
116
+ .catch (error => {
117
+ if (error.response.status == 401) {
118
+ this.$router.push('/logout');
119
+ }
120
+ })
121
+ }
122
+ }
123
+ }
124
+ </script>
125
+
126
+ <style scoped>
127
+ .subscription_header h1 {
128
+ margin-bottom: 30px;
129
+ }
130
+
131
+ .fields_area {
132
+ border: 1px solid #e5e5e5;
133
+ width: 600px;
134
+ box-sizing: border-box;
135
+ margin-bottom: 30px;
136
+ }
137
+ </style>
138
+
139
+ <style>
140
+ .fields_area .fields_wrapper {
141
+ position: relative;
142
+ background-color: #fff;
143
+ padding: 20px;
144
+ box-sizing: border-box;
145
+ border-bottom: 1px solid #e5e5e5;
146
+ }
147
+ .fields_area .fields_wrapper.configured {
148
+ background-color: #f8f9fb;
149
+ }
150
+
151
+ .fields_area .fields_wrapper .fields_title_wrapper {
152
+ margin-bottom: 16px;
153
+ border-bottom: none;
154
+ }
155
+
156
+ .fields_area .fields_wrapper .fields_title_wrapper .fields_title {
157
+ font-size: 16px;
158
+ font-weight: bold;
159
+ }
160
+
161
+ .fields_area .fields_wrapper .fields_title_wrapper p {
162
+ position: absolute;
163
+ top: 15px;
164
+ right: 15px;
165
+ }
166
+
167
+ .fields_area .fields_wrapper .field_wrapper {
168
+ margin-bottom: 16px;
169
+ }
170
+
171
+ .fields_area .fields_wrapper .field_wrapper:last-child {
172
+ margin-bottom: 0;
173
+ }
174
+
175
+ .fields_area .fields_wrapper .field_wrapper.hidden {
176
+ display: none;
177
+ }
178
+
179
+ .fields_area .fields_wrapper .field_wrapper .field_label {
180
+ margin-bottom: 8px;
181
+ }
182
+
183
+ .fields_area .fields_wrapper .field_wrapper .field_label label {
184
+ font-size: 14px;
185
+ }
186
+
187
+ .ui label {
188
+ font-size: 14px;
189
+ }
190
+
191
+ /* button */
192
+ .ui.button button,
193
+ .ui.button .button {
194
+ cursor: pointer;
195
+ color: #4f4f4f;
196
+ font-weight: bold;
197
+ font-size: 12px;
198
+ padding: 10px 14px;
199
+ margin-left: 10px;
200
+ border: 1px solid #e5e5e5;
201
+ background-color: #fafafa;
202
+ }
203
+
204
+ .ui.button button:first-child,
205
+ .ui.button .button:first-child {
206
+ margin-left: 0;
207
+ }
208
+
209
+ .ui.text_field input {
210
+ margin: 0;
211
+ outline: 0;
212
+ padding: 10px;
213
+ font-size: 14px;
214
+ border: 1px solid #e5e5e5;
215
+ border-radius: 3px;
216
+ box-shadow: 0 0 0 0 transparent inset;
217
+ }
218
+
219
+ /* checkbox */
220
+ .ui.checkbox {
221
+ position: relative;
222
+ left: 300px;
223
+ margin-top: -26px;
224
+ width: 40px;
225
+ }
226
+
227
+ .ui.checkbox input {
228
+ position: absolute;
229
+ margin-left: -9999px;
230
+ visibility: hidden;
231
+ }
232
+
233
+ .ui.checkbox .slider {
234
+ display: block;
235
+ position: relative;
236
+ cursor: pointer;
237
+ outline: none;
238
+ user-select: none;
239
+
240
+ padding: 2px;
241
+ width: 36px;
242
+ height: 20px;
243
+ background-color: #dddddd;
244
+ border-radius: 20px;
245
+ }
246
+
247
+ .ui.checkbox .slider:before,
248
+ .ui.checkbox .slider:after {
249
+ display: block;
250
+ position: absolute;
251
+ top: 1px;
252
+ left: 1px;
253
+ bottom: 1px;
254
+ content: "";
255
+ }
256
+
257
+ .ui.checkbox .slider:before {
258
+ right: 1px;
259
+ background-color: #f1f1f1;
260
+ border-radius: 20px;
261
+ transition: background 0.4s;
262
+ }
263
+
264
+ .ui.checkbox .slider:after {
265
+ width: 20px;
266
+ background-color: #fff;
267
+ border-radius: 100%;
268
+ box-shadow: 0 1px 1px rgba(0, 0, 0, 0.3);
269
+ transition: margin 0.4s;
270
+ }
271
+
272
+ .ui.checkbox input:checked + .slider:before {
273
+ background-color: #8ce196;
274
+ }
275
+
276
+ .ui.checkbox input:checked + .slider:after {
277
+ margin-left: 18px;
278
+ }
279
+ </style>
@@ -0,0 +1,112 @@
1
+ <template>
2
+ <div class="fields_wrapper">
3
+ <form class="new_subscription" @submit.prevent="createSubscription">
4
+ <div class="field_wrapper subscribing">
5
+ <div class="field_label">
6
+ <label>
7
+ Notification key
8
+ </label>
9
+ </div>
10
+
11
+ <div class="field">
12
+ <div class="ui text_field">
13
+ <input type="text" v-model="subscriptionParams.key" placeholder="Notification key" />
14
+ </div>
15
+ </div>
16
+ </div>
17
+
18
+ <div class="field_wrapper subscribing">
19
+ <div class="field_label">
20
+ <label>
21
+ Notification
22
+ </label>
23
+ </div>
24
+
25
+ <div class="field">
26
+ <div class="ui checkbox">
27
+ <label>
28
+ <input type="checkbox" v-model="subscriptionParams.subscribing" v-on:click="arrangeSubscription()" />
29
+ <div class="slider" />
30
+ </label>
31
+ </div>
32
+ </div>
33
+ </div>
34
+
35
+ <div v-bind:class="[subscriptionParams.subscribing ? '' : 'hidden', 'field_wrapper subscribing_to_email']">
36
+ <div class="field_label">
37
+ <label>
38
+ Email notification
39
+ </label>
40
+ </div>
41
+ <div class="field">
42
+ <div class="ui checkbox">
43
+ <label>
44
+ <input type="checkbox" v-model="subscriptionParams.subscribing_to_email" />
45
+ <div class="slider" />
46
+ </label>
47
+ </div>
48
+ </div>
49
+ </div>
50
+
51
+ <div class="ui button">
52
+ <button type="submit">Create subscription</button>
53
+ </div>
54
+ </form>
55
+ </div>
56
+ </template>
57
+
58
+ <script>
59
+ import axios from 'axios'
60
+
61
+ export default {
62
+ name: 'Subscription',
63
+ props: {
64
+ targetApiPath: {
65
+ type: String,
66
+ required: true
67
+ }
68
+ },
69
+ data () {
70
+ return {
71
+ baseURL: axios.defaults.baseURL + this.targetApiPath,
72
+ subscriptionParams: {
73
+ key: "",
74
+ subscribing: true,
75
+ subscribing_to_email: true,
76
+ optional_targets: {}
77
+ }
78
+ }
79
+ },
80
+ methods: {
81
+ createSubscription () {
82
+ axios
83
+ .post(this.targetApiPath + '/subscriptions', { subscription: this.subscriptionParams })
84
+ .then(response => {
85
+ if (response.status == 201) {
86
+ this.$emit('getSubscriptions');
87
+ this.resetSubscriptionParams();
88
+ }
89
+ })
90
+ .catch (error => {
91
+ if (error.response.status == 401) {
92
+ this.$router.push('/logout');
93
+ }
94
+ })
95
+ },
96
+ arrangeSubscription () {
97
+ this.subscriptionParams.subscribing_to_email = !this.subscriptionParams.subscribing;
98
+ },
99
+ resetSubscriptionParams () {
100
+ this.subscriptionParams = {
101
+ key: "",
102
+ subscribing: true,
103
+ subscribing_to_email: true,
104
+ optional_targets: {}
105
+ }
106
+ }
107
+ }
108
+ }
109
+ </script>
110
+
111
+ <style scoped>
112
+ </style>
@@ -0,0 +1,141 @@
1
+ <template>
2
+ <div class="fields_wrapper">
3
+ <form class="new_subscription" @submit.prevent="createSubscription">
4
+ <div class="fields_title_wrapper">
5
+ <h3 class="fields_title">
6
+ {{ notificationKey }}
7
+ </h3>
8
+
9
+ <p>
10
+ <router-link v-bind:to="{ path : $route.path.replace('subscriptions', 'notifications') + '?filtered_by_key=' + notificationKey }">Notifications</router-link>
11
+ </p>
12
+ </div>
13
+
14
+ <div class="field_wrapper subscribing">
15
+ <div class="field_label">
16
+ <label>
17
+ Notification
18
+ </label>
19
+ </div>
20
+
21
+ <div class="field">
22
+ <div class="ui checkbox">
23
+ <label>
24
+ <input type="checkbox" v-model="subscriptionParams.subscribing" v-on:click="arrangeSubscription()" />
25
+ <div class="slider" />
26
+ </label>
27
+ </div>
28
+ </div>
29
+ </div>
30
+
31
+ <div v-bind:class="[subscriptionParams.subscribing ? '' : 'hidden', 'field_wrapper subscribing_to_email']">
32
+ <div class="field_label">
33
+ <label>
34
+ Email notification
35
+ </label>
36
+ </div>
37
+ <div class="field">
38
+ <div class="ui checkbox">
39
+ <label>
40
+ <input type="checkbox" v-model="subscriptionParams.subscribing_to_email" />
41
+ <div class="slider" />
42
+ </label>
43
+ </div>
44
+ </div>
45
+ </div>
46
+
47
+ <div v-bind:class="[subscriptionParams.subscribing ? '' : 'hidden', 'field_wrapper subscribing_to_optional_targets']">
48
+ <div v-for="optionalTargetName in configuredOptionalTargetNames" :key="optionalTargetName">
49
+ <div class="field_label">
50
+ <label>
51
+ Optional tagret ({{ optionalTargetName }})
52
+ </label>
53
+ </div>
54
+ <div class="field">
55
+ <div class="ui checkbox">
56
+ <label>
57
+ <input type="checkbox" v-model="subscriptionParams.optional_targets[optionalTargetName].subscribing" />
58
+ <div class="slider" />
59
+ </label>
60
+ </div>
61
+ </div>
62
+ </div>
63
+ </div>
64
+
65
+ <div class="ui button">
66
+ <button type="submit">Configure subscription</button>
67
+ </div>
68
+ </form>
69
+ </div>
70
+ </template>
71
+
72
+ <script>
73
+ import axios from 'axios'
74
+
75
+ export default {
76
+ name: 'Subscription',
77
+ props: {
78
+ notificationKey: {
79
+ type: String,
80
+ required: true
81
+ },
82
+ targetApiPath: {
83
+ type: String,
84
+ required: true
85
+ }
86
+ },
87
+ data () {
88
+ return {
89
+ baseURL: axios.defaults.baseURL + this.targetApiPath,
90
+ configuredOptionalTargetNames: [],
91
+ subscriptionParams: {
92
+ key: this.notificationKey,
93
+ subscribing: true,
94
+ subscribing_to_email: true,
95
+ optional_targets: {}
96
+ }
97
+ }
98
+ },
99
+ mounted () {
100
+ axios
101
+ .get(this.targetApiPath + '/subscriptions/optional_target_names?key=' + this.notificationKey)
102
+ .then(response => {
103
+ this.configuredOptionalTargetNames = response.data.optional_target_names;
104
+ for (let optionalTargetName of this.configuredOptionalTargetNames) {
105
+ this.subscriptionParams.optional_targets[optionalTargetName] = {};
106
+ this.subscriptionParams.optional_targets[optionalTargetName].subscribing = true;
107
+ }
108
+ })
109
+ .catch (error => {
110
+ if (error.response.status == 401) {
111
+ this.$router.push('/logout');
112
+ }
113
+ })
114
+ },
115
+ methods: {
116
+ createSubscription () {
117
+ axios
118
+ .post(this.targetApiPath + '/subscriptions', { subscription: this.subscriptionParams })
119
+ .then(response => {
120
+ if (response.status == 201) {
121
+ this.$emit('getSubscriptions');
122
+ }
123
+ })
124
+ .catch (error => {
125
+ if (error.response.status == 401) {
126
+ this.$router.push('/logout');
127
+ }
128
+ })
129
+ },
130
+ arrangeSubscription () {
131
+ this.subscriptionParams.subscribing_to_email = !this.subscriptionParams.subscribing;
132
+ for (let optionalTargetName of this.configuredOptionalTargetNames) {
133
+ this.subscriptionParams.optional_targets[optionalTargetName].subscribing = !this.subscriptionParams.subscribing;
134
+ }
135
+ }
136
+ }
137
+ }
138
+ </script>
139
+
140
+ <style scoped>
141
+ </style>