@jsonforms/core 3.0.0-alpha.1 → 3.0.0-alpha.2
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/docs/assets/js/search.json +1 -1
- package/docs/globals.html +716 -401
- package/docs/index.html +60 -36
- package/docs/interfaces/addcellrendereraction.html +3 -3
- package/docs/interfaces/addrendereraction.html +3 -3
- package/docs/interfaces/adduischemaaction.html +3 -3
- package/docs/interfaces/arraycontrolprops.html +21 -21
- package/docs/interfaces/arraylayoutprops.html +21 -21
- package/docs/interfaces/cellprops.html +14 -14
- package/docs/interfaces/combinatorrendererprops.html +13 -13
- package/docs/interfaces/controlprops.html +16 -16
- package/docs/interfaces/controlstate.html +2 -2
- package/docs/interfaces/controlwithdetailprops.html +17 -17
- package/docs/interfaces/dispatchcellprops.html +13 -13
- package/docs/interfaces/dispatchcellstateprops.html +13 -13
- package/docs/interfaces/dispatchpropsofarraycontrol.html +4 -4
- package/docs/interfaces/dispatchpropsofcontrol.html +1 -1
- package/docs/interfaces/dispatchpropsofmultienumcontrol.html +2 -2
- package/docs/interfaces/enumcellprops.html +15 -15
- package/docs/interfaces/enumoption.html +2 -2
- package/docs/interfaces/initaction.html +6 -6
- package/docs/interfaces/initactionoptions.html +3 -3
- package/docs/interfaces/jsonformscore.html +7 -7
- package/docs/interfaces/{jsonformslocalestate.html → jsonformsi18nstate.html} +20 -20
- package/docs/interfaces/jsonformsprops.html +9 -9
- package/docs/interfaces/jsonformssubstates.html +11 -1
- package/docs/interfaces/layoutprops.html +10 -10
- package/docs/interfaces/ownpropsofcell.html +10 -10
- package/docs/interfaces/ownpropsofcontrol.html +9 -9
- package/docs/interfaces/ownpropsofenum.html +1 -1
- package/docs/interfaces/ownpropsofenumcell.html +11 -11
- package/docs/interfaces/ownpropsofjsonformsrenderer.html +8 -8
- package/docs/interfaces/ownpropsoflayout.html +9 -9
- package/docs/interfaces/ownpropsofmasterlistitem.html +6 -6
- package/docs/interfaces/ownpropsofrenderer.html +8 -8
- package/docs/interfaces/registerdefaultdataaction.html +3 -3
- package/docs/interfaces/removecellrendereraction.html +3 -3
- package/docs/interfaces/removerendereraction.html +3 -3
- package/docs/interfaces/removeuischemaaction.html +2 -2
- package/docs/interfaces/rendererprops.html +9 -9
- package/docs/interfaces/setajvaction.html +3 -3
- package/docs/interfaces/setconfigaction.html +2 -2
- package/docs/interfaces/setlocaleaction.html +3 -3
- package/docs/interfaces/setschemaaction.html +2 -2
- package/docs/interfaces/{setlocalizedschemasaction.html → settranslatoraction.html} +29 -15
- package/docs/interfaces/setuischemaaction.html +2 -2
- package/docs/interfaces/setvalidationmodeaction.html +2 -2
- package/docs/interfaces/statepropsofarraycontrol.html +17 -17
- package/docs/interfaces/statepropsofarraylayout.html +17 -17
- package/docs/interfaces/statepropsofcell.html +13 -13
- package/docs/interfaces/statepropsofcombinator.html +12 -12
- package/docs/interfaces/statepropsofcontrol.html +15 -15
- package/docs/interfaces/statepropsofcontrolwithdetail.html +16 -16
- package/docs/interfaces/statepropsofenumcell.html +14 -14
- package/docs/interfaces/statepropsofjsonformsrenderer.html +9 -9
- package/docs/interfaces/statepropsoflayout.html +10 -10
- package/docs/interfaces/statepropsofmasteritem.html +7 -7
- package/docs/interfaces/statepropsofrenderer.html +9 -9
- package/docs/interfaces/statepropsofscopedrenderer.html +12 -12
- package/docs/interfaces/unregisterdefaultdataaction.html +2 -2
- package/docs/interfaces/updateaction.html +3 -3
- package/docs/interfaces/updatecoreaction.html +6 -6
- package/docs/interfaces/updateerrorsaction.html +2 -2
- package/docs/interfaces/{setlocalizeduischemasaction.html → updatei18naction.html} +43 -15
- package/docs/interfaces/withclassname.html +1 -1
- package/lib/Helpers.js +1 -0
- package/lib/Helpers.js.map +1 -1
- package/lib/actions/actions.d.ts +29 -25
- package/lib/actions/actions.js +52 -28
- package/lib/actions/actions.js.map +1 -1
- package/lib/configDefault.js +1 -0
- package/lib/configDefault.js.map +1 -1
- package/lib/generators/Generate.js +1 -0
- package/lib/generators/Generate.js.map +1 -1
- package/lib/generators/schema.js +3 -1
- package/lib/generators/schema.js.map +1 -1
- package/lib/generators/uischema.js +5 -2
- package/lib/generators/uischema.js.map +1 -1
- package/lib/i18n/i18nTypes.d.ts +15 -0
- package/lib/i18n/i18nTypes.js +3 -0
- package/lib/i18n/i18nTypes.js.map +1 -0
- package/lib/i18n/i18nUtil.d.ts +11 -0
- package/lib/i18n/i18nUtil.js +58 -0
- package/lib/i18n/i18nUtil.js.map +1 -0
- package/lib/i18n/index.d.ts +2 -0
- package/lib/i18n/index.js +6 -0
- package/lib/i18n/index.js.map +1 -0
- package/lib/index.d.ts +1 -0
- package/lib/index.js +3 -0
- package/lib/index.js.map +1 -1
- package/lib/jsonforms-core.js +9 -3
- package/lib/jsonforms-core.js.map +1 -1
- package/lib/models/draft4.js +1 -0
- package/lib/models/draft4.js.map +1 -1
- package/lib/models/index.js +3 -0
- package/lib/models/index.js.map +1 -1
- package/lib/models/uischema.js +5 -2
- package/lib/models/uischema.js.map +1 -1
- package/lib/reducers/cells.js +3 -1
- package/lib/reducers/cells.js.map +1 -1
- package/lib/reducers/config.js +3 -1
- package/lib/reducers/config.js.map +1 -1
- package/lib/reducers/core.d.ts +3 -2
- package/lib/reducers/core.js +72 -37
- package/lib/reducers/core.js.map +1 -1
- package/lib/reducers/default-data.js +5 -2
- package/lib/reducers/default-data.js.map +1 -1
- package/lib/reducers/i18n.d.ts +7 -10
- package/lib/reducers/i18n.js +38 -20
- package/lib/reducers/i18n.js.map +1 -1
- package/lib/reducers/reducers.d.ts +8 -7
- package/lib/reducers/reducers.js +25 -17
- package/lib/reducers/reducers.js.map +1 -1
- package/lib/reducers/renderers.js +3 -1
- package/lib/reducers/renderers.js.map +1 -1
- package/lib/reducers/selectors.d.ts +1 -1
- package/lib/reducers/selectors.js +17 -8
- package/lib/reducers/selectors.js.map +1 -1
- package/lib/reducers/uischemas.js +5 -2
- package/lib/reducers/uischemas.js.map +1 -1
- package/lib/store.d.ts +5 -4
- package/lib/testers/testers.js +39 -19
- package/lib/testers/testers.js.map +1 -1
- package/lib/util/array.js +1 -0
- package/lib/util/array.js.map +1 -1
- package/lib/util/cell.js +25 -9
- package/lib/util/cell.js.map +1 -1
- package/lib/util/combinators.js +5 -2
- package/lib/util/combinators.js.map +1 -1
- package/lib/util/ids.js +7 -3
- package/lib/util/ids.js.map +1 -1
- package/lib/util/index.js +2 -0
- package/lib/util/index.js.map +1 -1
- package/lib/util/label.js +5 -2
- package/lib/util/label.js.map +1 -1
- package/lib/util/path.js +9 -4
- package/lib/util/path.js.map +1 -1
- package/lib/util/renderer.d.ts +13 -4
- package/lib/util/renderer.js +120 -39
- package/lib/util/renderer.js.map +1 -1
- package/lib/util/resolvers.js +7 -3
- package/lib/util/resolvers.js.map +1 -1
- package/lib/util/runtime.d.ts +4 -5
- package/lib/util/runtime.js +15 -7
- package/lib/util/runtime.js.map +1 -1
- package/lib/util/schema.js +3 -1
- package/lib/util/schema.js.map +1 -1
- package/lib/util/uischema.js +7 -3
- package/lib/util/uischema.js.map +1 -1
- package/lib/util/util.d.ts +1 -1
- package/lib/util/util.js +9 -4
- package/lib/util/util.js.map +1 -1
- package/lib/util/validator.d.ts +3 -2
- package/lib/util/validator.js +8 -7
- package/lib/util/validator.js.map +1 -1
- package/package.json +5 -4
- package/src/actions/actions.ts +46 -36
- package/src/i18n/i18nTypes.ts +17 -0
- package/src/i18n/i18nUtil.ts +76 -0
- package/src/i18n/index.ts +2 -0
- package/src/index.ts +1 -0
- package/src/reducers/core.ts +70 -48
- package/src/reducers/i18n.ts +41 -35
- package/src/reducers/reducers.ts +10 -9
- package/src/reducers/selectors.ts +1 -1
- package/src/store.ts +4 -4
- package/src/util/cell.ts +24 -4
- package/src/util/renderer.ts +116 -27
- package/src/util/runtime.ts +1 -1
- package/src/util/util.ts +1 -1
- package/src/util/validator.ts +5 -9
- package/test/reducers/core.test.ts +29 -41
- package/test/util/cell.test.ts +2 -2
- package/test/util/renderer.test.ts +425 -4
|
@@ -56,10 +56,14 @@ import {
|
|
|
56
56
|
OwnPropsOfControl,
|
|
57
57
|
rankWith,
|
|
58
58
|
RuleEffect,
|
|
59
|
-
UISchemaElement
|
|
59
|
+
UISchemaElement,
|
|
60
|
+
setValidationMode,
|
|
61
|
+
defaultJsonFormsI18nState,
|
|
62
|
+
i18nJsonSchema,
|
|
63
|
+
mapStateToEnumControlProps,
|
|
64
|
+
mapStateToOneOfEnumControlProps
|
|
60
65
|
} from '../../src';
|
|
61
66
|
import { ErrorObject } from 'ajv';
|
|
62
|
-
import { setValidationMode } from '../../lib';
|
|
63
67
|
|
|
64
68
|
const middlewares: Redux.Middleware[] = [];
|
|
65
69
|
const mockStore = configureStore<JsonFormsState>(middlewares);
|
|
@@ -384,7 +388,7 @@ test('mapStateToControlProps - errors', t => {
|
|
|
384
388
|
};
|
|
385
389
|
const clonedState = _.cloneDeep(createState(coreUISchema));
|
|
386
390
|
const error: ErrorObject = {
|
|
387
|
-
|
|
391
|
+
instancePath: '/firstName',
|
|
388
392
|
message: 'Duff beer',
|
|
389
393
|
keyword: 'whatever',
|
|
390
394
|
schemaPath: '',
|
|
@@ -1274,6 +1278,423 @@ test('mapStateToAnyOfProps - const constraint in anyOf schema should return corr
|
|
|
1274
1278
|
}
|
|
1275
1279
|
};
|
|
1276
1280
|
const props = mapStateToAnyOfProps(state, ownProps);
|
|
1277
|
-
console.log(JSON.stringify(props, null, 2));
|
|
1278
1281
|
t.is(props.indexOfFittingSchema, 2);
|
|
1279
1282
|
});
|
|
1283
|
+
|
|
1284
|
+
test('mapStateToControlProps - i18n - mapStateToControlProps should not crash without i18n', t => {
|
|
1285
|
+
const ownProps = {
|
|
1286
|
+
uischema: coreUISchema
|
|
1287
|
+
};
|
|
1288
|
+
const state: JsonFormsState = createState(coreUISchema);
|
|
1289
|
+
state.jsonforms.i18n = undefined;
|
|
1290
|
+
|
|
1291
|
+
const props = mapStateToControlProps(state, ownProps);
|
|
1292
|
+
t.is(props.label, 'First Name');
|
|
1293
|
+
});
|
|
1294
|
+
|
|
1295
|
+
test('mapStateToControlProps - i18n - default translation has no effect', t => {
|
|
1296
|
+
const ownProps = {
|
|
1297
|
+
uischema: coreUISchema
|
|
1298
|
+
};
|
|
1299
|
+
const state: JsonFormsState = createState(coreUISchema);
|
|
1300
|
+
state.jsonforms.i18n = defaultJsonFormsI18nState;
|
|
1301
|
+
|
|
1302
|
+
const props = mapStateToControlProps(state, ownProps);
|
|
1303
|
+
t.is(props.label, 'First Name');
|
|
1304
|
+
t.is(props.description, undefined);
|
|
1305
|
+
});
|
|
1306
|
+
|
|
1307
|
+
test('mapStateToControlProps - i18n - translation via label key', t => {
|
|
1308
|
+
const ownProps = {
|
|
1309
|
+
uischema: coreUISchema
|
|
1310
|
+
};
|
|
1311
|
+
const state: JsonFormsState = createState(coreUISchema);
|
|
1312
|
+
state.jsonforms.i18n = defaultJsonFormsI18nState;
|
|
1313
|
+
state.jsonforms.i18n.translate = (key: string, defaultMessage: string | undefined) => {
|
|
1314
|
+
switch(key){
|
|
1315
|
+
case 'First Name': return 'my translation';
|
|
1316
|
+
default: return defaultMessage;
|
|
1317
|
+
}
|
|
1318
|
+
}
|
|
1319
|
+
|
|
1320
|
+
const props = mapStateToControlProps(state, ownProps);
|
|
1321
|
+
t.is(props.label, 'my translation');
|
|
1322
|
+
t.is(props.description, undefined);
|
|
1323
|
+
});
|
|
1324
|
+
|
|
1325
|
+
test('mapStateToControlProps - i18n - translation via JSON Schema i18n key', t => {
|
|
1326
|
+
const ownProps = {
|
|
1327
|
+
uischema: coreUISchema
|
|
1328
|
+
};
|
|
1329
|
+
const state: JsonFormsState = createState(coreUISchema);
|
|
1330
|
+
state.jsonforms.i18n = defaultJsonFormsI18nState;
|
|
1331
|
+
(state.jsonforms.core.schema.properties.firstName as i18nJsonSchema).i18n = 'my-key';
|
|
1332
|
+
state.jsonforms.i18n.translate = (key: string, defaultMessage: string | undefined) => {
|
|
1333
|
+
switch(key){
|
|
1334
|
+
case 'my-key.label': return 'my label';
|
|
1335
|
+
case 'my-key.description': return 'my description';
|
|
1336
|
+
default: return defaultMessage;
|
|
1337
|
+
}
|
|
1338
|
+
}
|
|
1339
|
+
|
|
1340
|
+
const props = mapStateToControlProps(state, ownProps);
|
|
1341
|
+
t.is(props.label, 'my label');
|
|
1342
|
+
t.is(props.description, 'my description');
|
|
1343
|
+
});
|
|
1344
|
+
|
|
1345
|
+
test('mapStateToControlProps - i18n - translation via UI Schema i18n key', t => {
|
|
1346
|
+
const ownProps = {
|
|
1347
|
+
uischema: coreUISchema
|
|
1348
|
+
};
|
|
1349
|
+
const state: JsonFormsState = createState(coreUISchema);
|
|
1350
|
+
state.jsonforms.i18n = defaultJsonFormsI18nState;
|
|
1351
|
+
ownProps.uischema = {...ownProps.uischema, options: {i18n: 'my-key'}};
|
|
1352
|
+
state.jsonforms.i18n.translate = (key: string, defaultMessage: string | undefined) => {
|
|
1353
|
+
switch(key){
|
|
1354
|
+
case 'my-key.label': return 'my label';
|
|
1355
|
+
case 'my-key.description': return 'my description';
|
|
1356
|
+
default: return defaultMessage;
|
|
1357
|
+
}
|
|
1358
|
+
}
|
|
1359
|
+
|
|
1360
|
+
const props = mapStateToControlProps(state, ownProps);
|
|
1361
|
+
t.is(props.label, 'my label');
|
|
1362
|
+
t.is(props.description, 'my description');
|
|
1363
|
+
});
|
|
1364
|
+
|
|
1365
|
+
test('mapStateToControlProps - i18n errors - should not crash without i18n', t => {
|
|
1366
|
+
const ownProps = {
|
|
1367
|
+
uischema: coreUISchema
|
|
1368
|
+
};
|
|
1369
|
+
const state: JsonFormsState = createState(coreUISchema);
|
|
1370
|
+
state.jsonforms.core.schema.properties.firstName.pattern = "[0-9]+"
|
|
1371
|
+
state.jsonforms.core = coreReducer(
|
|
1372
|
+
state.jsonforms.core,
|
|
1373
|
+
init(
|
|
1374
|
+
state.jsonforms.core.data,
|
|
1375
|
+
state.jsonforms.core.schema,
|
|
1376
|
+
state.jsonforms.core.uischema,
|
|
1377
|
+
createAjv()
|
|
1378
|
+
)
|
|
1379
|
+
);
|
|
1380
|
+
state.jsonforms.i18n = undefined;
|
|
1381
|
+
|
|
1382
|
+
const props = mapStateToControlProps(state, ownProps);
|
|
1383
|
+
t.is(props.errors, 'must match pattern "[0-9]+"');
|
|
1384
|
+
});
|
|
1385
|
+
|
|
1386
|
+
test('mapStateToControlProps - i18n errors - default translation has no effect', t => {
|
|
1387
|
+
const ownProps = {
|
|
1388
|
+
uischema: coreUISchema
|
|
1389
|
+
};
|
|
1390
|
+
const state: JsonFormsState = createState(coreUISchema);
|
|
1391
|
+
state.jsonforms.core.schema.properties.firstName.pattern = "[0-9]+"
|
|
1392
|
+
state.jsonforms.core = coreReducer(
|
|
1393
|
+
state.jsonforms.core,
|
|
1394
|
+
init(
|
|
1395
|
+
state.jsonforms.core.data,
|
|
1396
|
+
state.jsonforms.core.schema,
|
|
1397
|
+
state.jsonforms.core.uischema,
|
|
1398
|
+
createAjv()
|
|
1399
|
+
)
|
|
1400
|
+
);
|
|
1401
|
+
state.jsonforms.i18n = defaultJsonFormsI18nState;
|
|
1402
|
+
|
|
1403
|
+
const props = mapStateToControlProps(state, ownProps);
|
|
1404
|
+
t.is(props.errors, 'must match pattern "[0-9]+"');
|
|
1405
|
+
});
|
|
1406
|
+
|
|
1407
|
+
test('mapStateToControlProps - i18n errors - translate via error message key', t => {
|
|
1408
|
+
const ownProps = {
|
|
1409
|
+
uischema: coreUISchema
|
|
1410
|
+
};
|
|
1411
|
+
const state: JsonFormsState = createState(coreUISchema);
|
|
1412
|
+
state.jsonforms.core.schema.properties.firstName.pattern = "[0-9]+"
|
|
1413
|
+
state.jsonforms.core = coreReducer(
|
|
1414
|
+
state.jsonforms.core,
|
|
1415
|
+
init(
|
|
1416
|
+
state.jsonforms.core.data,
|
|
1417
|
+
state.jsonforms.core.schema,
|
|
1418
|
+
state.jsonforms.core.uischema,
|
|
1419
|
+
createAjv()
|
|
1420
|
+
)
|
|
1421
|
+
);
|
|
1422
|
+
state.jsonforms.i18n = defaultJsonFormsI18nState;
|
|
1423
|
+
state.jsonforms.i18n.translate = (key: string, defaultMessage: string | undefined) => {
|
|
1424
|
+
switch(key){
|
|
1425
|
+
case 'must match pattern "[0-9]+"': return 'my error message';
|
|
1426
|
+
default: return defaultMessage;
|
|
1427
|
+
}
|
|
1428
|
+
}
|
|
1429
|
+
|
|
1430
|
+
const props = mapStateToControlProps(state, ownProps);
|
|
1431
|
+
t.is(props.errors, 'my error message');
|
|
1432
|
+
});
|
|
1433
|
+
|
|
1434
|
+
test('mapStateToControlProps - i18n errors - translate via i18 specialized error keyword key', t => {
|
|
1435
|
+
const ownProps = {
|
|
1436
|
+
uischema: coreUISchema
|
|
1437
|
+
};
|
|
1438
|
+
const state: JsonFormsState = createState(coreUISchema);
|
|
1439
|
+
state.jsonforms.core.schema.properties.firstName.pattern = "[0-9]+";
|
|
1440
|
+
(state.jsonforms.core.schema.properties.firstName as i18nJsonSchema).i18n = 'my-key';
|
|
1441
|
+
state.jsonforms.core = coreReducer(
|
|
1442
|
+
state.jsonforms.core,
|
|
1443
|
+
init(
|
|
1444
|
+
state.jsonforms.core.data,
|
|
1445
|
+
state.jsonforms.core.schema,
|
|
1446
|
+
state.jsonforms.core.uischema,
|
|
1447
|
+
createAjv()
|
|
1448
|
+
)
|
|
1449
|
+
);
|
|
1450
|
+
state.jsonforms.i18n = defaultJsonFormsI18nState;
|
|
1451
|
+
state.jsonforms.i18n.translate = (key: string, defaultMessage: string | undefined) => {
|
|
1452
|
+
switch(key){
|
|
1453
|
+
case 'my-key.error.pattern': return 'my error message';
|
|
1454
|
+
default: return defaultMessage;
|
|
1455
|
+
}
|
|
1456
|
+
}
|
|
1457
|
+
|
|
1458
|
+
const props = mapStateToControlProps(state, ownProps);
|
|
1459
|
+
t.is(props.errors, 'my error message');
|
|
1460
|
+
});
|
|
1461
|
+
|
|
1462
|
+
test('mapStateToControlProps - i18n errors - translate via i18 general error keyword key', t => {
|
|
1463
|
+
const ownProps = {
|
|
1464
|
+
uischema: coreUISchema
|
|
1465
|
+
};
|
|
1466
|
+
const state: JsonFormsState = createState(coreUISchema);
|
|
1467
|
+
state.jsonforms.core.schema.properties.firstName.pattern = "[0-9]+";
|
|
1468
|
+
(state.jsonforms.core.schema.properties.firstName as i18nJsonSchema).i18n = 'my-key';
|
|
1469
|
+
state.jsonforms.core = coreReducer(
|
|
1470
|
+
state.jsonforms.core,
|
|
1471
|
+
init(
|
|
1472
|
+
state.jsonforms.core.data,
|
|
1473
|
+
state.jsonforms.core.schema,
|
|
1474
|
+
state.jsonforms.core.uischema,
|
|
1475
|
+
createAjv()
|
|
1476
|
+
)
|
|
1477
|
+
);
|
|
1478
|
+
state.jsonforms.i18n = defaultJsonFormsI18nState;
|
|
1479
|
+
state.jsonforms.i18n.translate = (key: string, defaultMessage: string | undefined) => {
|
|
1480
|
+
switch(key){
|
|
1481
|
+
case 'error.pattern': return 'my error message';
|
|
1482
|
+
default: return defaultMessage;
|
|
1483
|
+
}
|
|
1484
|
+
}
|
|
1485
|
+
|
|
1486
|
+
const props = mapStateToControlProps(state, ownProps);
|
|
1487
|
+
t.is(props.errors, 'my error message');
|
|
1488
|
+
});
|
|
1489
|
+
|
|
1490
|
+
test('mapStateToControlProps - i18n errors - specialized keyword wins over generic keyword', t => {
|
|
1491
|
+
const ownProps = {
|
|
1492
|
+
uischema: coreUISchema
|
|
1493
|
+
};
|
|
1494
|
+
const state: JsonFormsState = createState(coreUISchema);
|
|
1495
|
+
state.jsonforms.core.schema.properties.firstName.pattern = "[0-9]+";
|
|
1496
|
+
(state.jsonforms.core.schema.properties.firstName as i18nJsonSchema).i18n = 'my-key';
|
|
1497
|
+
state.jsonforms.core = coreReducer(
|
|
1498
|
+
state.jsonforms.core,
|
|
1499
|
+
init(
|
|
1500
|
+
state.jsonforms.core.data,
|
|
1501
|
+
state.jsonforms.core.schema,
|
|
1502
|
+
state.jsonforms.core.uischema,
|
|
1503
|
+
createAjv()
|
|
1504
|
+
)
|
|
1505
|
+
);
|
|
1506
|
+
state.jsonforms.i18n = defaultJsonFormsI18nState;
|
|
1507
|
+
state.jsonforms.i18n.translate = (key: string, defaultMessage: string | undefined) => {
|
|
1508
|
+
switch(key){
|
|
1509
|
+
case 'my-key.error.pattern': return 'my key error message';
|
|
1510
|
+
case 'error.pattern': return 'my error message';
|
|
1511
|
+
default: return defaultMessage;
|
|
1512
|
+
}
|
|
1513
|
+
}
|
|
1514
|
+
|
|
1515
|
+
const props = mapStateToControlProps(state, ownProps);
|
|
1516
|
+
t.is(props.errors, 'my key error message');
|
|
1517
|
+
});
|
|
1518
|
+
|
|
1519
|
+
test('mapStateToControlProps - i18n errors - multiple errors customization', t => {
|
|
1520
|
+
const ownProps = {
|
|
1521
|
+
uischema: coreUISchema
|
|
1522
|
+
};
|
|
1523
|
+
const state: JsonFormsState = createState(coreUISchema);
|
|
1524
|
+
state.jsonforms.core.schema.properties.firstName.pattern = "[0-9]+";
|
|
1525
|
+
state.jsonforms.core.schema.properties.firstName.maxLength = 2;
|
|
1526
|
+
(state.jsonforms.core.schema.properties.firstName as i18nJsonSchema).i18n = 'my-key';
|
|
1527
|
+
state.jsonforms.core = coreReducer(
|
|
1528
|
+
state.jsonforms.core,
|
|
1529
|
+
init(
|
|
1530
|
+
state.jsonforms.core.data,
|
|
1531
|
+
state.jsonforms.core.schema,
|
|
1532
|
+
state.jsonforms.core.uischema,
|
|
1533
|
+
createAjv()
|
|
1534
|
+
)
|
|
1535
|
+
);
|
|
1536
|
+
state.jsonforms.i18n = defaultJsonFormsI18nState;
|
|
1537
|
+
state.jsonforms.i18n.translate = (key: string, defaultMessage: string | undefined) => {
|
|
1538
|
+
switch(key){
|
|
1539
|
+
case 'error.maxLength': return 'max length message';
|
|
1540
|
+
case 'my-key.error.pattern': return 'my key error message';
|
|
1541
|
+
default: return defaultMessage;
|
|
1542
|
+
}
|
|
1543
|
+
}
|
|
1544
|
+
|
|
1545
|
+
const props = mapStateToControlProps(state, ownProps);
|
|
1546
|
+
t.is(props.errors, 'max length message\nmy key error message');
|
|
1547
|
+
});
|
|
1548
|
+
|
|
1549
|
+
test('mapStateToControlProps - i18n errors - custom keyword wins over all other errors', t => {
|
|
1550
|
+
const ownProps = {
|
|
1551
|
+
uischema: coreUISchema
|
|
1552
|
+
};
|
|
1553
|
+
const state: JsonFormsState = createState(coreUISchema);
|
|
1554
|
+
state.jsonforms.core.schema.properties.firstName.pattern = "[0-9]+";
|
|
1555
|
+
state.jsonforms.core.schema.properties.firstName.maxLength = 2;
|
|
1556
|
+
(state.jsonforms.core.schema.properties.firstName as i18nJsonSchema).i18n = 'my-key';
|
|
1557
|
+
state.jsonforms.core = coreReducer(
|
|
1558
|
+
state.jsonforms.core,
|
|
1559
|
+
init(
|
|
1560
|
+
state.jsonforms.core.data,
|
|
1561
|
+
state.jsonforms.core.schema,
|
|
1562
|
+
state.jsonforms.core.uischema,
|
|
1563
|
+
createAjv()
|
|
1564
|
+
)
|
|
1565
|
+
);
|
|
1566
|
+
state.jsonforms.i18n = defaultJsonFormsI18nState;
|
|
1567
|
+
state.jsonforms.i18n.translate = (key: string, defaultMessage: string | undefined) => {
|
|
1568
|
+
switch(key){
|
|
1569
|
+
case 'my-key.error.custom': return 'this is my error custom error message';
|
|
1570
|
+
case 'my-key.error.pattern': return 'my key error message';
|
|
1571
|
+
case 'error.pattern': return 'my error message';
|
|
1572
|
+
default: return defaultMessage;
|
|
1573
|
+
}
|
|
1574
|
+
}
|
|
1575
|
+
|
|
1576
|
+
const props = mapStateToControlProps(state, ownProps);
|
|
1577
|
+
t.is(props.errors, 'this is my error custom error message');
|
|
1578
|
+
});
|
|
1579
|
+
|
|
1580
|
+
test('mapStateToEnumControlProps - i18n - should not crash without i18n', t => {
|
|
1581
|
+
const ownProps = {
|
|
1582
|
+
uischema: coreUISchema
|
|
1583
|
+
};
|
|
1584
|
+
const state: JsonFormsState = createState(coreUISchema);
|
|
1585
|
+
state.jsonforms.core.schema.properties.firstName.enum = ['a', 'b'];
|
|
1586
|
+
state.jsonforms.i18n = undefined;
|
|
1587
|
+
|
|
1588
|
+
const props = mapStateToEnumControlProps(state, ownProps);
|
|
1589
|
+
t.is(props.options[0].label, 'a');
|
|
1590
|
+
});
|
|
1591
|
+
|
|
1592
|
+
test('mapStateToEnumControlProps - i18n - default translation has no effect', t => {
|
|
1593
|
+
const ownProps = {
|
|
1594
|
+
uischema: coreUISchema
|
|
1595
|
+
};
|
|
1596
|
+
const state: JsonFormsState = createState(coreUISchema);
|
|
1597
|
+
state.jsonforms.core.schema.properties.firstName.enum = ['a', 'b'];
|
|
1598
|
+
state.jsonforms.i18n = defaultJsonFormsI18nState;
|
|
1599
|
+
|
|
1600
|
+
const props = mapStateToEnumControlProps(state, ownProps);
|
|
1601
|
+
t.is(props.options[0].label, 'a');
|
|
1602
|
+
});
|
|
1603
|
+
|
|
1604
|
+
test('mapStateToEnumControlProps - i18n - label translation', t => {
|
|
1605
|
+
const ownProps = {
|
|
1606
|
+
uischema: coreUISchema
|
|
1607
|
+
};
|
|
1608
|
+
const state: JsonFormsState = createState(coreUISchema);
|
|
1609
|
+
state.jsonforms.core.schema.properties.firstName.enum = ['a', 'b'];
|
|
1610
|
+
state.jsonforms.i18n = defaultJsonFormsI18nState;
|
|
1611
|
+
state.jsonforms.i18n.translate = (key: string, defaultMessage: string | undefined) => {
|
|
1612
|
+
switch(key){
|
|
1613
|
+
case 'a': return 'my message';
|
|
1614
|
+
default: return defaultMessage;
|
|
1615
|
+
}
|
|
1616
|
+
}
|
|
1617
|
+
|
|
1618
|
+
const props = mapStateToEnumControlProps(state, ownProps);
|
|
1619
|
+
t.is(props.options[0].label, 'my message');
|
|
1620
|
+
});
|
|
1621
|
+
|
|
1622
|
+
test('mapStateToEnumControlProps - i18n - i18n key translation', t => {
|
|
1623
|
+
const ownProps = {
|
|
1624
|
+
uischema: coreUISchema
|
|
1625
|
+
};
|
|
1626
|
+
const state: JsonFormsState = createState(coreUISchema);
|
|
1627
|
+
state.jsonforms.core.schema.properties.firstName.enum = ['a', 'b'];
|
|
1628
|
+
(state.jsonforms.core.schema.properties.firstName as i18nJsonSchema).i18n = 'my-key';
|
|
1629
|
+
state.jsonforms.i18n = defaultJsonFormsI18nState;
|
|
1630
|
+
state.jsonforms.i18n.translate = (key: string, defaultMessage: string | undefined) => {
|
|
1631
|
+
switch(key){
|
|
1632
|
+
case 'my-key.a': return 'my message';
|
|
1633
|
+
default: return defaultMessage;
|
|
1634
|
+
}
|
|
1635
|
+
}
|
|
1636
|
+
|
|
1637
|
+
const props = mapStateToEnumControlProps(state, ownProps);
|
|
1638
|
+
t.is(props.options[0].label, 'my message');
|
|
1639
|
+
});
|
|
1640
|
+
|
|
1641
|
+
test('mapStateToOneOfEnumControlProps - i18n - should not crash without i18n', t => {
|
|
1642
|
+
const ownProps = {
|
|
1643
|
+
uischema: coreUISchema
|
|
1644
|
+
};
|
|
1645
|
+
const state: JsonFormsState = createState(coreUISchema);
|
|
1646
|
+
state.jsonforms.core.schema.properties.firstName.oneOf = [{const: 'a', title: 'foo'}, {const: 'b', title: 'bar'}]
|
|
1647
|
+
state.jsonforms.i18n = undefined;
|
|
1648
|
+
|
|
1649
|
+
const props = mapStateToOneOfEnumControlProps(state, ownProps);
|
|
1650
|
+
t.is(props.options[0].label, 'foo');
|
|
1651
|
+
});
|
|
1652
|
+
|
|
1653
|
+
test('mapStateToOneOfEnumControlProps- i18n - default translation has no effect', t => {
|
|
1654
|
+
const ownProps = {
|
|
1655
|
+
uischema: coreUISchema
|
|
1656
|
+
};
|
|
1657
|
+
const state: JsonFormsState = createState(coreUISchema);
|
|
1658
|
+
state.jsonforms.core.schema.properties.firstName.oneOf = [{const: 'a', title: 'foo'}, {const: 'b', title: 'bar'}]
|
|
1659
|
+
state.jsonforms.i18n = defaultJsonFormsI18nState;
|
|
1660
|
+
|
|
1661
|
+
const props = mapStateToOneOfEnumControlProps(state, ownProps);
|
|
1662
|
+
t.is(props.options[0].label, 'foo');
|
|
1663
|
+
});
|
|
1664
|
+
|
|
1665
|
+
test('mapStateToOneOfEnumControlProps - i18n - label translation', t => {
|
|
1666
|
+
const ownProps = {
|
|
1667
|
+
uischema: coreUISchema
|
|
1668
|
+
};
|
|
1669
|
+
const state: JsonFormsState = createState(coreUISchema);
|
|
1670
|
+
state.jsonforms.core.schema.properties.firstName.oneOf = [{const: 'a', title: 'foo'}, {const: 'b', title: 'bar'}]
|
|
1671
|
+
state.jsonforms.i18n = defaultJsonFormsI18nState;
|
|
1672
|
+
state.jsonforms.i18n.translate = (key: string, defaultMessage: string | undefined) => {
|
|
1673
|
+
switch(key){
|
|
1674
|
+
case 'foo': return 'my message';
|
|
1675
|
+
default: return defaultMessage;
|
|
1676
|
+
}
|
|
1677
|
+
}
|
|
1678
|
+
|
|
1679
|
+
const props = mapStateToOneOfEnumControlProps(state, ownProps);
|
|
1680
|
+
t.is(props.options[0].label, 'my message');
|
|
1681
|
+
});
|
|
1682
|
+
|
|
1683
|
+
test('mapStateToOneOfEnumControlProps - i18n - i18n key translation', t => {
|
|
1684
|
+
const ownProps = {
|
|
1685
|
+
uischema: coreUISchema
|
|
1686
|
+
};
|
|
1687
|
+
const state: JsonFormsState = createState(coreUISchema);
|
|
1688
|
+
(state.jsonforms.core.schema.properties.firstName.oneOf as any) =
|
|
1689
|
+
[{const: 'a', title: 'foo', i18n: 'my-foo'}, {const: 'b', title: 'bar', i18n:'my-bar'}];
|
|
1690
|
+
state.jsonforms.i18n = defaultJsonFormsI18nState;
|
|
1691
|
+
state.jsonforms.i18n.translate = (key: string, defaultMessage: string | undefined) => {
|
|
1692
|
+
switch(key){
|
|
1693
|
+
case 'my-foo': return 'my message';
|
|
1694
|
+
default: return defaultMessage;
|
|
1695
|
+
}
|
|
1696
|
+
}
|
|
1697
|
+
|
|
1698
|
+
const props = mapStateToOneOfEnumControlProps(state, ownProps);
|
|
1699
|
+
t.is(props.options[0].label, 'my message');
|
|
1700
|
+
});
|