@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.
Files changed (247) hide show
  1. package/package.json +3 -3
  2. package/dist/client/AddButton.d.ts +0 -16
  3. package/dist/client/Branch.d.ts +0 -17
  4. package/dist/client/CanvasContent.d.ts +0 -12
  5. package/dist/client/ExecutionCanvas.d.ts +0 -10
  6. package/dist/client/ExecutionContextProvider.d.ts +0 -15
  7. package/dist/client/ExecutionLink.d.ts +0 -10
  8. package/dist/client/ExecutionPage.d.ts +0 -10
  9. package/dist/client/ExecutionResourceProvider.d.ts +0 -14
  10. package/dist/client/FlowContext.d.ts +0 -11
  11. package/dist/client/WorkflowCanvas.d.ts +0 -10
  12. package/dist/client/WorkflowLink.d.ts +0 -10
  13. package/dist/client/WorkflowPage.d.ts +0 -10
  14. package/dist/client/WorkflowPane.d.ts +0 -10
  15. package/dist/client/components/AssignedFieldsFormSchemaConfig.d.ts +0 -10
  16. package/dist/client/components/CheckboxGroupWithTooltip.d.ts +0 -15
  17. package/dist/client/components/CollectionBlockInitializer.d.ts +0 -10
  18. package/dist/client/components/CollectionFieldset.d.ts +0 -14
  19. package/dist/client/components/DetailsBlockProvider.d.ts +0 -14
  20. package/dist/client/components/DrawerDescription.d.ts +0 -10
  21. package/dist/client/components/DrawerForm.d.ts +0 -13
  22. package/dist/client/components/ExecutionStatus.d.ts +0 -13
  23. package/dist/client/components/FieldsSelect.d.ts +0 -10
  24. package/dist/client/components/FilterDynamicComponent.d.ts +0 -14
  25. package/dist/client/components/OpenDrawer.d.ts +0 -14
  26. package/dist/client/components/RadioWithTooltip.d.ts +0 -15
  27. package/dist/client/components/SimpleDesigner.d.ts +0 -10
  28. package/dist/client/components/StatusButton.d.ts +0 -10
  29. package/dist/client/components/TriggerOptionRender.d.ts +0 -12
  30. package/dist/client/components/ValueBlock.d.ts +0 -14
  31. package/dist/client/components/index.d.ts +0 -16
  32. package/dist/client/components/renderEngineReference.d.ts +0 -10
  33. package/dist/client/constants.d.ts +0 -45
  34. package/dist/client/hooks/index.d.ts +0 -11
  35. package/dist/client/hooks/useGetAriaLabelOfAddButton.d.ts +0 -14
  36. package/dist/client/hooks/useRefreshActionProps.d.ts +0 -11
  37. package/dist/client/hooks/useTriggerWorkflowActionProps.d.ts +0 -20
  38. package/dist/client/hooks/useWorkflowExecuted.d.ts +0 -10
  39. package/dist/client/index.d.ts +0 -43
  40. package/dist/client/index.js +0 -569
  41. package/dist/client/locale/index.d.ts +0 -11
  42. package/dist/client/nodes/calculation.d.ts +0 -80
  43. package/dist/client/nodes/condition.d.ts +0 -108
  44. package/dist/client/nodes/create.d.ts +0 -110
  45. package/dist/client/nodes/destroy.d.ts +0 -54
  46. package/dist/client/nodes/end.d.ts +0 -30
  47. package/dist/client/nodes/index.d.ts +0 -76
  48. package/dist/client/nodes/query.d.ts +0 -236
  49. package/dist/client/nodes/update.d.ts +0 -114
  50. package/dist/client/schemas/collection.d.ts +0 -170
  51. package/dist/client/schemas/executions.d.ts +0 -282
  52. package/dist/client/schemas/workflows.d.ts +0 -10
  53. package/dist/client/settings/customizeSubmitToWorkflowActionSettings.d.ts +0 -10
  54. package/dist/client/style.d.ts +0 -30
  55. package/dist/client/triggers/collection.d.ts +0 -124
  56. package/dist/client/triggers/index.d.ts +0 -36
  57. package/dist/client/triggers/schedule/EndsByField.d.ts +0 -13
  58. package/dist/client/triggers/schedule/OnField.d.ts +0 -13
  59. package/dist/client/triggers/schedule/RepeatField.d.ts +0 -13
  60. package/dist/client/triggers/schedule/ScheduleConfig.d.ts +0 -10
  61. package/dist/client/triggers/schedule/constants.d.ts +0 -12
  62. package/dist/client/triggers/schedule/index.d.ts +0 -33
  63. package/dist/client/triggers/schedule/locale/Cron.zh-CN.d.ts +0 -42
  64. package/dist/client/utils.d.ts +0 -12
  65. package/dist/client/variable.d.ts +0 -93
  66. package/dist/externalVersion.js +0 -34
  67. package/dist/index.d.ts +0 -10
  68. package/dist/index.js +0 -48
  69. package/dist/locale/en-US.json +0 -98
  70. package/dist/locale/es-ES.json +0 -98
  71. package/dist/locale/fr-FR.json +0 -98
  72. package/dist/locale/ja-JP.json +0 -82
  73. package/dist/locale/ko_KR.json +0 -168
  74. package/dist/locale/pt-BR.json +0 -98
  75. package/dist/locale/ru-RU.json +0 -82
  76. package/dist/locale/tr-TR.json +0 -82
  77. package/dist/locale/zh-CN.json +0 -205
  78. package/dist/node_modules/cron-parser/.eslintrc.json +0 -15
  79. package/dist/node_modules/cron-parser/.travis.yml +0 -7
  80. package/dist/node_modules/cron-parser/LICENSE +0 -21
  81. package/dist/node_modules/cron-parser/component.json +0 -11
  82. package/dist/node_modules/cron-parser/index.d.ts +0 -1
  83. package/dist/node_modules/cron-parser/lib/date.js +0 -252
  84. package/dist/node_modules/cron-parser/lib/expression.js +0 -983
  85. package/dist/node_modules/cron-parser/lib/field_compactor.js +0 -70
  86. package/dist/node_modules/cron-parser/lib/field_stringify.js +0 -38
  87. package/dist/node_modules/cron-parser/lib/parser.js +0 -1
  88. package/dist/node_modules/cron-parser/node_modules/luxon/build/amd/luxon.js +0 -8489
  89. package/dist/node_modules/cron-parser/node_modules/luxon/build/cjs-browser/luxon.js +0 -8487
  90. package/dist/node_modules/cron-parser/node_modules/luxon/build/global/luxon.js +0 -8490
  91. package/dist/node_modules/cron-parser/node_modules/luxon/build/global/luxon.min.js +0 -1
  92. package/dist/node_modules/cron-parser/node_modules/luxon/build/node/luxon.js +0 -7522
  93. package/dist/node_modules/cron-parser/node_modules/luxon/package.json +0 -96
  94. package/dist/node_modules/cron-parser/node_modules/luxon/src/datetime.js +0 -2169
  95. package/dist/node_modules/cron-parser/node_modules/luxon/src/duration.js +0 -880
  96. package/dist/node_modules/cron-parser/node_modules/luxon/src/errors.js +0 -61
  97. package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/conversions.js +0 -157
  98. package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/diff.js +0 -80
  99. package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/digits.js +0 -76
  100. package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/english.js +0 -233
  101. package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/formats.js +0 -191
  102. package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/formatter.js +0 -386
  103. package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/invalid.js +0 -14
  104. package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/locale.js +0 -482
  105. package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/regexParser.js +0 -335
  106. package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/tokenParser.js +0 -424
  107. package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/util.js +0 -292
  108. package/dist/node_modules/cron-parser/node_modules/luxon/src/impl/zoneUtil.js +0 -36
  109. package/dist/node_modules/cron-parser/node_modules/luxon/src/info.js +0 -193
  110. package/dist/node_modules/cron-parser/node_modules/luxon/src/interval.js +0 -602
  111. package/dist/node_modules/cron-parser/node_modules/luxon/src/luxon.js +0 -26
  112. package/dist/node_modules/cron-parser/node_modules/luxon/src/luxonFilled.js +0 -13
  113. package/dist/node_modules/cron-parser/node_modules/luxon/src/settings.js +0 -137
  114. package/dist/node_modules/cron-parser/node_modules/luxon/src/zone.js +0 -88
  115. package/dist/node_modules/cron-parser/node_modules/luxon/src/zones/IANAZone.js +0 -191
  116. package/dist/node_modules/cron-parser/node_modules/luxon/src/zones/fixedOffsetZone.js +0 -94
  117. package/dist/node_modules/cron-parser/node_modules/luxon/src/zones/invalidZone.js +0 -53
  118. package/dist/node_modules/cron-parser/node_modules/luxon/src/zones/localZone.js +0 -63
  119. package/dist/node_modules/cron-parser/package.json +0 -1
  120. package/dist/node_modules/cron-parser/test/31_of_month.js +0 -17
  121. package/dist/node_modules/cron-parser/test/bug.js +0 -29
  122. package/dist/node_modules/cron-parser/test/crondate.js +0 -16
  123. package/dist/node_modules/cron-parser/test/crontab.example +0 -7
  124. package/dist/node_modules/cron-parser/test/empty_around_comma.js +0 -22
  125. package/dist/node_modules/cron-parser/test/expression.js +0 -1489
  126. package/dist/node_modules/cron-parser/test/field_compactor.js +0 -250
  127. package/dist/node_modules/cron-parser/test/field_stringify.js +0 -84
  128. package/dist/node_modules/cron-parser/test/fields.js +0 -32
  129. package/dist/node_modules/cron-parser/test/increment_on_first_iteration.js +0 -22
  130. package/dist/node_modules/cron-parser/test/index-ts3.test-d.ts +0 -133
  131. package/dist/node_modules/cron-parser/test/index.test-d.ts +0 -138
  132. package/dist/node_modules/cron-parser/test/leap_year.js +0 -17
  133. package/dist/node_modules/cron-parser/test/parser.js +0 -46
  134. package/dist/node_modules/cron-parser/test/parser_crondate_formats.js +0 -145
  135. package/dist/node_modules/cron-parser/test/parser_day_of_month.js +0 -169
  136. package/dist/node_modules/cron-parser/test/prev_date.js +0 -32
  137. package/dist/node_modules/cron-parser/test/stringify.js +0 -402
  138. package/dist/node_modules/cron-parser/test/timezone.js +0 -422
  139. package/dist/node_modules/cron-parser/types/common.d.ts +0 -131
  140. package/dist/node_modules/cron-parser/types/index.d.ts +0 -45
  141. package/dist/node_modules/cron-parser/types/ts3/index.d.ts +0 -28
  142. package/dist/node_modules/lru-cache/LICENSE +0 -15
  143. package/dist/node_modules/lru-cache/dist/cjs/index-cjs.d.ts +0 -7
  144. package/dist/node_modules/lru-cache/dist/cjs/index-cjs.js +0 -1
  145. package/dist/node_modules/lru-cache/dist/cjs/index.d.ts +0 -807
  146. package/dist/node_modules/lru-cache/dist/cjs/index.js +0 -1334
  147. package/dist/node_modules/lru-cache/dist/cjs/index.min.js +0 -2
  148. package/dist/node_modules/lru-cache/dist/cjs/package.json +0 -3
  149. package/dist/node_modules/lru-cache/dist/mjs/index.d.ts +0 -807
  150. package/dist/node_modules/lru-cache/dist/mjs/index.js +0 -1330
  151. package/dist/node_modules/lru-cache/dist/mjs/index.min.js +0 -2
  152. package/dist/node_modules/lru-cache/dist/mjs/package.json +0 -3
  153. package/dist/node_modules/lru-cache/package.json +0 -1
  154. package/dist/server/Plugin.d.ts +0 -84
  155. package/dist/server/Plugin.js +0 -503
  156. package/dist/server/Processor.d.ts +0 -115
  157. package/dist/server/Processor.js +0 -363
  158. package/dist/server/actions/executions.d.ts +0 -11
  159. package/dist/server/actions/executions.js +0 -96
  160. package/dist/server/actions/index.d.ts +0 -11
  161. package/dist/server/actions/index.js +0 -66
  162. package/dist/server/actions/nodes.d.ts +0 -12
  163. package/dist/server/actions/nodes.js +0 -217
  164. package/dist/server/actions/workflows.d.ts +0 -14
  165. package/dist/server/actions/workflows.js +0 -184
  166. package/dist/server/collections/executions.d.ts +0 -11
  167. package/dist/server/collections/executions.js +0 -66
  168. package/dist/server/collections/flow_nodes.d.ts +0 -11
  169. package/dist/server/collections/flow_nodes.js +0 -87
  170. package/dist/server/collections/jobs.d.ts +0 -11
  171. package/dist/server/collections/jobs.js +0 -66
  172. package/dist/server/collections/workflows.d.ts +0 -10
  173. package/dist/server/collections/workflows.js +0 -126
  174. package/dist/server/constants.d.ts +0 -29
  175. package/dist/server/constants.js +0 -58
  176. package/dist/server/functions/index.d.ts +0 -17
  177. package/dist/server/functions/index.js +0 -40
  178. package/dist/server/index.d.ts +0 -15
  179. package/dist/server/index.js +0 -60
  180. package/dist/server/instructions/CalculationInstruction.d.ts +0 -25
  181. package/dist/server/instructions/CalculationInstruction.js +0 -59
  182. package/dist/server/instructions/ConditionInstruction.d.ts +0 -36
  183. package/dist/server/instructions/ConditionInstruction.js +0 -167
  184. package/dist/server/instructions/CreateInstruction.d.ts +0 -18
  185. package/dist/server/instructions/CreateInstruction.js +0 -75
  186. package/dist/server/instructions/DestroyInstruction.d.ts +0 -18
  187. package/dist/server/instructions/DestroyInstruction.js +0 -59
  188. package/dist/server/instructions/EndInstruction.d.ts +0 -14
  189. package/dist/server/instructions/EndInstruction.js +0 -55
  190. package/dist/server/instructions/QueryInstruction.d.ts +0 -21
  191. package/dist/server/instructions/QueryInstruction.js +0 -82
  192. package/dist/server/instructions/UpdateInstruction.d.ts +0 -18
  193. package/dist/server/instructions/UpdateInstruction.js +0 -59
  194. package/dist/server/instructions/index.d.ts +0 -31
  195. package/dist/server/instructions/index.js +0 -42
  196. package/dist/server/migrations/20221129153547-calculation-variables.d.ts +0 -14
  197. package/dist/server/migrations/20221129153547-calculation-variables.js +0 -92
  198. package/dist/server/migrations/20230221032941-change-request-body-type.d.ts +0 -14
  199. package/dist/server/migrations/20230221032941-change-request-body-type.js +0 -102
  200. package/dist/server/migrations/20230221071831-calculation-expression.d.ts +0 -13
  201. package/dist/server/migrations/20230221071831-calculation-expression.js +0 -121
  202. package/dist/server/migrations/20230221121203-condition-calculation.d.ts +0 -13
  203. package/dist/server/migrations/20230221121203-condition-calculation.js +0 -106
  204. package/dist/server/migrations/20230221162902-jsonb-to-json.d.ts +0 -13
  205. package/dist/server/migrations/20230221162902-jsonb-to-json.js +0 -63
  206. package/dist/server/migrations/20230411034722-manual-multi-form.d.ts +0 -13
  207. package/dist/server/migrations/20230411034722-manual-multi-form.js +0 -283
  208. package/dist/server/migrations/20230612021134-manual-collection-block.d.ts +0 -13
  209. package/dist/server/migrations/20230612021134-manual-collection-block.js +0 -152
  210. package/dist/server/migrations/20230710115902-manual-action-values.d.ts +0 -13
  211. package/dist/server/migrations/20230710115902-manual-action-values.js +0 -101
  212. package/dist/server/migrations/20230809113132-workflow-options.d.ts +0 -13
  213. package/dist/server/migrations/20230809113132-workflow-options.js +0 -64
  214. package/dist/server/migrations/20231024172342-add-node-key.d.ts +0 -13
  215. package/dist/server/migrations/20231024172342-add-node-key.js +0 -90
  216. package/dist/server/migrations/20231122143143-split-to-plugins.d.ts +0 -13
  217. package/dist/server/migrations/20231122143143-split-to-plugins.js +0 -67
  218. package/dist/server/migrations/20240115220721-add-node-key-to-job.d.ts +0 -14
  219. package/dist/server/migrations/20240115220721-add-node-key-to-job.js +0 -63
  220. package/dist/server/migrations/20240613222612-fix-assign-field-config.d.ts +0 -13
  221. package/dist/server/migrations/20240613222612-fix-assign-field-config.js +0 -62
  222. package/dist/server/triggers/CollectionTrigger.d.ts +0 -22
  223. package/dist/server/triggers/CollectionTrigger.js +0 -184
  224. package/dist/server/triggers/ScheduleTrigger/DateFieldScheduleTrigger.d.ts +0 -39
  225. package/dist/server/triggers/ScheduleTrigger/DateFieldScheduleTrigger.js +0 -356
  226. package/dist/server/triggers/ScheduleTrigger/StaticScheduleTrigger.d.ts +0 -21
  227. package/dist/server/triggers/ScheduleTrigger/StaticScheduleTrigger.js +0 -152
  228. package/dist/server/triggers/ScheduleTrigger/index.d.ts +0 -18
  229. package/dist/server/triggers/ScheduleTrigger/index.js +0 -84
  230. package/dist/server/triggers/ScheduleTrigger/utils.d.ts +0 -13
  231. package/dist/server/triggers/ScheduleTrigger/utils.js +0 -44
  232. package/dist/server/triggers/index.d.ts +0 -21
  233. package/dist/server/triggers/index.js +0 -46
  234. package/dist/server/types/Execution.d.ts +0 -25
  235. package/dist/server/types/Execution.js +0 -34
  236. package/dist/server/types/FlowNode.d.ts +0 -24
  237. package/dist/server/types/FlowNode.js +0 -34
  238. package/dist/server/types/Job.d.ts +0 -22
  239. package/dist/server/types/Job.js +0 -34
  240. package/dist/server/types/Workflow.d.ts +0 -35
  241. package/dist/server/types/Workflow.js +0 -34
  242. package/dist/server/types/index.d.ts +0 -12
  243. package/dist/server/types/index.js +0 -24
  244. package/dist/server/utils.d.ts +0 -9
  245. package/dist/server/utils.js +0 -51
  246. package/dist/swagger/index.d.ts +0 -762
  247. 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
- }