lesli_admin 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/Rakefile +5 -0
- data/app/assets/config/lesli_admin_manifest.js +38 -0
- data/app/assets/javascripts/lesli_admin/application.js +3713 -0
- data/app/assets/stylesheets/lesli_admin/application.css +15 -0
- data/app/controllers/lesli_admin/accounts_controller.rb +125 -0
- data/app/controllers/lesli_admin/application_controller.rb +4 -0
- data/app/controllers/lesli_admin/dashboards_controller.rb +60 -0
- data/app/controllers/lesli_admin/users_controller.rb +244 -0
- data/app/helpers/lesli_admin/application_helper.rb +4 -0
- data/app/helpers/lesli_admin/dashboards_helper.rb +4 -0
- data/app/jobs/lesli_admin/application_job.rb +4 -0
- data/app/mailers/lesli_admin/application_mailer.rb +6 -0
- data/app/models/lesli_admin/account.rb +66 -0
- data/app/models/lesli_admin/application_record.rb +5 -0
- data/app/models/lesli_admin/dashboard.rb +4 -0
- data/app/models/lesli_admin/user.rb +4 -0
- data/app/services/lesli_admin/user_service.rb +300 -0
- data/app/views/layouts/lesli_admin/application.html.erb +15 -0
- data/app/views/lesli_admin/accounts/_account.html.erb +2 -0
- data/app/views/lesli_admin/accounts/_form.html.erb +17 -0
- data/app/views/lesli_admin/accounts/edit.html.erb +10 -0
- data/app/views/lesli_admin/accounts/index.html.erb +34 -0
- data/app/views/lesli_admin/accounts/new.html.erb +9 -0
- data/app/views/lesli_admin/accounts/show.html.erb +34 -0
- data/app/views/lesli_admin/dashboards/_dashboard.html.erb +2 -0
- data/app/views/lesli_admin/dashboards/_form.html.erb +17 -0
- data/app/views/lesli_admin/dashboards/edit.html.erb +10 -0
- data/app/views/lesli_admin/dashboards/index.html.erb +14 -0
- data/app/views/lesli_admin/dashboards/new.html.erb +9 -0
- data/app/views/lesli_admin/dashboards/show.html.erb +1 -0
- data/app/views/lesli_admin/partials/_engine-navigation.html.erb +52 -0
- data/app/views/lesli_admin/users/edit.html.erb +10 -0
- data/app/views/lesli_admin/users/index.html.erb +34 -0
- data/app/views/lesli_admin/users/new.html.erb +34 -0
- data/app/views/lesli_admin/users/show.html.erb +10 -0
- data/config/routes.rb +13 -0
- data/lib/lesli_admin/engine.rb +18 -0
- data/lib/lesli_admin/version.rb +3 -0
- data/lib/lesli_admin.rb +6 -0
- data/lib/tasks/lesli_admin_tasks.rake +4 -0
- data/lib/vue/application.js +153 -0
- data/lib/vue/apps/account/components/address-form.vue +134 -0
- data/lib/vue/apps/account/components/contact-form.vue +162 -0
- data/lib/vue/apps/account/components/form-information.vue +107 -0
- data/lib/vue/apps/account/show.vue +89 -0
- data/lib/vue/apps/dashboard/show.vue +33 -0
- data/lib/vue/apps/profile/components/change-email.vue +38 -0
- data/lib/vue/apps/profile/components/subscriptions.vue +94 -0
- data/lib/vue/apps/profile/show.vue +141 -0
- data/lib/vue/apps/users/components/information-card.vue +119 -0
- data/lib/vue/apps/users/components/information-form.vue +180 -0
- data/lib/vue/apps/users/components/integrations-information.vue +61 -0
- data/lib/vue/apps/users/components/management-roles.vue +109 -0
- data/lib/vue/apps/users/components/management-security.vue +113 -0
- data/lib/vue/apps/users/components/management-sessions.vue +106 -0
- data/lib/vue/apps/users/components/management-settings.vue +94 -0
- data/lib/vue/apps/users/index.vue +201 -0
- data/lib/vue/apps/users/new.vue +181 -0
- data/lib/vue/apps/users/show.vue +101 -0
- data/lib/vue/stores/account.js +113 -0
- data/lib/vue/stores/accountSettings.js +342 -0
- data/lib/vue/stores/descriptor.js +116 -0
- data/lib/vue/stores/descriptors.js +167 -0
- data/lib/vue/stores/integration.js +103 -0
- data/lib/vue/stores/role.js +243 -0
- data/lib/vue/stores/roles.js +89 -0
- data/lib/vue/stores/systemController.js +67 -0
- data/lib/vue/stores/user.js +319 -0
- data/lib/vue/stores/users.js +150 -0
- data/readme.md +28 -0
- metadata +130 -0
@@ -0,0 +1,342 @@
|
|
1
|
+
/*
|
2
|
+
Lesli
|
3
|
+
|
4
|
+
Copyright (c) 2023, Lesli Technologies, S. A.
|
5
|
+
|
6
|
+
This program is free software: you can redistribute it and/or modify
|
7
|
+
it under the terms of the GNU General Public License as published by
|
8
|
+
the Free Software Foundation, either version 3 of the License, or
|
9
|
+
(at your option) any later version.
|
10
|
+
|
11
|
+
This program is distributed in the hope that it will be useful,
|
12
|
+
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
13
|
+
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
14
|
+
GNU General Public License for more details.
|
15
|
+
|
16
|
+
You should have received a copy of the GNU General Public License
|
17
|
+
along with this program. If not, see http://www.gnu.org/licenses/.
|
18
|
+
|
19
|
+
Lesli · Ruby on Rails Development Platform.
|
20
|
+
|
21
|
+
Made with ♥ by https://www.lesli.tech
|
22
|
+
Building a better future, one line of code at a time.
|
23
|
+
|
24
|
+
@contact hello@lesli.tech
|
25
|
+
@website https://www.lesli.tech
|
26
|
+
@license GPLv3 http://www.gnu.org/licenses/gpl-3.0.en.html
|
27
|
+
|
28
|
+
// · ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~
|
29
|
+
// ·
|
30
|
+
*/
|
31
|
+
|
32
|
+
// ·
|
33
|
+
import { defineStore } from "pinia";
|
34
|
+
import axios from "axios";
|
35
|
+
|
36
|
+
// ·
|
37
|
+
export const useAccountSettings = defineStore("account_settings", {
|
38
|
+
state: () => {
|
39
|
+
return {
|
40
|
+
view: 0,
|
41
|
+
submitting_form : false,
|
42
|
+
settings: {
|
43
|
+
datetime_format_date: null,
|
44
|
+
datetime_format_time: null,
|
45
|
+
datetime_format_date_words: null,
|
46
|
+
datetime_format_date_time: null,
|
47
|
+
datetime_format_date_time_words: null,
|
48
|
+
datetime_time_zone: null,
|
49
|
+
password_enforce_complexity: null,
|
50
|
+
password_minimum_length: null,
|
51
|
+
password_expiration_time_days: null,
|
52
|
+
password_special_char_count: null,
|
53
|
+
password_uppercase_count: null,
|
54
|
+
password_lowercase_count: null,
|
55
|
+
password_digit_count: null,
|
56
|
+
lesli_theme_color_primary: null,
|
57
|
+
lesli_theme_color_secondary: null,
|
58
|
+
lesli_theme_header_color: null,
|
59
|
+
lesli_theme_sidebar_color: null,
|
60
|
+
lesli_theme_color_background: null,
|
61
|
+
lesli_theme_font_color: null,
|
62
|
+
lesli_theme_font_size: null,
|
63
|
+
default_role_id: null,
|
64
|
+
},
|
65
|
+
old_settings: {
|
66
|
+
lesli_theme_color_primary: null,
|
67
|
+
lesli_theme_color_secondary: null,
|
68
|
+
lesli_theme_header_color: null,
|
69
|
+
lesli_theme_sidebar_color: null,
|
70
|
+
lesli_theme_color_background: null,
|
71
|
+
lesli_theme_font_color: null,
|
72
|
+
lesli_theme_font_size: null
|
73
|
+
},
|
74
|
+
options: {
|
75
|
+
time_zones: []
|
76
|
+
},
|
77
|
+
roles: {},
|
78
|
+
branding_logos: {},
|
79
|
+
record_files: [],
|
80
|
+
new_file: {
|
81
|
+
url: null
|
82
|
+
},
|
83
|
+
loading: false,
|
84
|
+
}
|
85
|
+
},
|
86
|
+
actions: {
|
87
|
+
/**
|
88
|
+
* @description This action is used to fetch the list of options for time zone.
|
89
|
+
*/
|
90
|
+
getOptions (){
|
91
|
+
this.loading = true
|
92
|
+
this.http.get(this.url.admin("account/options")).then(result => {
|
93
|
+
this.options.time_zones = result.time_zones.map((time_zone)=> {
|
94
|
+
return {
|
95
|
+
label: time_zone.text,
|
96
|
+
value: time_zone.value
|
97
|
+
}
|
98
|
+
} )
|
99
|
+
}).catch(error => {
|
100
|
+
this.msg.danger(I18n.t("core.shared").messages_danger_internal_error)
|
101
|
+
}).finally(() => {
|
102
|
+
this.loading = false
|
103
|
+
})
|
104
|
+
},
|
105
|
+
|
106
|
+
/**
|
107
|
+
* @description This action is used to post the selected settings
|
108
|
+
*/
|
109
|
+
postSettings() {
|
110
|
+
this.submitting_form = true
|
111
|
+
this.http.post(this.url.admin("account/settings"), {
|
112
|
+
settings: this.settings
|
113
|
+
}).then(result => {
|
114
|
+
this.msg.success(I18n.t("core.account/settings").messages_success_settings_saved_successfully)
|
115
|
+
}).catch(error => {
|
116
|
+
console.log(error)
|
117
|
+
this.msg.danger(I18n.t("core.shared").messages_danger_internal_error)
|
118
|
+
}).finally(() => {
|
119
|
+
this.submitting_form = false
|
120
|
+
this.getSettings()
|
121
|
+
})
|
122
|
+
},
|
123
|
+
|
124
|
+
/**
|
125
|
+
* @description This action is used to fetch the user's roles
|
126
|
+
*/
|
127
|
+
getRoles(){
|
128
|
+
this.loading = true
|
129
|
+
this.http.get(this.url.admin("roles/list")).then(result => {
|
130
|
+
this.roles = result.map(record =>{
|
131
|
+
return {
|
132
|
+
label: record.name,
|
133
|
+
value: record.id,
|
134
|
+
};
|
135
|
+
})
|
136
|
+
}).catch(error => {
|
137
|
+
this.msg.danger(I18n.t("core.shared").messages_danger_internal_error)
|
138
|
+
}).finally(() => {
|
139
|
+
this.loading = false
|
140
|
+
})
|
141
|
+
},
|
142
|
+
|
143
|
+
/**
|
144
|
+
* @description This action is used to fetch the currently configured settings
|
145
|
+
*/
|
146
|
+
getSettings (){
|
147
|
+
this.loading = true
|
148
|
+
this.http.get(this.url.admin("account/settings")).then(result => {
|
149
|
+
result.forEach(setting => {
|
150
|
+
if (setting.name in this.settings){
|
151
|
+
this.settings[setting.name] = setting.value
|
152
|
+
}
|
153
|
+
})
|
154
|
+
}).catch(error => {
|
155
|
+
this.msg.danger(I18n.t("core.shared").messages_danger_internal_error)
|
156
|
+
}).finally(() => {
|
157
|
+
this.loading = false
|
158
|
+
})
|
159
|
+
},
|
160
|
+
|
161
|
+
/**
|
162
|
+
* @description This action is used to replace the new settings with the old settings
|
163
|
+
* @param {Object} setting_name The setting that is going to be replaced
|
164
|
+
*/
|
165
|
+
clearSetting(setting_name){
|
166
|
+
this.settings[setting_name] = this.old_settings[setting_name]
|
167
|
+
},
|
168
|
+
|
169
|
+
/**
|
170
|
+
* @description Initializing branding logos properties
|
171
|
+
*/
|
172
|
+
initializeBrandingLogos(){
|
173
|
+
this.branding_logos = {
|
174
|
+
app_icon: {
|
175
|
+
identifier: 'app_icon',
|
176
|
+
name: I18n.t('core.account/files').column_enum_file_type_app_icon,
|
177
|
+
description: I18n.t('core.account/files').view_text_app_icon_description,
|
178
|
+
format: I18n.t('core.account/files').view_text_svg_png_formats,
|
179
|
+
accept: ".svg, .png",
|
180
|
+
submitting: false,
|
181
|
+
file: null
|
182
|
+
},
|
183
|
+
app_logo: {
|
184
|
+
identifier: 'app_logo',
|
185
|
+
name: I18n.t('core.account/files').column_enum_file_type_app_logo,
|
186
|
+
description: I18n.t('core.account/files').view_text_file_type_app_logo_description,
|
187
|
+
format: I18n.t('core.account/files').view_text_svg_png_formats,
|
188
|
+
accept: ".svg, .png",
|
189
|
+
submitting: false,
|
190
|
+
file: null
|
191
|
+
},
|
192
|
+
favicon: {
|
193
|
+
identifier: 'favicon',
|
194
|
+
name: I18n.t('core.account/files').column_enum_file_type_favicon,
|
195
|
+
description: I18n.t('core.account/files').view_text_file_favicon_svg_description,
|
196
|
+
format: I18n.t('core.account/files').view_text_svg_png_ico_formats,
|
197
|
+
accept: ".svg, .png, .ico",
|
198
|
+
submitting: false,
|
199
|
+
file: null
|
200
|
+
}
|
201
|
+
}
|
202
|
+
this.record_files = []
|
203
|
+
},
|
204
|
+
|
205
|
+
/**
|
206
|
+
* @description Get account logos files
|
207
|
+
*/
|
208
|
+
getAccountLogos(){
|
209
|
+
this.loading = true
|
210
|
+
this.http.get(this.url.admin('account/files')).then(result => {
|
211
|
+
this.parseLogos(result)
|
212
|
+
}).catch(error => {
|
213
|
+
console.log(error)
|
214
|
+
this.msg.danger(I18n.t("core.shared").messages_danger_internal_error)
|
215
|
+
}).finally(() => {
|
216
|
+
this.loading = false
|
217
|
+
})
|
218
|
+
},
|
219
|
+
|
220
|
+
/**
|
221
|
+
* @description Parse logos to display the records in a table
|
222
|
+
*/
|
223
|
+
parseLogos(files){
|
224
|
+
for(let i = 0; i < files.length; i++){
|
225
|
+
let file = files[i]
|
226
|
+
let branding_logo = this.branding_logos[file.file_type]
|
227
|
+
if(branding_logo){
|
228
|
+
this.branding_logos[file.file_type].file = file
|
229
|
+
}
|
230
|
+
}
|
231
|
+
this.record_files = this.branding_logos
|
232
|
+
},
|
233
|
+
|
234
|
+
/**
|
235
|
+
*
|
236
|
+
* @param {string} id
|
237
|
+
* @description This method is used to get the url of a file
|
238
|
+
* @returns {string} file url
|
239
|
+
*/
|
240
|
+
getUrl(id) {
|
241
|
+
// · url to fetch file types that are allowed to upload
|
242
|
+
const url = this.url.admin('account/files/:id', id)
|
243
|
+
return url.toString()
|
244
|
+
},
|
245
|
+
|
246
|
+
/**
|
247
|
+
*
|
248
|
+
* @param {string} logo the logo to be deleted
|
249
|
+
* @description this action is used to delete a file from a cloud object.
|
250
|
+
*/
|
251
|
+
deleteFile(logo) {
|
252
|
+
this.loading = true
|
253
|
+
|
254
|
+
// · url to delete file
|
255
|
+
const url = this.url.admin('account/files/:id', logo.id)
|
256
|
+
this.http.delete(url).then(() => {
|
257
|
+
// · fetch files after delete a file
|
258
|
+
this.getAccountLogos()
|
259
|
+
this.initializeBrandingLogos()
|
260
|
+
this.msg.success(I18n.t("core.shared").messages_success_files_deleted)
|
261
|
+
}).catch(error => {
|
262
|
+
console.log(error)
|
263
|
+
this.msg.danger(I18n.t("core.shared").messages_danger_files_deleted)
|
264
|
+
}).finally(() => {
|
265
|
+
this.loading = false
|
266
|
+
})
|
267
|
+
},
|
268
|
+
|
269
|
+
/**
|
270
|
+
*
|
271
|
+
* @param {string} logo the logo that is being uploaded
|
272
|
+
* @param {string} event
|
273
|
+
* @description this action is used to process a file that is going to be uploaded
|
274
|
+
*/
|
275
|
+
processFile(event, logo) {
|
276
|
+
|
277
|
+
/*
|
278
|
+
const formData = new FormData();
|
279
|
+
formData.append('account_file[name]', "test")
|
280
|
+
formData.append('account_file[file_type]', "app_logo")
|
281
|
+
formData.append('account_file[attachment]', event.target.files[0]);
|
282
|
+
var headers = { 'Content-Type': 'multipart/form-data' };
|
283
|
+
|
284
|
+
this.http.post(this.url.admin('account/files'), formData, { headers }).then((res) => {
|
285
|
+
res.data.files; // binary representation of the file
|
286
|
+
res.status; // HTTP status
|
287
|
+
});
|
288
|
+
|
289
|
+
return
|
290
|
+
*/
|
291
|
+
this.new_file = event.target.files[0]
|
292
|
+
//this.new_file.url = URL.createObjectURL(this.new_file)
|
293
|
+
this.postFile(logo)
|
294
|
+
},
|
295
|
+
|
296
|
+
/**
|
297
|
+
*
|
298
|
+
* @param {string} logo the logo to be deleted
|
299
|
+
* @description this action is used to post a file into account files
|
300
|
+
*/
|
301
|
+
postFile(logo) {
|
302
|
+
|
303
|
+
const formData = new FormData()
|
304
|
+
formData.append('account_file[name]', logo.identifier)
|
305
|
+
formData.append('account_file[category]', logo.identifier)
|
306
|
+
formData.append('account_file[attachment]', this.new_file)
|
307
|
+
var headers = { 'Content-Type': 'multipart/form-data' };
|
308
|
+
|
309
|
+
this.http.postFile(this.url.admin('account/files'), formData).then((res) => {
|
310
|
+
//this.http.post(this.url.admin('account/files'), formData, { headers }).then((res) => {
|
311
|
+
this.msg.success(I18n.t("core.account/settings").messages_success_image_uploaded_successfully)
|
312
|
+
}).catch(error => {
|
313
|
+
console.log(error)
|
314
|
+
this.msg.danger(I18n.t("core.shared").messages_danger_files_deleted)
|
315
|
+
}).finally(()=>{
|
316
|
+
this.initializeBrandingLogos()
|
317
|
+
this.getAccountLogos()
|
318
|
+
})
|
319
|
+
|
320
|
+
},
|
321
|
+
/**
|
322
|
+
*
|
323
|
+
* @param {string} logo the logo to be deleted
|
324
|
+
* @description this action is used to show a dialog message to confirm the deletion
|
325
|
+
*/
|
326
|
+
confirmFileDeletion(logo){
|
327
|
+
this.dialog
|
328
|
+
.confirmation({
|
329
|
+
title: `${I18n.t('core.account/files').messages_danger_delete_confirmation_title}: ${logo.name}`,
|
330
|
+
text: I18n.t('core.account/files').messages_danger_delete_confirmation_body,
|
331
|
+
confirmText: I18n.t("core.shared").view_btn_accept,
|
332
|
+
cancelText: I18n.t("core.shared").view_btn_cancel
|
333
|
+
})
|
334
|
+
.then(({ isConfirmed }) => {
|
335
|
+
if (isConfirmed) {
|
336
|
+
this.deleteFile(logo)
|
337
|
+
}
|
338
|
+
})
|
339
|
+
}
|
340
|
+
|
341
|
+
},
|
342
|
+
});
|
@@ -0,0 +1,116 @@
|
|
1
|
+
/*
|
2
|
+
Lesli
|
3
|
+
|
4
|
+
Copyright (c) 2023, Lesli Technologies, S. A.
|
5
|
+
|
6
|
+
This program is free software: you can redistribute it and/or modify
|
7
|
+
it under the terms of the GNU General Public License as published by
|
8
|
+
the Free Software Foundation, either version 3 of the License, or
|
9
|
+
(at your option) any later version.
|
10
|
+
|
11
|
+
This program is distributed in the hope that it will be useful,
|
12
|
+
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
13
|
+
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
14
|
+
GNU General Public License for more details.
|
15
|
+
|
16
|
+
You should have received a copy of the GNU General Public License
|
17
|
+
along with this program. If not, see http://www.gnu.org/licenses/.
|
18
|
+
|
19
|
+
All the information provided by this platform is protected by international laws related to
|
20
|
+
industrial property, intellectual property, copyright and relative international laws.
|
21
|
+
All intellectual or industrial property rights of the code, texts, trade mark, design,
|
22
|
+
pictures and any other information belongs to the owner of this platform.
|
23
|
+
|
24
|
+
Made with ♥ by https://www.lesli.tech
|
25
|
+
Building a better future, one line of code at a time.
|
26
|
+
|
27
|
+
@contact hello@lesli.tech
|
28
|
+
@website https://www.lesli.tech
|
29
|
+
@license GPLv3 http://www.gnu.org/licenses/gpl-3.0.en.html
|
30
|
+
|
31
|
+
// · ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~
|
32
|
+
// ·
|
33
|
+
*/
|
34
|
+
|
35
|
+
|
36
|
+
// ·
|
37
|
+
import { defineStore } from "pinia"
|
38
|
+
|
39
|
+
|
40
|
+
// ·
|
41
|
+
export const useDescriptor = defineStore("administration.descriptor", {
|
42
|
+
state: () => {
|
43
|
+
return {
|
44
|
+
list: [],
|
45
|
+
descriptor: {},
|
46
|
+
privileges: [],
|
47
|
+
privilegesLoading: false
|
48
|
+
}
|
49
|
+
},
|
50
|
+
actions: {
|
51
|
+
|
52
|
+
fetchDescriptor(id) {
|
53
|
+
if (this.descriptor.id != null) {
|
54
|
+
return
|
55
|
+
}
|
56
|
+
|
57
|
+
this.getDescriptor(id)
|
58
|
+
},
|
59
|
+
|
60
|
+
getDescriptor(id) {
|
61
|
+
this.http.get(this.url.admin("descriptors/:id", id)).then(result => {
|
62
|
+
this.descriptor = result
|
63
|
+
this.getDescriptorPrivileges()
|
64
|
+
}).catch(error => {
|
65
|
+
this.msg.danger(I18n.t("core.shared.messages_danger_internal_error"))
|
66
|
+
}).finally(() => {
|
67
|
+
|
68
|
+
})
|
69
|
+
},
|
70
|
+
|
71
|
+
resetDescriptor() {
|
72
|
+
this.descriptor = {}
|
73
|
+
this.privileges = []
|
74
|
+
},
|
75
|
+
|
76
|
+
getDescriptorPrivileges() {
|
77
|
+
this.privilegesLoading = true
|
78
|
+
this.http.get(this.url.admin("descriptors/:id/privileges", this.descriptor.id)).then(result => {
|
79
|
+
this.privileges = result
|
80
|
+
}).catch(error => {
|
81
|
+
console.log(error)
|
82
|
+
}).finally(() => {
|
83
|
+
this.privilegesLoading = false
|
84
|
+
})
|
85
|
+
},
|
86
|
+
|
87
|
+
// Add privilege to descriptor
|
88
|
+
postDescriptorPrivilege(action) {
|
89
|
+
|
90
|
+
this.http.post(this.url.admin("descriptors/:id/privileges", this.descriptor.id), {
|
91
|
+
descriptor_privilege: {
|
92
|
+
//controller_id: action.controller_id,
|
93
|
+
action_id: action.action_id
|
94
|
+
}
|
95
|
+
}).then(result => {
|
96
|
+
console.log(result)
|
97
|
+
}).catch(error => {
|
98
|
+
console.log(error)
|
99
|
+
})
|
100
|
+
},
|
101
|
+
|
102
|
+
|
103
|
+
// Add privilege to descriptor
|
104
|
+
deleteDescriptorPrivilege(action) {
|
105
|
+
console.log(action)
|
106
|
+
this.http.delete(this.url.admin("descriptors/:descriptorId/privileges/:descriptorPrivilegeId", {
|
107
|
+
descriptorId: this.descriptor.id,
|
108
|
+
descriptorPrivilegeId: action.descriptor_privilege_id
|
109
|
+
})).then(result => {
|
110
|
+
console.log(result)
|
111
|
+
}).catch(error => {
|
112
|
+
console.log(error)
|
113
|
+
})
|
114
|
+
}
|
115
|
+
}
|
116
|
+
})
|
@@ -0,0 +1,167 @@
|
|
1
|
+
/*
|
2
|
+
Lesli
|
3
|
+
|
4
|
+
Copyright (c) 2023, Lesli Technologies, S. A.
|
5
|
+
|
6
|
+
This program is free software: you can redistribute it and/or modify
|
7
|
+
it under the terms of the GNU General Public License as published by
|
8
|
+
the Free Software Foundation, either version 3 of the License, or
|
9
|
+
(at your option) any later version.
|
10
|
+
|
11
|
+
This program is distributed in the hope that it will be useful,
|
12
|
+
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
13
|
+
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
14
|
+
GNU General Public License for more details.
|
15
|
+
|
16
|
+
You should have received a copy of the GNU General Public License
|
17
|
+
along with this program. If not, see http://www.gnu.org/licenses/.
|
18
|
+
|
19
|
+
Lesli · Ruby on Rails SaaS development platform.
|
20
|
+
|
21
|
+
Made with ♥ by https://www.lesli.tech
|
22
|
+
Building a better future, one line of code at a time.
|
23
|
+
|
24
|
+
@contact hello@lesli.tech
|
25
|
+
@website https://www.lesli.tech
|
26
|
+
@license GPLv3 http://www.gnu.org/licenses/gpl-3.0.en.html
|
27
|
+
|
28
|
+
// · ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~ ~·~
|
29
|
+
// ·
|
30
|
+
*/
|
31
|
+
|
32
|
+
|
33
|
+
// ·
|
34
|
+
import { defineStore } from "pinia"
|
35
|
+
|
36
|
+
|
37
|
+
// ·
|
38
|
+
export const useDescriptors = defineStore("administration.descriptors", {
|
39
|
+
state: () => {
|
40
|
+
return {
|
41
|
+
list: [],
|
42
|
+
descriptor: {},
|
43
|
+
index: {
|
44
|
+
loading: false,
|
45
|
+
pagination: {},
|
46
|
+
records: []
|
47
|
+
}
|
48
|
+
}
|
49
|
+
},
|
50
|
+
actions: {
|
51
|
+
|
52
|
+
fetchDescriptors() {
|
53
|
+
if (this.index.records.length > 0) {
|
54
|
+
return
|
55
|
+
}
|
56
|
+
|
57
|
+
this.getDescriptors()
|
58
|
+
},
|
59
|
+
|
60
|
+
getDescriptors() {
|
61
|
+
this.index.loading = true
|
62
|
+
this.http.get(this.url.admin("descriptors")).then(result => {
|
63
|
+
this.index.pagination = result.pagination
|
64
|
+
this.index.records = result.records
|
65
|
+
}).catch(error => {
|
66
|
+
this.msg.danger(I18n.t("core.shared.messages_danger_internal_error"))
|
67
|
+
}).finally(() => {
|
68
|
+
this.index.loading = false
|
69
|
+
})
|
70
|
+
},
|
71
|
+
|
72
|
+
postDescriptor() {
|
73
|
+
this.loading = true
|
74
|
+
this.http.post(this.url.admin("descriptors"), { descriptor: this.descriptor }).then(result => {
|
75
|
+
this.descriptor.id = result.id
|
76
|
+
this.msg.success(I18n.t("core.users.messages_success_operation"))
|
77
|
+
this.loading = false
|
78
|
+
}).catch(error => {
|
79
|
+
this.msg.danger(I18n.t("core.shared.messages_danger_internal_error"))
|
80
|
+
})
|
81
|
+
},
|
82
|
+
|
83
|
+
resetDescriptor() {
|
84
|
+
this.descriptor = {}
|
85
|
+
this.privileges = []
|
86
|
+
},
|
87
|
+
|
88
|
+
paginateIndex(page) {
|
89
|
+
console.log("store page: ", page)
|
90
|
+
this.index.pagination.page = page
|
91
|
+
//this.fetch(this.url.admin("descriptors").paginate(this.pagination.page))
|
92
|
+
},
|
93
|
+
|
94
|
+
/*
|
95
|
+
fetchDescriptorList() {
|
96
|
+
this.http.get(this.url.admin("descriptors/list")).then(result => {
|
97
|
+
this.list = result.map(descriptor => {
|
98
|
+
descriptor.active = false
|
99
|
+
return descriptor
|
100
|
+
})
|
101
|
+
})
|
102
|
+
},
|
103
|
+
|
104
|
+
/**
|
105
|
+
* @description This action is used to reset descriptor object
|
106
|
+
* /
|
107
|
+
|
108
|
+
|
109
|
+
/**
|
110
|
+
* @description This action is used to create a descriptor
|
111
|
+
* /
|
112
|
+
|
113
|
+
|
114
|
+
/**
|
115
|
+
* @description This action is used to update a descriptor
|
116
|
+
* /
|
117
|
+
updateDescriptor(){
|
118
|
+
this.loading = true
|
119
|
+
this.http.put(this.url.admin("descriptors/:id", this.descriptor.id), { descriptor: this.descriptor }).then(result => {
|
120
|
+
this.msg.success(I18n.t("core.users.messages_success_operation"))
|
121
|
+
this.loading = false
|
122
|
+
}).catch(error => {
|
123
|
+
this.msg.danger(I18n.t("core.shared.messages_danger_internal_error"))
|
124
|
+
})
|
125
|
+
|
126
|
+
},
|
127
|
+
/**
|
128
|
+
* @description This action is used to sort the results
|
129
|
+
* /
|
130
|
+
sortIndex(column, direction) {
|
131
|
+
this.fetch(this.url.admin("descriptors").order(column, direction))
|
132
|
+
},
|
133
|
+
/**
|
134
|
+
* @description This action is used to search
|
135
|
+
* @param {string} search_string
|
136
|
+
* /
|
137
|
+
search(search_string) {
|
138
|
+
this.fetch(this.url.admin("descriptors").search(search_string))
|
139
|
+
},
|
140
|
+
/**
|
141
|
+
* @description This action is used to paginate index
|
142
|
+
* @param {string} page actual page
|
143
|
+
* /
|
144
|
+
paginateIndex(page) {
|
145
|
+
this.pagination.page = page
|
146
|
+
this.fetch(this.url.admin("descriptors").paginate(this.pagination.page))
|
147
|
+
},
|
148
|
+
/**
|
149
|
+
* @description This action is used to get descriptors as options
|
150
|
+
* /
|
151
|
+
getDescriptorsOptions(){
|
152
|
+
this.loading = true
|
153
|
+
this.descriptors_options = []
|
154
|
+
this.http.get(this.url.admin("descriptors/list")).then(result => {
|
155
|
+
result.forEach((descriptor)=>{
|
156
|
+
this.descriptors_options.push({
|
157
|
+
label: descriptor.name,
|
158
|
+
value: descriptor.id
|
159
|
+
})
|
160
|
+
})
|
161
|
+
|
162
|
+
this.loading = false
|
163
|
+
})
|
164
|
+
},
|
165
|
+
*/
|
166
|
+
}
|
167
|
+
})
|