@nocobase/plugin-workflow 1.2.12-alpha → 1.3.0-alpha.20240710084543
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/package.json +3 -3
- package/dist/client/AddButton.d.ts +0 -16
- package/dist/client/Branch.d.ts +0 -17
- package/dist/client/CanvasContent.d.ts +0 -12
- package/dist/client/ExecutionCanvas.d.ts +0 -10
- package/dist/client/ExecutionContextProvider.d.ts +0 -15
- package/dist/client/ExecutionLink.d.ts +0 -10
- package/dist/client/ExecutionPage.d.ts +0 -10
- package/dist/client/ExecutionResourceProvider.d.ts +0 -14
- package/dist/client/FlowContext.d.ts +0 -11
- package/dist/client/WorkflowCanvas.d.ts +0 -10
- package/dist/client/WorkflowLink.d.ts +0 -10
- package/dist/client/WorkflowPage.d.ts +0 -10
- package/dist/client/WorkflowPane.d.ts +0 -10
- package/dist/client/components/AssignedFieldsFormSchemaConfig.d.ts +0 -10
- package/dist/client/components/CheckboxGroupWithTooltip.d.ts +0 -15
- package/dist/client/components/CollectionBlockInitializer.d.ts +0 -10
- package/dist/client/components/CollectionFieldset.d.ts +0 -14
- package/dist/client/components/DetailsBlockProvider.d.ts +0 -14
- package/dist/client/components/DrawerDescription.d.ts +0 -10
- package/dist/client/components/DrawerForm.d.ts +0 -13
- package/dist/client/components/ExecutionStatus.d.ts +0 -13
- package/dist/client/components/FieldsSelect.d.ts +0 -10
- package/dist/client/components/FilterDynamicComponent.d.ts +0 -14
- package/dist/client/components/OpenDrawer.d.ts +0 -14
- package/dist/client/components/RadioWithTooltip.d.ts +0 -15
- package/dist/client/components/SimpleDesigner.d.ts +0 -10
- package/dist/client/components/StatusButton.d.ts +0 -10
- package/dist/client/components/TriggerOptionRender.d.ts +0 -12
- package/dist/client/components/ValueBlock.d.ts +0 -14
- package/dist/client/components/index.d.ts +0 -16
- package/dist/client/components/renderEngineReference.d.ts +0 -10
- package/dist/client/constants.d.ts +0 -45
- package/dist/client/hooks/index.d.ts +0 -11
- package/dist/client/hooks/useGetAriaLabelOfAddButton.d.ts +0 -14
- package/dist/client/hooks/useRefreshActionProps.d.ts +0 -11
- package/dist/client/hooks/useTriggerWorkflowActionProps.d.ts +0 -20
- package/dist/client/hooks/useWorkflowExecuted.d.ts +0 -10
- package/dist/client/index.d.ts +0 -43
- package/dist/client/index.js +0 -569
- package/dist/client/locale/index.d.ts +0 -11
- package/dist/client/nodes/calculation.d.ts +0 -80
- package/dist/client/nodes/condition.d.ts +0 -108
- package/dist/client/nodes/create.d.ts +0 -110
- package/dist/client/nodes/destroy.d.ts +0 -54
- package/dist/client/nodes/end.d.ts +0 -30
- package/dist/client/nodes/index.d.ts +0 -76
- package/dist/client/nodes/query.d.ts +0 -236
- package/dist/client/nodes/update.d.ts +0 -114
- package/dist/client/schemas/collection.d.ts +0 -170
- package/dist/client/schemas/executions.d.ts +0 -282
- package/dist/client/schemas/workflows.d.ts +0 -10
- package/dist/client/settings/customizeSubmitToWorkflowActionSettings.d.ts +0 -10
- package/dist/client/style.d.ts +0 -30
- package/dist/client/triggers/collection.d.ts +0 -124
- package/dist/client/triggers/index.d.ts +0 -36
- package/dist/client/triggers/schedule/EndsByField.d.ts +0 -13
- package/dist/client/triggers/schedule/OnField.d.ts +0 -13
- package/dist/client/triggers/schedule/RepeatField.d.ts +0 -13
- package/dist/client/triggers/schedule/ScheduleConfig.d.ts +0 -10
- package/dist/client/triggers/schedule/constants.d.ts +0 -12
- package/dist/client/triggers/schedule/index.d.ts +0 -33
- package/dist/client/triggers/schedule/locale/Cron.zh-CN.d.ts +0 -42
- package/dist/client/utils.d.ts +0 -12
- package/dist/client/variable.d.ts +0 -93
- package/dist/externalVersion.js +0 -34
- package/dist/index.d.ts +0 -10
- package/dist/index.js +0 -48
- package/dist/locale/en-US.json +0 -98
- package/dist/locale/es-ES.json +0 -98
- package/dist/locale/fr-FR.json +0 -98
- package/dist/locale/ja-JP.json +0 -82
- package/dist/locale/ko_KR.json +0 -168
- package/dist/locale/pt-BR.json +0 -98
- package/dist/locale/ru-RU.json +0 -82
- package/dist/locale/tr-TR.json +0 -82
- package/dist/locale/zh-CN.json +0 -205
- package/dist/node_modules/cron-parser/.eslintrc.json +0 -15
- package/dist/node_modules/cron-parser/.travis.yml +0 -7
- package/dist/node_modules/cron-parser/LICENSE +0 -21
- package/dist/node_modules/cron-parser/component.json +0 -11
- package/dist/node_modules/cron-parser/index.d.ts +0 -1
- package/dist/node_modules/cron-parser/lib/date.js +0 -252
- package/dist/node_modules/cron-parser/lib/expression.js +0 -983
- package/dist/node_modules/cron-parser/lib/field_compactor.js +0 -70
- package/dist/node_modules/cron-parser/lib/field_stringify.js +0 -38
- package/dist/node_modules/cron-parser/lib/parser.js +0 -1
- package/dist/node_modules/cron-parser/node_modules/luxon/build/amd/luxon.js +0 -8489
- package/dist/node_modules/cron-parser/node_modules/luxon/build/cjs-browser/luxon.js +0 -8487
- package/dist/node_modules/cron-parser/node_modules/luxon/build/global/luxon.js +0 -8490
- package/dist/node_modules/cron-parser/node_modules/luxon/build/global/luxon.min.js +0 -1
- package/dist/node_modules/cron-parser/node_modules/luxon/build/node/luxon.js +0 -7522
- package/dist/node_modules/cron-parser/node_modules/luxon/package.json +0 -96
- package/dist/node_modules/cron-parser/node_modules/luxon/src/datetime.js +0 -2169
- package/dist/node_modules/cron-parser/node_modules/luxon/src/duration.js +0 -880
- package/dist/node_modules/cron-parser/node_modules/luxon/src/errors.js +0 -61
- package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/conversions.js +0 -157
- package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/diff.js +0 -80
- package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/digits.js +0 -76
- package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/english.js +0 -233
- package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/formats.js +0 -191
- package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/formatter.js +0 -386
- package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/invalid.js +0 -14
- package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/locale.js +0 -482
- package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/regexParser.js +0 -335
- package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/tokenParser.js +0 -424
- package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/util.js +0 -292
- package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/zoneUtil.js +0 -36
- package/dist/node_modules/cron-parser/node_modules/luxon/src/info.js +0 -193
- package/dist/node_modules/cron-parser/node_modules/luxon/src/interval.js +0 -602
- package/dist/node_modules/cron-parser/node_modules/luxon/src/luxon.js +0 -26
- package/dist/node_modules/cron-parser/node_modules/luxon/src/luxonFilled.js +0 -13
- package/dist/node_modules/cron-parser/node_modules/luxon/src/settings.js +0 -137
- package/dist/node_modules/cron-parser/node_modules/luxon/src/zone.js +0 -88
- package/dist/node_modules/cron-parser/node_modules/luxon/src/zones/IANAZone.js +0 -191
- package/dist/node_modules/cron-parser/node_modules/luxon/src/zones/fixedOffsetZone.js +0 -94
- package/dist/node_modules/cron-parser/node_modules/luxon/src/zones/invalidZone.js +0 -53
- package/dist/node_modules/cron-parser/node_modules/luxon/src/zones/localZone.js +0 -63
- package/dist/node_modules/cron-parser/package.json +0 -1
- package/dist/node_modules/cron-parser/test/31_of_month.js +0 -17
- package/dist/node_modules/cron-parser/test/bug.js +0 -29
- package/dist/node_modules/cron-parser/test/crondate.js +0 -16
- package/dist/node_modules/cron-parser/test/crontab.example +0 -7
- package/dist/node_modules/cron-parser/test/empty_around_comma.js +0 -22
- package/dist/node_modules/cron-parser/test/expression.js +0 -1489
- package/dist/node_modules/cron-parser/test/field_compactor.js +0 -250
- package/dist/node_modules/cron-parser/test/field_stringify.js +0 -84
- package/dist/node_modules/cron-parser/test/fields.js +0 -32
- package/dist/node_modules/cron-parser/test/increment_on_first_iteration.js +0 -22
- package/dist/node_modules/cron-parser/test/index-ts3.test-d.ts +0 -133
- package/dist/node_modules/cron-parser/test/index.test-d.ts +0 -138
- package/dist/node_modules/cron-parser/test/leap_year.js +0 -17
- package/dist/node_modules/cron-parser/test/parser.js +0 -46
- package/dist/node_modules/cron-parser/test/parser_crondate_formats.js +0 -145
- package/dist/node_modules/cron-parser/test/parser_day_of_month.js +0 -169
- package/dist/node_modules/cron-parser/test/prev_date.js +0 -32
- package/dist/node_modules/cron-parser/test/stringify.js +0 -402
- package/dist/node_modules/cron-parser/test/timezone.js +0 -422
- package/dist/node_modules/cron-parser/types/common.d.ts +0 -131
- package/dist/node_modules/cron-parser/types/index.d.ts +0 -45
- package/dist/node_modules/cron-parser/types/ts3/index.d.ts +0 -28
- package/dist/node_modules/lru-cache/LICENSE +0 -15
- package/dist/node_modules/lru-cache/dist/cjs/index-cjs.d.ts +0 -7
- package/dist/node_modules/lru-cache/dist/cjs/index-cjs.js +0 -1
- package/dist/node_modules/lru-cache/dist/cjs/index.d.ts +0 -807
- package/dist/node_modules/lru-cache/dist/cjs/index.js +0 -1334
- package/dist/node_modules/lru-cache/dist/cjs/index.min.js +0 -2
- package/dist/node_modules/lru-cache/dist/cjs/package.json +0 -3
- package/dist/node_modules/lru-cache/dist/mjs/index.d.ts +0 -807
- package/dist/node_modules/lru-cache/dist/mjs/index.js +0 -1330
- package/dist/node_modules/lru-cache/dist/mjs/index.min.js +0 -2
- package/dist/node_modules/lru-cache/dist/mjs/package.json +0 -3
- package/dist/node_modules/lru-cache/package.json +0 -1
- package/dist/server/Plugin.d.ts +0 -84
- package/dist/server/Plugin.js +0 -503
- package/dist/server/Processor.d.ts +0 -115
- package/dist/server/Processor.js +0 -363
- package/dist/server/actions/executions.d.ts +0 -11
- package/dist/server/actions/executions.js +0 -96
- package/dist/server/actions/index.d.ts +0 -11
- package/dist/server/actions/index.js +0 -66
- package/dist/server/actions/nodes.d.ts +0 -12
- package/dist/server/actions/nodes.js +0 -217
- package/dist/server/actions/workflows.d.ts +0 -14
- package/dist/server/actions/workflows.js +0 -184
- package/dist/server/collections/executions.d.ts +0 -11
- package/dist/server/collections/executions.js +0 -66
- package/dist/server/collections/flow_nodes.d.ts +0 -11
- package/dist/server/collections/flow_nodes.js +0 -87
- package/dist/server/collections/jobs.d.ts +0 -11
- package/dist/server/collections/jobs.js +0 -66
- package/dist/server/collections/workflows.d.ts +0 -10
- package/dist/server/collections/workflows.js +0 -126
- package/dist/server/constants.d.ts +0 -29
- package/dist/server/constants.js +0 -58
- package/dist/server/functions/index.d.ts +0 -17
- package/dist/server/functions/index.js +0 -40
- package/dist/server/index.d.ts +0 -15
- package/dist/server/index.js +0 -60
- package/dist/server/instructions/CalculationInstruction.d.ts +0 -25
- package/dist/server/instructions/CalculationInstruction.js +0 -59
- package/dist/server/instructions/ConditionInstruction.d.ts +0 -36
- package/dist/server/instructions/ConditionInstruction.js +0 -167
- package/dist/server/instructions/CreateInstruction.d.ts +0 -18
- package/dist/server/instructions/CreateInstruction.js +0 -75
- package/dist/server/instructions/DestroyInstruction.d.ts +0 -18
- package/dist/server/instructions/DestroyInstruction.js +0 -59
- package/dist/server/instructions/EndInstruction.d.ts +0 -14
- package/dist/server/instructions/EndInstruction.js +0 -55
- package/dist/server/instructions/QueryInstruction.d.ts +0 -21
- package/dist/server/instructions/QueryInstruction.js +0 -82
- package/dist/server/instructions/UpdateInstruction.d.ts +0 -18
- package/dist/server/instructions/UpdateInstruction.js +0 -59
- package/dist/server/instructions/index.d.ts +0 -31
- package/dist/server/instructions/index.js +0 -42
- package/dist/server/migrations/20221129153547-calculation-variables.d.ts +0 -14
- package/dist/server/migrations/20221129153547-calculation-variables.js +0 -92
- package/dist/server/migrations/20230221032941-change-request-body-type.d.ts +0 -14
- package/dist/server/migrations/20230221032941-change-request-body-type.js +0 -102
- package/dist/server/migrations/20230221071831-calculation-expression.d.ts +0 -13
- package/dist/server/migrations/20230221071831-calculation-expression.js +0 -121
- package/dist/server/migrations/20230221121203-condition-calculation.d.ts +0 -13
- package/dist/server/migrations/20230221121203-condition-calculation.js +0 -106
- package/dist/server/migrations/20230221162902-jsonb-to-json.d.ts +0 -13
- package/dist/server/migrations/20230221162902-jsonb-to-json.js +0 -63
- package/dist/server/migrations/20230411034722-manual-multi-form.d.ts +0 -13
- package/dist/server/migrations/20230411034722-manual-multi-form.js +0 -283
- package/dist/server/migrations/20230612021134-manual-collection-block.d.ts +0 -13
- package/dist/server/migrations/20230612021134-manual-collection-block.js +0 -152
- package/dist/server/migrations/20230710115902-manual-action-values.d.ts +0 -13
- package/dist/server/migrations/20230710115902-manual-action-values.js +0 -101
- package/dist/server/migrations/20230809113132-workflow-options.d.ts +0 -13
- package/dist/server/migrations/20230809113132-workflow-options.js +0 -64
- package/dist/server/migrations/20231024172342-add-node-key.d.ts +0 -13
- package/dist/server/migrations/20231024172342-add-node-key.js +0 -90
- package/dist/server/migrations/20231122143143-split-to-plugins.d.ts +0 -13
- package/dist/server/migrations/20231122143143-split-to-plugins.js +0 -67
- package/dist/server/migrations/20240115220721-add-node-key-to-job.d.ts +0 -14
- package/dist/server/migrations/20240115220721-add-node-key-to-job.js +0 -63
- package/dist/server/migrations/20240613222612-fix-assign-field-config.d.ts +0 -13
- package/dist/server/migrations/20240613222612-fix-assign-field-config.js +0 -62
- package/dist/server/triggers/CollectionTrigger.d.ts +0 -22
- package/dist/server/triggers/CollectionTrigger.js +0 -184
- package/dist/server/triggers/ScheduleTrigger/DateFieldScheduleTrigger.d.ts +0 -39
- package/dist/server/triggers/ScheduleTrigger/DateFieldScheduleTrigger.js +0 -356
- package/dist/server/triggers/ScheduleTrigger/StaticScheduleTrigger.d.ts +0 -21
- package/dist/server/triggers/ScheduleTrigger/StaticScheduleTrigger.js +0 -152
- package/dist/server/triggers/ScheduleTrigger/index.d.ts +0 -18
- package/dist/server/triggers/ScheduleTrigger/index.js +0 -84
- package/dist/server/triggers/ScheduleTrigger/utils.d.ts +0 -13
- package/dist/server/triggers/ScheduleTrigger/utils.js +0 -44
- package/dist/server/triggers/index.d.ts +0 -21
- package/dist/server/triggers/index.js +0 -46
- package/dist/server/types/Execution.d.ts +0 -25
- package/dist/server/types/Execution.js +0 -34
- package/dist/server/types/FlowNode.d.ts +0 -24
- package/dist/server/types/FlowNode.js +0 -34
- package/dist/server/types/Job.d.ts +0 -22
- package/dist/server/types/Job.js +0 -34
- package/dist/server/types/Workflow.d.ts +0 -35
- package/dist/server/types/Workflow.js +0 -34
- package/dist/server/types/index.d.ts +0 -12
- package/dist/server/types/index.js +0 -24
- package/dist/server/utils.d.ts +0 -9
- package/dist/server/utils.js +0 -51
- package/dist/swagger/index.d.ts +0 -762
- package/dist/swagger/index.js +0 -807
|
@@ -1,482 +0,0 @@
|
|
|
1
|
-
import { hasFormatToParts, hasIntl, padStart, roundTo, hasRelative } from "./util.js";
|
|
2
|
-
import * as English from "./english.js";
|
|
3
|
-
import Settings from "../settings.js";
|
|
4
|
-
import DateTime from "../datetime.js";
|
|
5
|
-
import Formatter from "./formatter.js";
|
|
6
|
-
import IANAZone from "../zones/IANAZone.js";
|
|
7
|
-
|
|
8
|
-
let intlDTCache = {};
|
|
9
|
-
function getCachedDTF(locString, opts = {}) {
|
|
10
|
-
const key = JSON.stringify([locString, opts]);
|
|
11
|
-
let dtf = intlDTCache[key];
|
|
12
|
-
if (!dtf) {
|
|
13
|
-
dtf = new Intl.DateTimeFormat(locString, opts);
|
|
14
|
-
intlDTCache[key] = dtf;
|
|
15
|
-
}
|
|
16
|
-
return dtf;
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
let intlNumCache = {};
|
|
20
|
-
function getCachedINF(locString, opts = {}) {
|
|
21
|
-
const key = JSON.stringify([locString, opts]);
|
|
22
|
-
let inf = intlNumCache[key];
|
|
23
|
-
if (!inf) {
|
|
24
|
-
inf = new Intl.NumberFormat(locString, opts);
|
|
25
|
-
intlNumCache[key] = inf;
|
|
26
|
-
}
|
|
27
|
-
return inf;
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
let intlRelCache = {};
|
|
31
|
-
function getCachedRTF(locString, opts = {}) {
|
|
32
|
-
const { base, ...cacheKeyOpts } = opts; // exclude `base` from the options
|
|
33
|
-
const key = JSON.stringify([locString, cacheKeyOpts]);
|
|
34
|
-
let inf = intlRelCache[key];
|
|
35
|
-
if (!inf) {
|
|
36
|
-
inf = new Intl.RelativeTimeFormat(locString, opts);
|
|
37
|
-
intlRelCache[key] = inf;
|
|
38
|
-
}
|
|
39
|
-
return inf;
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
let sysLocaleCache = null;
|
|
43
|
-
function systemLocale() {
|
|
44
|
-
if (sysLocaleCache) {
|
|
45
|
-
return sysLocaleCache;
|
|
46
|
-
} else if (hasIntl()) {
|
|
47
|
-
const computedSys = new Intl.DateTimeFormat().resolvedOptions().locale;
|
|
48
|
-
// node sometimes defaults to "und". Override that because that is dumb
|
|
49
|
-
sysLocaleCache = !computedSys || computedSys === "und" ? "en-US" : computedSys;
|
|
50
|
-
return sysLocaleCache;
|
|
51
|
-
} else {
|
|
52
|
-
sysLocaleCache = "en-US";
|
|
53
|
-
return sysLocaleCache;
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
function parseLocaleString(localeStr) {
|
|
58
|
-
// I really want to avoid writing a BCP 47 parser
|
|
59
|
-
// see, e.g. https://github.com/wooorm/bcp-47
|
|
60
|
-
// Instead, we'll do this:
|
|
61
|
-
|
|
62
|
-
// a) if the string has no -u extensions, just leave it alone
|
|
63
|
-
// b) if it does, use Intl to resolve everything
|
|
64
|
-
// c) if Intl fails, try again without the -u
|
|
65
|
-
|
|
66
|
-
const uIndex = localeStr.indexOf("-u-");
|
|
67
|
-
if (uIndex === -1) {
|
|
68
|
-
return [localeStr];
|
|
69
|
-
} else {
|
|
70
|
-
let options;
|
|
71
|
-
const smaller = localeStr.substring(0, uIndex);
|
|
72
|
-
try {
|
|
73
|
-
options = getCachedDTF(localeStr).resolvedOptions();
|
|
74
|
-
} catch (e) {
|
|
75
|
-
options = getCachedDTF(smaller).resolvedOptions();
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
const { numberingSystem, calendar } = options;
|
|
79
|
-
// return the smaller one so that we can append the calendar and numbering overrides to it
|
|
80
|
-
return [smaller, numberingSystem, calendar];
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
function intlConfigString(localeStr, numberingSystem, outputCalendar) {
|
|
85
|
-
if (hasIntl()) {
|
|
86
|
-
if (outputCalendar || numberingSystem) {
|
|
87
|
-
localeStr += "-u";
|
|
88
|
-
|
|
89
|
-
if (outputCalendar) {
|
|
90
|
-
localeStr += `-ca-${outputCalendar}`;
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
if (numberingSystem) {
|
|
94
|
-
localeStr += `-nu-${numberingSystem}`;
|
|
95
|
-
}
|
|
96
|
-
return localeStr;
|
|
97
|
-
} else {
|
|
98
|
-
return localeStr;
|
|
99
|
-
}
|
|
100
|
-
} else {
|
|
101
|
-
return [];
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
function mapMonths(f) {
|
|
106
|
-
const ms = [];
|
|
107
|
-
for (let i = 1; i <= 12; i++) {
|
|
108
|
-
const dt = DateTime.utc(2016, i, 1);
|
|
109
|
-
ms.push(f(dt));
|
|
110
|
-
}
|
|
111
|
-
return ms;
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
function mapWeekdays(f) {
|
|
115
|
-
const ms = [];
|
|
116
|
-
for (let i = 1; i <= 7; i++) {
|
|
117
|
-
const dt = DateTime.utc(2016, 11, 13 + i);
|
|
118
|
-
ms.push(f(dt));
|
|
119
|
-
}
|
|
120
|
-
return ms;
|
|
121
|
-
}
|
|
122
|
-
|
|
123
|
-
function listStuff(loc, length, defaultOK, englishFn, intlFn) {
|
|
124
|
-
const mode = loc.listingMode(defaultOK);
|
|
125
|
-
|
|
126
|
-
if (mode === "error") {
|
|
127
|
-
return null;
|
|
128
|
-
} else if (mode === "en") {
|
|
129
|
-
return englishFn(length);
|
|
130
|
-
} else {
|
|
131
|
-
return intlFn(length);
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
|
|
135
|
-
function supportsFastNumbers(loc) {
|
|
136
|
-
if (loc.numberingSystem && loc.numberingSystem !== "latn") {
|
|
137
|
-
return false;
|
|
138
|
-
} else {
|
|
139
|
-
return (
|
|
140
|
-
loc.numberingSystem === "latn" ||
|
|
141
|
-
!loc.locale ||
|
|
142
|
-
loc.locale.startsWith("en") ||
|
|
143
|
-
(hasIntl() && new Intl.DateTimeFormat(loc.intl).resolvedOptions().numberingSystem === "latn")
|
|
144
|
-
);
|
|
145
|
-
}
|
|
146
|
-
}
|
|
147
|
-
|
|
148
|
-
/**
|
|
149
|
-
* @private
|
|
150
|
-
*/
|
|
151
|
-
|
|
152
|
-
class PolyNumberFormatter {
|
|
153
|
-
constructor(intl, forceSimple, opts) {
|
|
154
|
-
this.padTo = opts.padTo || 0;
|
|
155
|
-
this.floor = opts.floor || false;
|
|
156
|
-
|
|
157
|
-
if (!forceSimple && hasIntl()) {
|
|
158
|
-
const intlOpts = { useGrouping: false };
|
|
159
|
-
if (opts.padTo > 0) intlOpts.minimumIntegerDigits = opts.padTo;
|
|
160
|
-
this.inf = getCachedINF(intl, intlOpts);
|
|
161
|
-
}
|
|
162
|
-
}
|
|
163
|
-
|
|
164
|
-
format(i) {
|
|
165
|
-
if (this.inf) {
|
|
166
|
-
const fixed = this.floor ? Math.floor(i) : i;
|
|
167
|
-
return this.inf.format(fixed);
|
|
168
|
-
} else {
|
|
169
|
-
// to match the browser's numberformatter defaults
|
|
170
|
-
const fixed = this.floor ? Math.floor(i) : roundTo(i, 3);
|
|
171
|
-
return padStart(fixed, this.padTo);
|
|
172
|
-
}
|
|
173
|
-
}
|
|
174
|
-
}
|
|
175
|
-
|
|
176
|
-
/**
|
|
177
|
-
* @private
|
|
178
|
-
*/
|
|
179
|
-
|
|
180
|
-
class PolyDateFormatter {
|
|
181
|
-
constructor(dt, intl, opts) {
|
|
182
|
-
this.opts = opts;
|
|
183
|
-
this.hasIntl = hasIntl();
|
|
184
|
-
|
|
185
|
-
let z;
|
|
186
|
-
if (dt.zone.universal && this.hasIntl) {
|
|
187
|
-
// UTC-8 or Etc/UTC-8 are not part of tzdata, only Etc/GMT+8 and the like.
|
|
188
|
-
// That is why fixed-offset TZ is set to that unless it is:
|
|
189
|
-
// 1. Representing offset 0 when UTC is used to maintain previous behavior and does not become GMT.
|
|
190
|
-
// 2. Unsupported by the browser:
|
|
191
|
-
// - some do not support Etc/
|
|
192
|
-
// - < Etc/GMT-14, > Etc/GMT+12, and 30-minute or 45-minute offsets are not part of tzdata
|
|
193
|
-
const gmtOffset = -1 * (dt.offset / 60);
|
|
194
|
-
const offsetZ = gmtOffset >= 0 ? `Etc/GMT+${gmtOffset}` : `Etc/GMT${gmtOffset}`;
|
|
195
|
-
const isOffsetZoneSupported = IANAZone.isValidZone(offsetZ);
|
|
196
|
-
if (dt.offset !== 0 && isOffsetZoneSupported) {
|
|
197
|
-
z = offsetZ;
|
|
198
|
-
this.dt = dt;
|
|
199
|
-
} else {
|
|
200
|
-
// Not all fixed-offset zones like Etc/+4:30 are present in tzdata.
|
|
201
|
-
// So we have to make do. Two cases:
|
|
202
|
-
// 1. The format options tell us to show the zone. We can't do that, so the best
|
|
203
|
-
// we can do is format the date in UTC.
|
|
204
|
-
// 2. The format options don't tell us to show the zone. Then we can adjust them
|
|
205
|
-
// the time and tell the formatter to show it to us in UTC, so that the time is right
|
|
206
|
-
// and the bad zone doesn't show up.
|
|
207
|
-
z = "UTC";
|
|
208
|
-
if (opts.timeZoneName) {
|
|
209
|
-
this.dt = dt;
|
|
210
|
-
} else {
|
|
211
|
-
this.dt = dt.offset === 0 ? dt : DateTime.fromMillis(dt.ts + dt.offset * 60 * 1000);
|
|
212
|
-
}
|
|
213
|
-
}
|
|
214
|
-
} else if (dt.zone.type === "local") {
|
|
215
|
-
this.dt = dt;
|
|
216
|
-
} else {
|
|
217
|
-
this.dt = dt;
|
|
218
|
-
z = dt.zone.name;
|
|
219
|
-
}
|
|
220
|
-
|
|
221
|
-
if (this.hasIntl) {
|
|
222
|
-
const intlOpts = Object.assign({}, this.opts);
|
|
223
|
-
if (z) {
|
|
224
|
-
intlOpts.timeZone = z;
|
|
225
|
-
}
|
|
226
|
-
this.dtf = getCachedDTF(intl, intlOpts);
|
|
227
|
-
}
|
|
228
|
-
}
|
|
229
|
-
|
|
230
|
-
format() {
|
|
231
|
-
if (this.hasIntl) {
|
|
232
|
-
return this.dtf.format(this.dt.toJSDate());
|
|
233
|
-
} else {
|
|
234
|
-
const tokenFormat = English.formatString(this.opts),
|
|
235
|
-
loc = Locale.create("en-US");
|
|
236
|
-
return Formatter.create(loc).formatDateTimeFromString(this.dt, tokenFormat);
|
|
237
|
-
}
|
|
238
|
-
}
|
|
239
|
-
|
|
240
|
-
formatToParts() {
|
|
241
|
-
if (this.hasIntl && hasFormatToParts()) {
|
|
242
|
-
return this.dtf.formatToParts(this.dt.toJSDate());
|
|
243
|
-
} else {
|
|
244
|
-
// This is kind of a cop out. We actually could do this for English. However, we couldn't do it for intl strings
|
|
245
|
-
// and IMO it's too weird to have an uncanny valley like that
|
|
246
|
-
return [];
|
|
247
|
-
}
|
|
248
|
-
}
|
|
249
|
-
|
|
250
|
-
resolvedOptions() {
|
|
251
|
-
if (this.hasIntl) {
|
|
252
|
-
return this.dtf.resolvedOptions();
|
|
253
|
-
} else {
|
|
254
|
-
return {
|
|
255
|
-
locale: "en-US",
|
|
256
|
-
numberingSystem: "latn",
|
|
257
|
-
outputCalendar: "gregory"
|
|
258
|
-
};
|
|
259
|
-
}
|
|
260
|
-
}
|
|
261
|
-
}
|
|
262
|
-
|
|
263
|
-
/**
|
|
264
|
-
* @private
|
|
265
|
-
*/
|
|
266
|
-
class PolyRelFormatter {
|
|
267
|
-
constructor(intl, isEnglish, opts) {
|
|
268
|
-
this.opts = Object.assign({ style: "long" }, opts);
|
|
269
|
-
if (!isEnglish && hasRelative()) {
|
|
270
|
-
this.rtf = getCachedRTF(intl, opts);
|
|
271
|
-
}
|
|
272
|
-
}
|
|
273
|
-
|
|
274
|
-
format(count, unit) {
|
|
275
|
-
if (this.rtf) {
|
|
276
|
-
return this.rtf.format(count, unit);
|
|
277
|
-
} else {
|
|
278
|
-
return English.formatRelativeTime(unit, count, this.opts.numeric, this.opts.style !== "long");
|
|
279
|
-
}
|
|
280
|
-
}
|
|
281
|
-
|
|
282
|
-
formatToParts(count, unit) {
|
|
283
|
-
if (this.rtf) {
|
|
284
|
-
return this.rtf.formatToParts(count, unit);
|
|
285
|
-
} else {
|
|
286
|
-
return [];
|
|
287
|
-
}
|
|
288
|
-
}
|
|
289
|
-
}
|
|
290
|
-
|
|
291
|
-
/**
|
|
292
|
-
* @private
|
|
293
|
-
*/
|
|
294
|
-
|
|
295
|
-
export default class Locale {
|
|
296
|
-
static fromOpts(opts) {
|
|
297
|
-
return Locale.create(opts.locale, opts.numberingSystem, opts.outputCalendar, opts.defaultToEN);
|
|
298
|
-
}
|
|
299
|
-
|
|
300
|
-
static create(locale, numberingSystem, outputCalendar, defaultToEN = false) {
|
|
301
|
-
const specifiedLocale = locale || Settings.defaultLocale,
|
|
302
|
-
// the system locale is useful for human readable strings but annoying for parsing/formatting known formats
|
|
303
|
-
localeR = specifiedLocale || (defaultToEN ? "en-US" : systemLocale()),
|
|
304
|
-
numberingSystemR = numberingSystem || Settings.defaultNumberingSystem,
|
|
305
|
-
outputCalendarR = outputCalendar || Settings.defaultOutputCalendar;
|
|
306
|
-
return new Locale(localeR, numberingSystemR, outputCalendarR, specifiedLocale);
|
|
307
|
-
}
|
|
308
|
-
|
|
309
|
-
static resetCache() {
|
|
310
|
-
sysLocaleCache = null;
|
|
311
|
-
intlDTCache = {};
|
|
312
|
-
intlNumCache = {};
|
|
313
|
-
intlRelCache = {};
|
|
314
|
-
}
|
|
315
|
-
|
|
316
|
-
static fromObject({ locale, numberingSystem, outputCalendar } = {}) {
|
|
317
|
-
return Locale.create(locale, numberingSystem, outputCalendar);
|
|
318
|
-
}
|
|
319
|
-
|
|
320
|
-
constructor(locale, numbering, outputCalendar, specifiedLocale) {
|
|
321
|
-
const [parsedLocale, parsedNumberingSystem, parsedOutputCalendar] = parseLocaleString(locale);
|
|
322
|
-
|
|
323
|
-
this.locale = parsedLocale;
|
|
324
|
-
this.numberingSystem = numbering || parsedNumberingSystem || null;
|
|
325
|
-
this.outputCalendar = outputCalendar || parsedOutputCalendar || null;
|
|
326
|
-
this.intl = intlConfigString(this.locale, this.numberingSystem, this.outputCalendar);
|
|
327
|
-
|
|
328
|
-
this.weekdaysCache = { format: {}, standalone: {} };
|
|
329
|
-
this.monthsCache = { format: {}, standalone: {} };
|
|
330
|
-
this.meridiemCache = null;
|
|
331
|
-
this.eraCache = {};
|
|
332
|
-
|
|
333
|
-
this.specifiedLocale = specifiedLocale;
|
|
334
|
-
this.fastNumbersCached = null;
|
|
335
|
-
}
|
|
336
|
-
|
|
337
|
-
get fastNumbers() {
|
|
338
|
-
if (this.fastNumbersCached == null) {
|
|
339
|
-
this.fastNumbersCached = supportsFastNumbers(this);
|
|
340
|
-
}
|
|
341
|
-
|
|
342
|
-
return this.fastNumbersCached;
|
|
343
|
-
}
|
|
344
|
-
|
|
345
|
-
listingMode(defaultOK = true) {
|
|
346
|
-
const intl = hasIntl(),
|
|
347
|
-
hasFTP = intl && hasFormatToParts(),
|
|
348
|
-
isActuallyEn = this.isEnglish(),
|
|
349
|
-
hasNoWeirdness =
|
|
350
|
-
(this.numberingSystem === null || this.numberingSystem === "latn") &&
|
|
351
|
-
(this.outputCalendar === null || this.outputCalendar === "gregory");
|
|
352
|
-
|
|
353
|
-
if (!hasFTP && !(isActuallyEn && hasNoWeirdness) && !defaultOK) {
|
|
354
|
-
return "error";
|
|
355
|
-
} else if (!hasFTP || (isActuallyEn && hasNoWeirdness)) {
|
|
356
|
-
return "en";
|
|
357
|
-
} else {
|
|
358
|
-
return "intl";
|
|
359
|
-
}
|
|
360
|
-
}
|
|
361
|
-
|
|
362
|
-
clone(alts) {
|
|
363
|
-
if (!alts || Object.getOwnPropertyNames(alts).length === 0) {
|
|
364
|
-
return this;
|
|
365
|
-
} else {
|
|
366
|
-
return Locale.create(
|
|
367
|
-
alts.locale || this.specifiedLocale,
|
|
368
|
-
alts.numberingSystem || this.numberingSystem,
|
|
369
|
-
alts.outputCalendar || this.outputCalendar,
|
|
370
|
-
alts.defaultToEN || false
|
|
371
|
-
);
|
|
372
|
-
}
|
|
373
|
-
}
|
|
374
|
-
|
|
375
|
-
redefaultToEN(alts = {}) {
|
|
376
|
-
return this.clone(Object.assign({}, alts, { defaultToEN: true }));
|
|
377
|
-
}
|
|
378
|
-
|
|
379
|
-
redefaultToSystem(alts = {}) {
|
|
380
|
-
return this.clone(Object.assign({}, alts, { defaultToEN: false }));
|
|
381
|
-
}
|
|
382
|
-
|
|
383
|
-
months(length, format = false, defaultOK = true) {
|
|
384
|
-
return listStuff(this, length, defaultOK, English.months, () => {
|
|
385
|
-
const intl = format ? { month: length, day: "numeric" } : { month: length },
|
|
386
|
-
formatStr = format ? "format" : "standalone";
|
|
387
|
-
if (!this.monthsCache[formatStr][length]) {
|
|
388
|
-
this.monthsCache[formatStr][length] = mapMonths(dt => this.extract(dt, intl, "month"));
|
|
389
|
-
}
|
|
390
|
-
return this.monthsCache[formatStr][length];
|
|
391
|
-
});
|
|
392
|
-
}
|
|
393
|
-
|
|
394
|
-
weekdays(length, format = false, defaultOK = true) {
|
|
395
|
-
return listStuff(this, length, defaultOK, English.weekdays, () => {
|
|
396
|
-
const intl = format
|
|
397
|
-
? { weekday: length, year: "numeric", month: "long", day: "numeric" }
|
|
398
|
-
: { weekday: length },
|
|
399
|
-
formatStr = format ? "format" : "standalone";
|
|
400
|
-
if (!this.weekdaysCache[formatStr][length]) {
|
|
401
|
-
this.weekdaysCache[formatStr][length] = mapWeekdays(dt =>
|
|
402
|
-
this.extract(dt, intl, "weekday")
|
|
403
|
-
);
|
|
404
|
-
}
|
|
405
|
-
return this.weekdaysCache[formatStr][length];
|
|
406
|
-
});
|
|
407
|
-
}
|
|
408
|
-
|
|
409
|
-
meridiems(defaultOK = true) {
|
|
410
|
-
return listStuff(
|
|
411
|
-
this,
|
|
412
|
-
undefined,
|
|
413
|
-
defaultOK,
|
|
414
|
-
() => English.meridiems,
|
|
415
|
-
() => {
|
|
416
|
-
// In theory there could be aribitrary day periods. We're gonna assume there are exactly two
|
|
417
|
-
// for AM and PM. This is probably wrong, but it's makes parsing way easier.
|
|
418
|
-
if (!this.meridiemCache) {
|
|
419
|
-
const intl = { hour: "numeric", hour12: true };
|
|
420
|
-
this.meridiemCache = [DateTime.utc(2016, 11, 13, 9), DateTime.utc(2016, 11, 13, 19)].map(
|
|
421
|
-
dt => this.extract(dt, intl, "dayperiod")
|
|
422
|
-
);
|
|
423
|
-
}
|
|
424
|
-
|
|
425
|
-
return this.meridiemCache;
|
|
426
|
-
}
|
|
427
|
-
);
|
|
428
|
-
}
|
|
429
|
-
|
|
430
|
-
eras(length, defaultOK = true) {
|
|
431
|
-
return listStuff(this, length, defaultOK, English.eras, () => {
|
|
432
|
-
const intl = { era: length };
|
|
433
|
-
|
|
434
|
-
// This is problematic. Different calendars are going to define eras totally differently. What I need is the minimum set of dates
|
|
435
|
-
// to definitely enumerate them.
|
|
436
|
-
if (!this.eraCache[length]) {
|
|
437
|
-
this.eraCache[length] = [DateTime.utc(-40, 1, 1), DateTime.utc(2017, 1, 1)].map(dt =>
|
|
438
|
-
this.extract(dt, intl, "era")
|
|
439
|
-
);
|
|
440
|
-
}
|
|
441
|
-
|
|
442
|
-
return this.eraCache[length];
|
|
443
|
-
});
|
|
444
|
-
}
|
|
445
|
-
|
|
446
|
-
extract(dt, intlOpts, field) {
|
|
447
|
-
const df = this.dtFormatter(dt, intlOpts),
|
|
448
|
-
results = df.formatToParts(),
|
|
449
|
-
matching = results.find(m => m.type.toLowerCase() === field);
|
|
450
|
-
return matching ? matching.value : null;
|
|
451
|
-
}
|
|
452
|
-
|
|
453
|
-
numberFormatter(opts = {}) {
|
|
454
|
-
// this forcesimple option is never used (the only caller short-circuits on it, but it seems safer to leave)
|
|
455
|
-
// (in contrast, the rest of the condition is used heavily)
|
|
456
|
-
return new PolyNumberFormatter(this.intl, opts.forceSimple || this.fastNumbers, opts);
|
|
457
|
-
}
|
|
458
|
-
|
|
459
|
-
dtFormatter(dt, intlOpts = {}) {
|
|
460
|
-
return new PolyDateFormatter(dt, this.intl, intlOpts);
|
|
461
|
-
}
|
|
462
|
-
|
|
463
|
-
relFormatter(opts = {}) {
|
|
464
|
-
return new PolyRelFormatter(this.intl, this.isEnglish(), opts);
|
|
465
|
-
}
|
|
466
|
-
|
|
467
|
-
isEnglish() {
|
|
468
|
-
return (
|
|
469
|
-
this.locale === "en" ||
|
|
470
|
-
this.locale.toLowerCase() === "en-us" ||
|
|
471
|
-
(hasIntl() && new Intl.DateTimeFormat(this.intl).resolvedOptions().locale.startsWith("en-us"))
|
|
472
|
-
);
|
|
473
|
-
}
|
|
474
|
-
|
|
475
|
-
equals(other) {
|
|
476
|
-
return (
|
|
477
|
-
this.locale === other.locale &&
|
|
478
|
-
this.numberingSystem === other.numberingSystem &&
|
|
479
|
-
this.outputCalendar === other.outputCalendar
|
|
480
|
-
);
|
|
481
|
-
}
|
|
482
|
-
}
|