gobstones-board 1.8.5 → 1.8.6

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 76666ac8b9213ff7af0400c744283111acf7c47b13c8d4c3f5d5d9b5c832b779
4
- data.tar.gz: 24f3d7c29bdc76c3fd69ad1fe8b09284d2a41c7a08f3de5797d9619b42c9ebd2
3
+ metadata.gz: 93b38392bfc27dbf5119de2525754598229e76bb72a9f3baa8592b1d7ad10d7b
4
+ data.tar.gz: 94ef670f1fb68ff404049dc92c896531e95ef23d1ee43960d548dffe024eb487
5
5
  SHA512:
6
- metadata.gz: 549d07858827f2784995368615a3f595a2e50e1c90f920250e2f4790066936b3d57d8dc5b877924fec304c23ef90159955e102e2d28a254c64b4000f4098896c
7
- data.tar.gz: a28b292a0b2a2f5c6ef0f7f630a33ddddbe740f1ba354d8e634249f191afeee5c398b9a80e0b054ece7d8687c0931761b1c8245eab5ed799269b52dcea14513c
6
+ metadata.gz: 5123fc8e6f77678649395440dca2fb3d799a46932b98c6352254ef2013378b1311a4f229ca47dc12901775ace9a99b34ef1d074ffb7e56cd7a8a15fb6f630bc1
7
+ data.tar.gz: fe9269f9da4fc14889bc7cd4fb92d57f8d212dcb823c0fb349a5687e0a08073e043a35e9a3a5b126cadec1bf94e0fa288d8cba3104fc3ed0ae250aed8fa3f52a
data/Rakefile CHANGED
@@ -13,6 +13,7 @@ namespace :wrapper do
13
13
 
14
14
  # gs-board
15
15
  cp_r '../dist/gs-board.html', 'app/assets/htmls'
16
+ cp_r '../dist/components', 'app/assets/htmls'
16
17
 
17
18
  # polymer
18
19
  cp_r '../bower_components/polymer/polymer.html', 'app/assets/htmls/vendor'
