@smarterplan/ngx-smarterplan-admin 0.2.3 → 0.3.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.
- package/esm2022/lib/admin/admin.component.mjs +36 -0
- package/esm2022/lib/chevron/chevron.component.mjs +19 -0
- package/{esm2020 → esm2022}/lib/guest-link/guest-link.component.mjs +70 -62
- package/esm2022/lib/guide.guard.mjs +29 -0
- package/{esm2020 → esm2022}/lib/helpers.mjs +24 -24
- package/esm2022/lib/name-from-id.pipe.mjs +31 -0
- package/esm2022/lib/ngx-smarterplan-admin-routing.module.mjs +48 -0
- package/esm2022/lib/ngx-smarterplan-admin.module.mjs +89 -0
- package/esm2022/lib/ngx-smarterplan-admin.service.mjs +15 -0
- package/esm2022/lib/organisation/organisation.component.mjs +182 -0
- package/esm2022/lib/sp-admin.guard.mjs +29 -0
- package/esm2022/lib/user/detail-organisation/detail-organisation.component.mjs +207 -0
- package/esm2022/lib/user/form-mission/form-mission.component.mjs +290 -0
- package/esm2022/lib/user/form-organisation/form-organisation.component.mjs +139 -0
- package/esm2022/lib/user/user-mission-form/user-mission-form.component.mjs +132 -0
- package/esm2022/lib/user/user.component.mjs +353 -0
- package/esm2022/lib/visitor/create-batch/create-batch.component.mjs +112 -0
- package/esm2022/lib/visitor/template/template.component.mjs +295 -0
- package/esm2022/lib/visitor/visitor.component.mjs +318 -0
- package/{esm2020 → esm2022}/public-api.mjs +5 -5
- package/{esm2020 → esm2022}/smarterplan-ngx-smarterplan-admin.mjs +4 -4
- package/{fesm2020 → fesm2022}/smarterplan-ngx-smarterplan-admin.mjs +2205 -2065
- package/{fesm2020 → fesm2022}/smarterplan-ngx-smarterplan-admin.mjs.map +1 -1
- package/index.d.ts +5 -5
- package/lib/admin/admin.component.d.ts +13 -13
- package/lib/chevron/chevron.component.d.ts +9 -9
- package/lib/guest-link/guest-link.component.d.ts +20 -20
- package/lib/guide.guard.d.ts +11 -11
- package/lib/helpers.d.ts +2 -2
- package/lib/name-from-id.pipe.d.ts +11 -11
- package/lib/ngx-smarterplan-admin-routing.module.d.ts +7 -7
- package/lib/ngx-smarterplan-admin.module.d.ts +26 -26
- package/lib/ngx-smarterplan-admin.service.d.ts +6 -6
- package/lib/organisation/organisation.component.d.ts +54 -54
- package/lib/sp-admin.guard.d.ts +11 -11
- package/lib/user/detail-organisation/detail-organisation.component.d.ts +49 -49
- package/lib/user/form-mission/form-mission.component.d.ts +63 -63
- package/lib/user/form-organisation/form-organisation.component.d.ts +32 -32
- package/lib/user/user-mission-form/user-mission-form.component.d.ts +32 -32
- package/lib/user/user.component.d.ts +102 -102
- package/lib/visitor/create-batch/create-batch.component.d.ts +23 -23
- package/lib/visitor/template/template.component.d.ts +58 -58
- package/lib/visitor/visitor.component.d.ts +70 -70
- package/package.json +10 -16
- package/public-api.d.ts +2 -2
- package/esm2020/lib/admin/admin.component.mjs +0 -34
- package/esm2020/lib/chevron/chevron.component.mjs +0 -19
- package/esm2020/lib/guide.guard.mjs +0 -26
- package/esm2020/lib/name-from-id.pipe.mjs +0 -29
- package/esm2020/lib/ngx-smarterplan-admin-routing.module.mjs +0 -47
- package/esm2020/lib/ngx-smarterplan-admin.module.mjs +0 -88
- package/esm2020/lib/ngx-smarterplan-admin.service.mjs +0 -14
- package/esm2020/lib/organisation/organisation.component.mjs +0 -171
- package/esm2020/lib/sp-admin.guard.mjs +0 -26
- package/esm2020/lib/user/detail-organisation/detail-organisation.component.mjs +0 -191
- package/esm2020/lib/user/form-mission/form-mission.component.mjs +0 -265
- package/esm2020/lib/user/form-organisation/form-organisation.component.mjs +0 -125
- package/esm2020/lib/user/user-mission-form/user-mission-form.component.mjs +0 -121
- package/esm2020/lib/user/user.component.mjs +0 -336
- package/esm2020/lib/visitor/create-batch/create-batch.component.mjs +0 -106
- package/esm2020/lib/visitor/template/template.component.mjs +0 -277
- package/esm2020/lib/visitor/visitor.component.mjs +0 -299
- package/fesm2015/smarterplan-ngx-smarterplan-admin.mjs +0 -2245
- package/fesm2015/smarterplan-ngx-smarterplan-admin.mjs.map +0 -1
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { validEmail, RoleStatus } from '@smarterplan/ngx-smarterplan-core';
|
|
3
|
+
import * as Papa from 'papaparse';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@smarterplan/ngx-smarterplan-core";
|
|
6
|
+
import * as i2 from "@ngx-translate/core";
|
|
7
|
+
import * as i3 from "@angular/common";
|
|
8
|
+
class CreateBatchComponent {
|
|
9
|
+
missionService;
|
|
10
|
+
userService;
|
|
11
|
+
translate;
|
|
12
|
+
template;
|
|
13
|
+
createdMissions = new EventEmitter();
|
|
14
|
+
addedEmails = [];
|
|
15
|
+
csvFile;
|
|
16
|
+
working = false;
|
|
17
|
+
constructor(missionService, userService, translate) {
|
|
18
|
+
this.missionService = missionService;
|
|
19
|
+
this.userService = userService;
|
|
20
|
+
this.translate = translate;
|
|
21
|
+
}
|
|
22
|
+
ngOnInit() { }
|
|
23
|
+
onAddEmail(value) {
|
|
24
|
+
if (value) {
|
|
25
|
+
if (validEmail(value)) {
|
|
26
|
+
this.addedEmails.push(value);
|
|
27
|
+
}
|
|
28
|
+
else {
|
|
29
|
+
alert("Please, enter a valid email address");
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
onDelete(index) {
|
|
34
|
+
this.addedEmails.splice(index, 1);
|
|
35
|
+
}
|
|
36
|
+
onCancel() {
|
|
37
|
+
this.createdMissions.emit(null);
|
|
38
|
+
}
|
|
39
|
+
async onCreateMissions() {
|
|
40
|
+
const createdMissions = [];
|
|
41
|
+
let user;
|
|
42
|
+
this.working = true;
|
|
43
|
+
await Promise.all(this.addedEmails.map(async (mail) => {
|
|
44
|
+
user = await this.userService.profileForMail(mail);
|
|
45
|
+
if (!user) {
|
|
46
|
+
try {
|
|
47
|
+
const profile = await this.userService.createUserAWSandProfile({
|
|
48
|
+
email: mail,
|
|
49
|
+
lastName: mail,
|
|
50
|
+
firstName: "",
|
|
51
|
+
phone: "",
|
|
52
|
+
}, true);
|
|
53
|
+
user = profile;
|
|
54
|
+
}
|
|
55
|
+
catch (error) {
|
|
56
|
+
alert(`Error creating users: ${this.translate.instant(error)}`);
|
|
57
|
+
this.working = false;
|
|
58
|
+
return;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
if (user) {
|
|
62
|
+
const missionInput = {
|
|
63
|
+
organisationID: this.template.organisationID,
|
|
64
|
+
orderedOrganisationID: this.template.organisationID,
|
|
65
|
+
level: this.template.level,
|
|
66
|
+
role: RoleStatus.VISITOR_MUSEUM,
|
|
67
|
+
description: "Generated from template",
|
|
68
|
+
userID: user.id,
|
|
69
|
+
startDateTime: this.template.startDateTime,
|
|
70
|
+
endDateTime: this.template.endDateTime,
|
|
71
|
+
spaceID: this.template.spaceID,
|
|
72
|
+
zoneID: this.template.zoneID,
|
|
73
|
+
templateMissionID: this.template.id,
|
|
74
|
+
hashtags: this.template.hashtags,
|
|
75
|
+
};
|
|
76
|
+
const mission = await this.missionService.create(missionInput);
|
|
77
|
+
createdMissions.push(mission);
|
|
78
|
+
}
|
|
79
|
+
}));
|
|
80
|
+
this.working = false;
|
|
81
|
+
this.createdMissions.emit(createdMissions);
|
|
82
|
+
this.addedEmails = [];
|
|
83
|
+
}
|
|
84
|
+
async handleFileInput(eventTarget) {
|
|
85
|
+
const files = eventTarget.files;
|
|
86
|
+
const uploaded = files.item(0);
|
|
87
|
+
if (uploaded.name.includes(".csv")) {
|
|
88
|
+
Papa.parse(uploaded, {
|
|
89
|
+
complete: function onComplete(results) {
|
|
90
|
+
for (const mail of results.data) {
|
|
91
|
+
this.addedEmails.push(mail[0]);
|
|
92
|
+
}
|
|
93
|
+
}.bind(this),
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
else {
|
|
97
|
+
alert("Not a csv file");
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CreateBatchComponent, deps: [{ token: i1.MissionService }, { token: i1.BaseUserService }, { token: i2.TranslateService }], target: i0.ɵɵFactoryTarget.Component });
|
|
101
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CreateBatchComponent, selector: "lib-create-batch", inputs: { template: "template" }, outputs: { createdMissions: "createdMissions" }, ngImport: i0, template: "<div>\r\n <h4>{{'Add email address' | translate}}</h4>\r\n <div class=\"row\">\r\n <input class=\"form-control custom-form\" #box (keyup.enter)=\"onAddEmail(box.value); box.value=''\"\r\n placeholder=\"me@example.com\" data-testid=\"form-user-email\">\r\n <div class=\"outer_circle\" style='margin-left: 1.1em;'>\r\n <button id='btn-icon' (click)=\"onAddEmail(box.value); box.value=''\" data-testid=\"form-user-email-btn\"></button>\r\n </div>\r\n </div>\r\n\r\n <div class=\"row mt-3\">\r\n <label for=\"file\" class=\"btn btn-label-file rounded-pill\">\r\n <input type=\"file\" id=\"file\" (change)=\"handleFileInput($event.target)\" />\r\n {{'Upload from csv' | translate}}</label>\r\n </div>\r\n\r\n <ul *ngIf=\"addedEmails.length > 0\">\r\n <li class=\"list_item\" *ngFor=\"let mail of addedEmails; index as index\">{{mail}}\r\n <div class=\"icon-container\" (click)=\"onDelete(index)\">\r\n <span class=\"iconify\" data-icon=\"mdi:trash-can-outline\"></span>\r\n </div>\r\n </li>\r\n </ul>\r\n <div class=\"d-flex justify-content-center\" *ngIf=\"working\">\r\n <lib-loader></lib-loader>\r\n </div>\r\n <div class=\"row action-button-container\">\r\n <button class=\"btn btn-outline-primary rounded-pill mr-2 mt-3 action-button\" data-testid=\"form-user-submit-btn\" (click)=\"onCreateMissions()\">\r\n {{'Create users' | translate}}</button>\r\n <button class=\"btn btn-outline-primary rounded-pill mr-2 mt-3 action-button\" data-testid=\"form-user-cancel-btn\" (click)=\"onCancel()\">\r\n {{'Cancel' | translate}}</button>\r\n </div>\r\n\r\n</div>", styles: ["#btn-icon{width:30px;height:30px;background:url(../../../../assets/icons/plus.svg);border:none;vertical-align:middle}#btn-icon:hover{background:url(../../../../assets/icons/plus-over.svg)}#btn-icon[disabled]:hover{background:url(../../../../assets/icons/plus.svg)}.outer_circle{background-color:#ebebeb;border-radius:50%;width:32px;height:32px;padding:1px;margin-left:5px}.custom-form{width:80%}h4{color:var(--smarterplan-primary)}.pointer{cursor:pointer}.list_item{display:flex;font-size:1.1em}.icon-container{cursor:pointer;margin-left:5px}input[type=file]{display:none}.form-group{margin:1.5rem 0}label.col-sm-4.col-form-label{width:200px;min-width:200px}.action-button-container{display:flex;justify-content:space-evenly}.action-button-container .action-button{width:145px}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i1.LoaderComponent, selector: "lib-loader", inputs: ["useLogo", "color"] }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }] });
|
|
102
|
+
}
|
|
103
|
+
export { CreateBatchComponent };
|
|
104
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CreateBatchComponent, decorators: [{
|
|
105
|
+
type: Component,
|
|
106
|
+
args: [{ selector: 'lib-create-batch', template: "<div>\r\n <h4>{{'Add email address' | translate}}</h4>\r\n <div class=\"row\">\r\n <input class=\"form-control custom-form\" #box (keyup.enter)=\"onAddEmail(box.value); box.value=''\"\r\n placeholder=\"me@example.com\" data-testid=\"form-user-email\">\r\n <div class=\"outer_circle\" style='margin-left: 1.1em;'>\r\n <button id='btn-icon' (click)=\"onAddEmail(box.value); box.value=''\" data-testid=\"form-user-email-btn\"></button>\r\n </div>\r\n </div>\r\n\r\n <div class=\"row mt-3\">\r\n <label for=\"file\" class=\"btn btn-label-file rounded-pill\">\r\n <input type=\"file\" id=\"file\" (change)=\"handleFileInput($event.target)\" />\r\n {{'Upload from csv' | translate}}</label>\r\n </div>\r\n\r\n <ul *ngIf=\"addedEmails.length > 0\">\r\n <li class=\"list_item\" *ngFor=\"let mail of addedEmails; index as index\">{{mail}}\r\n <div class=\"icon-container\" (click)=\"onDelete(index)\">\r\n <span class=\"iconify\" data-icon=\"mdi:trash-can-outline\"></span>\r\n </div>\r\n </li>\r\n </ul>\r\n <div class=\"d-flex justify-content-center\" *ngIf=\"working\">\r\n <lib-loader></lib-loader>\r\n </div>\r\n <div class=\"row action-button-container\">\r\n <button class=\"btn btn-outline-primary rounded-pill mr-2 mt-3 action-button\" data-testid=\"form-user-submit-btn\" (click)=\"onCreateMissions()\">\r\n {{'Create users' | translate}}</button>\r\n <button class=\"btn btn-outline-primary rounded-pill mr-2 mt-3 action-button\" data-testid=\"form-user-cancel-btn\" (click)=\"onCancel()\">\r\n {{'Cancel' | translate}}</button>\r\n </div>\r\n\r\n</div>", styles: ["#btn-icon{width:30px;height:30px;background:url(../../../../assets/icons/plus.svg);border:none;vertical-align:middle}#btn-icon:hover{background:url(../../../../assets/icons/plus-over.svg)}#btn-icon[disabled]:hover{background:url(../../../../assets/icons/plus.svg)}.outer_circle{background-color:#ebebeb;border-radius:50%;width:32px;height:32px;padding:1px;margin-left:5px}.custom-form{width:80%}h4{color:var(--smarterplan-primary)}.pointer{cursor:pointer}.list_item{display:flex;font-size:1.1em}.icon-container{cursor:pointer;margin-left:5px}input[type=file]{display:none}.form-group{margin:1.5rem 0}label.col-sm-4.col-form-label{width:200px;min-width:200px}.action-button-container{display:flex;justify-content:space-evenly}.action-button-container .action-button{width:145px}\n"] }]
|
|
107
|
+
}], ctorParameters: function () { return [{ type: i1.MissionService }, { type: i1.BaseUserService }, { type: i2.TranslateService }]; }, propDecorators: { template: [{
|
|
108
|
+
type: Input
|
|
109
|
+
}], createdMissions: [{
|
|
110
|
+
type: Output
|
|
111
|
+
}] } });
|
|
112
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create-batch.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-smarterplan-admin/src/lib/visitor/create-batch/create-batch.component.ts","../../../../../../projects/ngx-smarterplan-admin/src/lib/visitor/create-batch/create-batch.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { Mission, MissionService, BaseUserService, Profile, validEmail, VisitTemplate, RoleStatus } from '@smarterplan/ngx-smarterplan-core';\r\nimport * as Papa from 'papaparse';\r\n\r\n@Component({\r\n    selector: 'lib-create-batch',\r\n    templateUrl: './create-batch.component.html',\r\n    styleUrls: ['./create-batch.component.scss']\r\n})\r\nexport class CreateBatchComponent implements OnInit {\r\n    @Input() template: VisitTemplate;\r\n\r\n    @Output() createdMissions = new EventEmitter<Mission[]>();\r\n\r\n    addedEmails: string[] = [];\r\n\r\n    csvFile: File;\r\n\r\n    working = false;\r\n\r\n    constructor(\r\n        private missionService: MissionService,\r\n        private userService: BaseUserService,\r\n        private translate: TranslateService,\r\n    ) { }\r\n\r\n    ngOnInit(): void { }\r\n\r\n    onAddEmail(value: string) {\r\n        if (value) {\r\n            if (validEmail(value)) {\r\n                this.addedEmails.push(value);\r\n            } else {\r\n                alert(\"Please, enter a valid email address\");\r\n            }\r\n        }\r\n    }\r\n\r\n    onDelete(index) {\r\n        this.addedEmails.splice(index, 1);\r\n    }\r\n\r\n    onCancel() {\r\n        this.createdMissions.emit(null);\r\n    }\r\n\r\n    async onCreateMissions() {\r\n        const createdMissions = [];\r\n        let user: Profile;\r\n        this.working = true;\r\n        await Promise.all(\r\n            this.addedEmails.map(async (mail) => {\r\n                user = await this.userService.profileForMail(mail);\r\n                if (!user) {\r\n                    try {\r\n                        const profile =\r\n                            await this.userService.createUserAWSandProfile(\r\n                                {\r\n                                    email: mail,\r\n                                    lastName: mail,\r\n                                    firstName: \"\",\r\n                                    phone: \"\",\r\n                                },\r\n                                true,\r\n                            );\r\n                        user = profile;\r\n                    } catch (error) {\r\n                        alert(\r\n                            `Error creating users: ${this.translate.instant(\r\n                                error as string,\r\n                            )}`,\r\n                        );\r\n                        this.working = false;\r\n                        return;\r\n                    }\r\n                }\r\n                if (user) {\r\n                    const missionInput: Mission = {\r\n                        organisationID: this.template.organisationID,\r\n                        orderedOrganisationID: this.template.organisationID,\r\n                        level: this.template.level,\r\n                        role: RoleStatus.VISITOR_MUSEUM,\r\n                        description: \"Generated from template\",\r\n                        userID: user.id,\r\n                        startDateTime: this.template.startDateTime,\r\n                        endDateTime: this.template.endDateTime,\r\n                        spaceID: this.template.spaceID,\r\n                        zoneID: this.template.zoneID,\r\n                        templateMissionID: this.template.id,\r\n                        hashtags: this.template.hashtags,\r\n                    };\r\n                    const mission = await this.missionService.create(\r\n                        missionInput,\r\n                    );\r\n                    createdMissions.push(mission);\r\n                }\r\n            }),\r\n        );\r\n        this.working = false;\r\n        this.createdMissions.emit(createdMissions);\r\n        this.addedEmails = [];\r\n    }\r\n\r\n    async handleFileInput(eventTarget: any) {\r\n        const files = eventTarget.files;\r\n        const uploaded = files.item(0);\r\n        if (uploaded.name.includes(\".csv\")) {\r\n            Papa.parse(uploaded, {\r\n                complete: function onComplete(results) {\r\n                    for (const mail of results.data) {\r\n                        this.addedEmails.push(mail[0]);\r\n                    }\r\n                }.bind(this),\r\n            });\r\n        } else {\r\n            alert(\"Not a csv file\");\r\n        }\r\n    }\r\n\r\n}\r\n","<div>\r\n    <h4>{{'Add email address' | translate}}</h4>\r\n    <div class=\"row\">\r\n        <input class=\"form-control custom-form\" #box (keyup.enter)=\"onAddEmail(box.value); box.value=''\"\r\n            placeholder=\"me@example.com\" data-testid=\"form-user-email\">\r\n        <div class=\"outer_circle\" style='margin-left: 1.1em;'>\r\n            <button id='btn-icon' (click)=\"onAddEmail(box.value); box.value=''\" data-testid=\"form-user-email-btn\"></button>\r\n        </div>\r\n    </div>\r\n\r\n    <div class=\"row mt-3\">\r\n        <label for=\"file\" class=\"btn btn-label-file rounded-pill\">\r\n            <input type=\"file\" id=\"file\" (change)=\"handleFileInput($event.target)\" />\r\n            {{'Upload from csv' | translate}}</label>\r\n    </div>\r\n\r\n    <ul *ngIf=\"addedEmails.length > 0\">\r\n        <li class=\"list_item\" *ngFor=\"let mail of addedEmails; index as index\">{{mail}}\r\n            <div class=\"icon-container\" (click)=\"onDelete(index)\">\r\n                <span class=\"iconify\" data-icon=\"mdi:trash-can-outline\"></span>\r\n            </div>\r\n        </li>\r\n    </ul>\r\n    <div class=\"d-flex justify-content-center\" *ngIf=\"working\">\r\n        <lib-loader></lib-loader>\r\n    </div>\r\n    <div class=\"row action-button-container\">\r\n        <button class=\"btn btn-outline-primary rounded-pill mr-2 mt-3 action-button\" data-testid=\"form-user-submit-btn\" (click)=\"onCreateMissions()\">\r\n            {{'Create users' | translate}}</button>\r\n        <button class=\"btn btn-outline-primary rounded-pill mr-2 mt-3 action-button\" data-testid=\"form-user-cancel-btn\" (click)=\"onCancel()\">\r\n            {{'Cancel' | translate}}</button>\r\n    </div>\r\n\r\n</div>"]}
|