Проект iMpos. Часть 008. Редактирование справочника пользователей

QTableWidgetItem, QAction, QTableWidget, QDialog

Диалог редактирование справочника пользователей

В форме mainwindow.ui добавляем пункт меню Пользователи которому соответвует объект actionUsers. Назначаем ему значок и горячую клавишу.
Создаем Класс формы Qt Designer с именем UsersDialog.
В слоте MainWindow::on_actionUsers_triggered() реализуем вызов диалога Пользователи.

void MainWindow::on_actionUsers_triggered()
{
    UsersDialog *usersDlg = new UsersDialog(this);
    usersDlg->move(this->geometry().center().x() - usersDlg->geometry().center().x(),
                   this->geometry().center().y() - usersDlg->geometry().center().y());
    usersDlg->exec();
}

Добавляем в диалог, используя Qt Designer, элементы управления.

Реализация класса UserDialog
userdialog.h

#ifndef USERSDIALOG_H
#define USERSDIALOG_H

#include <QDialog>
#include <QSqlQuery>
#include <QSqlError>
#include <QTableWidgetItem>

namespace Ui {
class UsersDialog;
}

class UsersDialog : public QDialog
{
    Q_OBJECT

public:
    explicit UsersDialog(QWidget *parent = nullptr);
    ~UsersDialog();

private slots:
    void on_pushButtonAdd_clicked();
    void on_buttonBox_accepted();
    void on_tableWidget_itemSelectionChanged();
    void on_buttonBox_rejected();
    void on_pushButtonEdit_clicked();
    void on_pushButtonClose_clicked();
    void on_tableWidget_cellDoubleClicked(int row, int column);

private:
    void createUI();            //Создание первоначального интерефейса
    void createTable();         //Заолнение TableWidget
private:
    Ui::UsersDialog *ui;
    QSqlDatabase db;                    // Объект Базы данных
    QTableWidgetItem *currentItem;      //Текущий оператор.
    bool isNew;                         //Выполняется добавление оператора или правка

};

#endif // USERSDIALOG_H

userdialog.cpp

#include "usersdialog.h"
#include "ui_usersdialog.h"
#include "LoggingCategories/loggingcategories.h"
#include <QMessageBox>


UsersDialog::UsersDialog(QWidget *parent) :
    QDialog(parent),
    ui(new Ui::UsersDialog)
{
    ui->setupUi(this);

    //Используем соединение options
    db = QSqlDatabase::database("options");

    createUI();
}

UsersDialog::~UsersDialog()
{
    delete ui;
}

void UsersDialog::createUI()
{
    ui->groupBoxUserData->hide();           //Скрываем информацию о пользователе.
    ui->checkBoxIsActive->setChecked(true); //Устанавливаем выбранным
    //Колличество столбцов
    ui->tableWidget->setColumnCount(5);
    //Заолняем TableWidget данными
    createTable();
}

void UsersDialog::createTable()
{
    //заголовки столбцов
    ui->tableWidget->setHorizontalHeaderLabels(QStringList()<<"ID"<<"Логин"<<"Пароль"<<""<<"Активность");
    QSqlQuery q = QSqlQuery(db);
    //Получаем список пользователей
    if(!q.exec("select user_id, fio, password, isactive FROM users order by user_id"))
        qCritical(logCritical())<< "Не возможно получить список пользователей" << q.lastError().text();
    int i = 0;              //Текущая строка
    //Создаем и заполняем таблицу пользователей
    while(q.next()){
        ui->tableWidget->insertRow(i);
        ui->tableWidget->setItem(i,0,new QTableWidgetItem(q.value(0).toString()));
        ui->tableWidget->setItem(i,1,new QTableWidgetItem(q.value(1).toString()));
        ui->tableWidget->setItem(i,2,new QTableWidgetItem(q.value(2).toString()));
        ui->tableWidget->setItem(i,3,new QTableWidgetItem(q.value(3).toString()));
        if(q.value(3).toBool()){
            ui->tableWidget->setItem(i,4, new QTableWidgetItem(QIcon(":/Image/userActive.png"),"Активен"));
        } else {
            ui->tableWidget->setItem(i,4, new QTableWidgetItem(QIcon(":/Image/userNoActive.png"),"Не Активен"));
        }
        ++i;
    }
    //Скрываем горизонтальный заголовок и 3-й столбец
    ui->tableWidget->verticalHeader()->hide();
    ui->tableWidget->hideColumn(3);
    //Ширина колонки по содержимому
    ui->tableWidget->resizeColumnsToContents();
    //Высота сторок
    ui->tableWidget->verticalHeader()->setDefaultSectionSize(40);
    ui->pushButtonEdit->setDisabled(true);

}