@@ -0,0 +1,57 @@
1
+ <dom-module id="cell-dresser">
2
+ <template>
3
+ <style>
4
+
5
+
6
+ /*# sourceMappingURL=style.css.map */
7
+
8
+ </style>
9
+
10
+
11
+ </template>
12
+ <script>
13
+ Polymer({
14
+ is: 'cell-dresser',
15
+ getRule: function(cell, isHeader, attire) {
16
+ if ((attire == null) || !attire.enabled) {
17
+ return;
18
+ }
19
+ return attire != null ? attire.rules.filter((function(_this) {
20
+ return function(rule) {
21
+ return _this._doesSatisfyRule(cell, isHeader, rule);
22
+ };
23
+ })(this))[0] : void 0;
24
+ },
25
+ _doesSatisfyRule: function(cell, isHeader, rule) {
26
+ var itSatisfies;
27
+ itSatisfies = (function(_this) {
28
+ return function(color) {
29
+ return _this._doesSatisfyQuantity(cell[color], rule.when[color]) && _this._doesSatisfyHeader(isHeader, rule.when.head);
30
+ };
31
+ })(this);
32
+ return ["red", "blue", "green", "black"].reduce((function(_this) {
33
+ return function(previousCondition, color) {
34
+ return previousCondition && itSatisfies(color);
35
+ };
36
+ })(this), true);
37
+ },
38
+ _doesSatisfyQuantity: function(quantity, expectedQuantity) {
39
+ if (quantity == null) {
40
+ quantity = 0;
41
+ }
42
+ switch (expectedQuantity) {
43
+ case "*":
44
+ return true;
45
+ case "+":
46
+ return quantity > 0;
47
+ default:
48
+ return quantity === expectedQuantity;
49
+ }
50
+ },
51
+ _doesSatisfyHeader: function(isHeader, expectedHeader) {
52
+ return (expectedHeader == null) || expectedHeader === isHeader;
53
+ }
54
+ });
55
+
56
+ </script>
57
+ </dom-module>
@@ -0,0 +1,216 @@
1
+ <dom-module id="board-demo">
2
+ <template>
3
+ <style>
4
+
5
+
6
+ /*# sourceMappingURL=style.css.map */
7
+
8
+ </style>
9
+
10
+ <div>
11
+ <gs-board>
12
+ GBB/1.0
13
+ size 4 3
14
+ cell 1 2 Azul 0 Negro 0 Rojo 8 Verde 0
15
+ cell 3 2 Azul 2 Negro 0 Rojo 5 Verde 1
16
+ cell 2 1 Azul 0 Negro 6 Rojo 0 Verde 0
17
+ head 1 2
18
+ </gs-board>
19
+ </div>
20
+
21
+ <!--
22
+ <div>
23
+ <gs-board attire-src="mines">
24
+ GBB/1.0
25
+ size 4 3
26
+ cell 1 2 Azul 0 Negro 0 Rojo 8 Verde 0
27
+ cell 3 2 Azul 2 Negro 0 Rojo 5 Verde 1
28
+ cell 2 1 Azul 0 Negro 6 Rojo 0 Verde 0
29
+ head 1 2
30
+ </gs-board>
31
+ </div>
32
+ -->
33
+
34
+ <div>
35
+ <gs-board table="{{model.table}}" options='{ "editable": false }'></gs-board>
36
+ </div>
37
+ <div>
38
+ <gs-board table="{{model.table}}" options='{ "editable": false }' boom></gs-board>
39
+ </div>
40
+ <div>
41
+ <gs-board size='{ "x": 3, "y": 5 }' options='{ "editable": true }'></gs-board>
42
+ </div>
43
+ <div>
44
+ <gs-board id="thing" size='{ "x": 2, "y": 2 }' options='{ "editable": true }'></gs-board>
45
+ </div>
46
+ <div>
47
+ <gs-board table="{{modelWithAttire.table}}" options='{ "editable": false }' attire='{{attire}}'></gs-board>
48
+ </div>
49
+ <div class="board-wrap-json">
50
+ <juicy-jsoneditor id="jsoneditor" style="height: 300px;" json="{{jsonModel}}"></juicy-jsoneditor>
51
+ </div>
52
+
53
+ </template>
54
+ <script>
55
+ var model, modelWithAttire;
56
+
57
+ model = {
58
+ table: [
59
+ [{}, {}, {}, {}], [{}, {}, {}, {}], [
60
+ {
61
+ black: 1
62
+ }, {
63
+ blue: 87493312
64
+ }, {
65
+ green: 2
66
+ }, {}
67
+ ], [
68
+ {
69
+ red: 3,
70
+ black: 4
71
+ }, {}, {}, {}
72
+ ]
73
+ ]
74
+ };
75
+
76
+ modelWithAttire = {
77
+ table: [
78
+ [
79
+ {
80
+ green: 1
81
+ }, {}, {}, {
82
+ blue: 1
83
+ }
84
+ ], [
85
+ {}, {
86
+ red: 4,
87
+ black: 1
88
+ }, {
89
+ red: 4,
90
+ black: 2
91
+ }, {}
92
+ ], [
93
+ {}, {
94
+ red: 1
95
+ }, {
96
+ red: 4,
97
+ black: 3
98
+ }, {}
99
+ ], [
100
+ {
101
+ red: 1
102
+ }, {}, {}, {
103
+ black: 1
104
+ }
105
+ ]
106
+ ]
107
+ };
108
+
109
+ Polymer({
110
+ is: 'board-demo',
111
+ properties: {
112
+ model: {
113
+ type: Object,
114
+ value: model,
115
+ notify: true
116
+ },
117
+ modelWithAttire: {
118
+ type: Object,
119
+ value: modelWithAttire,
120
+ notify: true
121
+ },
122
+ jsonModel: {
123
+ type: Object,
124
+ value: model
125
+ },
126
+ attire: {
127
+ type: Object
128
+ }
129
+ },
130
+ ready: function() {
131
+ this.attire = {
132
+ "enabled": true,
133
+ "rules": [
134
+ {
135
+ "when": {
136
+ "blue": "*",
137
+ "black": "+",
138
+ "red": 4,
139
+ "green": "*"
140
+ },
141
+ "image": "https://cloud.githubusercontent.com/assets/1631752/19217961/ef2e0d4c-8dea-11e6-960d-69585778f89d.png"
142
+ }, {
143
+ "when": {
144
+ "blue": 0,
145
+ "black": 0,
146
+ "red": 0,
147
+ "green": 0
148
+ },
149
+ "image": "https://cloud.githubusercontent.com/assets/1631752/19217956/ef1d928c-8dea-11e6-8b53-8d2495cdd3e9.png"
150
+ }, {
151
+ "when": {
152
+ "blue": 0,
153
+ "black": 0,
154
+ "red": 0,
155
+ "green": 1
156
+ },
157
+ "image": "https://cloud.githubusercontent.com/assets/1631752/19217959/ef27e822-8dea-11e6-9bb0-57892593c9d8.png"
158
+ }, {
159
+ "when": {
160
+ "blue": 1,
161
+ "black": 0,
162
+ "red": 0,
163
+ "green": 0
164
+ },
165
+ "image": "https://cloud.githubusercontent.com/assets/1631752/19217958/ef245892-8dea-11e6-80f4-aeb5d1862b1c.png"
166
+ }, {
167
+ "when": {
168
+ "blue": 0,
169
+ "black": 1,
170
+ "red": 0,
171
+ "green": 0
172
+ },
173
+ "image": "https://cloud.githubusercontent.com/assets/1631752/19217957/ef20120a-8dea-11e6-825c-23e7773269b0.png"
174
+ }, {
175
+ "when": {
176
+ "blue": 0,
177
+ "black": 0,
178
+ "red": 1,
179
+ "green": 0,
180
+ "head": true
181
+ },
182
+ "image": "https://user-images.githubusercontent.com/1631752/33194059-c9794fb0-d0d5-11e7-81dc-65a0f7472a94.png"
183
+ }, {
184
+ "when": {
185
+ "blue": 0,
186
+ "black": 0,
187
+ "red": 1,
188
+ "green": 0
189
+ },
190
+ "image": "https://cloud.githubusercontent.com/assets/1631752/19217960/ef2ad3c0-8dea-11e6-8434-ff9152b76f3b.png"
191
+ }
192
+ ]
193
+ };
194
+ return setInterval((function(_this) {
195
+ return function() {
196
+ return _this.set("attire.enabled", !_this.attire.enabled);
197
+ };
198
+ })(this), 2000);
199
+ },
200
+ listeners: {
201
+ 'jsoneditor.change': '_jsonChange'
202
+ },
203
+ _jsonChange: function() {
204
+ return this.async(this._forceRender, 0);
205
+ },
206
+ _forceRender: function() {
207
+ this.model = null;
208
+ return this.async(this._setModel, 0);
209
+ },
210
+ _setModel: function() {
211
+ return this.model = model;
212
+ }
213
+ });
214
+
215
+ </script>
216
+ </dom-module>
@@ -0,0 +1,441 @@
1
+ <link rel="import" href="gs-cell.html">
2
+ <link rel="import" href="key-tracker.html">
3
+ <dom-module id="gs-board">
4
+ <template>
5
+ <style>
6
+ .gbs_pointer {
7
+ cursor: pointer;
8
+ }
9
+
10
+ .gbs_unselectable {
11
+ -webkit-touch-callout: none;
12
+ -webkit-user-select: none;
13
+ -khtml-user-select: none;
14
+ -moz-user-select: none;
15
+ -ms-user-select: none;
16
+ user-select: none;
17
+ }
18
+
19
+ table.gbs_board {
20
+ border-style: none;
21
+ border: solid black 0px;
22
+ border-spacing: 0;
23
+ border-collapse: collapse;
24
+ font-family: Arial, Helvetica, sans-serif;
25
+ font-size: 9pt;
26
+ display: inline-block;
27
+ vertical-align: top;
28
+ }
29
+
30
+ .gbs_board td {
31
+ margin: 0;
32
+ padding: var(--cell-padding);
33
+ border: var(--cell-border);
34
+ width: 30px;
35
+ height: 30px;
36
+ }
37
+
38
+ .gbs_board td.gbs_lv {
39
+ /* labels at the side */
40
+ text-align: center;
41
+ vertical-align: middle;
42
+ border-style: none;
43
+ border: solid black 0px;
44
+ background: #ddd;
45
+ width: 15px;
46
+ }
47
+
48
+ .gbs_board td.gbs_lh {
49
+ /* labels at the top / bottom */
50
+ text-align: center;
51
+ vertical-align: middle;
52
+ border-style: none;
53
+ border: solid black 0px;
54
+ background: #ddd;
55
+ height: 15px;
56
+ }
57
+
58
+ .gbs_board td.gbs_lx {
59
+ /* corner */
60
+ border-style: none;
61
+ border: solid black 0px;
62
+ background: #ddd;
63
+ width: 15px;
64
+ height: 15px;
65
+ }
66
+
67
+ .gbs_board td.gbs_top_left {
68
+ -webkit-border-top-left-radius: 10px;
69
+ -moz-border-top-left-radius: 10px;
70
+ border-top-left-radius: 10px;
71
+ }
72
+
73
+ .gbs_board td.gbs_top_right {
74
+ -webkit-border-top-right-radius: 10px;
75
+ -moz-border-top-right-radius: 10px;
76
+ border-top-right-radius: 10px;
77
+ }
78
+
79
+ .gbs_board td.gbs_bottom_left {
80
+ -webkit-border-bottom-left-radius: 10px;
81
+ -moz-border-bottom-left-radius: 10px;
82
+ border-bottom-left-radius: 10px;
83
+ }
84
+
85
+ .gbs_board td.gbs_bottom_right {
86
+ -webkit-border-bottom-right-radius: 10px;
87
+ -moz-border-bottom-right-radius: 10px;
88
+ border-bottom-right-radius: 10px;
89
+ }
90
+
91
+ table.gbs_boom {
92
+ background-image: url();
93
+ background-size: contain;
94
+ background-repeat: no-repeat;
95
+ background-position: center;
96
+ }
97
+
98
+ /*# sourceMappingURL=style.css.map */
99
+
100
+ </style>
101
+
102
+ <key-tracker id="keyTracker"></key-tracker>
103
+
104
+ <table class$="gbs_board ui-widget-content {{boomCssClass(boom)}}">
105
+ <tbody>
106
+ <tr>
107
+ <td class="gbs_lx gbs_top_left"></td>
108
+ <template is="dom-repeat" items="{{columnIndexes}}" as="columnIndex">
109
+ <td class="gbs_lh">{{columnIndex}}</td>
110
+ </template>
111
+ <td class="gbs_lx gbs_top_right"></td>
112
+ </tr>
113
+ <template is="dom-repeat" items="{{table}}" as="row" index-as="rowIndex">
114
+ <tr>
115
+ <td class="gbs_lv">{{getRowNumber(table, rowIndex)}}</td>
116
+ <template is="dom-repeat" items="{{row}}" as="cell" index-as="cellIndex">
117
+ <td>
118
+ <gs-cell cell-index="{{cellIndex}}" row-index="{{rowIndex}}" cell="{{cell}}" table="{{table}}" header="{{header}}" options="{{options}}" attire="{{attire}}" boom="{{boom}}"></gs-cell>
119
+ </td>
120
+ </template>
121
+ <td class="gbs_lv">{{getRowNumber(table, rowIndex)}}</td>
122
+ </tr>
123
+ </template>
124
+ <tr>
125
+ <td class="gbs_lx gbs_bottom_left"></td>
126
+ <template is="dom-repeat" items="{{columnIndexes}}" as="columnIndex">
127
+ <td class="gbs_lh">{{columnIndex}}</td>
128
+ </template>
129
+ <td class="gbs_lx gbs_bottom_right"></td>
130
+ </tr>
131
+ </tbody>
132
+ </table>
133
+
134
+ </template>
135
+ <script>
136
+
137
+ var stringUtils = {
138
+ splitByLines: function (string) {
139
+ return string.split(/\r\n|\r|\n/);
140
+ },
141
+
142
+ scan: function (string, regExp) {
143
+ if (!regExp.global) {
144
+ throw new Error('The regExp must be global (with "g" flag)');
145
+ }
146
+ var m = [];
147
+ var r = m;
148
+ m = regExp.exec(string);
149
+ while (m) {
150
+ m.shift();
151
+ r.push(m);
152
+ m = regExp.exec(string);
153
+ }
154
+ return r;
155
+ }
156
+ };
157
+
158
+ var gbbReader = {
159
+ };
160
+
161
+ gbbReader.fromString = function (gbbString) {
162
+ var gbbCode = this._try(gbbString);
163
+
164
+ var rawLines = stringUtils.splitByLines(gbbCode).map(function(line) {
165
+ return line.trim();
166
+ });
167
+
168
+ var lines = rawLines.filter(function (line) {
169
+ return !/GBB\/(\d\.)+\d$/.test(line) && line !== '';
170
+ });
171
+
172
+ return this._buildBoard(lines);
173
+ };
174
+
175
+ gbbReader._buildBoard = function (lines) {
176
+ var dimensions = this._getDimensions(lines);
177
+ var header = this._getHeader(lines);
178
+
179
+ try {
180
+ var board = {
181
+ width: dimensions[0],
182
+ height: dimensions[1],
183
+ head: { x: header[0], y: header[1] },
184
+ table: []
185
+ };
186
+ for (var i = board.height - 1; i >= 0; i--) {
187
+ board.table[i] = [];
188
+ for (var j = 0; j < board.width; j++) {
189
+ board.table[i][j] = {};
190
+ }
191
+ }
192
+ this._putCells(lines, board);
193
+
194
+ return board;
195
+ } catch (err) {
196
+ var error = new Error('Error building the board');
197
+ error.inner = err;
198
+ throw error;
199
+ }
200
+ };
201
+
202
+ gbbReader._getDimensions = function (lines) {
203
+ var dimensions = this._try(
204
+ lines[0].match(/^size (\d+) (\d+)$/)
205
+ , 'dimensions');
206
+ return this._getPositionOf(dimensions);
207
+ };
208
+
209
+ gbbReader._getHeader = function (lines) {
210
+ var header = this._try(
211
+ lines[lines.length - 1].match(/^head (\d+) (\d+)$/)
212
+ , 'header');
213
+ return this._getPositionOf(header);
214
+ };
215
+
216
+ gbbReader._putCells = function (lines, board) {
217
+ var CELL_REGEXP = /^cell (\d+) (\d+)/;
218
+
219
+ var cellLines = lines.filter(function (line) {
220
+ return CELL_REGEXP.test(line);
221
+ });
222
+
223
+ cellLines.forEach(function (line) {
224
+ var cell = line.match(CELL_REGEXP);
225
+ var position = this._getPositionOf(cell, line);
226
+
227
+ var x = position[0];
228
+ var y = position[1];
229
+ this._putBalls(x, y, line, board);
230
+ }.bind(this));
231
+ };
232
+
233
+ gbbReader._putBalls = function (x, y, line, board) {
234
+ var values = stringUtils.scan(line, /(Azul|Negro|Rojo|Verde) (\d+)/g);
235
+ var getAmount = function (color) {
236
+ var value = values.filter(function (it) {
237
+ return it[0] === color;
238
+ });
239
+ return parseInt((value[0] || {})[1] || 0, 0);
240
+ };
241
+
242
+ const cell = board.table[board.height - 1 - y][x];
243
+ cell.blue = getAmount('Azul');
244
+ cell.black = getAmount('Negro');
245
+ cell.red = getAmount('Rojo');
246
+ cell.green = getAmount('Verde');
247
+ };
248
+
249
+ gbbReader._getPositionOf = function (source, element) {
250
+ source = source || {};
251
+
252
+ return [
253
+ this._try(source[1], element), this._try(source[2], element)
254
+ ].map(function (it) {
255
+ return parseInt(it, 0);
256
+ });
257
+ };
258
+
259
+ gbbReader._try = function (value, thingToParse) {
260
+ if (!value) {
261
+ throw new Error('Error parsing ' + (thingToParse || 'GBB file'));
262
+ }
263
+ return value;
264
+ };
265
+ ;
266
+ Polymer({
267
+ is: 'gs-board',
268
+ properties: {
269
+ table: Array,
270
+ size: {
271
+ type: Object,
272
+ value: {
273
+ x: 2,
274
+ y: 2
275
+ },
276
+ observer: "_updateSize"
277
+ },
278
+ header: {
279
+ type: Object,
280
+ value: {
281
+ x: 0,
282
+ y: 0
283
+ }
284
+ },
285
+ options: Object,
286
+ boom: {
287
+ type: Boolean,
288
+ value: false
289
+ },
290
+ attire: {
291
+ type: Object
292
+ },
293
+ attireSrc: {
294
+ type: String
295
+ }
296
+ },
297
+ observers: ['_updateStyles(attire.*)'],
298
+ ready: function() {
299
+ this._setBorderOn();
300
+ this._readGbb();
301
+ this._initializeTable();
302
+ return this._initializeOptions();
303
+ },
304
+ getRowNumber: function(table, rowIndex) {
305
+ return table.length - 1 - rowIndex;
306
+ },
307
+ isCtrlPressed: function() {
308
+ return this.$.keyTracker.isPressed("Control");
309
+ },
310
+ isShiftPressed: function() {
311
+ return this.$.keyTracker.isPressed("Shift");
312
+ },
313
+ boomCssClass: function(boom) {
314
+ if (boom) {
315
+ return "gbs_boom";
316
+ } else {
317
+ return "";
318
+ }
319
+ },
320
+ fillTable: function() {
321
+ var i, j, limit, table, _base, _i, _j, _ref, _ref1;
322
+ if (this.table == null) {
323
+ return;
324
+ }
325
+ limit = function(array, limit) {
326
+ return array.slice(0, limit);
327
+ };
328
+ table = this.table.slice().reverse();
329
+ for (i = _i = 0, _ref = this.size.y; 0 <= _ref ? _i < _ref : _i > _ref; i = 0 <= _ref ? ++_i : --_i) {
330
+ for (j = _j = 0, _ref1 = this.size.x; 0 <= _ref1 ? _j < _ref1 : _j > _ref1; j = 0 <= _ref1 ? ++_j : --_j) {
331
+ if (table[i] == null) {
332
+ table[i] = [];
333
+ }
334
+ table[i] = limit(table[i], this.size.x);
335
+ if ((_base = table[i])[j] == null) {
336
+ _base[j] = {};
337
+ }
338
+ }
339
+ }
340
+ table = limit(table, this.size.y);
341
+ this.table = table.reverse();
342
+ return this._forceHeaderSet();
343
+ },
344
+ update: function(table, header) {
345
+ this.table = table;
346
+ this.header = header;
347
+ this._setSizeFromTable();
348
+ return this.fillTable();
349
+ },
350
+ _initializeTable: function() {
351
+ if (this.table != null) {
352
+ return this._setSizeFromTable();
353
+ } else {
354
+ this.table = [];
355
+ return this.fillTable();
356
+ }
357
+ },
358
+ _setSizeFromTable: function() {
359
+ var _ref;
360
+ return this.size = {
361
+ x: ((_ref = this.table[0]) != null ? _ref.length : void 0) || 0,
362
+ y: this.table.length || 0
363
+ };
364
+ },
365
+ _initializeOptions: function() {
366
+ var _base;
367
+ if (this.options == null) {
368
+ this.options = {};
369
+ }
370
+ return (_base = this.options).editable != null ? _base.editable : _base.editable = false;
371
+ },
372
+ _updateSize: function() {
373
+ var _i, _ref, _results;
374
+ this.columnIndexes = (function() {
375
+ _results = [];
376
+ for (var _i = 0, _ref = this.size.x; 0 <= _ref ? _i < _ref : _i > _ref; 0 <= _ref ? _i++ : _i--){ _results.push(_i); }
377
+ return _results;
378
+ }).apply(this);
379
+ return this.fire("board-changed");
380
+ },
381
+ _forceHeaderSet: function() {
382
+ var x, y;
383
+ x = Math.min(this.header.x, this.size.x - 1);
384
+ y = Math.min(this.header.y, this.size.y - 1);
385
+ this.header = null;
386
+ return this.header = {
387
+ x: x,
388
+ y: y
389
+ };
390
+ },
391
+ _readGbb: function() {
392
+ var gbb, height, width, _ref;
393
+ gbb = Polymer.dom(this).textContent;
394
+ if ((gbb == null) || gbb.indexOf("GBB") < 0) {
395
+ return;
396
+ }
397
+ _ref = gbbReader.fromString(gbb), this.table = _ref.table, this.header = _ref.head, width = _ref.width, height = _ref.height;
398
+ this.size.x = width;
399
+ this.size.y = height;
400
+ if (this.attireSrc) {
401
+ return this.attire = GobstonesBoard.getAttire(this.attireSrc);
402
+ }
403
+ },
404
+ _updateStyles: function(_arg) {
405
+ var attire;
406
+ attire = _arg.base;
407
+ if ((attire != null) && attire.enabled) {
408
+ this._setBorderOff();
409
+ } else {
410
+ this._setBorderOn();
411
+ }
412
+ return this.updateStyles();
413
+ },
414
+ _setBorderOn: function() {
415
+ this.customStyle["--cell-padding"] = "2px";
416
+ return this.customStyle["--cell-border"] = "solid #888 1px";
417
+ },
418
+ _setBorderOff: function() {
419
+ this.customStyle["--cell-padding"] = "0 0";
420
+ return this.customStyle["--cell-border"] = "none";
421
+ }
422
+ });
423
+
424
+ window.GobstonesBoard = {
425
+ attireProvider: null,
426
+ getAttire: function(name) {
427
+ if (this.attireProvider == null) {
428
+ throw new Error("You need to provide an attire provider with GobstonesBoard.setAttireProvider");
429
+ }
430
+ return this.attireProvider.get(name);
431
+ },
432
+ setAttireProvider: function(attireProvider) {
433
+ if (!(attireProvider != null ? attireProvider.get : void 0)) {
434
+ throw new Error("Attire providers must have a `get` method");
435
+ }
436
+ return this.attireProvider = attireProvider;
437
+ }
438
+ };
439
+
440
+ </script>
441
+ </dom-module>