@omegagrid/grid-core 0.2.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (185) hide show
  1. package/dist/calculations/autofill.d.ts +7 -0
  2. package/dist/calculations/autofill.d.ts.map +1 -0
  3. package/dist/calculations/autofill.js +81 -0
  4. package/dist/calculations/autofill.js.map +1 -0
  5. package/dist/calculations/calculationModel.d.ts +35 -0
  6. package/dist/calculations/calculationModel.d.ts.map +1 -0
  7. package/dist/calculations/calculationModel.js +199 -0
  8. package/dist/calculations/calculationModel.js.map +1 -0
  9. package/dist/calculations/conditions.d.ts +4 -0
  10. package/dist/calculations/conditions.d.ts.map +1 -0
  11. package/dist/calculations/conditions.js +46 -0
  12. package/dist/calculations/conditions.js.map +1 -0
  13. package/dist/calculations/context.d.ts +53 -0
  14. package/dist/calculations/context.d.ts.map +1 -0
  15. package/dist/calculations/context.js +83 -0
  16. package/dist/calculations/context.js.map +1 -0
  17. package/dist/calculations/formula.d.ts +69 -0
  18. package/dist/calculations/formula.d.ts.map +1 -0
  19. package/dist/calculations/formula.js +360 -0
  20. package/dist/calculations/formula.js.map +1 -0
  21. package/dist/calculations/functions/dates.d.ts +6 -0
  22. package/dist/calculations/functions/dates.d.ts.map +1 -0
  23. package/dist/calculations/functions/dates.js +28 -0
  24. package/dist/calculations/functions/dates.js.map +1 -0
  25. package/dist/calculations/functions/helpers.d.ts +11 -0
  26. package/dist/calculations/functions/helpers.d.ts.map +1 -0
  27. package/dist/calculations/functions/helpers.js +38 -0
  28. package/dist/calculations/functions/helpers.js.map +1 -0
  29. package/dist/calculations/functions/index.d.ts +5 -0
  30. package/dist/calculations/functions/index.d.ts.map +1 -0
  31. package/dist/calculations/functions/index.js +73 -0
  32. package/dist/calculations/functions/index.js.map +1 -0
  33. package/dist/calculations/functions/logical.d.ts +10 -0
  34. package/dist/calculations/functions/logical.d.ts.map +1 -0
  35. package/dist/calculations/functions/logical.js +49 -0
  36. package/dist/calculations/functions/logical.js.map +1 -0
  37. package/dist/calculations/functions/lookup.d.ts +17 -0
  38. package/dist/calculations/functions/lookup.d.ts.map +1 -0
  39. package/dist/calculations/functions/lookup.js +167 -0
  40. package/dist/calculations/functions/lookup.js.map +1 -0
  41. package/dist/calculations/functions/math.d.ts +62 -0
  42. package/dist/calculations/functions/math.d.ts.map +1 -0
  43. package/dist/calculations/functions/math.js +228 -0
  44. package/dist/calculations/functions/math.js.map +1 -0
  45. package/dist/calculations/functions/special.d.ts +2 -0
  46. package/dist/calculations/functions/special.d.ts.map +1 -0
  47. package/dist/calculations/functions/special.js +55 -0
  48. package/dist/calculations/functions/special.js.map +1 -0
  49. package/dist/calculations/functions/statistical.d.ts +5 -0
  50. package/dist/calculations/functions/statistical.d.ts.map +1 -0
  51. package/dist/calculations/functions/statistical.js +47 -0
  52. package/dist/calculations/functions/statistical.js.map +1 -0
  53. package/dist/calculations/functions/text.d.ts +5 -0
  54. package/dist/calculations/functions/text.d.ts.map +1 -0
  55. package/dist/calculations/functions/text.js +23 -0
  56. package/dist/calculations/functions/text.js.map +1 -0
  57. package/dist/calculations/index.d.ts +6 -0
  58. package/dist/calculations/index.d.ts.map +1 -0
  59. package/dist/calculations/index.js +22 -0
  60. package/dist/calculations/index.js.map +1 -0
  61. package/dist/calculations/operators.d.ts +19 -0
  62. package/dist/calculations/operators.d.ts.map +1 -0
  63. package/dist/calculations/operators.js +66 -0
  64. package/dist/calculations/operators.js.map +1 -0
  65. package/dist/calculations/tokenization.d.ts +34 -0
  66. package/dist/calculations/tokenization.d.ts.map +1 -0
  67. package/dist/calculations/tokenization.js +192 -0
  68. package/dist/calculations/tokenization.js.map +1 -0
  69. package/dist/comments/comments.d.ts +37 -0
  70. package/dist/comments/comments.d.ts.map +1 -0
  71. package/dist/comments/comments.js +39 -0
  72. package/dist/comments/comments.js.map +1 -0
  73. package/dist/comments/index.d.ts +2 -0
  74. package/dist/comments/index.d.ts.map +1 -0
  75. package/dist/comments/index.js +18 -0
  76. package/dist/comments/index.js.map +1 -0
  77. package/dist/common/index.d.ts +2 -0
  78. package/dist/common/index.d.ts.map +1 -0
  79. package/dist/common/index.js +18 -0
  80. package/dist/common/index.js.map +1 -0
  81. package/dist/common/range.d.ts +65 -0
  82. package/dist/common/range.d.ts.map +1 -0
  83. package/dist/common/range.js +220 -0
  84. package/dist/common/range.js.map +1 -0
  85. package/dist/constants.d.ts +60 -0
  86. package/dist/constants.d.ts.map +1 -0
  87. package/dist/constants.js +75 -0
  88. package/dist/constants.js.map +1 -0
  89. package/dist/formatting/conditionalFormats.d.ts +34 -0
  90. package/dist/formatting/conditionalFormats.d.ts.map +1 -0
  91. package/dist/formatting/conditionalFormats.js +107 -0
  92. package/dist/formatting/conditionalFormats.js.map +1 -0
  93. package/dist/formatting/index.d.ts +2 -0
  94. package/dist/formatting/index.d.ts.map +1 -0
  95. package/dist/formatting/index.js +18 -0
  96. package/dist/formatting/index.js.map +1 -0
  97. package/dist/index.d.ts +9 -0
  98. package/dist/index.d.ts.map +1 -0
  99. package/dist/index.js +30 -0
  100. package/dist/index.js.map +1 -0
  101. package/dist/model/cellModel.d.ts +105 -0
  102. package/dist/model/cellModel.d.ts.map +1 -0
  103. package/dist/model/cellModel.js +251 -0
  104. package/dist/model/cellModel.js.map +1 -0
  105. package/dist/model/columnModel.d.ts +132 -0
  106. package/dist/model/columnModel.d.ts.map +1 -0
  107. package/dist/model/columnModel.js +147 -0
  108. package/dist/model/columnModel.js.map +1 -0
  109. package/dist/model/columnSorting.d.ts +50 -0
  110. package/dist/model/columnSorting.d.ts.map +1 -0
  111. package/dist/model/columnSorting.js +164 -0
  112. package/dist/model/columnSorting.js.map +1 -0
  113. package/dist/model/cssStyle.d.ts +18 -0
  114. package/dist/model/cssStyle.d.ts.map +1 -0
  115. package/dist/model/cssStyle.js +197 -0
  116. package/dist/model/cssStyle.js.map +1 -0
  117. package/dist/model/dependencies.d.ts +28 -0
  118. package/dist/model/dependencies.d.ts.map +1 -0
  119. package/dist/model/dependencies.js +129 -0
  120. package/dist/model/dependencies.js.map +1 -0
  121. package/dist/model/elementModel.d.ts +98 -0
  122. package/dist/model/elementModel.d.ts.map +1 -0
  123. package/dist/model/elementModel.js +109 -0
  124. package/dist/model/elementModel.js.map +1 -0
  125. package/dist/model/filterModel.d.ts +22 -0
  126. package/dist/model/filterModel.d.ts.map +1 -0
  127. package/dist/model/filterModel.js +83 -0
  128. package/dist/model/filterModel.js.map +1 -0
  129. package/dist/model/gridModel.d.ts +172 -0
  130. package/dist/model/gridModel.d.ts.map +1 -0
  131. package/dist/model/gridModel.js +639 -0
  132. package/dist/model/gridModel.js.map +1 -0
  133. package/dist/model/groupModel.d.ts +23 -0
  134. package/dist/model/groupModel.d.ts.map +1 -0
  135. package/dist/model/groupModel.js +102 -0
  136. package/dist/model/groupModel.js.map +1 -0
  137. package/dist/model/history.d.ts +21 -0
  138. package/dist/model/history.d.ts.map +1 -0
  139. package/dist/model/history.js +39 -0
  140. package/dist/model/history.js.map +1 -0
  141. package/dist/model/index.d.ts +17 -0
  142. package/dist/model/index.d.ts.map +1 -0
  143. package/dist/model/index.js +33 -0
  144. package/dist/model/index.js.map +1 -0
  145. package/dist/model/iterableRange.d.ts +32 -0
  146. package/dist/model/iterableRange.d.ts.map +1 -0
  147. package/dist/model/iterableRange.js +79 -0
  148. package/dist/model/iterableRange.js.map +1 -0
  149. package/dist/model/namingModel.d.ts +24 -0
  150. package/dist/model/namingModel.d.ts.map +1 -0
  151. package/dist/model/namingModel.js +75 -0
  152. package/dist/model/namingModel.js.map +1 -0
  153. package/dist/model/options.d.ts +56 -0
  154. package/dist/model/options.d.ts.map +1 -0
  155. package/dist/model/options.js +27 -0
  156. package/dist/model/options.js.map +1 -0
  157. package/dist/model/rowModel.d.ts +91 -0
  158. package/dist/model/rowModel.d.ts.map +1 -0
  159. package/dist/model/rowModel.js +137 -0
  160. package/dist/model/rowModel.js.map +1 -0
  161. package/dist/model/selectionModel.d.ts +20 -0
  162. package/dist/model/selectionModel.d.ts.map +1 -0
  163. package/dist/model/selectionModel.js +45 -0
  164. package/dist/model/selectionModel.js.map +1 -0
  165. package/dist/model/style.d.ts +73 -0
  166. package/dist/model/style.d.ts.map +1 -0
  167. package/dist/model/style.js +38 -0
  168. package/dist/model/style.js.map +1 -0
  169. package/dist/model/styleModel.d.ts +20 -0
  170. package/dist/model/styleModel.d.ts.map +1 -0
  171. package/dist/model/styleModel.js +85 -0
  172. package/dist/model/styleModel.js.map +1 -0
  173. package/dist/sparklines/index.d.ts +2 -0
  174. package/dist/sparklines/index.d.ts.map +1 -0
  175. package/dist/sparklines/index.js +18 -0
  176. package/dist/sparklines/index.js.map +1 -0
  177. package/dist/sparklines/sparklines.d.ts +61 -0
  178. package/dist/sparklines/sparklines.d.ts.map +1 -0
  179. package/dist/sparklines/sparklines.js +185 -0
  180. package/dist/sparklines/sparklines.js.map +1 -0
  181. package/dist/types.d.ts +27 -0
  182. package/dist/types.d.ts.map +1 -0
  183. package/dist/types.js +9 -0
  184. package/dist/types.js.map +1 -0
  185. package/package.json +56 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"range.d.ts","sourceRoot":"","sources":["../../src/common/range.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,220 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.sortRanges = exports.decodeColumn = exports.encodeColumn = exports.decodeRow = exports.encodeRow = exports.CellRange = void 0;
4
+ function moveCoord(v, count, max = null, cycle = true) {
5
+ v = v + count;
6
+ return count == 0 ? v : (v >= 0
7
+ ? (max ? (cycle ? (v % max) : Math.min(v, max - 1)) : v)
8
+ : (cycle && max ? (max + (v % max)) : Math.max(v, 0)));
9
+ }
10
+ function escapeSheetName(name) {
11
+ return name.indexOf(' ') > -1 ? ("'" + name + "'") : name;
12
+ }
13
+ const A1_REGEX = /(\$?)([a-z]*)(\$?)(\d*)(?::(\$?)([a-z]*)(\$?)(\d*))?/i;
14
+ class CellRange {
15
+ constructor(c1, r1, c2, r2, sheet) {
16
+ this.setCoords(c1, r1, c2, r2);
17
+ this.sheet = sheet;
18
+ }
19
+ setCoords(c1, r1, c2, r2) {
20
+ this.c1 = c1 == null && c2 == null ? 0 : c1;
21
+ this.r1 = r1 == null && r2 == null ? 0 : r1;
22
+ this.c2 = (r2 != null || c1 == null) && c2 == null ? Infinity : (c2 == null ? c1 : c2);
23
+ this.r2 = (c2 != null || r1 == null) && r2 == null ? Infinity : (r2 == null ? r1 : r2);
24
+ this.normalize();
25
+ }
26
+ get size() {
27
+ return {
28
+ columns: this.c2 - this.c1 + 1,
29
+ rows: this.r2 - this.r1 + 1
30
+ };
31
+ }
32
+ get count() {
33
+ const { columns, rows } = this.size;
34
+ return columns * rows;
35
+ }
36
+ normalize() {
37
+ const [c1, c2] = [Math.min(this.c1, this.c2), Math.max(this.c1, this.c2)];
38
+ const [r1, r2] = [Math.min(this.r1, this.r2), Math.max(this.r1, this.r2)];
39
+ this.c1 = c1;
40
+ this.c2 = c2;
41
+ this.r1 = r1;
42
+ this.r2 = r2;
43
+ return this;
44
+ }
45
+ move(columns, rows, maxColumns = null, maxRows = null, cycle = true) {
46
+ const c1 = moveCoord(this.c1, columns, maxColumns, cycle);
47
+ if (cycle) {
48
+ rows += this.c1 + columns != c1 && columns != 0 ? (columns > 0 ? 1 : -1) : 0;
49
+ }
50
+ this.c1 = c1;
51
+ this.r1 = moveCoord(this.r1, rows, maxRows, cycle);
52
+ this.c2 = moveCoord(this.c2, columns, maxColumns, cycle);
53
+ this.r2 = moveCoord(this.r2, rows, maxRows, cycle);
54
+ }
55
+ contains(r) { return r.c1 >= this.c1 && r.c2 <= this.c2 && r.r1 >= this.r1 && r.r2 <= this.r2; }
56
+ containsColumn(c) { return this.c1 <= c && this.c2 >= c; }
57
+ containsRow(r) { return this.r1 <= r && this.r2 >= r; }
58
+ removeAnchors() {
59
+ this.c1Anchor = false;
60
+ this.c2Anchor = false;
61
+ this.r1Anchor = false;
62
+ this.r2Anchor = false;
63
+ return this;
64
+ }
65
+ addAnchors() {
66
+ this.c1Anchor = true;
67
+ this.c2Anchor = true;
68
+ this.r1Anchor = true;
69
+ this.r2Anchor = true;
70
+ return this;
71
+ }
72
+ shiftLeft(c, offset = 1, maxIndex = null) {
73
+ if (c <= this.c1 && !this.c1Anchor && (maxIndex == null || this.c1 <= maxIndex))
74
+ this.c1 -= offset;
75
+ if (c <= this.c2 && !this.c2Anchor && (maxIndex == null || this.c2 <= maxIndex))
76
+ this.c2 -= offset;
77
+ return this;
78
+ }
79
+ shiftRight(c, offset = 1, maxIndex = null) {
80
+ if (c <= this.c1 && !this.c1Anchor && (maxIndex == null || this.c1 <= maxIndex))
81
+ this.c1 += offset;
82
+ if (c <= this.c2 && !this.c2Anchor && (maxIndex == null || this.c2 <= maxIndex))
83
+ this.c2 += offset;
84
+ return this;
85
+ }
86
+ shiftUp(r, offset = 1, maxIndex = null) {
87
+ if (r <= this.r1 && !this.r1Anchor && (maxIndex == null || this.r1 <= maxIndex))
88
+ this.r1 -= offset;
89
+ if (r <= this.r2 && !this.r2Anchor && (maxIndex == null || this.r2 <= maxIndex))
90
+ this.r2 -= offset;
91
+ return this;
92
+ }
93
+ shiftDown(r, offset = 1, maxIndex = null) {
94
+ if (r <= this.r1 && !this.r1Anchor && (maxIndex == null || this.r1 <= maxIndex))
95
+ this.r1 += offset;
96
+ if (r <= this.r2 && !this.r2Anchor && (maxIndex == null || this.r2 <= maxIndex))
97
+ this.r2 += offset;
98
+ return this;
99
+ }
100
+ shift(index, offset, direction, maxIndex = null) {
101
+ switch (direction) {
102
+ case 'down': return this.shiftDown(index, offset, maxIndex);
103
+ case 'up': return this.shiftUp(index, offset, maxIndex);
104
+ case 'left': return this.shiftLeft(index, offset, maxIndex);
105
+ case 'right': return this.shiftRight(index, offset, maxIndex);
106
+ }
107
+ }
108
+ intersect(r) {
109
+ const leftX = Math.max(r.c1, this.c1);
110
+ const rightX = Math.min(r.c2, this.c2);
111
+ const topY = Math.max(r.r1, this.r1);
112
+ const bottomY = Math.min(r.r2, this.r2);
113
+ if (leftX <= rightX && topY <= bottomY) {
114
+ return new CellRange(leftX, topY, rightX, bottomY, this.sheet);
115
+ }
116
+ else {
117
+ return null;
118
+ }
119
+ }
120
+ unite(r) {
121
+ return new CellRange(Math.min(this.c1, r.c1), Math.min(this.r1, r.r1), Math.max(this.c2, r.c2), Math.max(this.r2, r.r2), this.sheet);
122
+ }
123
+ clone() {
124
+ const r = new CellRange(this.c1, this.r1, this.c2, this.r2, this.sheet);
125
+ r.c1Anchor = this.c1Anchor;
126
+ r.r1Anchor = this.r1Anchor;
127
+ r.c2Anchor = this.c2Anchor;
128
+ r.r2Anchor = this.r2Anchor;
129
+ return r;
130
+ }
131
+ equals(r, exact = false) {
132
+ return r.c1 == this.c1 && r.r1 == this.r1 && r.c2 == this.c2 && r.r2 == this.r2
133
+ && (exact == false || (r.c1Anchor == this.c1Anchor && r.r1Anchor == this.r1Anchor
134
+ && r.c2Anchor == this.c2Anchor && r.r2Anchor == this.r2Anchor));
135
+ }
136
+ get isCell() { return (this.c2 == this.c2 && this.r2 == this.r1); }
137
+ get isRange() { return (this.c2 != this.c1 || this.r2 != this.r1); }
138
+ get isColumn() { return this.r1 == 0 && this.r2 == Infinity; }
139
+ get isRow() { return this.c1 == 0 && this.c2 == Infinity; }
140
+ get A1() {
141
+ const isRange = this.isRange;
142
+ const from = (this.c1Anchor ? '$' : '')
143
+ + (!(this.c1 === 0 && this.c2 === Infinity) ? encodeColumn(this.c1) : '')
144
+ + (this.r1Anchor ? '$' : '')
145
+ + (!(this.r1 === 0 && this.r2 === Infinity) ? encodeRow(this.r1) : '');
146
+ const to = !isRange ? from :
147
+ (this.c2Anchor ? '$' : '')
148
+ + (!isNaN(this.c2) && this.c2 < Infinity ? encodeColumn(this.c2) : '')
149
+ + (this.r2Anchor ? '$' : '')
150
+ + (!isNaN(this.r2) && this.r2 < Infinity ? encodeRow(this.r2) : '');
151
+ return (this.sheet == null ? '' : (escapeSheetName(this.sheet) + '!')) + (from == to ? from : (from + ':' + to));
152
+ }
153
+ get bounds() {
154
+ return [[
155
+ new CellRange(this.c1, this.r1),
156
+ this.c2 < Infinity ? new CellRange(this.c2, this.r1) : null
157
+ ], [
158
+ this.r2 < Infinity ? new CellRange(this.c1, this.r2) : null,
159
+ this.r2 < Infinity && this.c2 < Infinity ? new CellRange(this.c2, this.r2) : null,
160
+ ]];
161
+ }
162
+ static fromA1(a1) {
163
+ const m = A1_REGEX.exec(a1.toUpperCase());
164
+ const r = new CellRange(m[2] ? decodeColumn(m[2]) : null, m[4] ? decodeRow(m[4]) : null, m[6] ? decodeColumn(m[6]) : null, m[8] ? decodeRow(m[8]) : null);
165
+ if (m[1])
166
+ r.c1Anchor = true;
167
+ if (m[3])
168
+ r.r1Anchor = true;
169
+ if (m[5] || (m[1] && !m[6]))
170
+ r.c2Anchor = true;
171
+ if (m[7] || (m[3] && !m[8]))
172
+ r.r2Anchor = true;
173
+ return r;
174
+ }
175
+ }
176
+ exports.CellRange = CellRange;
177
+ CellRange.fromA1s = (a1, delimiter = ';') => a1.split(delimiter).map(s => CellRange.fromA1(s));
178
+ CellRange.toA1s = (ranges, delimiter = ';') => ranges.map(r => r.A1).join(delimiter);
179
+ CellRange.fromCoords = (r) => new CellRange(r.c1, r.r1, r.c2, r.r2);
180
+ CellRange.fullColumn = (c) => new CellRange(c, 0, c, Infinity);
181
+ CellRange.fullRow = (r) => new CellRange(0, r, Infinity, r);
182
+ function encodeRow(row) {
183
+ return (row + 1).toString();
184
+ }
185
+ exports.encodeRow = encodeRow;
186
+ function decodeRow(row) {
187
+ return parseInt(row) - 1;
188
+ }
189
+ exports.decodeRow = decodeRow;
190
+ function encodeColumn(column) {
191
+ ++column;
192
+ let temp, letter = '';
193
+ while (column > 0) {
194
+ temp = (column - 1) % 26;
195
+ letter = String.fromCharCode(temp + 65) + letter;
196
+ column = (column - temp - 1) / 26;
197
+ }
198
+ return letter;
199
+ }
200
+ exports.encodeColumn = encodeColumn;
201
+ function decodeColumn(letter) {
202
+ const length = letter.length;
203
+ let column = 0;
204
+ for (let i = 0; i < length; i++) {
205
+ column += (letter.charCodeAt(i) - 64) * Math.pow(26, length - i - 1);
206
+ }
207
+ return column - 1;
208
+ }
209
+ exports.decodeColumn = decodeColumn;
210
+ function sortRanges(ranges) {
211
+ return ranges.sort((a, b) => {
212
+ const r1 = Math.min(a.r1, a.r2);
213
+ const r2 = Math.min(b.r1, b.r2);
214
+ const c1 = Math.min(a.c1, a.c2);
215
+ const c2 = Math.min(b.c1, b.c2);
216
+ return r1 < r2 ? -1 : (r1 > r2 ? 1 : (c1 < c2 ? -1 : (c2 > c1 ? 1 : 0)));
217
+ });
218
+ }
219
+ exports.sortRanges = sortRanges;
220
+ //# sourceMappingURL=range.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"range.js","sourceRoot":"","sources":["../../src/common/range.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,60 @@
1
+ /// <reference types="color" />
2
+ import { Options } from './model';
3
+ import { SparklineOptions } from './sparklines';
4
+ declare const _default: {
5
+ LOCALE: string;
6
+ PREFIX: string;
7
+ DEFAULT_ACCENT_COLOR: string;
8
+ DEFAULT_ACCENT_COLOR_2: import("color")<string | number | ArrayLike<number> | import("color")<string | number | ArrayLike<number> | import("color")<string | number | ArrayLike<number> | import("color")<string | number | ArrayLike<number> | import("color")<string | number | ArrayLike<number> | import("color")<string | number | ArrayLike<number> | import("color")<string | number | ArrayLike<number> | import("color")<string | number | ArrayLike<number> | import("color")<string | number | ArrayLike<number> | import("color")<string | number | ArrayLike<number> | import("color")<string | number | ArrayLike<number> | import("color")<any> | {
9
+ [key: string]: any;
10
+ }> | {
11
+ [key: string]: any;
12
+ }> | {
13
+ [key: string]: any;
14
+ }> | {
15
+ [key: string]: any;
16
+ }> | {
17
+ [key: string]: any;
18
+ }> | {
19
+ [key: string]: any;
20
+ }> | {
21
+ [key: string]: any;
22
+ }> | {
23
+ [key: string]: any;
24
+ }> | {
25
+ [key: string]: any;
26
+ }> | {
27
+ [key: string]: any;
28
+ }> | {
29
+ [key: string]: any;
30
+ }>;
31
+ SIZER_SIZE: number;
32
+ SLIDER_SIZE: number;
33
+ SLIDER_MIN_LENGTH: number;
34
+ EXPANDER_SIZE: number;
35
+ LIST_ITEM_HEIGHT: number;
36
+ LIST_RENDERING_TRESHOLD: number;
37
+ LIST_AUTOSCROLL_TRESHOLD: number;
38
+ LIST_AUTOSCROLL_DELAY: number;
39
+ DEFAULT_TEXT_HIGHLIGHT_COLOR: string;
40
+ TOOLTIP_MARGIN: number;
41
+ MENU_ITEM_HEIGHT: number;
42
+ COLORPICKER_COLOR_SIZE: number;
43
+ RESIZE_TRESHOLD: number;
44
+ ROW_HEADER_WIDTH: number;
45
+ DEFAULT_ROW_HEIGHT: number;
46
+ MAX_CACHE_ITEMS: number;
47
+ CACHE_CLEAN_INTERVAL: number;
48
+ COMMENT_HIDE_TIMEOUT: number;
49
+ SELECTOR_BORDER_WIDTH: number;
50
+ MIN_ROW_HEIGHT: number;
51
+ MIN_COL_WIDTH: number;
52
+ SPARKLINE_GAP: number;
53
+ AUTOSCROLL_TRESHOLD: number;
54
+ AUTOSCROLL_RATIO: number;
55
+ AUTOSCROLL_INTERVAL: number;
56
+ DEFAULT_SPARKLINE_OPTIONS: SparklineOptions;
57
+ DEFAULT_OPTIONS: Options;
58
+ };
59
+ export default _default;
60
+ //# sourceMappingURL=constants.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../src/constants.ts"],"names":[],"mappings":";AACA,OAAO,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AAClC,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAyDhD,wBAmBE"}
@@ -0,0 +1,75 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const core_1 = require("@omegagrid/core");
4
+ const DEFAULT_OPTIONS = {
5
+ rows: 100,
6
+ columns: 20,
7
+ readOnly: false,
8
+ rowNumbers: true,
9
+ rowTree: true,
10
+ colLetters: true,
11
+ freezeTop: 0,
12
+ fontSize: 12,
13
+ rowHeight: 22,
14
+ freezeLeft: 0,
15
+ freezeRight: 0,
16
+ freezeBottom: 0,
17
+ maxSortingColums: 3,
18
+ attributeTooltip: true,
19
+ numberFormat: null,
20
+ levelIndent: 20,
21
+ emptyClickable: false,
22
+ grid: true,
23
+ autofill: true,
24
+ undoRedo: true,
25
+ commandWindow: true,
26
+ editing: {
27
+ rowInsertion: true,
28
+ rowDeletion: true,
29
+ colInsertion: true,
30
+ colDeletion: true,
31
+ },
32
+ comments: {
33
+ hideTimeout: 1000,
34
+ offsetX: 30,
35
+ offsetY: -30,
36
+ zIndex: 500
37
+ },
38
+ scrolling: {
39
+ verticalOverscroll: true,
40
+ horizontalOverscroll: true
41
+ }
42
+ };
43
+ const DEFAULT_SPARKLINE_OPTIONS = {
44
+ minValue: 'auto',
45
+ maxValue: 'auto',
46
+ type: 'line',
47
+ style: {
48
+ color: '0094FF',
49
+ weight: 1
50
+ },
51
+ marker: {
52
+ color: 'ff0000'
53
+ }
54
+ };
55
+ exports.default = {
56
+ RESIZE_TRESHOLD: 10,
57
+ ROW_HEADER_WIDTH: 60,
58
+ SLIDER_SIZE: 12,
59
+ EXPANDER_SIZE: 13,
60
+ DEFAULT_ROW_HEIGHT: 22,
61
+ MAX_CACHE_ITEMS: 5000, //50000,
62
+ CACHE_CLEAN_INTERVAL: 30,
63
+ COMMENT_HIDE_TIMEOUT: 1000,
64
+ SELECTOR_BORDER_WIDTH: 2,
65
+ MIN_ROW_HEIGHT: 5,
66
+ MIN_COL_WIDTH: 5,
67
+ SPARKLINE_GAP: 4,
68
+ AUTOSCROLL_TRESHOLD: 100,
69
+ AUTOSCROLL_RATIO: 1.1,
70
+ AUTOSCROLL_INTERVAL: 100,
71
+ DEFAULT_SPARKLINE_OPTIONS: DEFAULT_SPARKLINE_OPTIONS,
72
+ DEFAULT_OPTIONS: DEFAULT_OPTIONS,
73
+ ...core_1.constants
74
+ };
75
+ //# sourceMappingURL=constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.js","sourceRoot":"","sources":["../src/constants.ts"],"names":[],"mappings":";;AAAA,0CAA6D;AAI7D,MAAM,eAAe,GAAG;IACvB,IAAI,EAAE,GAAG;IACT,OAAO,EAAE,EAAE;IACX,QAAQ,EAAE,KAAK;IACf,UAAU,EAAE,IAAI;IAChB,OAAO,EAAE,IAAI;IACb,UAAU,EAAE,IAAI;IAChB,SAAS,EAAE,CAAC;IACZ,QAAQ,EAAE,EAAE;IACZ,SAAS,EAAE,EAAE;IACb,UAAU,EAAE,CAAC;IACb,WAAW,EAAE,CAAC;IACd,YAAY,EAAE,CAAC;IACf,gBAAgB,EAAE,CAAC;IACnB,gBAAgB,EAAE,IAAI;IACtB,YAAY,EAAE,IAAI;IAClB,WAAW,EAAE,EAAE;IACf,cAAc,EAAE,KAAK;IACrB,IAAI,EAAE,IAAI;IACV,QAAQ,EAAE,IAAI;IACd,QAAQ,EAAE,IAAI;IACd,aAAa,EAAE,IAAI;IACnB,OAAO,EAAE;QACR,YAAY,EAAE,IAAI;QAClB,WAAW,EAAE,IAAI;QACjB,YAAY,EAAE,IAAI;QAClB,WAAW,EAAE,IAAI;KACjB;IACD,QAAQ,EAAE;QACT,WAAW,EAAE,IAAI;QACjB,OAAO,EAAE,EAAE;QACX,OAAO,EAAE,CAAC,EAAE;QACZ,MAAM,EAAE,GAAG;KACX;IACD,SAAS,EAAE;QACV,kBAAkB,EAAE,IAAI;QACxB,oBAAoB,EAAE,IAAI;KAC1B;CACU,CAAC;AAGb,MAAM,yBAAyB,GAAG;IACjC,QAAQ,EAAE,MAAM;IAChB,QAAQ,EAAE,MAAM;IAChB,IAAI,EAAE,MAAM;IACZ,KAAK,EAAE;QACN,KAAK,EAAE,QAAQ;QACf,MAAM,EAAE,CAAC;KACT;IACD,MAAM,EAAE;QACP,KAAK,EAAE,QAAQ;KACf;CACmB,CAAA;AAGrB,kBAAe;IACd,eAAe,EAAE,EAAE;IACnB,gBAAgB,EAAE,EAAE;IACpB,WAAW,EAAE,EAAE;IACf,aAAa,EAAE,EAAE;IACjB,kBAAkB,EAAE,EAAE;IACtB,eAAe,EAAE,IAAI,EAAE,QAAQ;IAC/B,oBAAoB,EAAE,EAAE;IACxB,oBAAoB,EAAE,IAAI;IAC1B,qBAAqB,EAAE,CAAC;IACxB,cAAc,EAAE,CAAC;IACjB,aAAa,EAAE,CAAC;IAChB,aAAa,EAAE,CAAC;IAChB,mBAAmB,EAAE,GAAG;IACxB,gBAAgB,EAAE,GAAG;IACrB,mBAAmB,EAAE,GAAG;IACxB,yBAAyB,EAAE,yBAAyB;IACpD,eAAe,EAAE,eAAe;IAChC,GAAG,gBAAa;CAChB,CAAC"}
@@ -0,0 +1,34 @@
1
+ import { Formula, FormulaString } from "../calculations";
2
+ import { CellRange, RangeAddress } from "../common";
3
+ import { CellModel, GridModel, Style, Dependencies } from "../model";
4
+ export type ConditionalFormatItemSource = {
5
+ ranges: RangeAddress;
6
+ style?: Style;
7
+ condition?: FormulaString;
8
+ stop?: boolean;
9
+ };
10
+ export type ConditionalFormatSource = ConditionalFormatItemSource[];
11
+ export type ConditionalFormat = {
12
+ ranges: CellRange[];
13
+ firstCell: CellRange;
14
+ style: Style;
15
+ condition: FormulaString;
16
+ formula: Formula;
17
+ stop: boolean;
18
+ };
19
+ export declare class ConditionalFormats {
20
+ readonly model: GridModel;
21
+ readonly formats: ConditionalFormat[];
22
+ readonly cellFormulaMap: Map<string, [ConditionalFormat, Formula][]>;
23
+ private _dependencies;
24
+ get dependencies(): Dependencies;
25
+ constructor(model: GridModel, sourceData?: ConditionalFormatSource);
26
+ populate(sourceData: ConditionalFormatSource): void;
27
+ refresh(): void;
28
+ clearCellDependecies(cell: CellModel): this;
29
+ evaluate(cell: CellModel): Style;
30
+ initFormatCondition(item: ConditionalFormat): ConditionalFormat;
31
+ add(itemSource: ConditionalFormatItemSource): void;
32
+ getSourceData(): ConditionalFormatItemSource[];
33
+ }
34
+ //# sourceMappingURL=conditionalFormats.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"conditionalFormats.d.ts","sourceRoot":"","sources":["../../src/formatting/conditionalFormats.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAA;AACxD,OAAO,EAAe,SAAS,EAAE,YAAY,EAAE,MAAM,WAAW,CAAA;AAChE,OAAO,EAAE,SAAS,EAAE,SAAS,EAAwB,KAAK,EAAE,YAAY,EAAE,MAAM,UAAU,CAAA;AAE1F,MAAM,MAAM,2BAA2B,GAAG;IACzC,MAAM,EAAE,YAAY,CAAC;IACrB,KAAK,CAAC,EAAE,KAAK,CAAC;IACd,SAAS,CAAC,EAAE,aAAa,CAAC;IAC1B,IAAI,CAAC,EAAE,OAAO,CAAA;CACd,CAAC;AAEF,MAAM,MAAM,uBAAuB,GAAG,2BAA2B,EAAE,CAAC;AAEpE,MAAM,MAAM,iBAAiB,GAAG;IAC/B,MAAM,EAAE,SAAS,EAAE,CAAC;IACpB,SAAS,EAAE,SAAS,CAAC;IACrB,KAAK,EAAE,KAAK,CAAC;IACb,SAAS,EAAE,aAAa,CAAC;IACzB,OAAO,EAAE,OAAO,CAAC;IACjB,IAAI,EAAE,OAAO,CAAA;CACb,CAAA;AAED,qBAAa,kBAAkB;aAQF,KAAK,EAAE,SAAS;IAN5C,SAAgB,OAAO,EAAE,iBAAiB,EAAE,CAAM;IAClD,SAAgB,cAAc,8CAA0D;IAExF,OAAO,CAAC,aAAa,CAAe;IACpC,IAAI,YAAY,iBAAgC;gBAEpB,KAAK,EAAE,SAAS,EAAE,UAAU,CAAC,EAAE,uBAAuB;IAKlF,QAAQ,CAAC,UAAU,EAAE,uBAAuB;IAU5C,OAAO;IAMP,oBAAoB,CAAC,IAAI,EAAE,SAAS;IAQpC,QAAQ,CAAC,IAAI,EAAE,SAAS;IA0BxB,mBAAmB,CAAC,IAAI,EAAE,iBAAiB;IAoB3C,GAAG,CAAC,UAAU,EAAE,2BAA2B;IAa3C,aAAa;CASb"}
@@ -0,0 +1,107 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ConditionalFormats = void 0;
4
+ const calculations_1 = require("../calculations");
5
+ const common_1 = require("../common");
6
+ const model_1 = require("../model");
7
+ class ConditionalFormats {
8
+ get dependencies() { return this._dependencies; }
9
+ constructor(model, sourceData) {
10
+ this.model = model;
11
+ this.formats = [];
12
+ this.cellFormulaMap = new Map();
13
+ this._dependencies = new model_1.Dependencies(model);
14
+ if (sourceData)
15
+ this.populate(sourceData);
16
+ }
17
+ populate(sourceData) {
18
+ sourceData.forEach(item => {
19
+ try {
20
+ this.add(item);
21
+ }
22
+ catch (error) {
23
+ this.model.logger.error(`conditional format error: ${JSON.stringify(item)}`, error);
24
+ }
25
+ });
26
+ }
27
+ refresh() {
28
+ this.dependencies.clear();
29
+ this.cellFormulaMap.clear();
30
+ this.formats.forEach(item => this.initFormatCondition(item));
31
+ }
32
+ clearCellDependecies(cell) {
33
+ const addr = cell.address;
34
+ this.dependencies.clearCellDependecies(addr);
35
+ const item = this.cellFormulaMap.get(addr);
36
+ item.forEach(i => i[1] = null);
37
+ return this;
38
+ }
39
+ evaluate(cell) {
40
+ const addr = cell.address;
41
+ const formulas = this.cellFormulaMap.get(addr);
42
+ if (!formulas)
43
+ return null;
44
+ let style = null;
45
+ for (const item of formulas) {
46
+ if (!item[1]) {
47
+ const f = new calculations_1.Formula(item[0].condition, this.model.calculations.tokenizer);
48
+ item[1] = f.shift(0, cell.c - item[0].firstCell.c1, 'right').shift(0, cell.r - item[0].firstCell.r1, 'down');
49
+ f.cells.forEach(dep => this._dependencies.add(addr, dep[1].A1, dep[2]));
50
+ f.ranges.forEach(dep => this._dependencies.add(addr, dep[1].A1, dep[2]));
51
+ f.variables.forEach(([_i, v]) => {
52
+ const c = this.model.getCellByName(v, cell.range);
53
+ if (c)
54
+ this._dependencies.add(addr, c.address, null);
55
+ });
56
+ }
57
+ const res = this.model.calculations.evaluateFormula(item[1], cell);
58
+ if (res) {
59
+ style = item[0].style;
60
+ if (item[0].stop)
61
+ break;
62
+ }
63
+ }
64
+ return style;
65
+ }
66
+ initFormatCondition(item) {
67
+ item.ranges.forEach(range => {
68
+ for (const r of new model_1.IterableAddressRange(range.intersect(this.model.gridRange))) {
69
+ const a1 = r.A1;
70
+ let f = null;
71
+ if (!item.firstCell) {
72
+ item.firstCell = r;
73
+ f = new calculations_1.Formula(item.condition, this.model.calculations.tokenizer);
74
+ item.formula = f;
75
+ }
76
+ else {
77
+ // f = new Formula(item.condition, this.model.calculations.tokenizer);
78
+ // f.shift(0, r.c1 - item.firstCell.c1, 'right').shift(0, r.r1 - item.firstCell.r1, 'down');
79
+ }
80
+ const formulas = this.cellFormulaMap.get(a1) || this.cellFormulaMap.set(a1, []).get(a1);
81
+ formulas.push([item, f]);
82
+ }
83
+ });
84
+ return item;
85
+ }
86
+ add(itemSource) {
87
+ const item = {
88
+ ranges: common_1.CellRange.fromA1s(itemSource.ranges),
89
+ firstCell: null,
90
+ formula: null,
91
+ style: itemSource.style,
92
+ condition: itemSource.condition,
93
+ stop: itemSource.stop == null ? false : itemSource.stop
94
+ };
95
+ this.formats.push(this.initFormatCondition(item));
96
+ }
97
+ getSourceData() {
98
+ return this.formats.map(format => ({
99
+ ranges: common_1.CellRange.toA1s(format.ranges),
100
+ style: format.style,
101
+ condition: format.condition,
102
+ stop: format.stop
103
+ }));
104
+ }
105
+ }
106
+ exports.ConditionalFormats = ConditionalFormats;
107
+ //# sourceMappingURL=conditionalFormats.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"conditionalFormats.js","sourceRoot":"","sources":["../../src/formatting/conditionalFormats.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export * from './conditionalFormats';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/formatting/index.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAC"}
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./conditionalFormats"), exports);
18
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/formatting/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,uDAAqC"}
@@ -0,0 +1,9 @@
1
+ export { default as gridConstants } from './constants';
2
+ export * from './calculations';
3
+ export * from './comments';
4
+ export * from './common';
5
+ export * from './formatting';
6
+ export * from './model';
7
+ export * from './sparklines';
8
+ export * from './types';
9
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,OAAO,IAAI,aAAa,EAAC,MAAM,aAAa,CAAC;AACrD,cAAc,gBAAgB,CAAC;AAC/B,cAAc,YAAY,CAAC;AAC3B,cAAc,UAAU,CAAC;AACzB,cAAc,cAAc,CAAC;AAC7B,cAAc,SAAS,CAAC;AACxB,cAAc,cAAc,CAAC;AAC7B,cAAc,SAAS,CAAC"}
package/dist/index.js ADDED
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ var __importDefault = (this && this.__importDefault) || function (mod) {
17
+ return (mod && mod.__esModule) ? mod : { "default": mod };
18
+ };
19
+ Object.defineProperty(exports, "__esModule", { value: true });
20
+ exports.gridConstants = void 0;
21
+ var constants_1 = require("./constants");
22
+ Object.defineProperty(exports, "gridConstants", { enumerable: true, get: function () { return __importDefault(constants_1).default; } });
23
+ __exportStar(require("./calculations"), exports);
24
+ __exportStar(require("./comments"), exports);
25
+ __exportStar(require("./common"), exports);
26
+ __exportStar(require("./formatting"), exports);
27
+ __exportStar(require("./model"), exports);
28
+ __exportStar(require("./sparklines"), exports);
29
+ __exportStar(require("./types"), exports);
30
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA,yCAAqD;AAA7C,2HAAA,OAAO,OAAiB;AAChC,iDAA+B;AAC/B,6CAA2B;AAC3B,2CAAyB;AACzB,+CAA6B;AAC7B,0CAAwB;AACxB,+CAA6B;AAC7B,0CAAwB"}