summaryrefslogtreecommitdiff
path: root/src/gui/windowAdmin.py
blob: 3996615cd00fcbff41fff5d4fbb7af069747479d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180

from PyQt5.QtWidgets import (
    QDialog, QGroupBox, QLabel,
    QLineEdit, QVBoxLayout, QHBoxLayout,
    QGridLayout, QPushButton, QComboBox
)
from src.database import dbsearch, dbadmin, dbmission
from src.core import coreAdmin


class admin_emplois():
    def cmb_populate(self, mainWindow: object , cmb: object) -> None:
        # Instanciation DB
        search:  object = dbsearch.DbSearch(mainWindow)
        allJobs: object = search.get_job_all()
        cmb.clear()
        for i in allJobs:
            cmb.addItem(f"{i[2]}", i[0])

    def __init__(self, mainWindow: object) -> None:
        # Fenêtre
        dial: object = QDialog(parent = mainWindow)
        dial.setWindowTitle("Admin - Emplois")

        # Widgets Ajout
        labAjoutEn: object = QLabel("Nom en Anglais")
        inpAjoutEn: object = QLineEdit()
        labAjoutFr: object = QLabel("Nom en Français")
        inpAjoutFr: object = QLineEdit()
        btnAjout:   object = QPushButton("Enregistrer")
        btnAjout.clicked.connect(
            lambda: [
                coreAdmin.core_ajout_emploi(
                    mainWindow,
                    inpAjoutEn.text(),
                    inpAjoutFr.text()
                ),
                self.cmb_populate(mainWindow, cmbSuppr)
            ]
        )
        # Layout Ajout
        layAjout: object = QGridLayout()
        layAjout.addWidget(labAjoutEn, 0, 0)
        layAjout.addWidget(inpAjoutEn, 0, 1)
        layAjout.addWidget(labAjoutFr, 1, 0)
        layAjout.addWidget(inpAjoutFr, 1, 1)
        layAjout.addWidget(btnAjout,   2, 1)
        # Grp Ajout
        grpAjout: object = QGroupBox("Ajout d'un emploi")
        grpAjout.setLayout(layAjout)

        # Widgets Suppr
        labSuppr: object = QLabel("Emploi à supprimmer")
        cmbSuppr: object = QComboBox()
        self.cmb_populate(mainWindow, cmbSuppr)
        btnSuppr: object = QPushButton("Supprimer")
        btnSuppr.clicked.connect(
            lambda: [
                coreAdmin.core_suppr_emploi(
                    mainWindow,
                    cmbSuppr.currentData()
                ),
                self.cmb_populate(mainWindow, cmbSuppr)
            ]
        )
        # Layouts Suppr
        laySuppr: object = QGridLayout()
        laySuppr.addWidget(labSuppr, 0, 0)
        laySuppr.addWidget(cmbSuppr, 0, 1)
        laySuppr.addWidget(btnSuppr, 1, 1)
        # Grp Suppr
        grpSuppr: object = QGroupBox("Suppression d'un emploi")
        grpSuppr.setLayout(laySuppr)

        # Layout Main & show
        layoutMain: object = QVBoxLayout()
        layoutMain.addWidget(grpAjout)
        layoutMain.addWidget(grpSuppr)
        dial.setLayout(layoutMain)
        dial.show()


def admin_users(mainWindow: object) -> None:
    # Instanciation DB
    admin:    object = dbadmin.DbAdmin(mainWindow)
    allUsers: object = admin.get_all_users_account()

    # Fenêtre
    dial: object = QDialog(parent = mainWindow)
    dial.setWindowTitle("Admin - Utilisateurs")

    # Widgets Users
    labUserId: object = QLabel("Id à supprimer")
    inpUserId: object = QLineEdit()
    btnSuppr:  object = QPushButton("Supprimer")
    btnSuppr.clicked.connect(
        lambda: [
            coreAdmin.core_suppr_user(
                mainWindow,
                inpUserId.text()
            ),
            dial.close()
        ]
    )
    labAllUsers: list = []
    for i in allUsers:
        labAllUsers.append(QLabel(f"ID:{i[0]} Mail:{i[1]} Inscr.{i[4]} Status:{i[5]}"))
    # Layouts Users
    layUsersCmd: object = QHBoxLayout()
    layUsersCmd.addStretch()
    layUsersCmd.addWidget(labUserId)
    layUsersCmd.addWidget(inpUserId)
    layUsersCmd.addWidget(btnSuppr)
    layUsersCmd.addStretch()
    layUsers: object = QVBoxLayout()
    for i in range(len(labAllUsers)):
        layUsers.addWidget(labAllUsers[i])
    layUserMain: object = QVBoxLayout()
    layUserMain.addLayout(layUsersCmd)
    layUserMain.addLayout(layUsers)
    # Grp Users
    grpUser: object = QGroupBox("Suppression d'un utilisateur")
    grpUser.setLayout(layUserMain)

    # Layout Main & Show
    layoutMain: object = QVBoxLayout()
    layoutMain.addWidget(grpUser)
    dial.setLayout(layoutMain)
    dial.show()


def admin_missions(mainWindow: object):
    # Instanciation DB
    mission: object = dbmission.DbMission(mainWindow)
    search:  object = dbsearch.DbSearch(mainWindow)

    # Fenêtre
    dial: object = QDialog(parent = mainWindow)
    dial.setWindowTitle("Admin - Missions")

    # Widgets Users
    labMissionId:   object = QLabel("Id à supprimer")
    inpMissionId:   object = QLineEdit()
    btnSuppr:       object = QPushButton("Supprimer")
    btnSuppr.clicked.connect(
        lambda: [
            coreAdmin.core_suppr_mission(
                mainWindow,
                inpMissionId.text()
            ),
            dial.close()
        ]
    )
    allMissions:    object = mission.get_all_missions()
    labAllMissions: list = []
    for i in allMissions:
        emploi = search.get_job_by_jobid(i[10])[0][2]
        labAllMissions.append(QLabel(f"ID:{i[0]} date:{i[1].strftime('%m/%d/%Y')} Emploi:{emploi} sujet:{i[2]} clientId:{i[8]} proId:{i[9]} "))
    # Layouts Missions
    layMissionsCmd: object = QHBoxLayout()
    layMissionsCmd.addStretch()
    layMissionsCmd.addWidget(labMissionId)
    layMissionsCmd.addWidget(inpMissionId)
    layMissionsCmd.addWidget(btnSuppr)
    layMissionsCmd.addStretch()
    layMissions: object = QVBoxLayout()
    for i in range(len(labAllMissions)):
        layMissions.addWidget(labAllMissions[i])
    layMissionMain: object = QVBoxLayout()
    layMissionMain.addLayout(layMissionsCmd)
    layMissionMain.addLayout(layMissions)
    # Grp Missions
    grpMission: object = QGroupBox("Suppression d'une mission")
    grpMission.setLayout(layMissionMain)

    # Layout Main & Show
    layoutMain: object = QVBoxLayout()
    layoutMain.addWidget(grpMission)
    dial.setLayout(layoutMain)
    dial.show()