/usr/share/help/gl/gnome-devel-demos/buttonbox.js.page is in gnome-devel-docs 3.28.0-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 | <?xml version="1.0" encoding="utf-8"?>
<page xmlns="http://projectmallard.org/1.0/" xmlns:its="http://www.w3.org/2005/11/its" xmlns:xi="http://www.w3.org/2001/XInclude" type="guide" style="task" id="buttonbox.js" xml:lang="gl">
<info>
<title type="text">ButtonBox (JavaScript)</title>
<link type="guide" xref="beginner.js#layout"/>
<link type="seealso" xref="button.js"/>
<revision version="0.2" date="2013-06-25" status="review"/>
<credit type="author copyright">
<name>Meg Ford</name>
<email its:translate="no">megford@gnome.org</email>
<years>2013</years>
</credit>
<desc>A container for arranging buttons</desc>
<mal:credit xmlns:mal="http://projectmallard.org/1.0/" type="translator copyright">
<mal:name>Fran Dieguez</mal:name>
<mal:email>frandieguez@gnome.org</mal:email>
<mal:years>2012-2013.</mal:years>
</mal:credit>
</info>
<title>ButtonBox</title>
<media type="image" mime="image/png" src="media/buttonbox_calculator.png"/>
<p>Unha calculadora - os botóns están dispostos en ButtonBoxes horizontais.</p>
<links type="section"/>
<section id="code">
<title>Código usado para xerar este exemplo</title>
<code mime="application/javascript" style="numbered">#!/usr/bin/gjs
imports.gi.versions.Gtk = '3.0';
const GObject = imports.gi.GObject;
const Gtk = imports.gi.Gtk;
class ButtonBoxExample {
// Create the application itthis
constructor() {
this.application = new Gtk.Application({
application_id: 'org.example.jsbuttonbox'
});
// Connect 'activate' and 'startup' signals to the callback functions
this.application.connect('activate', this._onActivate.bind(this));
this.application.connect('startup', this._onStartup.bind(this));
}
// Callback function for 'activate' signal presents windows when active
_onActivate() {
this.window.present();
}
// Callback function for 'startup' signal builds the UI
_onStartup() {
this._buildUI();
}
// Build the application's UI
_buildUI() {
// Create the application window
this.window = new Gtk.ApplicationWindow ({ application: this.application,
window_position: Gtk.WindowPosition.CENTER,
title: "Calculator",
default_width: 350,
default_height: 200,
border_width: 10 });
this.entry = new Gtk.Entry();
this.entry.set_text('0');
// text aligned on the right
this.entry.set_alignment(1);
// the text in the entry cannot be modified by writing in it
this.entry.set_can_focus(false);
// a grid
this.grid = new Gtk.Grid();
this.grid.set_row_spacing(5);
// to attach the entry
this.grid.attach(this.entry, 0, 0, 1, 1);
// the labels for the buttons
this.buttons = [ 7, 8, 9, '/', 4, 5, 6, '*', 1, 2, 3, '-', 'C', 0, '=', '+' ];
// each row is a ButtonBox, attached to the grid
for (let i = 0; i < 4; i++) {
this.hbox = Gtk.ButtonBox.new(Gtk.Orientation.HORIZONTAL);
this.hbox.set_spacing(5);
this.grid.attach(this.hbox, 0, i + 1, 1, 1);
// each ButtonBox has 4 buttons, connected to the callback function
for (let j= 0; j < 4; j++) {
this.button = new Gtk.Button();
this.buttonLabel = (this.buttons[i * 4 + j].toString());
this.button.set_label(this.buttonLabel);
this.button.set_can_focus(false);
this.button.connect("clicked", this._buttonClicked.bind(this));
this.hbox.add(this.button);
}
}
// some variables for the calculations
this.firstNumber = 0;
this.secondNumber = 0;
this.counter = 0;
this.operation = "";
// add the grid to the window
this.window.add(this.grid);
this.window.show_all();
}
// callback function for all the buttons
_buttonClicked(button) {
this.button = button;
// for the operations
if (this.button.get_label() == '+') {
this.counter += 1
if (this.counter > 1)
this._doOperation();
this.entry.set_text('0');
this.operation = "plus";
}
else if (this.button.get_label() == '-') {
this.counter += 1;
if (this.counter > 1)
this._doOperation();
this.entry.set_text('0');
this.operation = "minus";
}
else if (this.button.get_label() == '*') {
this.counter += 1;
if (this.counter > 1)
this._doOperation();
this.entry.set_text('0');
this.operation = "multiplication";
}
else if (this.button.get_label() == '/') {
this.counter += 1
if (this.counter > 1)
this._doOperation();
this.entry.set_text('0');
this.operation = "division";
}
// for =
else if (this.button.get_label() == '=') {
this._doOperation();
this.entry.set_text(this.firstNumber.toString());
this.counter = 1;
}
// for Cancel
else if (this.button.get_label() == 'C') {
this.firstNumber = 0;
this.secondNumber = 0;
this.counter = 0;
this.entry.set_text('0');
this.operation = "";
}
// for a digit button
else {
this.newDigit = parseInt(this.button.get_label());
if (this.entry.get_text() == "error")
this.number = 0;
else
this.number = parseInt(this.entry.get_text());
this.number = this.number * 10 + this.newDigit;
if (this.counter == 0)
this.firstNumber = this.number;
else
this.secondNumber = this.number;
this.entry.set_text(this.number.toString());
}
}
_doOperation() {
if (this.operation == "plus") {
this.firstNumber += this.secondNumber;
} else if (this.operation == "minus") {
this.firstNumber -= this.secondNumber;
} else if (this.operation == "multiplication") {
this.firstNumber *= this.secondNumber;
} else if (this.operation == "division") {
if (this.secondNumber != 0) {
this.firstNumber /= this.secondNumber;
} else {
this.firstNumber = 0;
this.secondNumber = 0;
this.counter = 0;
this.entry.set_text("error");
this.operation = "";
return
}
} else {
this.firstNumber = 0;
this.secondNumber = 0;
this.counter = 0;
this.entry.set_text("error");
}
}
};
// Run the application
let app = new ButtonBoxExample();
app.application.run (ARGV);
</code>
</section>
<section id="references">
<title>API References</title>
<p>Neste exemplo empregaremos o seguinte:</p>
<list>
<item><p><link href="http://www.roojs.com/seed/gir-1.2-gtk-3.0/gjs/Gtk.ButtonBox.html">GtkButtonBox</link></p></item>
<item><p><link href="http://www.roojs.com/seed/gir-1.2-gtk-3.0/gjs/Gtk.Box.html">GtkBox</link></p></item>
<item><p><link href="http://www.roojs.com/seed/gir-1.2-gtk-3.0/gjs/Gtk.Button.html">GtkButton</link></p></item>
<item><p><link href="http://www.roojs.com/seed/gir-1.2-gtk-3.0/gjs/Gtk.Entry.html">GtkEntry</link></p></item>
<item><p><link href="http://www.roojs.com/seed/gir-1.2-gtk-3.0/gjs/Gtk.Grid.html">GtkGrid</link></p></item>
</list>
</section>
</page>
|