Merge branch 'main' into schnacke
refresh
This commit is contained in:
@@ -3,7 +3,7 @@ import QtQuick.Layouts
|
|||||||
import QtQuick.Controls
|
import QtQuick.Controls
|
||||||
ApplicationWindow
|
ApplicationWindow
|
||||||
{
|
{
|
||||||
id: addmitarbeiter
|
id: addMitarbeiter
|
||||||
title: qsTr("Objekt - Neuer Mitarbeiter")
|
title: qsTr("Objekt - Neuer Mitarbeiter")
|
||||||
|
|
||||||
ColumnLayout
|
ColumnLayout
|
||||||
@@ -31,6 +31,7 @@ ApplicationWindow
|
|||||||
}
|
}
|
||||||
TextField
|
TextField
|
||||||
{
|
{
|
||||||
|
id: assignee
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
}
|
}
|
||||||
Label
|
Label
|
||||||
@@ -40,6 +41,7 @@ ApplicationWindow
|
|||||||
}
|
}
|
||||||
TextField
|
TextField
|
||||||
{
|
{
|
||||||
|
id: wage
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
}
|
}
|
||||||
Label
|
Label
|
||||||
@@ -49,6 +51,7 @@ ApplicationWindow
|
|||||||
}
|
}
|
||||||
TextField
|
TextField
|
||||||
{
|
{
|
||||||
|
id: duration
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
}
|
}
|
||||||
Label
|
Label
|
||||||
@@ -58,6 +61,7 @@ ApplicationWindow
|
|||||||
}
|
}
|
||||||
TextField
|
TextField
|
||||||
{
|
{
|
||||||
|
id: cleanDays
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
}
|
}
|
||||||
Label
|
Label
|
||||||
@@ -67,6 +71,7 @@ ApplicationWindow
|
|||||||
}
|
}
|
||||||
TextField
|
TextField
|
||||||
{
|
{
|
||||||
|
id: tasks
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
}
|
}
|
||||||
Label
|
Label
|
||||||
@@ -76,6 +81,7 @@ ApplicationWindow
|
|||||||
}
|
}
|
||||||
TextField
|
TextField
|
||||||
{
|
{
|
||||||
|
id: output
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -90,11 +96,30 @@ ApplicationWindow
|
|||||||
Button
|
Button
|
||||||
{
|
{
|
||||||
text: qsTr("Abbrechen")
|
text: qsTr("Abbrechen")
|
||||||
|
onClicked: addMitarbeiter.close()
|
||||||
}
|
}
|
||||||
Button
|
Button
|
||||||
{
|
{
|
||||||
text: qsTr("Hinzufügen")
|
text: qsTr("Hinzufügen")
|
||||||
|
onClicked:
|
||||||
|
{
|
||||||
|
if (assignee.text.trim() !== "" && duration.text.trim() !== "" && wage.text.trim() !== "" && cleanDays.text.trim() !== "" && tasks.text.trim() !== "" && output.text.trim() !== "")
|
||||||
|
{
|
||||||
|
var ne = {
|
||||||
|
"assignee": assignee.text.trim(),
|
||||||
|
"duration": duration.text.trim(),
|
||||||
|
"wage": wage.text.trim(),
|
||||||
|
"cleandays": cleanDays.text.trim(),
|
||||||
|
"tasks": tasks.text.trim(),
|
||||||
|
"output": output.text.trim(),
|
||||||
|
};
|
||||||
|
addMitarbeiter.addNewEmployee(ne)
|
||||||
|
addMitarbeiter.close()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
signal addNewEmployee(var new_employee)
|
||||||
|
}
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ import QtQuick.Controls
|
|||||||
|
|
||||||
GridLayout
|
GridLayout
|
||||||
{
|
{
|
||||||
|
property var contacts: null
|
||||||
columns: 2
|
columns: 2
|
||||||
|
|
||||||
CheckBox
|
CheckBox
|
||||||
@@ -11,14 +12,6 @@ GridLayout
|
|||||||
id: contactperson
|
id: contactperson
|
||||||
text: qsTr("Ansprechpartner")
|
text: qsTr("Ansprechpartner")
|
||||||
Layout.columnSpan: 2
|
Layout.columnSpan: 2
|
||||||
onCheckStateChanged:
|
|
||||||
{
|
|
||||||
title.enabled = contactperson.checked
|
|
||||||
firstname.enabled = contactperson.checked
|
|
||||||
lastname.enabled = contactperson.checked
|
|
||||||
phonenumber.enabled = contactperson.checked
|
|
||||||
posizion.enabled = contactperson.checked
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
Label
|
Label
|
||||||
{
|
{
|
||||||
@@ -30,7 +23,7 @@ GridLayout
|
|||||||
id: title
|
id: title
|
||||||
model: [qsTr("Herr"),qsTr("Frau")]
|
model: [qsTr("Herr"),qsTr("Frau")]
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
enabled: false
|
enabled: contactperson.checked
|
||||||
}
|
}
|
||||||
Label
|
Label
|
||||||
{
|
{
|
||||||
@@ -43,7 +36,7 @@ GridLayout
|
|||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
placeholderText: "Pflichtfeld"
|
placeholderText: "Pflichtfeld"
|
||||||
placeholderTextColor: "red"
|
placeholderTextColor: "red"
|
||||||
enabled: false
|
enabled: contactperson.checked
|
||||||
}
|
}
|
||||||
Label
|
Label
|
||||||
{
|
{
|
||||||
@@ -56,7 +49,7 @@ GridLayout
|
|||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
placeholderText: "Pflichtfeld"
|
placeholderText: "Pflichtfeld"
|
||||||
placeholderTextColor: "red"
|
placeholderTextColor: "red"
|
||||||
enabled: false
|
enabled: contactperson.checked
|
||||||
}
|
}
|
||||||
Label
|
Label
|
||||||
{
|
{
|
||||||
@@ -69,7 +62,7 @@ GridLayout
|
|||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
placeholderText: "Pflichtfeld"
|
placeholderText: "Pflichtfeld"
|
||||||
placeholderTextColor: "red"
|
placeholderTextColor: "red"
|
||||||
enabled: false
|
enabled: contactperson.checked
|
||||||
}
|
}
|
||||||
Label
|
Label
|
||||||
{
|
{
|
||||||
@@ -82,8 +75,147 @@ GridLayout
|
|||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
placeholderText: "Pflichtfeld"
|
placeholderText: "Pflichtfeld"
|
||||||
placeholderTextColor: "red"
|
placeholderTextColor: "red"
|
||||||
enabled: false
|
enabled: contactperson.checked
|
||||||
}
|
}
|
||||||
|
|
||||||
|
RowLayout
|
||||||
|
{
|
||||||
|
Layout.fillWidth: true
|
||||||
|
Layout.columnSpan: 2
|
||||||
|
|
||||||
|
Item
|
||||||
|
{
|
||||||
|
Layout.fillWidth: true
|
||||||
|
}
|
||||||
|
|
||||||
|
Button
|
||||||
|
{
|
||||||
|
id: removeContact
|
||||||
|
text: qsTr("Entfernen")
|
||||||
|
enabled: contactperson.checked
|
||||||
|
}
|
||||||
|
|
||||||
|
Button
|
||||||
|
{
|
||||||
|
id: addContact
|
||||||
|
text: qsTr("Hinzufügen")
|
||||||
|
enabled: contactperson.checked
|
||||||
|
onClicked:
|
||||||
|
{
|
||||||
|
var num_contacts = 0
|
||||||
|
if (contacts !== null && contacts !== undefined) num_contacts = Object.keys(contacts).length
|
||||||
|
else contacts = {}
|
||||||
|
if (num_contacts < 3 && firstname.text.trim() !== "" && lastname.text.trim() !== "" && phonenumber.text.trim() !== "" && posizion.text.trim() !== "")
|
||||||
|
{
|
||||||
|
contacts[num_contacts] = {}
|
||||||
|
contacts[num_contacts]["title"] = title.currentText
|
||||||
|
contacts[num_contacts]["fname"] = firstname.text.trim()
|
||||||
|
contacts[num_contacts]["lname"] = lastname.text.trim()
|
||||||
|
contacts[num_contacts]["phone"] = phonenumber.text.trim()
|
||||||
|
contacts[num_contacts]["position"] = posizion.text.trim()
|
||||||
|
|
||||||
|
contactModel.append({name: title.currentText + " " + firstname.text.trim() + " " + lastname.text.trim(), phone: phonenumber.text.trim(), posizion: posizion.text.trim()})
|
||||||
|
|
||||||
|
firstname.text = ""
|
||||||
|
lastname.text = ""
|
||||||
|
phonenumber.text = ""
|
||||||
|
posizion.text = ""
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Label
|
||||||
|
{
|
||||||
|
text: qsTr("Ansprechpartner")
|
||||||
|
Layout.alignment: Qt.AlignRight | Qt.AlignTop
|
||||||
|
}
|
||||||
|
|
||||||
|
ListModel
|
||||||
|
{
|
||||||
|
id: contactModel
|
||||||
|
}
|
||||||
|
|
||||||
|
Component
|
||||||
|
{
|
||||||
|
id: headline
|
||||||
|
Row
|
||||||
|
{
|
||||||
|
Text
|
||||||
|
{
|
||||||
|
id: cpname
|
||||||
|
text: qsTr("Name")
|
||||||
|
width: 175
|
||||||
|
font.bold: true
|
||||||
|
horizontalAlignment: Text.AlignLeft
|
||||||
|
color: "black"
|
||||||
|
}
|
||||||
|
|
||||||
|
Text
|
||||||
|
{
|
||||||
|
id: cpphone
|
||||||
|
text: qsTr("Telefon")
|
||||||
|
width: 100
|
||||||
|
font.bold: true
|
||||||
|
horizontalAlignment: Text.AlignLeft
|
||||||
|
color: "black"
|
||||||
|
}
|
||||||
|
|
||||||
|
Text
|
||||||
|
{
|
||||||
|
id: cppos
|
||||||
|
text: qsTr("Position")
|
||||||
|
width: 150
|
||||||
|
font.bold: true
|
||||||
|
horizontalAlignment: Text.AlignLeft
|
||||||
|
color: "black"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Rectangle
|
||||||
|
{
|
||||||
|
Layout.fillWidth: true
|
||||||
|
implicitHeight: 100
|
||||||
|
color: firstname.palette.base
|
||||||
|
border.color: firstname.activeFocus? firstname.palette.highlight: firstname.palette.base
|
||||||
|
ListView
|
||||||
|
{
|
||||||
|
id: contactView
|
||||||
|
implicitHeight: parent.height
|
||||||
|
model: contactModel
|
||||||
|
|
||||||
|
header: headline
|
||||||
|
|
||||||
|
delegate: Item
|
||||||
|
{
|
||||||
|
width: parent.width
|
||||||
|
height: 15
|
||||||
|
|
||||||
|
Row
|
||||||
|
{
|
||||||
|
//spacing: 9
|
||||||
|
Text
|
||||||
|
{
|
||||||
|
text: model.name
|
||||||
|
width: 175
|
||||||
|
horizontalAlignment: Text.AlignLeft
|
||||||
|
}
|
||||||
|
Text
|
||||||
|
{
|
||||||
|
text: model.phone
|
||||||
|
width: 100
|
||||||
|
horizontalAlignment: Text.AlignLeft
|
||||||
|
}
|
||||||
|
Text
|
||||||
|
{
|
||||||
|
text: model.posizion
|
||||||
|
width: 150
|
||||||
|
horizontalAlignment: Text.AlignLeft
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -4,50 +4,125 @@ import QtQuick.Controls
|
|||||||
|
|
||||||
GridLayout
|
GridLayout
|
||||||
{
|
{
|
||||||
|
property var employeeForm: null
|
||||||
|
property var employees: null
|
||||||
id: oaoemployee
|
id: oaoemployee
|
||||||
columns: 2
|
columns: 2
|
||||||
rows: 4
|
rows: 4
|
||||||
Label
|
Label
|
||||||
{
|
{
|
||||||
text: qsTr("Mitarbeiter")
|
text: qsTr("Mitarbeiter")
|
||||||
|
Layout.alignment: Qt.AlignRight | Qt.AlignTop
|
||||||
}
|
}
|
||||||
ScrollView
|
|
||||||
{
|
|
||||||
Layout.rowSpan: 3
|
|
||||||
Layout.fillWidth: true
|
|
||||||
|
|
||||||
TextArea
|
ListModel
|
||||||
{
|
{
|
||||||
id: mitarbeitertext
|
id: employeeModel
|
||||||
implicitWidth: parent.width
|
}
|
||||||
implicitHeight: 100
|
|
||||||
wrapMode: TextEdit.Wrap
|
Component
|
||||||
background: Rectangle
|
|
||||||
{
|
{
|
||||||
|
id: employeesHeader
|
||||||
|
Row
|
||||||
|
{
|
||||||
|
Text
|
||||||
|
{
|
||||||
|
id: empName
|
||||||
|
text: qsTr("Mitarbeiter")
|
||||||
|
width: 175
|
||||||
|
font.bold: true
|
||||||
|
horizontalAlignment: Text.AlignHCenter
|
||||||
|
color: "yellow"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Rectangle
|
||||||
|
{
|
||||||
|
Layout.fillWidth: true
|
||||||
|
implicitHeight: 75
|
||||||
|
Layout.rowSpan: 2
|
||||||
color: mitarbeiterhin.palette.base
|
color: mitarbeiterhin.palette.base
|
||||||
border.color: mitarbeiterhin.activeFocus? mitarbeiterhin.palette.highlight: mitarbeiterhin.palette.base
|
border.color: mitarbeiterhin.activeFocus? mitarbeiterhin.palette.highlight: mitarbeiterhin.palette.base
|
||||||
|
ListView
|
||||||
|
{
|
||||||
|
id: employeesList
|
||||||
|
//anchors.fill: parent
|
||||||
|
implicitHeight: parent.height
|
||||||
|
|
||||||
|
model: employeeModel
|
||||||
|
|
||||||
|
header: employeesHeader
|
||||||
|
|
||||||
|
delegate: Row
|
||||||
|
{
|
||||||
|
width: 200
|
||||||
|
height: 15
|
||||||
|
padding: 7
|
||||||
|
Text
|
||||||
|
{
|
||||||
|
text: model.namens
|
||||||
|
color: "yellow"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
RowLayout
|
||||||
|
{
|
||||||
|
Layout.columnSpan: 2
|
||||||
|
Layout.fillWidth: true
|
||||||
|
Item
|
||||||
|
{
|
||||||
|
Layout.fillWidth: true
|
||||||
|
}
|
||||||
|
|
||||||
|
Button
|
||||||
|
{
|
||||||
|
id: mitarbeiterraus
|
||||||
|
text: qsTr("Mitarbeiter entfernen")
|
||||||
|
}
|
||||||
|
|
||||||
Button
|
Button
|
||||||
{
|
{
|
||||||
id: mitarbeiterhin
|
id: mitarbeiterhin
|
||||||
property var neuermitarbeiter: undefined
|
|
||||||
text: qsTr("Mitarbeiter hinzufügen")
|
text: qsTr("Mitarbeiter hinzufügen")
|
||||||
Layout.columnSpan: 2
|
|
||||||
Layout.fillWidth: true
|
|
||||||
Layout.alignment: Qt.AlignRight
|
|
||||||
Layout.maximumWidth: mitarbeitertext.width
|
|
||||||
onClicked:
|
onClicked:
|
||||||
{
|
{
|
||||||
var nm = Qt.createComponent("AddObjectEmployee.qml")
|
var nm = Qt.createComponent("AddObjectEmployee.qml")
|
||||||
if (nm.status === Component.Ready)
|
if (nm.status === Component.Ready)
|
||||||
{
|
{
|
||||||
neuermitarbeiter = nm.createObject (appWindow, {width: 600, height: 400})
|
employeeForm = nm.createObject (appWindow, {width: 600, height: 400})
|
||||||
neuermitarbeiter.show()
|
employeeForm.addNewEmployee.connect(onAddEmployee)
|
||||||
|
employeeForm.show()
|
||||||
|
}
|
||||||
|
else console.log(nm.errorString())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function onAddEmployee(new_employee)
|
||||||
|
{
|
||||||
|
var num_employees = 0
|
||||||
|
|
||||||
|
if (employees === null || employees === undefined) employees = {}
|
||||||
|
else num_employees = Object.keys(employees).length;
|
||||||
|
|
||||||
|
employees[num_employees] = {}
|
||||||
|
employees[num_employees]["assignee"] = new_employee["assignee"];
|
||||||
|
employees[num_employees]["duration"] = new_employee["duration"];
|
||||||
|
employees[num_employees]["wage"] = new_employee["wage"];
|
||||||
|
employees[num_employees]["cleandays"] = new_employee["cleandays"];
|
||||||
|
employees[num_employees]["tasks"] = new_employee["tasks"];
|
||||||
|
employees[num_employees]["output"] = new_employee["output"];
|
||||||
|
|
||||||
|
employeeModel.append({namens: new_employee["assignee"]});
|
||||||
|
|
||||||
|
console.log(employeeModel.get(num_employees).namens)
|
||||||
|
|
||||||
|
console.log(new_employee["assignee"])
|
||||||
|
console.log(JSON.stringify(new_employee))
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -164,10 +164,8 @@ GridLayout
|
|||||||
{
|
{
|
||||||
id: infoview
|
id: infoview
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
Layout.preferredHeight: 200
|
Layout.preferredHeight: 110
|
||||||
//Layout.columnSpan: 3
|
|
||||||
ScrollBar.horizontal: ScrollBar
|
ScrollBar.horizontal: ScrollBar
|
||||||
|
|
||||||
{
|
{
|
||||||
policy: ScrollBar.AlwaysOn
|
policy: ScrollBar.AlwaysOn
|
||||||
}
|
}
|
||||||
@@ -176,9 +174,7 @@ GridLayout
|
|||||||
{
|
{
|
||||||
id: objectInfo
|
id: objectInfo
|
||||||
property string name: "objectinfo"
|
property string name: "objectinfo"
|
||||||
Layout.fillWidth: true
|
implicitWidth: parent.width
|
||||||
Layout.fillHeight: true
|
|
||||||
|
|
||||||
wrapMode: TextEdit.Wrap
|
wrapMode: TextEdit.Wrap
|
||||||
background: Rectangle
|
background: Rectangle
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -7,8 +7,8 @@ import QtCore
|
|||||||
ApplicationWindow
|
ApplicationWindow
|
||||||
{
|
{
|
||||||
id: appWindow
|
id: appWindow
|
||||||
width: Screen.width * .6
|
width: Screen.width * .75
|
||||||
height: Screen.height * .75
|
height: Screen.height * .85
|
||||||
visible: true
|
visible: true
|
||||||
title: "PYQCRM"
|
title: "PYQCRM"
|
||||||
property string confile: ""
|
property string confile: ""
|
||||||
|
|||||||
Reference in New Issue
Block a user