@cratis/components 0.1.19 → 1.0.3
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/dist/cjs/CommandDialog/CommandDialog.js +14 -25
- package/dist/cjs/CommandDialog/CommandDialog.js.map +1 -1
- package/dist/cjs/CommandForm/fields/CheckboxField.js +2 -2
- package/dist/cjs/CommandForm/fields/CheckboxField.js.map +1 -1
- package/dist/cjs/CommandForm/fields/DropdownField.js +5 -5
- package/dist/cjs/CommandForm/fields/DropdownField.js.map +1 -1
- package/dist/cjs/CommandForm/fields/InputTextField.js +2 -2
- package/dist/cjs/CommandForm/fields/InputTextField.js.map +1 -1
- package/dist/cjs/CommandForm/fields/NumberField.js +2 -2
- package/dist/cjs/CommandForm/fields/NumberField.js.map +1 -1
- package/dist/cjs/CommandForm/fields/SliderField.js +5 -9
- package/dist/cjs/CommandForm/fields/SliderField.js.map +1 -1
- package/dist/cjs/CommandForm/fields/TextAreaField.js +2 -2
- package/dist/cjs/CommandForm/fields/TextAreaField.js.map +1 -1
- package/dist/cjs/CommandForm/index.js +35 -15
- package/dist/cjs/CommandForm/index.js.map +1 -1
- package/dist/cjs/DataTables/DataTableForObservableQuery.js +53 -1
- package/dist/cjs/DataTables/DataTableForObservableQuery.js.map +1 -1
- package/dist/cjs/DataTables/DataTableForQuery.js +19 -1
- package/dist/cjs/DataTables/DataTableForQuery.js.map +1 -1
- package/dist/cjs/Dialogs/BusyIndicatorDialog.js +2 -3
- package/dist/cjs/Dialogs/BusyIndicatorDialog.js.map +1 -1
- package/dist/cjs/Dialogs/ConfirmationDialog.js +4 -21
- package/dist/cjs/Dialogs/ConfirmationDialog.js.map +1 -1
- package/dist/cjs/Dialogs/Dialog.js +66 -0
- package/dist/cjs/Dialogs/Dialog.js.map +1 -0
- package/dist/cjs/Dialogs/index.js +4 -2
- package/dist/cjs/Dialogs/index.js.map +1 -1
- package/dist/cjs/ObjectContentEditor/ObjectContentEditor.js +156 -0
- package/dist/cjs/ObjectContentEditor/ObjectContentEditor.js.map +1 -0
- package/dist/cjs/ObjectContentEditor/index.js +8 -0
- package/dist/cjs/{EventModeling → ObjectContentEditor}/index.js.map +1 -1
- package/dist/cjs/ObjectNavigationalBar/ObjectNavigationalBar.js +45 -0
- package/dist/cjs/ObjectNavigationalBar/ObjectNavigationalBar.js.map +1 -0
- package/dist/cjs/ObjectNavigationalBar/index.js +8 -0
- package/dist/cjs/ObjectNavigationalBar/index.js.map +1 -0
- package/dist/cjs/SchemaEditor/NameCell.js +38 -0
- package/dist/cjs/SchemaEditor/NameCell.js.map +1 -0
- package/dist/cjs/SchemaEditor/SchemaEditor.js +352 -0
- package/dist/cjs/SchemaEditor/SchemaEditor.js.map +1 -0
- package/dist/cjs/SchemaEditor/SchemaEditor.module.css +11 -0
- package/dist/cjs/SchemaEditor/TypeCell.js +102 -0
- package/dist/cjs/SchemaEditor/TypeCell.js.map +1 -0
- package/dist/cjs/SchemaEditor/index.js +10 -0
- package/dist/cjs/SchemaEditor/index.js.map +1 -0
- package/dist/cjs/index.js +10 -6
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/types/TypeFormat.js +20 -0
- package/dist/cjs/types/TypeFormat.js.map +1 -0
- package/dist/esm/CommandDialog/CommandDialog.d.ts +1 -1
- package/dist/esm/CommandDialog/CommandDialog.d.ts.map +1 -1
- package/dist/esm/CommandDialog/CommandDialog.js +15 -26
- package/dist/esm/CommandDialog/CommandDialog.js.map +1 -1
- package/dist/esm/CommandDialog/CommandDialog.stories.d.ts +1 -0
- package/dist/esm/CommandDialog/CommandDialog.stories.d.ts.map +1 -1
- package/dist/esm/CommandDialog/CommandDialog.stories.js +57 -3
- package/dist/esm/CommandDialog/CommandDialog.stories.js.map +1 -1
- package/dist/esm/CommandForm/fields/CheckboxField.d.ts +3 -2
- package/dist/esm/CommandForm/fields/CheckboxField.d.ts.map +1 -1
- package/dist/esm/CommandForm/fields/CheckboxField.js +1 -1
- package/dist/esm/CommandForm/fields/CheckboxField.js.map +1 -1
- package/dist/esm/CommandForm/fields/DropdownField.d.ts +7 -6
- package/dist/esm/CommandForm/fields/DropdownField.d.ts.map +1 -1
- package/dist/esm/CommandForm/fields/DropdownField.js +6 -6
- package/dist/esm/CommandForm/fields/DropdownField.js.map +1 -1
- package/dist/esm/CommandForm/fields/Fields.stories.d.ts +13 -0
- package/dist/esm/CommandForm/fields/Fields.stories.d.ts.map +1 -0
- package/dist/esm/CommandForm/fields/Fields.stories.js +137 -0
- package/dist/esm/CommandForm/fields/Fields.stories.js.map +1 -0
- package/dist/esm/CommandForm/fields/InputTextField.d.ts +3 -2
- package/dist/esm/CommandForm/fields/InputTextField.d.ts.map +1 -1
- package/dist/esm/CommandForm/fields/InputTextField.js +1 -1
- package/dist/esm/CommandForm/fields/InputTextField.js.map +1 -1
- package/dist/esm/CommandForm/fields/NumberField.d.ts +3 -2
- package/dist/esm/CommandForm/fields/NumberField.d.ts.map +1 -1
- package/dist/esm/CommandForm/fields/NumberField.js +1 -1
- package/dist/esm/CommandForm/fields/NumberField.js.map +1 -1
- package/dist/esm/CommandForm/fields/SliderField.d.ts +5 -4
- package/dist/esm/CommandForm/fields/SliderField.d.ts.map +1 -1
- package/dist/esm/CommandForm/fields/SliderField.js +5 -9
- package/dist/esm/CommandForm/fields/SliderField.js.map +1 -1
- package/dist/esm/CommandForm/fields/TextAreaField.d.ts +3 -2
- package/dist/esm/CommandForm/fields/TextAreaField.d.ts.map +1 -1
- package/dist/esm/CommandForm/fields/TextAreaField.js +1 -1
- package/dist/esm/CommandForm/fields/TextAreaField.js.map +1 -1
- package/dist/esm/CommandForm/fields/index.d.ts +2 -2
- package/dist/esm/CommandForm/fields/index.d.ts.map +1 -1
- package/dist/esm/CommandForm/fields/index.js +2 -2
- package/dist/esm/CommandForm/fields/index.js.map +1 -1
- package/dist/esm/CommandForm/index.d.ts +1 -5
- package/dist/esm/CommandForm/index.d.ts.map +1 -1
- package/dist/esm/CommandForm/index.js +3 -7
- package/dist/esm/CommandForm/index.js.map +1 -1
- package/dist/esm/Common/ErrorBoundary.d.ts +1 -1
- package/dist/esm/Common/ErrorBoundary.stories.d.ts +7 -7
- package/dist/esm/Common/ErrorBoundary.stories.d.ts.map +1 -1
- package/dist/esm/Common/ErrorBoundary.stories.js +21 -5
- package/dist/esm/Common/ErrorBoundary.stories.js.map +1 -1
- package/dist/esm/Common/FormElement.stories.d.ts +8 -7
- package/dist/esm/Common/FormElement.stories.d.ts.map +1 -1
- package/dist/esm/Common/FormElement.stories.js +25 -4
- package/dist/esm/Common/FormElement.stories.js.map +1 -1
- package/dist/esm/Common/Page.stories.d.ts +7 -7
- package/dist/esm/Common/Page.stories.d.ts.map +1 -1
- package/dist/esm/Common/Page.stories.js +20 -5
- package/dist/esm/Common/Page.stories.js.map +1 -1
- package/dist/esm/DataPage/DataPage.stories.d.ts +7 -7
- package/dist/esm/DataPage/DataPage.stories.d.ts.map +1 -1
- package/dist/esm/DataPage/DataPage.stories.js +33 -5
- package/dist/esm/DataPage/DataPage.stories.js.map +1 -1
- package/dist/esm/DataTables/DataTableForObservableQuery.d.ts +1 -0
- package/dist/esm/DataTables/DataTableForObservableQuery.d.ts.map +1 -1
- package/dist/esm/DataTables/DataTableForObservableQuery.js +55 -3
- package/dist/esm/DataTables/DataTableForObservableQuery.js.map +1 -1
- package/dist/esm/DataTables/DataTableForObservableQuery.stories.d.ts +7 -7
- package/dist/esm/DataTables/DataTableForObservableQuery.stories.d.ts.map +1 -1
- package/dist/esm/DataTables/DataTableForObservableQuery.stories.js +55 -5
- package/dist/esm/DataTables/DataTableForObservableQuery.stories.js.map +1 -1
- package/dist/esm/DataTables/DataTableForQuery.d.ts +1 -0
- package/dist/esm/DataTables/DataTableForQuery.d.ts.map +1 -1
- package/dist/esm/DataTables/DataTableForQuery.js +21 -3
- package/dist/esm/DataTables/DataTableForQuery.js.map +1 -1
- package/dist/esm/DataTables/DataTableForQuery.stories.d.ts +7 -7
- package/dist/esm/DataTables/DataTableForQuery.stories.d.ts.map +1 -1
- package/dist/esm/DataTables/DataTableForQuery.stories.js +31 -5
- package/dist/esm/DataTables/DataTableForQuery.stories.js.map +1 -1
- package/dist/esm/Dialogs/BusyIndicatorDialog.d.ts.map +1 -1
- package/dist/esm/Dialogs/BusyIndicatorDialog.js +3 -4
- package/dist/esm/Dialogs/BusyIndicatorDialog.js.map +1 -1
- package/dist/esm/Dialogs/ConfirmationDialog.d.ts.map +1 -1
- package/dist/esm/Dialogs/ConfirmationDialog.js +6 -23
- package/dist/esm/Dialogs/ConfirmationDialog.js.map +1 -1
- package/dist/esm/Dialogs/Dialog.d.ts +23 -0
- package/dist/esm/Dialogs/Dialog.d.ts.map +1 -0
- package/dist/esm/Dialogs/Dialog.js +64 -0
- package/dist/esm/Dialogs/Dialog.js.map +1 -0
- package/dist/esm/Dialogs/index.d.ts +2 -1
- package/dist/esm/Dialogs/index.d.ts.map +1 -1
- package/dist/esm/Dialogs/index.js +2 -1
- package/dist/esm/Dialogs/index.js.map +1 -1
- package/dist/esm/ObjectContentEditor/ObjectContentEditor.d.ts +8 -0
- package/dist/esm/ObjectContentEditor/ObjectContentEditor.d.ts.map +1 -0
- package/dist/esm/ObjectContentEditor/ObjectContentEditor.js +135 -0
- package/dist/esm/ObjectContentEditor/ObjectContentEditor.js.map +1 -0
- package/dist/esm/ObjectContentEditor/ObjectContentEditor.stories.d.ts +10 -0
- package/dist/esm/ObjectContentEditor/ObjectContentEditor.stories.d.ts.map +1 -0
- package/dist/esm/ObjectContentEditor/ObjectContentEditor.stories.js +144 -0
- package/dist/esm/ObjectContentEditor/ObjectContentEditor.stories.js.map +1 -0
- package/dist/esm/ObjectContentEditor/index.d.ts +2 -0
- package/dist/esm/ObjectContentEditor/index.d.ts.map +1 -0
- package/dist/esm/ObjectContentEditor/index.js +2 -0
- package/dist/esm/ObjectContentEditor/index.js.map +1 -0
- package/dist/esm/ObjectNavigationalBar/ObjectNavigationalBar.d.ts +6 -0
- package/dist/esm/ObjectNavigationalBar/ObjectNavigationalBar.d.ts.map +1 -0
- package/dist/esm/ObjectNavigationalBar/ObjectNavigationalBar.js +24 -0
- package/dist/esm/ObjectNavigationalBar/ObjectNavigationalBar.js.map +1 -0
- package/dist/esm/ObjectNavigationalBar/ObjectNavigationalBar.stories.d.ts +10 -0
- package/dist/esm/ObjectNavigationalBar/ObjectNavigationalBar.stories.d.ts.map +1 -0
- package/dist/esm/ObjectNavigationalBar/ObjectNavigationalBar.stories.js +46 -0
- package/dist/esm/ObjectNavigationalBar/ObjectNavigationalBar.stories.js.map +1 -0
- package/dist/esm/ObjectNavigationalBar/index.d.ts +2 -0
- package/dist/esm/ObjectNavigationalBar/index.d.ts.map +1 -0
- package/dist/esm/ObjectNavigationalBar/index.js +2 -0
- package/dist/esm/ObjectNavigationalBar/index.js.map +1 -0
- package/dist/esm/SchemaEditor/NameCell.d.ts +9 -0
- package/dist/esm/SchemaEditor/NameCell.d.ts.map +1 -0
- package/dist/esm/SchemaEditor/NameCell.js +17 -0
- package/dist/esm/SchemaEditor/NameCell.js.map +1 -0
- package/dist/esm/SchemaEditor/SchemaEditor.d.ts +17 -0
- package/dist/esm/SchemaEditor/SchemaEditor.d.ts.map +1 -0
- package/dist/esm/SchemaEditor/SchemaEditor.js +331 -0
- package/dist/esm/SchemaEditor/SchemaEditor.js.map +1 -0
- package/dist/esm/SchemaEditor/SchemaEditor.module.css +11 -0
- package/dist/esm/SchemaEditor/SchemaEditor.stories.d.ts +12 -0
- package/dist/esm/SchemaEditor/SchemaEditor.stories.d.ts.map +1 -0
- package/dist/esm/SchemaEditor/SchemaEditor.stories.js +158 -0
- package/dist/esm/SchemaEditor/SchemaEditor.stories.js.map +1 -0
- package/dist/esm/SchemaEditor/TypeCell.d.ts +14 -0
- package/dist/esm/SchemaEditor/TypeCell.d.ts.map +1 -0
- package/dist/esm/SchemaEditor/TypeCell.js +81 -0
- package/dist/esm/SchemaEditor/TypeCell.js.map +1 -0
- package/dist/esm/SchemaEditor/index.d.ts +4 -0
- package/dist/esm/SchemaEditor/index.d.ts.map +1 -0
- package/dist/esm/SchemaEditor/index.js +3 -0
- package/dist/esm/TimeMachine/EventsView.stories.d.ts +8 -7
- package/dist/esm/TimeMachine/EventsView.stories.d.ts.map +1 -1
- package/dist/esm/TimeMachine/EventsView.stories.js +80 -4
- package/dist/esm/TimeMachine/EventsView.stories.js.map +1 -1
- package/dist/esm/TimeMachine/Properties.stories.d.ts +9 -7
- package/dist/esm/TimeMachine/Properties.stories.d.ts.map +1 -1
- package/dist/esm/TimeMachine/Properties.stories.js +49 -4
- package/dist/esm/TimeMachine/Properties.stories.js.map +1 -1
- package/dist/esm/TimeMachine/ReadModelView.stories.d.ts +7 -7
- package/dist/esm/TimeMachine/ReadModelView.stories.d.ts.map +1 -1
- package/dist/esm/TimeMachine/ReadModelView.stories.js +79 -5
- package/dist/esm/TimeMachine/ReadModelView.stories.js.map +1 -1
- package/dist/esm/TimeMachine/TimeMachine.stories.d.ts +8 -7
- package/dist/esm/TimeMachine/TimeMachine.stories.d.ts.map +1 -1
- package/dist/esm/TimeMachine/TimeMachine.stories.js +113 -4
- package/dist/esm/TimeMachine/TimeMachine.stories.js.map +1 -1
- package/dist/esm/index.d.ts +4 -2
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +10 -6
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/tsconfig.tsbuildinfo +1 -1
- package/dist/esm/types/JsonSchema.d.ts +32 -0
- package/dist/esm/types/JsonSchema.d.ts.map +1 -0
- package/dist/esm/types/JsonSchema.js +2 -0
- package/dist/esm/types/JsonSchema.js.map +1 -0
- package/dist/esm/types/TypeFormat.d.ts +6 -0
- package/dist/esm/types/TypeFormat.d.ts.map +1 -0
- package/dist/esm/types/TypeFormat.js +18 -0
- package/dist/esm/types/TypeFormat.js.map +1 -0
- package/package.json +10 -5
- package/dist/cjs/CommandForm/CommandForm.js +0 -183
- package/dist/cjs/CommandForm/CommandForm.js.map +0 -1
- package/dist/cjs/CommandForm/CommandFormField.js +0 -11
- package/dist/cjs/CommandForm/CommandFormField.js.map +0 -1
- package/dist/cjs/CommandForm/CommandFormFields.js +0 -73
- package/dist/cjs/CommandForm/CommandFormFields.js.map +0 -1
- package/dist/cjs/CommandForm/ValidationMessage.js +0 -24
- package/dist/cjs/CommandForm/ValidationMessage.js.map +0 -1
- package/dist/cjs/CommandForm/asCommandFormField.js +0 -47
- package/dist/cjs/CommandForm/asCommandFormField.js.map +0 -1
- package/dist/cjs/EventModeling/EventModeling.css +0 -146
- package/dist/cjs/EventModeling/EventModeling.js +0 -209
- package/dist/cjs/EventModeling/EventModeling.js.map +0 -1
- package/dist/cjs/EventModeling/components/Canvas.js +0 -403
- package/dist/cjs/EventModeling/components/Canvas.js.map +0 -1
- package/dist/cjs/EventModeling/components/CanvasControls.js +0 -10
- package/dist/cjs/EventModeling/components/CanvasControls.js.map +0 -1
- package/dist/cjs/EventModeling/components/Toolbox.js +0 -18
- package/dist/cjs/EventModeling/components/Toolbox.js.map +0 -1
- package/dist/cjs/EventModeling/engine/connectorGraphics.js +0 -173
- package/dist/cjs/EventModeling/engine/connectorGraphics.js.map +0 -1
- package/dist/cjs/EventModeling/engine/elementSprites.js +0 -301
- package/dist/cjs/EventModeling/engine/elementSprites.js.map +0 -1
- package/dist/cjs/EventModeling/index.js +0 -12
- package/dist/cjs/EventModeling/types.js +0 -60
- package/dist/cjs/EventModeling/types.js.map +0 -1
- package/dist/esm/CommandForm/CommandForm.d.ts +0 -49
- package/dist/esm/CommandForm/CommandForm.d.ts.map +0 -1
- package/dist/esm/CommandForm/CommandForm.js +0 -178
- package/dist/esm/CommandForm/CommandForm.js.map +0 -1
- package/dist/esm/CommandForm/CommandForm.stories.d.ts +0 -8
- package/dist/esm/CommandForm/CommandForm.stories.d.ts.map +0 -1
- package/dist/esm/CommandForm/CommandForm.stories.js +0 -45
- package/dist/esm/CommandForm/CommandForm.stories.js.map +0 -1
- package/dist/esm/CommandForm/CommandFormField.d.ts +0 -18
- package/dist/esm/CommandForm/CommandFormField.d.ts.map +0 -1
- package/dist/esm/CommandForm/CommandFormField.js +0 -9
- package/dist/esm/CommandForm/CommandFormField.js.map +0 -1
- package/dist/esm/CommandForm/CommandFormFields.d.ts +0 -11
- package/dist/esm/CommandForm/CommandFormFields.d.ts.map +0 -1
- package/dist/esm/CommandForm/CommandFormFields.js +0 -71
- package/dist/esm/CommandForm/CommandFormFields.js.map +0 -1
- package/dist/esm/CommandForm/UserRegistrationCommand.d.ts +0 -63
- package/dist/esm/CommandForm/UserRegistrationCommand.d.ts.map +0 -1
- package/dist/esm/CommandForm/UserRegistrationCommand.js +0 -143
- package/dist/esm/CommandForm/UserRegistrationCommand.js.map +0 -1
- package/dist/esm/CommandForm/ValidationMessage.d.ts +0 -8
- package/dist/esm/CommandForm/ValidationMessage.d.ts.map +0 -1
- package/dist/esm/CommandForm/ValidationMessage.js +0 -22
- package/dist/esm/CommandForm/ValidationMessage.js.map +0 -1
- package/dist/esm/CommandForm/asCommandFormField.d.ts +0 -32
- package/dist/esm/CommandForm/asCommandFormField.d.ts.map +0 -1
- package/dist/esm/CommandForm/asCommandFormField.js +0 -45
- package/dist/esm/CommandForm/asCommandFormField.js.map +0 -1
- package/dist/esm/EventModeling/EventModeling.css +0 -146
- package/dist/esm/EventModeling/EventModeling.d.ts +0 -11
- package/dist/esm/EventModeling/EventModeling.d.ts.map +0 -1
- package/dist/esm/EventModeling/EventModeling.js +0 -207
- package/dist/esm/EventModeling/EventModeling.js.map +0 -1
- package/dist/esm/EventModeling/EventModeling.stories.d.ts +0 -10
- package/dist/esm/EventModeling/EventModeling.stories.d.ts.map +0 -1
- package/dist/esm/EventModeling/EventModeling.stories.js +0 -252
- package/dist/esm/EventModeling/EventModeling.stories.js.map +0 -1
- package/dist/esm/EventModeling/components/Canvas.d.ts +0 -23
- package/dist/esm/EventModeling/components/Canvas.d.ts.map +0 -1
- package/dist/esm/EventModeling/components/Canvas.js +0 -382
- package/dist/esm/EventModeling/components/Canvas.js.map +0 -1
- package/dist/esm/EventModeling/components/CanvasControls.d.ts +0 -10
- package/dist/esm/EventModeling/components/CanvasControls.d.ts.map +0 -1
- package/dist/esm/EventModeling/components/CanvasControls.js +0 -8
- package/dist/esm/EventModeling/components/CanvasControls.js.map +0 -1
- package/dist/esm/EventModeling/components/Toolbox.d.ts +0 -9
- package/dist/esm/EventModeling/components/Toolbox.d.ts.map +0 -1
- package/dist/esm/EventModeling/components/Toolbox.js +0 -16
- package/dist/esm/EventModeling/components/Toolbox.js.map +0 -1
- package/dist/esm/EventModeling/engine/connectorGraphics.d.ts +0 -12
- package/dist/esm/EventModeling/engine/connectorGraphics.d.ts.map +0 -1
- package/dist/esm/EventModeling/engine/connectorGraphics.js +0 -151
- package/dist/esm/EventModeling/engine/connectorGraphics.js.map +0 -1
- package/dist/esm/EventModeling/engine/elementSprites.d.ts +0 -23
- package/dist/esm/EventModeling/engine/elementSprites.d.ts.map +0 -1
- package/dist/esm/EventModeling/engine/elementSprites.js +0 -276
- package/dist/esm/EventModeling/engine/elementSprites.js.map +0 -1
- package/dist/esm/EventModeling/index.d.ts +0 -3
- package/dist/esm/EventModeling/index.d.ts.map +0 -1
- package/dist/esm/EventModeling/index.js +0 -3
- package/dist/esm/EventModeling/types.d.ts +0 -79
- package/dist/esm/EventModeling/types.d.ts.map +0 -1
- package/dist/esm/EventModeling/types.js +0 -56
- package/dist/esm/EventModeling/types.js.map +0 -1
- /package/dist/esm/{EventModeling → SchemaEditor}/index.js.map +0 -0
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import { jsxs, Fragment, jsx } from 'react/jsx-runtime';
|
|
2
|
+
import { Button } from 'primereact/button';
|
|
3
|
+
import { Dropdown } from 'primereact/dropdown';
|
|
4
|
+
import * as faIcons from 'react-icons/fa6';
|
|
5
|
+
|
|
6
|
+
const CONTAINER_TYPES = [
|
|
7
|
+
{ label: 'array', value: 'array' },
|
|
8
|
+
{ label: 'object', value: 'object' }
|
|
9
|
+
];
|
|
10
|
+
const TypeCell = ({ rowData, isEditMode, typeFormats, onUpdateProperty, onUpdateArrayItemType, onNavigateToProperty, onNavigateToArrayItems, onRemoveProperty }) => {
|
|
11
|
+
const DEFAULT_TYPE_OPTIONS = [
|
|
12
|
+
{ label: 'string', value: 'string' },
|
|
13
|
+
{ label: 'integer', value: 'integer' },
|
|
14
|
+
{ label: 'number', value: 'number' },
|
|
15
|
+
{ label: 'boolean', value: 'boolean' }
|
|
16
|
+
];
|
|
17
|
+
const formatOptions = typeFormats.length > 0
|
|
18
|
+
? typeFormats.map(tf => {
|
|
19
|
+
const format = (!tf.format || tf.format === '' ? tf.jsonType : tf.format);
|
|
20
|
+
return { label: format, value: format };
|
|
21
|
+
})
|
|
22
|
+
: DEFAULT_TYPE_OPTIONS;
|
|
23
|
+
const allTypeOptions = [
|
|
24
|
+
...formatOptions,
|
|
25
|
+
...CONTAINER_TYPES
|
|
26
|
+
];
|
|
27
|
+
const displayValue = rowData.format || rowData.type || 'string';
|
|
28
|
+
const currentValue = rowData.format || rowData.type || 'string';
|
|
29
|
+
const handleTypeChange = (value, propertyName, isArrayItem = false) => {
|
|
30
|
+
if (value === 'array' || value === 'object') {
|
|
31
|
+
if (isArrayItem) {
|
|
32
|
+
onUpdateArrayItemType(propertyName, value);
|
|
33
|
+
}
|
|
34
|
+
else {
|
|
35
|
+
onUpdateProperty(propertyName, 'type', value, { format: undefined });
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
const typeFormat = typeFormats.find(tf => {
|
|
40
|
+
const effectiveFormat = (!tf.format || tf.format === '' ? tf.jsonType : tf.format);
|
|
41
|
+
return effectiveFormat === value;
|
|
42
|
+
});
|
|
43
|
+
if (typeFormat) {
|
|
44
|
+
if (isArrayItem) {
|
|
45
|
+
onUpdateArrayItemType(propertyName, typeFormat.jsonType);
|
|
46
|
+
}
|
|
47
|
+
else {
|
|
48
|
+
if (typeFormat.format && typeFormat.format !== '') {
|
|
49
|
+
onUpdateProperty(propertyName, 'type', typeFormat.jsonType, { format: value });
|
|
50
|
+
}
|
|
51
|
+
else {
|
|
52
|
+
onUpdateProperty(propertyName, 'type', typeFormat.jsonType, { format: undefined });
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
if (isArrayItem) {
|
|
58
|
+
onUpdateArrayItemType(propertyName, value);
|
|
59
|
+
}
|
|
60
|
+
else {
|
|
61
|
+
onUpdateProperty(propertyName, 'type', value, { format: undefined });
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
};
|
|
66
|
+
if (!isEditMode) {
|
|
67
|
+
if (rowData.type === 'array') {
|
|
68
|
+
const itemType = rowData.items?.type || 'string';
|
|
69
|
+
const isNavigable = itemType === 'object';
|
|
70
|
+
return (jsxs("div", { className: "flex align-items-center gap-2 w-full", style: { height: '100%' }, "data-pr-tooltip": isNavigable ? 'Click to navigate to item definition' : undefined, "data-pr-position": "top", children: [jsxs("span", { children: ["Array of ", itemType] }), isNavigable && (jsxs(Fragment, { children: [jsx("div", { style: { flex: 1 } }), jsx("span", { style: { display: 'flex', alignItems: 'center' }, children: jsx(faIcons.FaArrowRight, { style: { fontSize: '1rem', color: 'var(--primary-color)' } }) })] }))] }));
|
|
71
|
+
}
|
|
72
|
+
else if (rowData.type === 'object') {
|
|
73
|
+
return (jsxs("div", { className: "flex align-items-center gap-2 w-full", style: { height: '100%' }, "data-pr-tooltip": "Click to navigate to object properties", "data-pr-position": "top", children: [jsx("span", { children: "Object" }), jsx("div", { style: { flex: 1 } }), jsx("span", { style: { display: 'flex', alignItems: 'center' }, children: jsx(faIcons.FaArrowRight, { style: { fontSize: '1rem', color: 'var(--primary-color)' } }) })] }));
|
|
74
|
+
}
|
|
75
|
+
return displayValue;
|
|
76
|
+
}
|
|
77
|
+
return (jsxs("div", { className: "flex align-items-center gap-2 w-full", style: { minHeight: '2.5rem' }, children: [jsx(Dropdown, { value: currentValue, options: allTypeOptions, onChange: (e) => handleTypeChange(e.value, rowData.name || ''), className: "flex-1" }), rowData.type === 'array' && rowData.items && (jsxs(Fragment, { children: [jsx("span", { style: { whiteSpace: 'nowrap', display: 'flex', alignItems: 'center' }, children: "of" }), jsx(Dropdown, { value: rowData.items.type || 'string', options: allTypeOptions, onChange: (e) => handleTypeChange(e.value, rowData.name || '', true), className: "flex-1" })] })), jsxs("div", { style: { marginLeft: 'auto', display: 'flex', alignItems: 'center', gap: '0.5rem' }, children: [rowData.type === 'array' && rowData.items?.type === 'object' && rowData.name && (jsx(Button, { icon: jsx(faIcons.FaArrowRight, {}), className: "p-button-text p-button-sm", onClick: () => onNavigateToArrayItems(rowData.name), tooltip: "Navigate to item definition", tooltipOptions: { position: 'top' } })), rowData.type === 'object' && rowData.name && (jsx(Button, { icon: jsx(faIcons.FaArrowRight, {}), className: "p-button-text p-button-sm", onClick: () => onNavigateToProperty(rowData.name), tooltip: "Navigate to object properties", tooltipOptions: { position: 'top' } })), rowData.name && (jsx(Button, { icon: jsx(faIcons.FaTrash, {}), className: "p-button-text p-button-danger p-button-sm", onClick: () => onRemoveProperty(rowData.name), tooltip: "Delete property", tooltipOptions: { position: 'top' } }))] })] }));
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
export { TypeCell };
|
|
81
|
+
//# sourceMappingURL=TypeCell.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"TypeCell.js","sources":["../../../SchemaEditor/TypeCell.tsx"],"sourcesContent":["// Copyright (c) Cratis. All rights reserved.\n// Licensed under the MIT license. See LICENSE file in the project root for full license information.\n\nimport { Button } from 'primereact/button';\nimport { Dropdown } from 'primereact/dropdown';\nimport * as faIcons from 'react-icons/fa6';\nimport { TypeFormat } from '../types/TypeFormat';\nimport { JsonSchemaProperty } from '../types/JsonSchema';\n\nexport interface TypeCellProps {\n rowData: JsonSchemaProperty;\n isEditMode: boolean;\n typeFormats: TypeFormat[];\n onUpdateProperty: (oldName: string, field: keyof JsonSchemaProperty, value: unknown, additionalUpdates?: Partial<JsonSchemaProperty>) => void;\n onUpdateArrayItemType: (propertyName: string, itemType: string) => void;\n onNavigateToProperty: (propertyName: string) => void;\n onNavigateToArrayItems: (propertyName: string) => void;\n onRemoveProperty: (propertyName: string) => void;\n}\n\nconst CONTAINER_TYPES = [\n { label: 'array', value: 'array' },\n { label: 'object', value: 'object' }\n];\n\nexport const TypeCell = ({\n rowData,\n isEditMode,\n typeFormats,\n onUpdateProperty,\n onUpdateArrayItemType,\n onNavigateToProperty,\n onNavigateToArrayItems,\n onRemoveProperty\n}: TypeCellProps) => {\n const DEFAULT_TYPE_OPTIONS = [\n { label: 'string', value: 'string' },\n { label: 'integer', value: 'integer' },\n { label: 'number', value: 'number' },\n { label: 'boolean', value: 'boolean' }\n ];\n\n const formatOptions = typeFormats.length > 0\n ? typeFormats.map(tf => {\n const format = (!tf.format || tf.format === '' ? tf.jsonType : tf.format);\n return { label: format, value: format };\n })\n : DEFAULT_TYPE_OPTIONS;\n\n const allTypeOptions = [\n ...formatOptions,\n ...CONTAINER_TYPES\n ];\n\n const displayValue = rowData.format || rowData.type || 'string';\n const currentValue = rowData.format || rowData.type || 'string';\n\n const handleTypeChange = (value: string, propertyName: string, isArrayItem: boolean = false) => {\n if (value === 'array' || value === 'object') {\n if (isArrayItem) {\n onUpdateArrayItemType(propertyName, value);\n } else {\n onUpdateProperty(propertyName, 'type', value, { format: undefined });\n }\n } else {\n const typeFormat = typeFormats.find(tf => {\n const effectiveFormat = (!tf.format || tf.format === '' ? tf.jsonType : tf.format);\n return effectiveFormat === value;\n });\n\n if (typeFormat) {\n if (isArrayItem) {\n onUpdateArrayItemType(propertyName, typeFormat.jsonType);\n } else {\n if (typeFormat.format && typeFormat.format !== '') {\n onUpdateProperty(propertyName, 'type', typeFormat.jsonType, { format: value });\n } else {\n onUpdateProperty(propertyName, 'type', typeFormat.jsonType, { format: undefined });\n }\n }\n } else {\n if (isArrayItem) {\n onUpdateArrayItemType(propertyName, value);\n } else {\n onUpdateProperty(propertyName, 'type', value, { format: undefined });\n }\n }\n }\n };\n\n if (!isEditMode) {\n if (rowData.type === 'array') {\n const itemType = rowData.items?.type || 'string';\n const isNavigable = itemType === 'object';\n return (\n <div\n className=\"flex align-items-center gap-2 w-full\"\n style={{ height: '100%' }}\n data-pr-tooltip={isNavigable ? 'Click to navigate to item definition' : undefined}\n data-pr-position=\"top\"\n >\n <span>Array of {itemType}</span>\n {isNavigable && (\n <>\n <div style={{ flex: 1 }} />\n <span style={{ display: 'flex', alignItems: 'center' }}>\n <faIcons.FaArrowRight style={{ fontSize: '1rem', color: 'var(--primary-color)' }} />\n </span>\n </>\n )}\n </div>\n );\n } else if (rowData.type === 'object') {\n return (\n <div\n className=\"flex align-items-center gap-2 w-full\"\n style={{ height: '100%' }}\n data-pr-tooltip=\"Click to navigate to object properties\"\n data-pr-position=\"top\"\n >\n <span>Object</span>\n <div style={{ flex: 1 }} />\n <span style={{ display: 'flex', alignItems: 'center' }}>\n <faIcons.FaArrowRight style={{ fontSize: '1rem', color: 'var(--primary-color)' }} />\n </span>\n </div>\n );\n }\n return displayValue;\n }\n\n return (\n <div className=\"flex align-items-center gap-2 w-full\" style={{ minHeight: '2.5rem' }}>\n <Dropdown\n value={currentValue}\n options={allTypeOptions}\n onChange={(e) => handleTypeChange(e.value, rowData.name || '')}\n className=\"flex-1\"\n />\n {rowData.type === 'array' && rowData.items && (\n <>\n <span style={{ whiteSpace: 'nowrap', display: 'flex', alignItems: 'center' }}>of</span>\n <Dropdown\n value={rowData.items.type || 'string'}\n options={allTypeOptions}\n onChange={(e) => handleTypeChange(e.value, rowData.name || '', true)}\n className=\"flex-1\"\n />\n </>\n )}\n <div style={{ marginLeft: 'auto', display: 'flex', alignItems: 'center', gap: '0.5rem' }}>\n {rowData.type === 'array' && rowData.items?.type === 'object' && rowData.name && (\n <Button\n icon={<faIcons.FaArrowRight />}\n className=\"p-button-text p-button-sm\"\n onClick={() => onNavigateToArrayItems(rowData.name!)}\n tooltip=\"Navigate to item definition\"\n tooltipOptions={{ position: 'top' }}\n />\n )}\n {rowData.type === 'object' && rowData.name && (\n <Button\n icon={<faIcons.FaArrowRight />}\n className=\"p-button-text p-button-sm\"\n onClick={() => onNavigateToProperty(rowData.name!)}\n tooltip=\"Navigate to object properties\"\n tooltipOptions={{ position: 'top' }}\n />\n )}\n {rowData.name && (\n <Button\n icon={<faIcons.FaTrash />}\n className=\"p-button-text p-button-danger p-button-sm\"\n onClick={() => onRemoveProperty(rowData.name!)}\n tooltip=\"Delete property\"\n tooltipOptions={{ position: 'top' }}\n />\n )}\n </div>\n </div>\n );\n};\n"],"names":["_jsxs","_jsx","_Fragment"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../SchemaEditor/index.ts"],"names":[],"mappings":"AAGA,cAAc,gBAAgB,CAAC;AAC/B,cAAc,qBAAqB,CAAC;AACpC,cAAc,qBAAqB,CAAC"}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
|
-
import
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
export
|
|
7
|
-
export declare const
|
|
1
|
+
import { Meta, StoryObj } from '@storybook/react';
|
|
2
|
+
import { EventsView } from './EventsView';
|
|
3
|
+
declare const meta: Meta<typeof EventsView>;
|
|
4
|
+
export default meta;
|
|
5
|
+
type Story = StoryObj<typeof EventsView>;
|
|
6
|
+
export declare const Default: Story;
|
|
7
|
+
export declare const SingleEvent: Story;
|
|
8
|
+
export declare const EmptyEvents: Story;
|
|
8
9
|
//# sourceMappingURL=EventsView.stories.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EventsView.stories.d.ts","sourceRoot":"","sources":["../../../TimeMachine/EventsView.stories.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"EventsView.stories.d.ts","sourceRoot":"","sources":["../../../TimeMachine/EventsView.stories.tsx"],"names":[],"mappings":"AAIA,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAG1C,QAAA,MAAM,IAAI,EAAE,IAAI,CAAC,OAAO,UAAU,CAMjC,CAAC;AAEF,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,UAAU,CAAC,CAAC;AAwDzC,eAAO,MAAM,OAAO,EAAE,KASrB,CAAC;AAEF,eAAO,MAAM,WAAW,EAAE,KASzB,CAAC;AAEF,eAAO,MAAM,WAAW,EAAE,KASzB,CAAC"}
|
|
@@ -1,6 +1,82 @@
|
|
|
1
1
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
-
import
|
|
3
|
-
const
|
|
4
|
-
|
|
5
|
-
|
|
2
|
+
import { EventsView } from './EventsView';
|
|
3
|
+
const meta = {
|
|
4
|
+
title: 'TimeMachine/EventsView',
|
|
5
|
+
component: EventsView,
|
|
6
|
+
parameters: {
|
|
7
|
+
layout: 'fullscreen',
|
|
8
|
+
},
|
|
9
|
+
};
|
|
10
|
+
export default meta;
|
|
11
|
+
const sampleEvents = [
|
|
12
|
+
{
|
|
13
|
+
sequenceNumber: 1,
|
|
14
|
+
type: 'UserRegistered',
|
|
15
|
+
occurred: new Date('2024-02-10T09:00:00'),
|
|
16
|
+
content: {
|
|
17
|
+
userId: 'user-001',
|
|
18
|
+
email: 'john.doe@example.com',
|
|
19
|
+
username: 'john.doe',
|
|
20
|
+
role: 'user'
|
|
21
|
+
}
|
|
22
|
+
},
|
|
23
|
+
{
|
|
24
|
+
sequenceNumber: 2,
|
|
25
|
+
type: 'ProfileUpdated',
|
|
26
|
+
occurred: new Date('2024-02-10T10:15:00'),
|
|
27
|
+
content: {
|
|
28
|
+
userId: 'user-001',
|
|
29
|
+
firstName: 'John',
|
|
30
|
+
lastName: 'Doe',
|
|
31
|
+
bio: 'Software developer'
|
|
32
|
+
}
|
|
33
|
+
},
|
|
34
|
+
{
|
|
35
|
+
sequenceNumber: 3,
|
|
36
|
+
type: 'RoleChanged',
|
|
37
|
+
occurred: new Date('2024-02-10T11:30:00'),
|
|
38
|
+
content: {
|
|
39
|
+
userId: 'user-001',
|
|
40
|
+
oldRole: 'user',
|
|
41
|
+
newRole: 'admin'
|
|
42
|
+
}
|
|
43
|
+
},
|
|
44
|
+
{
|
|
45
|
+
sequenceNumber: 4,
|
|
46
|
+
type: 'PasswordChanged',
|
|
47
|
+
occurred: new Date('2024-02-10T12:45:00'),
|
|
48
|
+
content: {
|
|
49
|
+
userId: 'user-001',
|
|
50
|
+
timestamp: new Date('2024-02-10T12:45:00')
|
|
51
|
+
}
|
|
52
|
+
},
|
|
53
|
+
{
|
|
54
|
+
sequenceNumber: 5,
|
|
55
|
+
type: 'EmailVerified',
|
|
56
|
+
occurred: new Date('2024-02-10T13:00:00'),
|
|
57
|
+
content: {
|
|
58
|
+
userId: 'user-001',
|
|
59
|
+
email: 'john.doe@example.com',
|
|
60
|
+
verifiedAt: new Date('2024-02-10T13:00:00')
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
];
|
|
64
|
+
export const Default = {
|
|
65
|
+
args: {
|
|
66
|
+
events: sampleEvents,
|
|
67
|
+
},
|
|
68
|
+
render: (args) => (_jsx("div", { style: { height: '600px', background: '#1a1a1a' }, children: _jsx(EventsView, { ...args }) }))
|
|
69
|
+
};
|
|
70
|
+
export const SingleEvent = {
|
|
71
|
+
args: {
|
|
72
|
+
events: [sampleEvents[0]],
|
|
73
|
+
},
|
|
74
|
+
render: (args) => (_jsx("div", { style: { height: '600px', background: '#1a1a1a' }, children: _jsx(EventsView, { ...args }) }))
|
|
75
|
+
};
|
|
76
|
+
export const EmptyEvents = {
|
|
77
|
+
args: {
|
|
78
|
+
events: [],
|
|
79
|
+
},
|
|
80
|
+
render: (args) => (_jsx("div", { style: { height: '600px', background: '#1a1a1a' }, children: _jsx(EventsView, { ...args }) }))
|
|
81
|
+
};
|
|
6
82
|
//# sourceMappingURL=EventsView.stories.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"EventsView.stories.js","sourceRoot":"","sources":["../../../TimeMachine/EventsView.stories.tsx"],"names":[],"mappings":";
|
|
1
|
+
{"version":3,"file":"EventsView.stories.js","sourceRoot":"","sources":["../../../TimeMachine/EventsView.stories.tsx"],"names":[],"mappings":";AAKA,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAG1C,MAAM,IAAI,GAA4B;IAClC,KAAK,EAAE,wBAAwB;IAC/B,SAAS,EAAE,UAAU;IACrB,UAAU,EAAE;QACR,MAAM,EAAE,YAAY;KACvB;CACJ,CAAC;AAEF,eAAe,IAAI,CAAC;AAGpB,MAAM,YAAY,GAAY;IAC1B;QACI,cAAc,EAAE,CAAC;QACjB,IAAI,EAAE,gBAAgB;QACtB,QAAQ,EAAE,IAAI,IAAI,CAAC,qBAAqB,CAAC;QACzC,OAAO,EAAE;YACL,MAAM,EAAE,UAAU;YAClB,KAAK,EAAE,sBAAsB;YAC7B,QAAQ,EAAE,UAAU;YACpB,IAAI,EAAE,MAAM;SACf;KACJ;IACD;QACI,cAAc,EAAE,CAAC;QACjB,IAAI,EAAE,gBAAgB;QACtB,QAAQ,EAAE,IAAI,IAAI,CAAC,qBAAqB,CAAC;QACzC,OAAO,EAAE;YACL,MAAM,EAAE,UAAU;YAClB,SAAS,EAAE,MAAM;YACjB,QAAQ,EAAE,KAAK;YACf,GAAG,EAAE,oBAAoB;SAC5B;KACJ;IACD;QACI,cAAc,EAAE,CAAC;QACjB,IAAI,EAAE,aAAa;QACnB,QAAQ,EAAE,IAAI,IAAI,CAAC,qBAAqB,CAAC;QACzC,OAAO,EAAE;YACL,MAAM,EAAE,UAAU;YAClB,OAAO,EAAE,MAAM;YACf,OAAO,EAAE,OAAO;SACnB;KACJ;IACD;QACI,cAAc,EAAE,CAAC;QACjB,IAAI,EAAE,iBAAiB;QACvB,QAAQ,EAAE,IAAI,IAAI,CAAC,qBAAqB,CAAC;QACzC,OAAO,EAAE;YACL,MAAM,EAAE,UAAU;YAClB,SAAS,EAAE,IAAI,IAAI,CAAC,qBAAqB,CAAC;SAC7C;KACJ;IACD;QACI,cAAc,EAAE,CAAC;QACjB,IAAI,EAAE,eAAe;QACrB,QAAQ,EAAE,IAAI,IAAI,CAAC,qBAAqB,CAAC;QACzC,OAAO,EAAE;YACL,MAAM,EAAE,UAAU;YAClB,KAAK,EAAE,sBAAsB;YAC7B,UAAU,EAAE,IAAI,IAAI,CAAC,qBAAqB,CAAC;SAC9C;KACJ;CACJ,CAAC;AAEF,MAAM,CAAC,MAAM,OAAO,GAAU;IAC1B,IAAI,EAAE;QACF,MAAM,EAAE,YAAY;KACvB;IACD,MAAM,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,CACd,cAAK,KAAK,EAAE,EAAE,MAAM,EAAE,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,YAClD,KAAC,UAAU,OAAK,IAAI,GAAI,GACtB,CACT;CACJ,CAAC;AAEF,MAAM,CAAC,MAAM,WAAW,GAAU;IAC9B,IAAI,EAAE;QACF,MAAM,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;KAC5B;IACD,MAAM,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,CACd,cAAK,KAAK,EAAE,EAAE,MAAM,EAAE,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,YAClD,KAAC,UAAU,OAAK,IAAI,GAAI,GACtB,CACT;CACJ,CAAC;AAEF,MAAM,CAAC,MAAM,WAAW,GAAU;IAC9B,IAAI,EAAE;QACF,MAAM,EAAE,EAAE;KACb;IACD,MAAM,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,CACd,cAAK,KAAK,EAAE,EAAE,MAAM,EAAE,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,YAClD,KAAC,UAAU,OAAK,IAAI,GAAI,GACtB,CACT;CACJ,CAAC"}
|
|
@@ -1,8 +1,10 @@
|
|
|
1
|
-
import
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
export
|
|
7
|
-
export declare const
|
|
1
|
+
import { Meta, StoryObj } from '@storybook/react';
|
|
2
|
+
import { Properties } from './Properties';
|
|
3
|
+
declare const meta: Meta<typeof Properties>;
|
|
4
|
+
export default meta;
|
|
5
|
+
type Story = StoryObj<typeof Properties>;
|
|
6
|
+
export declare const Default: Story;
|
|
7
|
+
export declare const LeftAligned: Story;
|
|
8
|
+
export declare const RightAligned: Story;
|
|
9
|
+
export declare const WithNullValues: Story;
|
|
8
10
|
//# sourceMappingURL=Properties.stories.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Properties.stories.d.ts","sourceRoot":"","sources":["../../../TimeMachine/Properties.stories.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"Properties.stories.d.ts","sourceRoot":"","sources":["../../../TimeMachine/Properties.stories.tsx"],"names":[],"mappings":"AAIA,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAE1C,QAAA,MAAM,IAAI,EAAE,IAAI,CAAC,OAAO,UAAU,CAGjC,CAAC;AAEF,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,UAAU,CAAC,CAAC;AAczC,eAAO,MAAM,OAAO,EAAE,KASrB,CAAC;AAEF,eAAO,MAAM,WAAW,EAAE,KAUzB,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,KAU1B,CAAC;AAEF,eAAO,MAAM,cAAc,EAAE,KAe5B,CAAC"}
|
|
@@ -1,6 +1,51 @@
|
|
|
1
1
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
-
import
|
|
3
|
-
const
|
|
4
|
-
|
|
5
|
-
|
|
2
|
+
import { Properties } from './Properties';
|
|
3
|
+
const meta = {
|
|
4
|
+
title: 'TimeMachine/Properties',
|
|
5
|
+
component: Properties,
|
|
6
|
+
};
|
|
7
|
+
export default meta;
|
|
8
|
+
const sampleData = {
|
|
9
|
+
userId: 'user-12345',
|
|
10
|
+
username: 'john.doe',
|
|
11
|
+
email: 'john.doe@example.com',
|
|
12
|
+
age: 30,
|
|
13
|
+
isActive: true,
|
|
14
|
+
lastLogin: new Date('2024-02-10T10:30:00'),
|
|
15
|
+
role: 'administrator',
|
|
16
|
+
permissions: ['read', 'write', 'delete'],
|
|
17
|
+
metadata: { theme: 'dark', language: 'en' }
|
|
18
|
+
};
|
|
19
|
+
export const Default = {
|
|
20
|
+
args: {
|
|
21
|
+
data: sampleData,
|
|
22
|
+
},
|
|
23
|
+
render: (args) => (_jsx("div", { style: { padding: '20px', background: '#1a1a1a', minHeight: '400px' }, children: _jsx(Properties, { ...args }) }))
|
|
24
|
+
};
|
|
25
|
+
export const LeftAligned = {
|
|
26
|
+
args: {
|
|
27
|
+
data: sampleData,
|
|
28
|
+
align: 'left',
|
|
29
|
+
},
|
|
30
|
+
render: (args) => (_jsx("div", { style: { padding: '20px', background: '#1a1a1a', minHeight: '400px' }, children: _jsx(Properties, { ...args }) }))
|
|
31
|
+
};
|
|
32
|
+
export const RightAligned = {
|
|
33
|
+
args: {
|
|
34
|
+
data: sampleData,
|
|
35
|
+
align: 'right',
|
|
36
|
+
},
|
|
37
|
+
render: (args) => (_jsx("div", { style: { padding: '20px', background: '#1a1a1a', minHeight: '400px' }, children: _jsx(Properties, { ...args }) }))
|
|
38
|
+
};
|
|
39
|
+
export const WithNullValues = {
|
|
40
|
+
args: {
|
|
41
|
+
data: {
|
|
42
|
+
name: 'John Doe',
|
|
43
|
+
email: null,
|
|
44
|
+
phone: undefined,
|
|
45
|
+
age: 30,
|
|
46
|
+
isActive: false,
|
|
47
|
+
},
|
|
48
|
+
},
|
|
49
|
+
render: (args) => (_jsx("div", { style: { padding: '20px', background: '#1a1a1a', minHeight: '400px' }, children: _jsx(Properties, { ...args }) }))
|
|
50
|
+
};
|
|
6
51
|
//# sourceMappingURL=Properties.stories.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Properties.stories.js","sourceRoot":"","sources":["../../../TimeMachine/Properties.stories.tsx"],"names":[],"mappings":";
|
|
1
|
+
{"version":3,"file":"Properties.stories.js","sourceRoot":"","sources":["../../../TimeMachine/Properties.stories.tsx"],"names":[],"mappings":";AAKA,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAE1C,MAAM,IAAI,GAA4B;IAClC,KAAK,EAAE,wBAAwB;IAC/B,SAAS,EAAE,UAAU;CACxB,CAAC;AAEF,eAAe,IAAI,CAAC;AAGpB,MAAM,UAAU,GAAG;IACf,MAAM,EAAE,YAAY;IACpB,QAAQ,EAAE,UAAU;IACpB,KAAK,EAAE,sBAAsB;IAC7B,GAAG,EAAE,EAAE;IACP,QAAQ,EAAE,IAAI;IACd,SAAS,EAAE,IAAI,IAAI,CAAC,qBAAqB,CAAC;IAC1C,IAAI,EAAE,eAAe;IACrB,WAAW,EAAE,CAAC,MAAM,EAAE,OAAO,EAAE,QAAQ,CAAC;IACxC,QAAQ,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE;CAC9C,CAAC;AAEF,MAAM,CAAC,MAAM,OAAO,GAAU;IAC1B,IAAI,EAAE;QACF,IAAI,EAAE,UAAU;KACnB;IACD,MAAM,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,CACd,cAAK,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,SAAS,EAAE,OAAO,EAAE,YACtE,KAAC,UAAU,OAAK,IAAI,GAAI,GACtB,CACT;CACJ,CAAC;AAEF,MAAM,CAAC,MAAM,WAAW,GAAU;IAC9B,IAAI,EAAE;QACF,IAAI,EAAE,UAAU;QAChB,KAAK,EAAE,MAAM;KAChB;IACD,MAAM,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,CACd,cAAK,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,SAAS,EAAE,OAAO,EAAE,YACtE,KAAC,UAAU,OAAK,IAAI,GAAI,GACtB,CACT;CACJ,CAAC;AAEF,MAAM,CAAC,MAAM,YAAY,GAAU;IAC/B,IAAI,EAAE;QACF,IAAI,EAAE,UAAU;QAChB,KAAK,EAAE,OAAO;KACjB;IACD,MAAM,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,CACd,cAAK,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,SAAS,EAAE,OAAO,EAAE,YACtE,KAAC,UAAU,OAAK,IAAI,GAAI,GACtB,CACT;CACJ,CAAC;AAEF,MAAM,CAAC,MAAM,cAAc,GAAU;IACjC,IAAI,EAAE;QACF,IAAI,EAAE;YACF,IAAI,EAAE,UAAU;YAChB,KAAK,EAAE,IAAI;YACX,KAAK,EAAE,SAAS;YAChB,GAAG,EAAE,EAAE;YACP,QAAQ,EAAE,KAAK;SAClB;KACJ;IACD,MAAM,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,CACd,cAAK,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,SAAS,EAAE,OAAO,EAAE,YACtE,KAAC,UAAU,OAAK,IAAI,GAAI,GACtB,CACT;CACJ,CAAC"}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
export
|
|
7
|
-
export declare const
|
|
1
|
+
import { Meta, StoryObj } from '@storybook/react';
|
|
2
|
+
import { ReadModelView } from './ReadModelView';
|
|
3
|
+
declare const meta: Meta<typeof ReadModelView>;
|
|
4
|
+
export default meta;
|
|
5
|
+
type Story = StoryObj<typeof ReadModelView>;
|
|
6
|
+
export declare const Default: Story;
|
|
7
|
+
export declare const SingleVersion: Story;
|
|
8
8
|
//# sourceMappingURL=ReadModelView.stories.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ReadModelView.stories.d.ts","sourceRoot":"","sources":["../../../TimeMachine/ReadModelView.stories.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"ReadModelView.stories.d.ts","sourceRoot":"","sources":["../../../TimeMachine/ReadModelView.stories.tsx"],"names":[],"mappings":"AAIA,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAIhD,QAAA,MAAM,IAAI,EAAE,IAAI,CAAC,OAAO,aAAa,CAMpC,CAAC;AAEF,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,aAAa,CAAC,CAAC;AA6F5C,eAAO,MAAM,OAAO,EAAE,KAErB,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,KAE3B,CAAC"}
|
|
@@ -1,6 +1,80 @@
|
|
|
1
|
-
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
-
import
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { useState } from 'react';
|
|
3
|
+
import { ReadModelView } from './ReadModelView';
|
|
4
|
+
import { Properties } from './Properties';
|
|
5
|
+
const meta = {
|
|
6
|
+
title: 'TimeMachine/ReadModelView',
|
|
7
|
+
component: ReadModelView,
|
|
8
|
+
parameters: {
|
|
9
|
+
layout: 'fullscreen',
|
|
10
|
+
},
|
|
11
|
+
};
|
|
12
|
+
export default meta;
|
|
13
|
+
const sampleVersions = [
|
|
14
|
+
{
|
|
15
|
+
id: 'v1',
|
|
16
|
+
timestamp: new Date('2024-02-10T08:00:00'),
|
|
17
|
+
label: 'v1 - Initial State',
|
|
18
|
+
content: (_jsx(Properties, { data: {
|
|
19
|
+
userId: 'user-001',
|
|
20
|
+
username: 'john.doe',
|
|
21
|
+
email: 'john.doe@example.com',
|
|
22
|
+
role: 'user',
|
|
23
|
+
isActive: false
|
|
24
|
+
} })),
|
|
25
|
+
events: []
|
|
26
|
+
},
|
|
27
|
+
{
|
|
28
|
+
id: 'v2',
|
|
29
|
+
timestamp: new Date('2024-02-10T09:00:00'),
|
|
30
|
+
label: 'v2 - User Activated',
|
|
31
|
+
content: (_jsx(Properties, { data: {
|
|
32
|
+
userId: 'user-001',
|
|
33
|
+
username: 'john.doe',
|
|
34
|
+
email: 'john.doe@example.com',
|
|
35
|
+
role: 'user',
|
|
36
|
+
isActive: true
|
|
37
|
+
} })),
|
|
38
|
+
events: [
|
|
39
|
+
{
|
|
40
|
+
sequenceNumber: 1,
|
|
41
|
+
type: 'UserActivated',
|
|
42
|
+
occurred: new Date('2024-02-10T09:00:00'),
|
|
43
|
+
content: { userId: 'user-001' }
|
|
44
|
+
}
|
|
45
|
+
]
|
|
46
|
+
},
|
|
47
|
+
{
|
|
48
|
+
id: 'v3',
|
|
49
|
+
timestamp: new Date('2024-02-10T10:00:00'),
|
|
50
|
+
label: 'v3 - Role Changed',
|
|
51
|
+
content: (_jsx(Properties, { data: {
|
|
52
|
+
userId: 'user-001',
|
|
53
|
+
username: 'john.doe',
|
|
54
|
+
email: 'john.doe@example.com',
|
|
55
|
+
role: 'admin',
|
|
56
|
+
isActive: true
|
|
57
|
+
} })),
|
|
58
|
+
events: [
|
|
59
|
+
{
|
|
60
|
+
sequenceNumber: 2,
|
|
61
|
+
type: 'RoleChanged',
|
|
62
|
+
occurred: new Date('2024-02-10T10:00:00'),
|
|
63
|
+
content: { userId: 'user-001', oldRole: 'user', newRole: 'admin' }
|
|
64
|
+
}
|
|
65
|
+
]
|
|
66
|
+
}
|
|
67
|
+
];
|
|
68
|
+
const ReadModelViewWrapper = ({ versions }) => {
|
|
69
|
+
const [selectedIndex, setSelectedIndex] = useState(0);
|
|
70
|
+
const [hoveredIndex] = useState(null);
|
|
71
|
+
const [isHoveringCard, setIsHoveringCard] = useState(false);
|
|
72
|
+
return (_jsxs("div", { style: { height: '800px', background: '#0a0a0a', position: 'relative' }, children: [_jsx(ReadModelView, { versions: versions, selectedIndex: selectedIndex, hoveredIndex: hoveredIndex, onVersionSelect: setSelectedIndex, onHoveringCardChange: setIsHoveringCard }), _jsxs("div", { style: { position: 'absolute', bottom: 20, left: 20, color: 'white', background: 'rgba(0,0,0,0.7)', padding: '10px', borderRadius: '5px' }, children: [_jsxs("p", { children: ["Selected Version: ", selectedIndex + 1, " of ", versions.length] }), _jsxs("p", { children: ["Hovering Card: ", String(isHoveringCard)] }), _jsx("p", { children: "Click on cards to select, scroll to navigate" })] })] }));
|
|
73
|
+
};
|
|
74
|
+
export const Default = {
|
|
75
|
+
render: () => _jsx(ReadModelViewWrapper, { versions: sampleVersions })
|
|
76
|
+
};
|
|
77
|
+
export const SingleVersion = {
|
|
78
|
+
render: () => _jsx(ReadModelViewWrapper, { versions: [sampleVersions[0]] })
|
|
79
|
+
};
|
|
6
80
|
//# sourceMappingURL=ReadModelView.stories.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ReadModelView.stories.js","sourceRoot":"","sources":["../../../TimeMachine/ReadModelView.stories.tsx"],"names":[],"mappings":";
|
|
1
|
+
{"version":3,"file":"ReadModelView.stories.js","sourceRoot":"","sources":["../../../TimeMachine/ReadModelView.stories.tsx"],"names":[],"mappings":"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"}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
|
-
import
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
export
|
|
7
|
-
export declare const
|
|
1
|
+
import { Meta, StoryObj } from '@storybook/react';
|
|
2
|
+
import { TimeMachine } from './TimeMachine';
|
|
3
|
+
declare const meta: Meta<typeof TimeMachine>;
|
|
4
|
+
export default meta;
|
|
5
|
+
type Story = StoryObj<typeof TimeMachine>;
|
|
6
|
+
export declare const Default: Story;
|
|
7
|
+
export declare const StartAtLatestVersion: Story;
|
|
8
|
+
export declare const HighScrollSensitivity: Story;
|
|
8
9
|
//# sourceMappingURL=TimeMachine.stories.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TimeMachine.stories.d.ts","sourceRoot":"","sources":["../../../TimeMachine/TimeMachine.stories.tsx"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"TimeMachine.stories.d.ts","sourceRoot":"","sources":["../../../TimeMachine/TimeMachine.stories.tsx"],"names":[],"mappings":"AAIA,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAClD,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAI5C,QAAA,MAAM,IAAI,EAAE,IAAI,CAAC,OAAO,WAAW,CAMlC,CAAC;AAEF,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,WAAW,CAAC,CAAC;AAkG1C,eAAO,MAAM,OAAO,EAAE,KAWrB,CAAC;AAEF,eAAO,MAAM,oBAAoB,EAAE,KAWlC,CAAC;AAEF,eAAO,MAAM,qBAAqB,EAAE,KAWnC,CAAC"}
|
|
@@ -1,6 +1,115 @@
|
|
|
1
1
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
-
import
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
2
|
+
import { TimeMachine } from './TimeMachine';
|
|
3
|
+
import { Properties } from './Properties';
|
|
4
|
+
const meta = {
|
|
5
|
+
title: 'TimeMachine/TimeMachine',
|
|
6
|
+
component: TimeMachine,
|
|
7
|
+
parameters: {
|
|
8
|
+
layout: 'fullscreen',
|
|
9
|
+
},
|
|
10
|
+
};
|
|
11
|
+
export default meta;
|
|
12
|
+
const sampleVersions = [
|
|
13
|
+
{
|
|
14
|
+
id: 'v1',
|
|
15
|
+
timestamp: new Date('2024-02-10T08:00:00'),
|
|
16
|
+
label: 'Version 1 - Initial State',
|
|
17
|
+
content: (_jsx(Properties, { data: {
|
|
18
|
+
userId: 'user-001',
|
|
19
|
+
username: 'alice.smith',
|
|
20
|
+
email: 'alice@example.com',
|
|
21
|
+
role: 'user',
|
|
22
|
+
isActive: false,
|
|
23
|
+
credits: 0
|
|
24
|
+
} })),
|
|
25
|
+
events: []
|
|
26
|
+
},
|
|
27
|
+
{
|
|
28
|
+
id: 'v2',
|
|
29
|
+
timestamp: new Date('2024-02-10T09:00:00'),
|
|
30
|
+
label: 'Version 2 - User Activated',
|
|
31
|
+
content: (_jsx(Properties, { data: {
|
|
32
|
+
userId: 'user-001',
|
|
33
|
+
username: 'alice.smith',
|
|
34
|
+
email: 'alice@example.com',
|
|
35
|
+
role: 'user',
|
|
36
|
+
isActive: true,
|
|
37
|
+
credits: 100
|
|
38
|
+
} })),
|
|
39
|
+
events: [
|
|
40
|
+
{
|
|
41
|
+
sequenceNumber: 1,
|
|
42
|
+
type: 'UserActivated',
|
|
43
|
+
occurred: new Date('2024-02-10T09:00:00'),
|
|
44
|
+
content: { userId: 'user-001', credits: 100 }
|
|
45
|
+
}
|
|
46
|
+
]
|
|
47
|
+
},
|
|
48
|
+
{
|
|
49
|
+
id: 'v3',
|
|
50
|
+
timestamp: new Date('2024-02-10T10:00:00'),
|
|
51
|
+
label: 'Version 3 - Credits Added',
|
|
52
|
+
content: (_jsx(Properties, { data: {
|
|
53
|
+
userId: 'user-001',
|
|
54
|
+
username: 'alice.smith',
|
|
55
|
+
email: 'alice@example.com',
|
|
56
|
+
role: 'user',
|
|
57
|
+
isActive: true,
|
|
58
|
+
credits: 500
|
|
59
|
+
} })),
|
|
60
|
+
events: [
|
|
61
|
+
{
|
|
62
|
+
sequenceNumber: 2,
|
|
63
|
+
type: 'CreditsAdded',
|
|
64
|
+
occurred: new Date('2024-02-10T10:00:00'),
|
|
65
|
+
content: { userId: 'user-001', amount: 400, newBalance: 500 }
|
|
66
|
+
}
|
|
67
|
+
]
|
|
68
|
+
},
|
|
69
|
+
{
|
|
70
|
+
id: 'v4',
|
|
71
|
+
timestamp: new Date('2024-02-10T11:00:00'),
|
|
72
|
+
label: 'Version 4 - Promoted to Admin',
|
|
73
|
+
content: (_jsx(Properties, { data: {
|
|
74
|
+
userId: 'user-001',
|
|
75
|
+
username: 'alice.smith',
|
|
76
|
+
email: 'alice@example.com',
|
|
77
|
+
role: 'admin',
|
|
78
|
+
isActive: true,
|
|
79
|
+
credits: 500
|
|
80
|
+
} })),
|
|
81
|
+
events: [
|
|
82
|
+
{
|
|
83
|
+
sequenceNumber: 3,
|
|
84
|
+
type: 'RoleChanged',
|
|
85
|
+
occurred: new Date('2024-02-10T11:00:00'),
|
|
86
|
+
content: { userId: 'user-001', oldRole: 'user', newRole: 'admin' }
|
|
87
|
+
}
|
|
88
|
+
]
|
|
89
|
+
}
|
|
90
|
+
];
|
|
91
|
+
export const Default = {
|
|
92
|
+
args: {
|
|
93
|
+
versions: sampleVersions,
|
|
94
|
+
currentVersionIndex: 0,
|
|
95
|
+
scrollSensitivity: 50,
|
|
96
|
+
},
|
|
97
|
+
render: (args) => (_jsx("div", { style: { height: '100vh', width: '100vw' }, children: _jsx(TimeMachine, { ...args }) }))
|
|
98
|
+
};
|
|
99
|
+
export const StartAtLatestVersion = {
|
|
100
|
+
args: {
|
|
101
|
+
versions: sampleVersions,
|
|
102
|
+
currentVersionIndex: sampleVersions.length - 1,
|
|
103
|
+
scrollSensitivity: 50,
|
|
104
|
+
},
|
|
105
|
+
render: (args) => (_jsx("div", { style: { height: '100vh', width: '100vw' }, children: _jsx(TimeMachine, { ...args }) }))
|
|
106
|
+
};
|
|
107
|
+
export const HighScrollSensitivity = {
|
|
108
|
+
args: {
|
|
109
|
+
versions: sampleVersions,
|
|
110
|
+
currentVersionIndex: 0,
|
|
111
|
+
scrollSensitivity: 100,
|
|
112
|
+
},
|
|
113
|
+
render: (args) => (_jsx("div", { style: { height: '100vh', width: '100vw' }, children: _jsx(TimeMachine, { ...args }) }))
|
|
114
|
+
};
|
|
6
115
|
//# sourceMappingURL=TimeMachine.stories.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TimeMachine.stories.js","sourceRoot":"","sources":["../../../TimeMachine/TimeMachine.stories.tsx"],"names":[],"mappings":";
|
|
1
|
+
{"version":3,"file":"TimeMachine.stories.js","sourceRoot":"","sources":["../../../TimeMachine/TimeMachine.stories.tsx"],"names":[],"mappings":"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"}
|