summaryrefslogtreecommitdiff
path: root/qml/pages/Board.qml
blob: 0f2af457db0682cb4becf2ef427c43c2ffdbd547 (plain) (blame)
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
import QtQuick 2.2
import Sailfish.Silica 1.0
import Nemo.Configuration 1.0
import ".."

Page {
    id: page
    allowedOrientations: Orientation.Portrait

    Functions {
        id: functions
    }

    SilicaFlickable {
        anchors.fill: parent
        contentHeight: column.height

        PullDownMenu {
            MenuItem {
                text: qsTr("Refresh login")
                onClicked: {
                    access_token.value = "";
                    refresh_token.value = "";
                    pageStack.push(Qt.resolvedUrl("Login.qml"))
                }
            }
            MenuItem {
                text: qsTr("Random player")
                visible: functions.game_id === "" ? true : false
                onClicked: functions.start_seek()
            }
            MenuItem {
                text: qsTr("Challenge user")
                visible: functions.game_id === "" ? true : false
                onClicked: {
                    var dialog = pageStack.push("UserDialog.qml");
                    dialog.accepted.connect(function() {
                        functions.challenge(dialog.name);
                    });
                }
            }
            MenuItem {
                // I THINK it works like that
                text: qsTr("Abort game")
                visible: functions.game_id !== "" && functions.moves.split(" ").length <= 2 ? true : false
                onClicked: functions.abort()
            }
            MenuItem {
                text: qsTr("Resign game")
                visible: functions.game_id !== "" && functions.moves.split(" ").length > 2 ? true : false
                onClicked: functions.resign()
            }
            MenuItem {
                text: qsTr("Offer/accept draw")
                visible: functions.game_id !== "" && functions.moves.split(" ").length > 2 ? true : false
                onClicked: functions.offer_draw()
            }
        }

        Column {
            id: column

            width: page.width
            height: page.height
            spacing: Theme.paddingLarge

            PageHeader {
                title: qsTr("Chess")
            }

            LinkedLabel {
                id: information
                width: parent.width
                color: "white"
                anchors.horizontalCenter: parent.horizontalCenter
                anchors.bottom: grid.top
                bottomPadding: Theme.paddingMedium
                plainText: qsTr("Please start a game");
            }

            Grid {
                property int row: 0

                id: grid
                anchors.horizontalCenter: parent.horizontalCenter
                anchors.verticalCenter: parent.verticalCenter
                columns: 8
                rows: 8
                Repeater {
                    id: board
                    model: 64
                    delegate: Square {
                        i: index
                    }
                }
                Component.onCompleted: {
                    functions.event_stream();
                }
            }

            Label {
                id: turn_label
                anchors.horizontalCenter: parent.horizontalCenter
                anchors.top: grid.bottom
                topPadding: Theme.paddingMedium
                text: functions.turn ? qsTr("Your turn") : qsTr("Opponents turn");
            }

            LinkedLabel {
                id: chat
                width: parent.width
                color: "white"
                anchors.horizontalCenter: parent.horizontalCenter
                anchors.top: turn_label.bottom
                topPadding: Theme.paddingMedium
                plainText: "";
            }
        }
    }

    ConfigurationValue {
        id: access_token
        key: "/com/sailchess/access_token"
        defaultValue: ""
    }

    ConfigurationValue {
        id: refresh_token
        key: "/com/sailchess/refresh_token"
        defaultValue: ""
    }
}