void UsersDialog::on_pushButtonAdd_clicked()
{
    ui->groupBoxUserData->show();
    ui->tableWidget->setDisabled(true);
    ui->pushButtonAdd->setDisabled(true);
    ui->pushButtonEdit->setDisabled(true);
    isNew = true;
}

void UsersDialog::on_buttonBox_accepted()
{
    //Простая проверка заполнения полей
    if(ui->lineEditLogin->text().size()<3 || ui->lineEditPass->text().size()<1) {
        QMessageBox::warning(this,"Ошибка","Не заполнены обязательные поля.");
        return;
    }
    QSqlQuery q = QSqlQuery(db);
    if(isNew){
        //Новая запись
        q.prepare("INSERT INTO `users`(`fio`,`password`) VALUES (:userName,:passw)");
        q.bindValue(":userName", ui->lineEditLogin->text().trimmed());
        q.bindValue(":passw", ui->lineEditPass->text().trimmed());
        if(q.exec()){
            //Очищаем TableWidget
            ui->tableWidget->clear();
            ui->tableWidget->setRowCount(0);
            //Заолняем TableWidget обновленными данными
            createTable();
        } else {
            qInfo(logInfo()) << "Не удалось добавить опреатора" << q.lastError().text();
        }
    } else {
        //Редактируем запись
        q.prepare("UPDATE users SET fio = :userName, password = :passw, isactive = :isactive WHERE user_id = :userid");
        q.bindValue(":userName", ui->lineEditLogin->text().trimmed());
        q.bindValue(":passw", ui->lineEditPass->text().trimmed());
        q.bindValue(":isactive",(ui->checkBoxIsActive->isChecked()) ? "true" : "false" );
        q.bindValue(":userid", ui->tableWidget->item(currentItem->row(),0)->text());
        if(q.exec()){
            //Очищаем TableWidget
            ui->tableWidget->clear();
            ui->tableWidget->setRowCount(0);
            //Заолняем TableWidget обновленными данными
            createTable();
        } else {
            qInfo(logInfo()) << "Не удалось обновить данные оператора опреатора" << q.lastError().text();
        }
    }
    ui->groupBoxUserData->hide();
    ui->tableWidget->setEnabled(true);
    ui->tableWidget->clearSelection();
    ui->pushButtonAdd->setEnabled(true);
    ui->lineEditPass->clear();
    ui->lineEditLogin->clear();
}

void UsersDialog::on_buttonBox_rejected()
{
    ui->groupBoxUserData->hide();
    ui->tableWidget->setEnabled(true);
    ui->pushButtonAdd->setEnabled(true);
    ui->tableWidget->clearSelection();
    ui->lineEditPass->clear();
    ui->lineEditLogin->clear();
}

void UsersDialog::on_tableWidget_itemSelectionChanged()
{
    //Получаем текущее выделение
    currentItem = ui->tableWidget->currentItem();
    //разрешаем редактирование
    ui->pushButtonEdit->setEnabled(true);
}

void UsersDialog::on_pushButtonEdit_clicked()
{
    ui->groupBoxUserData->show();
    ui->tableWidget->setDisabled(true);
    ui->pushButtonAdd->setDisabled(true);
    ui->pushButtonEdit->setDisabled(true);
    //Заполняем объекты данными о выбранном пользователе
    ui->lineEditLogin->setText(ui->tableWidget->item(currentItem->row(),1)->text());
    ui->lineEditPass->setText(ui->tableWidget->item(currentItem->row(),2)->text());
    ui->checkBoxIsActive->setChecked(QVariant(ui->tableWidget->item(currentItem->row(),3)->text()).toBool());

    isNew = false;

}

void UsersDialog::on_pushButtonClose_clicked()
{
    this->reject();
}

void UsersDialog::on_tableWidget_cellDoubleClicked(int row, int column)
{
    //Вызываем редактирование по двойнгому щелчку мыши
    Q_UNUSED(row);
    Q_UNUSED(column);
    on_pushButtonEdit_clicked();
}

