@trebco/treb 23.6.2 → 25.0.0-rc1
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.
- package/.eslintignore +8 -0
- package/.eslintrc.js +164 -0
- package/README-shadow-DOM.md +88 -0
- package/README.md +37 -130
- package/api-config.json +29 -0
- package/api-generator/api-generator-types.ts +82 -0
- package/api-generator/api-generator.ts +1172 -0
- package/api-generator/package.json +3 -0
- package/build/treb-spreadsheet.mjs +14 -0
- package/{treb.d.ts → build/treb.d.ts} +293 -299
- package/esbuild-custom-element.mjs +336 -0
- package/esbuild.js +305 -0
- package/package.json +43 -14
- package/treb-base-types/package.json +5 -0
- package/treb-base-types/src/api_types.ts +36 -0
- package/treb-base-types/src/area.ts +583 -0
- package/treb-base-types/src/basic_types.ts +45 -0
- package/treb-base-types/src/cell.ts +612 -0
- package/treb-base-types/src/cells.ts +1066 -0
- package/treb-base-types/src/color.ts +124 -0
- package/treb-base-types/src/import.ts +71 -0
- package/treb-base-types/src/index-standalone.ts +29 -0
- package/treb-base-types/src/index.ts +42 -0
- package/treb-base-types/src/layout.ts +47 -0
- package/treb-base-types/src/localization.ts +187 -0
- package/treb-base-types/src/rectangle.ts +145 -0
- package/treb-base-types/src/render_text.ts +72 -0
- package/treb-base-types/src/style.ts +545 -0
- package/treb-base-types/src/table.ts +109 -0
- package/treb-base-types/src/text_part.ts +54 -0
- package/treb-base-types/src/theme.ts +608 -0
- package/treb-base-types/src/union.ts +152 -0
- package/treb-base-types/src/value-type.ts +164 -0
- package/treb-base-types/style/resizable.css +59 -0
- package/treb-calculator/modern.tsconfig.json +11 -0
- package/treb-calculator/package.json +5 -0
- package/treb-calculator/src/calculator.ts +2546 -0
- package/treb-calculator/src/complex-math.ts +558 -0
- package/treb-calculator/src/dag/array-vertex.ts +198 -0
- package/treb-calculator/src/dag/graph.ts +951 -0
- package/treb-calculator/src/dag/leaf_vertex.ts +118 -0
- package/treb-calculator/src/dag/spreadsheet_vertex.ts +327 -0
- package/treb-calculator/src/dag/spreadsheet_vertex_base.ts +44 -0
- package/treb-calculator/src/dag/vertex.ts +352 -0
- package/treb-calculator/src/descriptors.ts +162 -0
- package/treb-calculator/src/expression-calculator.ts +1069 -0
- package/treb-calculator/src/function-error.ts +103 -0
- package/treb-calculator/src/function-library.ts +103 -0
- package/treb-calculator/src/functions/base-functions.ts +1214 -0
- package/treb-calculator/src/functions/checkbox.ts +164 -0
- package/treb-calculator/src/functions/complex-functions.ts +253 -0
- package/treb-calculator/src/functions/finance-functions.ts +399 -0
- package/treb-calculator/src/functions/information-functions.ts +102 -0
- package/treb-calculator/src/functions/matrix-functions.ts +182 -0
- package/treb-calculator/src/functions/sparkline.ts +335 -0
- package/treb-calculator/src/functions/statistics-functions.ts +350 -0
- package/treb-calculator/src/functions/text-functions.ts +298 -0
- package/treb-calculator/src/index.ts +27 -0
- package/treb-calculator/src/notifier-types.ts +59 -0
- package/treb-calculator/src/primitives.ts +428 -0
- package/treb-calculator/src/utilities.ts +305 -0
- package/treb-charts/package.json +5 -0
- package/treb-charts/src/chart-functions.ts +156 -0
- package/treb-charts/src/chart-types.ts +230 -0
- package/treb-charts/src/chart.ts +1288 -0
- package/treb-charts/src/index.ts +24 -0
- package/treb-charts/src/main.ts +37 -0
- package/treb-charts/src/rectangle.ts +52 -0
- package/treb-charts/src/renderer.ts +1841 -0
- package/treb-charts/src/util.ts +122 -0
- package/treb-charts/style/charts.scss +221 -0
- package/treb-charts/style/old-charts.scss +250 -0
- package/treb-embed/markup/layout.html +137 -0
- package/treb-embed/markup/toolbar.html +175 -0
- package/treb-embed/modern.tsconfig.json +25 -0
- package/treb-embed/src/custom-element/content-types.d.ts +18 -0
- package/treb-embed/src/custom-element/global.d.ts +11 -0
- package/treb-embed/src/custom-element/spreadsheet-constructor.ts +1227 -0
- package/treb-embed/src/custom-element/treb-global.ts +44 -0
- package/treb-embed/src/custom-element/treb-spreadsheet-element.ts +52 -0
- package/treb-embed/src/embedded-spreadsheet.ts +5362 -0
- package/treb-embed/src/index.ts +16 -0
- package/treb-embed/src/language-model.ts +41 -0
- package/treb-embed/src/options.ts +320 -0
- package/treb-embed/src/progress-dialog.ts +228 -0
- package/treb-embed/src/selection-state.ts +16 -0
- package/treb-embed/src/spinner.ts +42 -0
- package/treb-embed/src/toolbar-message.ts +96 -0
- package/treb-embed/src/types.ts +167 -0
- package/treb-embed/style/autocomplete.scss +103 -0
- package/treb-embed/style/dark-theme.scss +114 -0
- package/treb-embed/style/defaults.scss +36 -0
- package/treb-embed/style/dialog.scss +181 -0
- package/treb-embed/style/dropdown-select.scss +101 -0
- package/treb-embed/style/formula-bar.scss +193 -0
- package/treb-embed/style/grid.scss +374 -0
- package/treb-embed/style/layout.scss +424 -0
- package/treb-embed/style/mouse-mask.scss +67 -0
- package/treb-embed/style/note.scss +92 -0
- package/treb-embed/style/overlay-editor.scss +102 -0
- package/treb-embed/style/spinner.scss +92 -0
- package/treb-embed/style/tab-bar.scss +228 -0
- package/treb-embed/style/table.scss +80 -0
- package/treb-embed/style/theme-defaults.scss +444 -0
- package/treb-embed/style/toolbar.scss +416 -0
- package/treb-embed/style/tooltip.scss +68 -0
- package/treb-embed/style/treb-icons.scss +130 -0
- package/treb-embed/style/treb-spreadsheet-element.scss +20 -0
- package/treb-embed/style/z-index.scss +43 -0
- package/treb-export/docs/charts.md +68 -0
- package/treb-export/modern.tsconfig.json +19 -0
- package/treb-export/package.json +4 -0
- package/treb-export/src/address-type.ts +77 -0
- package/treb-export/src/base-template.ts +22 -0
- package/treb-export/src/column-width.ts +85 -0
- package/treb-export/src/drawing2/chart-template-components2.ts +389 -0
- package/treb-export/src/drawing2/chart2.ts +282 -0
- package/treb-export/src/drawing2/column-chart-template2.ts +521 -0
- package/treb-export/src/drawing2/donut-chart-template2.ts +296 -0
- package/treb-export/src/drawing2/drawing2.ts +355 -0
- package/treb-export/src/drawing2/embedded-image.ts +71 -0
- package/treb-export/src/drawing2/scatter-chart-template2.ts +555 -0
- package/treb-export/src/export-worker/export-worker.ts +99 -0
- package/treb-export/src/export-worker/index-modern.ts +22 -0
- package/treb-export/src/export2.ts +2204 -0
- package/treb-export/src/import2.ts +882 -0
- package/treb-export/src/relationship.ts +36 -0
- package/treb-export/src/shared-strings2.ts +128 -0
- package/treb-export/src/template-2.ts +22 -0
- package/treb-export/src/unescape_xml.ts +47 -0
- package/treb-export/src/workbook-sheet2.ts +182 -0
- package/treb-export/src/workbook-style2.ts +1285 -0
- package/treb-export/src/workbook-theme2.ts +88 -0
- package/treb-export/src/workbook2.ts +491 -0
- package/treb-export/src/xml-utils.ts +201 -0
- package/treb-export/template/base/[Content_Types].xml +2 -0
- package/treb-export/template/base/_rels/.rels +2 -0
- package/treb-export/template/base/docProps/app.xml +2 -0
- package/treb-export/template/base/docProps/core.xml +12 -0
- package/treb-export/template/base/xl/_rels/workbook.xml.rels +2 -0
- package/treb-export/template/base/xl/sharedStrings.xml +2 -0
- package/treb-export/template/base/xl/styles.xml +2 -0
- package/treb-export/template/base/xl/theme/theme1.xml +2 -0
- package/treb-export/template/base/xl/workbook.xml +2 -0
- package/treb-export/template/base/xl/worksheets/sheet1.xml +2 -0
- package/treb-export/template/base.xlsx +0 -0
- package/treb-format/package.json +8 -0
- package/treb-format/src/format.test.ts +213 -0
- package/treb-format/src/format.ts +942 -0
- package/treb-format/src/format_cache.ts +199 -0
- package/treb-format/src/format_parser.ts +723 -0
- package/treb-format/src/index.ts +25 -0
- package/treb-format/src/number_format_section.ts +100 -0
- package/treb-format/src/value_parser.ts +337 -0
- package/treb-grid/package.json +5 -0
- package/treb-grid/src/editors/autocomplete.ts +394 -0
- package/treb-grid/src/editors/autocomplete_matcher.ts +260 -0
- package/treb-grid/src/editors/formula_bar.ts +473 -0
- package/treb-grid/src/editors/formula_editor_base.ts +910 -0
- package/treb-grid/src/editors/overlay_editor.ts +511 -0
- package/treb-grid/src/index.ts +37 -0
- package/treb-grid/src/layout/base_layout.ts +2618 -0
- package/treb-grid/src/layout/grid_layout.ts +299 -0
- package/treb-grid/src/layout/rectangle_cache.ts +86 -0
- package/treb-grid/src/render/selection-renderer.ts +414 -0
- package/treb-grid/src/render/svg_header_overlay.ts +93 -0
- package/treb-grid/src/render/svg_selection_block.ts +187 -0
- package/treb-grid/src/render/tile_renderer.ts +2122 -0
- package/treb-grid/src/types/annotation.ts +216 -0
- package/treb-grid/src/types/border_constants.ts +34 -0
- package/treb-grid/src/types/clipboard_data.ts +31 -0
- package/treb-grid/src/types/data_model.ts +334 -0
- package/treb-grid/src/types/drag_mask.ts +81 -0
- package/treb-grid/src/types/grid.ts +7743 -0
- package/treb-grid/src/types/grid_base.ts +3644 -0
- package/treb-grid/src/types/grid_command.ts +470 -0
- package/treb-grid/src/types/grid_events.ts +124 -0
- package/treb-grid/src/types/grid_options.ts +97 -0
- package/treb-grid/src/types/grid_selection.ts +60 -0
- package/treb-grid/src/types/named_range.ts +369 -0
- package/treb-grid/src/types/scale-control.ts +202 -0
- package/treb-grid/src/types/serialize_options.ts +72 -0
- package/treb-grid/src/types/set_range_options.ts +52 -0
- package/treb-grid/src/types/sheet.ts +3099 -0
- package/treb-grid/src/types/sheet_types.ts +95 -0
- package/treb-grid/src/types/tab_bar.ts +464 -0
- package/treb-grid/src/types/tile.ts +59 -0
- package/treb-grid/src/types/update_flags.ts +75 -0
- package/treb-grid/src/util/dom_utilities.ts +44 -0
- package/treb-grid/src/util/fontmetrics2.ts +179 -0
- package/treb-grid/src/util/ua.ts +104 -0
- package/treb-logo.svg +18 -0
- package/treb-parser/package.json +5 -0
- package/treb-parser/src/csv-parser.ts +122 -0
- package/treb-parser/src/index.ts +25 -0
- package/treb-parser/src/md-parser.ts +526 -0
- package/treb-parser/src/parser-types.ts +397 -0
- package/treb-parser/src/parser.test.ts +298 -0
- package/treb-parser/src/parser.ts +2673 -0
- package/treb-utils/package.json +5 -0
- package/treb-utils/src/dispatch.ts +57 -0
- package/treb-utils/src/event_source.ts +147 -0
- package/treb-utils/src/ievent_source.ts +33 -0
- package/treb-utils/src/index.ts +31 -0
- package/treb-utils/src/measurement.ts +174 -0
- package/treb-utils/src/resizable.ts +160 -0
- package/treb-utils/src/scale.ts +137 -0
- package/treb-utils/src/serialize_html.ts +124 -0
- package/treb-utils/src/template.ts +70 -0
- package/treb-utils/src/validate_uri.ts +61 -0
- package/tsconfig.json +10 -0
- package/tsproject.json +30 -0
- package/util/license-plugin-esbuild.js +86 -0
- package/util/list-css-vars.sh +46 -0
- package/README-esm.md +0 -37
- package/treb-bundle.css +0 -2
- package/treb-bundle.mjs +0 -15
|
@@ -0,0 +1,298 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* This file is part of TREB.
|
|
3
|
+
*
|
|
4
|
+
* TREB is free software: you can redistribute it and/or modify it under the
|
|
5
|
+
* terms of the GNU General Public License as published by the Free Software
|
|
6
|
+
* Foundation, either version 3 of the License, or (at your option) any
|
|
7
|
+
* later version.
|
|
8
|
+
*
|
|
9
|
+
* TREB is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
10
|
+
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
11
|
+
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
12
|
+
* details.
|
|
13
|
+
*
|
|
14
|
+
* You should have received a copy of the GNU General Public License along
|
|
15
|
+
* with TREB. If not, see <https://www.gnu.org/licenses/>.
|
|
16
|
+
*
|
|
17
|
+
* Copyright 2022-2023 trebco, llc.
|
|
18
|
+
* info@treb.app
|
|
19
|
+
*
|
|
20
|
+
*/
|
|
21
|
+
|
|
22
|
+
import type { FunctionMap } from '../descriptors';
|
|
23
|
+
import { NumberFormatCache, ValueParser } from 'treb-format';
|
|
24
|
+
import { Localization, UnionValue, ValueType } from 'treb-base-types';
|
|
25
|
+
import * as Utils from '../utilities';
|
|
26
|
+
import { ArgumentError, ValueError } from '../function-error';
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* parse a string with wildcards into a regex pattern
|
|
30
|
+
*
|
|
31
|
+
* from
|
|
32
|
+
* https://exceljet.net/glossary/wildcard
|
|
33
|
+
*
|
|
34
|
+
* Excel has 3 wildcards you can use in your formulas:
|
|
35
|
+
*
|
|
36
|
+
* Asterisk (*) - zero or more characters
|
|
37
|
+
* Question mark (?) - any one character
|
|
38
|
+
* Tilde (~) - escape for literal character (~*) a literal question mark (~?), or a literal tilde (~~)
|
|
39
|
+
*
|
|
40
|
+
* they're pretty liberal with escaping, nothing is an error, just roll with it
|
|
41
|
+
*
|
|
42
|
+
*/
|
|
43
|
+
const ParseWildcards = (text: string): string => {
|
|
44
|
+
|
|
45
|
+
const result: string[] = [];
|
|
46
|
+
const length = text.length;
|
|
47
|
+
|
|
48
|
+
const escaped_chars = '[\\^$.|?*+()';
|
|
49
|
+
|
|
50
|
+
for (let i = 0; i < length; i++) {
|
|
51
|
+
let char = text[i];
|
|
52
|
+
switch (char) {
|
|
53
|
+
|
|
54
|
+
case '*':
|
|
55
|
+
result.push('.', '*');
|
|
56
|
+
break;
|
|
57
|
+
|
|
58
|
+
case '?':
|
|
59
|
+
result.push('.');
|
|
60
|
+
break;
|
|
61
|
+
|
|
62
|
+
case '~':
|
|
63
|
+
char = text[++i] || '';
|
|
64
|
+
|
|
65
|
+
// eslint-disable-next-line no-fallthrough
|
|
66
|
+
default:
|
|
67
|
+
for (let j = 0; j < escaped_chars.length; j++) {
|
|
68
|
+
if (char === escaped_chars[j]) {
|
|
69
|
+
result.push('\\');
|
|
70
|
+
break;
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
result.push(char);
|
|
74
|
+
break;
|
|
75
|
+
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
return result.join('');
|
|
80
|
+
|
|
81
|
+
};
|
|
82
|
+
|
|
83
|
+
export const TextFunctionLibrary: FunctionMap = {
|
|
84
|
+
|
|
85
|
+
Char: {
|
|
86
|
+
arguments: [{
|
|
87
|
+
name: 'number',
|
|
88
|
+
}],
|
|
89
|
+
fn: (num: number): UnionValue => {
|
|
90
|
+
return { type: ValueType.string, value: String.fromCodePoint(num||32) };
|
|
91
|
+
},
|
|
92
|
+
category: ['text'],
|
|
93
|
+
},
|
|
94
|
+
|
|
95
|
+
Code: {
|
|
96
|
+
arguments: [{
|
|
97
|
+
name: 'string',
|
|
98
|
+
}],
|
|
99
|
+
fn: (str: string): UnionValue => {
|
|
100
|
+
return { type: ValueType.number, value: str.codePointAt(0) || 0 }; // FIXME: default?
|
|
101
|
+
},
|
|
102
|
+
category: ['text'],
|
|
103
|
+
},
|
|
104
|
+
|
|
105
|
+
Value: {
|
|
106
|
+
arguments: [
|
|
107
|
+
{ name: 'text' },
|
|
108
|
+
],
|
|
109
|
+
fn: (text: string): UnionValue => {
|
|
110
|
+
const value = ValueParser.TryParse(text);
|
|
111
|
+
if (value.type === ValueType.number) {
|
|
112
|
+
return { type: ValueType.number, value: value.value as number };
|
|
113
|
+
}
|
|
114
|
+
return ArgumentError();
|
|
115
|
+
|
|
116
|
+
},
|
|
117
|
+
category: ['text'],
|
|
118
|
+
},
|
|
119
|
+
|
|
120
|
+
Text: {
|
|
121
|
+
arguments: [
|
|
122
|
+
{ name: 'value' },
|
|
123
|
+
{ name: 'number format' },
|
|
124
|
+
],
|
|
125
|
+
fn: (value: number, format = '0.00####'): UnionValue => {
|
|
126
|
+
return { type: ValueType.string, value: NumberFormatCache.Get(format).Format(value || 0) };
|
|
127
|
+
},
|
|
128
|
+
category: ['text'],
|
|
129
|
+
},
|
|
130
|
+
|
|
131
|
+
Left: {
|
|
132
|
+
arguments: [
|
|
133
|
+
{ name: 'string' },
|
|
134
|
+
{ name: 'count' },
|
|
135
|
+
],
|
|
136
|
+
fn: (str: string, count = 1): UnionValue => {
|
|
137
|
+
return { type: ValueType.string, value: str.substr(0, count) };
|
|
138
|
+
},
|
|
139
|
+
category: ['text'],
|
|
140
|
+
},
|
|
141
|
+
|
|
142
|
+
Right: {
|
|
143
|
+
arguments: [
|
|
144
|
+
{ name: 'string' },
|
|
145
|
+
{ name: 'count' },
|
|
146
|
+
],
|
|
147
|
+
fn: (str: string, count = 1): UnionValue => {
|
|
148
|
+
return { type: ValueType.string, value: str.slice(-count) };
|
|
149
|
+
},
|
|
150
|
+
category: ['text'],
|
|
151
|
+
},
|
|
152
|
+
|
|
153
|
+
Mid: {
|
|
154
|
+
arguments: [
|
|
155
|
+
{ name: 'string' },
|
|
156
|
+
{ name: 'left' },
|
|
157
|
+
{ name: 'count' },
|
|
158
|
+
],
|
|
159
|
+
fn: (str: string, left = 0, count = 1): UnionValue => {
|
|
160
|
+
return { type: ValueType.string, value: str.substr(Math.max(0, left - 1), count) };
|
|
161
|
+
},
|
|
162
|
+
category: ['text'],
|
|
163
|
+
},
|
|
164
|
+
|
|
165
|
+
/*
|
|
166
|
+
|
|
167
|
+
Concatenate: {
|
|
168
|
+
description: 'Pastes strings together',
|
|
169
|
+
fn: (...args: any[]) => {
|
|
170
|
+
return args.map((arg) => {
|
|
171
|
+
|
|
172
|
+
// this is used when concatenating cells that contain numbers
|
|
173
|
+
// FIXME: get cell number format?
|
|
174
|
+
|
|
175
|
+
const string_arg = (typeof arg === 'undefined') ? '' : arg.toString();
|
|
176
|
+
|
|
177
|
+
if (typeof arg === 'number' && Localization.decimal_separator === ',') {
|
|
178
|
+
return string_arg.replace(/\./, ',');
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
return string_arg;
|
|
182
|
+
}).join('');
|
|
183
|
+
},
|
|
184
|
+
},
|
|
185
|
+
|
|
186
|
+
*/
|
|
187
|
+
|
|
188
|
+
/**
|
|
189
|
+
* shame we can't write a proper search function, but we need to be
|
|
190
|
+
* consistent. some notes:
|
|
191
|
+
*
|
|
192
|
+
* FIND is case-sensitive and does not support wildcards
|
|
193
|
+
* SEARCH is icase and supports wildcards
|
|
194
|
+
*
|
|
195
|
+
* re: wildcards, from
|
|
196
|
+
* https://exceljet.net/glossary/wildcard
|
|
197
|
+
*
|
|
198
|
+
* Excel has 3 wildcards you can use in your formulas:
|
|
199
|
+
*
|
|
200
|
+
* Asterisk (*) - zero or more characters
|
|
201
|
+
* Question mark (?) - any one character
|
|
202
|
+
* Tilde (~) - escape for literal character (~*) a literal question mark (~?), or a literal tilde (~~)
|
|
203
|
+
*
|
|
204
|
+
* start index is 1-based, and defaults to 1; < 1 is an error. if the string
|
|
205
|
+
* is not found, that's an error. if needle is empty, return start.
|
|
206
|
+
*
|
|
207
|
+
*/
|
|
208
|
+
Search: {
|
|
209
|
+
description: 'Find a string (needle) in another string (haystack). Case-insensitive.',
|
|
210
|
+
arguments: [
|
|
211
|
+
{ name: 'Needle', },
|
|
212
|
+
{ name: 'Haystack', },
|
|
213
|
+
{ name: 'Start', default: 1, },
|
|
214
|
+
],
|
|
215
|
+
fn: (needle: string, haystack: string, start = 1): UnionValue => {
|
|
216
|
+
if (start >= 1) {
|
|
217
|
+
if (!needle) {
|
|
218
|
+
return {
|
|
219
|
+
type: ValueType.number, value: start,
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
|
|
223
|
+
// translate into regex. do we need an actual parser for this, or
|
|
224
|
+
// can we get by with regexes? should we have some sort of cache
|
|
225
|
+
// for common patterns?
|
|
226
|
+
|
|
227
|
+
const pattern = ParseWildcards(needle);
|
|
228
|
+
// console.info('n', needle, 'p', pattern);
|
|
229
|
+
const match = new RegExp(pattern, 'i').exec(haystack.substr(start - 1));
|
|
230
|
+
|
|
231
|
+
if (match) {
|
|
232
|
+
return {
|
|
233
|
+
type: ValueType.number, value: match.index + start,
|
|
234
|
+
}
|
|
235
|
+
}
|
|
236
|
+
|
|
237
|
+
}
|
|
238
|
+
return ValueError();
|
|
239
|
+
},
|
|
240
|
+
},
|
|
241
|
+
|
|
242
|
+
Find: {
|
|
243
|
+
description: 'Find a string (needle) in another string (haystack). Case-sensitive.',
|
|
244
|
+
arguments: [
|
|
245
|
+
{ name: 'Needle', },
|
|
246
|
+
{ name: 'Haystack', },
|
|
247
|
+
{ name: 'Start', default: 1, },
|
|
248
|
+
],
|
|
249
|
+
fn: (needle: string, haystack: string, start = 1): UnionValue => {
|
|
250
|
+
if (start >= 1) {
|
|
251
|
+
if (!needle) {
|
|
252
|
+
return {
|
|
253
|
+
type: ValueType.number, value: start,
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
const match = new RegExp(needle).exec(haystack.substr(start - 1));
|
|
257
|
+
if (match) {
|
|
258
|
+
return {
|
|
259
|
+
type: ValueType.number, value: match.index + start,
|
|
260
|
+
}
|
|
261
|
+
}
|
|
262
|
+
}
|
|
263
|
+
return ValueError();
|
|
264
|
+
},
|
|
265
|
+
},
|
|
266
|
+
|
|
267
|
+
/** canonical should be CONCAT; concatenate can be an alias */
|
|
268
|
+
Concat: {
|
|
269
|
+
description: 'Pastes strings together',
|
|
270
|
+
fn: (...args: unknown[]): UnionValue => {
|
|
271
|
+
|
|
272
|
+
const values = Utils.FlattenUnboxed(args) as unknown[];
|
|
273
|
+
const value = values.map((arg) => {
|
|
274
|
+
|
|
275
|
+
// this is used when concatenating cells that contain numbers
|
|
276
|
+
// FIXME: get cell number format? we'd need to use metadata
|
|
277
|
+
|
|
278
|
+
const string_arg = (arg as any)?.toString() || '';
|
|
279
|
+
|
|
280
|
+
if (typeof arg === 'number' && Localization.decimal_separator === ',') {
|
|
281
|
+
return string_arg.replace(/\./, ',');
|
|
282
|
+
}
|
|
283
|
+
|
|
284
|
+
return string_arg;
|
|
285
|
+
|
|
286
|
+
}).join('');
|
|
287
|
+
|
|
288
|
+
return { type: ValueType.string, value };
|
|
289
|
+
|
|
290
|
+
},
|
|
291
|
+
},
|
|
292
|
+
|
|
293
|
+
};
|
|
294
|
+
|
|
295
|
+
export const TextFunctionAliases: Record<string, string> = {
|
|
296
|
+
Concatenate: 'Concat',
|
|
297
|
+
};
|
|
298
|
+
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* This file is part of TREB.
|
|
3
|
+
*
|
|
4
|
+
* TREB is free software: you can redistribute it and/or modify it under the
|
|
5
|
+
* terms of the GNU General Public License as published by the Free Software
|
|
6
|
+
* Foundation, either version 3 of the License, or (at your option) any
|
|
7
|
+
* later version.
|
|
8
|
+
*
|
|
9
|
+
* TREB is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
10
|
+
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
11
|
+
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
12
|
+
* details.
|
|
13
|
+
*
|
|
14
|
+
* You should have received a copy of the GNU General Public License along
|
|
15
|
+
* with TREB. If not, see <https://www.gnu.org/licenses/>.
|
|
16
|
+
*
|
|
17
|
+
* Copyright 2022-2023 trebco, llc.
|
|
18
|
+
* info@treb.app
|
|
19
|
+
*
|
|
20
|
+
*/
|
|
21
|
+
|
|
22
|
+
export * from './calculator';
|
|
23
|
+
// export * from './pack-results';
|
|
24
|
+
|
|
25
|
+
// for annotations that have dependencies
|
|
26
|
+
|
|
27
|
+
export {LeafVertex} from './dag/leaf_vertex';
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* This file is part of TREB.
|
|
3
|
+
*
|
|
4
|
+
* TREB is free software: you can redistribute it and/or modify it under the
|
|
5
|
+
* terms of the GNU General Public License as published by the Free Software
|
|
6
|
+
* Foundation, either version 3 of the License, or (at your option) any
|
|
7
|
+
* later version.
|
|
8
|
+
*
|
|
9
|
+
* TREB is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
10
|
+
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
|
|
11
|
+
* FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
|
|
12
|
+
* details.
|
|
13
|
+
*
|
|
14
|
+
* You should have received a copy of the GNU General Public License along
|
|
15
|
+
* with TREB. If not, see <https://www.gnu.org/licenses/>.
|
|
16
|
+
*
|
|
17
|
+
* Copyright 2022-2023 trebco, llc.
|
|
18
|
+
* info@treb.app
|
|
19
|
+
*
|
|
20
|
+
*/
|
|
21
|
+
|
|
22
|
+
import type { LeafVertex } from './dag/leaf_vertex';
|
|
23
|
+
import type { Area } from 'treb-base-types';
|
|
24
|
+
|
|
25
|
+
export interface NotifierType {
|
|
26
|
+
|
|
27
|
+
/** opaque user data */
|
|
28
|
+
data?: any;
|
|
29
|
+
|
|
30
|
+
/** function callback */
|
|
31
|
+
callback?: (data?: any) => void;
|
|
32
|
+
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
export interface InternalNotifierType {
|
|
36
|
+
|
|
37
|
+
/**
|
|
38
|
+
* assigned ID. this is (optionally) used for mamagement
|
|
39
|
+
*/
|
|
40
|
+
id: number;
|
|
41
|
+
|
|
42
|
+
/** client */
|
|
43
|
+
notifier: NotifierType;
|
|
44
|
+
|
|
45
|
+
/** node */
|
|
46
|
+
vertex: LeafVertex;
|
|
47
|
+
|
|
48
|
+
/** */
|
|
49
|
+
state: number;
|
|
50
|
+
|
|
51
|
+
/**
|
|
52
|
+
* we preserve our target ranges instead of the formula. this allows us
|
|
53
|
+
* to survive sheet name changes, as well as to rebuild when the original
|
|
54
|
+
* context sheet disappears.
|
|
55
|
+
*/
|
|
56
|
+
references: Area[];
|
|
57
|
+
|
|
58
|
+
|
|
59
|
+
}
|