Запускаем программу Натройки-Пользователи, добавляем нового.

Огрничение доступа

Для того чтобы ограничить всем пользователям кроме Администратора доступ к настройкам в MainWindow::createUI() изменим запрос для получения данных о текущем пользователе и если uiser_id не равен 1 деактивируем соответсвующие actions.

    q.exec("SELECT u.user_id, u.fio FROM users u "
           "INNER JOIN options o ON u.user_id = o.value "
           "WHERE o.option_id = 1020");
    q.next();
    labelUsers->setText("Пользователь: "+q.value(1).toString());
    if(q.value(0).toInt() != 1){
        ui->actionUsers->setEnabled(false);
        ui->actionSettings->setEnabled(false);
    }

Заходим под новым пользователем. Пункты меню в меню Инструменты не активны.

Архив проекта

iMposCh008.zip iMposCh008.zip

We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.

Comments

Only authorized users can post comments.
Please, Log in or Sign up
Donate

Hello, Dear Users of EVILEG!!!

If the site helped you, then support the development of the site financially, please.

You can do it by following ways:

Thank you, Evgenii Legotckoi

n
Dec. 9, 2019, 12:46 p.m.
nastya4554

C++ - Тест 003. Условия и циклы

  • Result:78points,
  • Rating points2
N
Dec. 9, 2019, 4:49 a.m.
Nnnnanananna

C ++ - Test 004. Pointers, Arrays and Loops

  • Result:20points,
  • Rating points-10
NB
Dec. 9, 2019, 3:29 a.m.
Nikolaj Batmanov

C++ - Test 002. Constants

  • Result:58points,
  • Rating points-2
Last comments
Dec. 9, 2019, 3:41 a.m.
Evgenij Legotskoj

Эта ошибка invalid use of incomplete type ‘class Ui::AnotherWindow’ обычно говорит о том, что не найдено определение класса или структуры. Типичная проблема - не подключён заголовочны…
NB
Dec. 9, 2019, 3:36 a.m.
Nikolaj Batmanov

Ну, не настолько со мной всё полхо...))) Вроде бы. Я ж кнопки отрисовываю.
Dec. 9, 2019, 3:14 a.m.
Evgenij Legotskoj

Добрый день. У вас ui файлов по ходу нет. UI файлы используются для вёрстки в графическом дизайнере.
NB
Dec. 9, 2019, 3:05 a.m.
Nikolaj Batmanov

Здравствуйте! Полностью скопировал ваш пример к себе, чтобы разобраться. А он не хочет запускаться, дает ошибку: invalid use of incomplete type ‘class Ui::AnotherWindow’ ui(new Ui…
Dec. 8, 2019, 7:23 a.m.
Evgenij Legotskoj

У меня здесь есть одна старая статья с примером векторного редактора. Там есть ответы на ваши вопросы. Поизучайте Qt/C++ - Урок 072. Пример векторного редактора на Qt QGraphicsItem, QG…
Now discuss on the forum
Dec. 9, 2019, 7:16 a.m.
qml_puthon_user

Я сделал простой вывод текста по испусканию сигнала... Чего не хватает программе?) Python: # системные библиотекиimport cv2import numpy as npimport sysimport threading# PyQt б…
SK
Dec. 8, 2019, 4:11 p.m.
Semen Kosandjak

інтерфейс qt, приклад того додаю на малюнку, я натискаю на кнопку і у мене з'являється 2 текст лайну в які я вводжу значення, тобто в 1 цифри,у другому випадку це літери, тобто c++, без графічно…
Dec. 8, 2019, 10:21 a.m.
qml_puthon_user

Тут не подскажу, пишу на питоне.)
Dec. 8, 2019, 5:31 a.m.
BlinCT

Всем привет. Впервые столкнулся со сборкой buildroot и наткнулся на пару странных ошибок. Надеюсь кто то прочитавший сможет что то подсказать, так как мне пока они не понятный. Пе…
Dec. 5, 2019, 4:12 p.m.
Evgenij Legotskoj

Это уже кастомная стилизация. Придётся отключать обрамление и самостоятельно реализовывать ресайз окна, его перемещение, стиль и т.д. Вот статья, как отключить обрамление окна - QML …
EVILEG
About
Services
© EVILEG 2015-2019
Recommend hosting TIMEWEB