mirror of
https://github.com/enso-org/enso.git
synced 2025-01-03 09:03:57 +03:00
a3873b9565
Closes #8751 Closes #8752 - The numeric widget allows the use of the input field after clicking with LMB - Slider is only visible if the engine provides widget configuration with set limits (see below for testing) - Setting value outside limits is possible - For now, to distinguish drag from click, we compare relative mouse movement on the mouse up event. We might benefit from using a timer instead, but let’s see how good it is now. - Changes after demo - No more input validation. You can enter literally anything and it would be accepted. - Updates debouncing – the code is updated on defocus or when slider dragging has finished. https://github.com/enso-org/enso/assets/6566674/b3580083-c678-4734-881c-97f8ac56176b
126 lines
4.0 KiB
TypeScript
126 lines
4.0 KiB
TypeScript
import '@/assets/base.css'
|
|
import { provideGuiConfig } from '@/providers/guiConfig'
|
|
import { provideVisualizationConfig } from '@/providers/visualizationConfig'
|
|
import { Vec2 } from '@/util/data/vec2'
|
|
import { MockTransport } from '@/util/net'
|
|
import type { QualifiedName } from '@/util/qualifiedName'
|
|
import { defineSetupVue3 } from '@histoire/plugin-vue'
|
|
import * as random from 'lib0/random'
|
|
import { createPinia } from 'pinia'
|
|
import type { LibraryComponentGroup, Uuid, response } from 'shared/languageServerTypes'
|
|
import type {
|
|
SuggestionEntry,
|
|
SuggestionsDatabaseUpdate,
|
|
} from 'shared/languageServerTypes/suggestions'
|
|
import { ref } from 'vue'
|
|
import CustomBackground from './histoire/CustomBackground.vue'
|
|
import mockDb from './mockSuggestions.json' assert { type: 'json' }
|
|
import './story.css'
|
|
|
|
const mockProjectId = random.uuidv4() as Uuid
|
|
const standardBase = 'Standard.Base' as QualifiedName
|
|
|
|
export function placeholderGroups(): LibraryComponentGroup[] {
|
|
return [
|
|
{ color: '#4D9A29', name: 'Input', library: standardBase, exports: [] },
|
|
{ color: '#B37923', name: 'Web', library: standardBase, exports: [] },
|
|
{ color: '#9735B9', name: 'Parse', library: standardBase, exports: [] },
|
|
{ color: '#4D9A29', name: 'Select', library: standardBase, exports: [] },
|
|
{ color: '#B37923', name: 'Join', library: standardBase, exports: [] },
|
|
{ color: '#9735B9', name: 'Transform', library: standardBase, exports: [] },
|
|
{ color: '#4D9A29', name: 'Output', library: standardBase, exports: [] },
|
|
]
|
|
}
|
|
|
|
MockTransport.addMock('engine', async (method, data, transport) => {
|
|
switch (method) {
|
|
case 'session/initProtocolConnection':
|
|
return {
|
|
contentRoots: [{ type: 'Project', id: mockProjectId }],
|
|
} satisfies response.InitProtocolConnection
|
|
case 'executionContext/create':
|
|
setTimeout(
|
|
() => transport.emit('executionContext/executionComplete', { contextId: data.contextId }),
|
|
100,
|
|
)
|
|
return {
|
|
contextId: data.contextId,
|
|
}
|
|
case 'search/getSuggestionsDatabase':
|
|
// We first send the empty database, and then update it 200 ms later, mimicking the real LS.
|
|
setTimeout(() => {
|
|
const updates: SuggestionsDatabaseUpdate[] = mockDb.map((suggestion, id) => ({
|
|
type: 'Add',
|
|
id,
|
|
suggestion: suggestion as SuggestionEntry,
|
|
}))
|
|
transport.emit('search/suggestionsDatabaseUpdates', { updates, currentVersion: 2 })
|
|
}, 200)
|
|
return {
|
|
entries: [],
|
|
currentVersion: 1,
|
|
} satisfies response.GetSuggestionsDatabase
|
|
case 'runtime/getComponentGroups':
|
|
return { componentGroups: placeholderGroups() } satisfies response.GetComponentGroups
|
|
case 'file/list':
|
|
return { paths: [] } satisfies response.FileList
|
|
case 'executionContext/push':
|
|
case 'executionContext/pop':
|
|
case 'executionContext/recompute':
|
|
case 'capability/acquire':
|
|
return {}
|
|
default:
|
|
return Promise.reject(`Method not mocked: ${method}`)
|
|
}
|
|
})
|
|
|
|
export const setupVue3 = defineSetupVue3(({ app, addWrapper }) => {
|
|
addWrapper(CustomBackground)
|
|
|
|
app.use(createPinia())
|
|
provideGuiConfig._mock(
|
|
ref({
|
|
startup: {
|
|
project: 'Mock Project',
|
|
displayedProjectName: 'Mock Project',
|
|
},
|
|
engine: { rpcUrl: 'mock://engine', dataUrl: 'mock://data' },
|
|
}),
|
|
app,
|
|
)
|
|
// Required for visualization stories.
|
|
provideVisualizationConfig._mock(
|
|
{
|
|
fullscreen: false,
|
|
scale: 1,
|
|
width: 200,
|
|
height: 150,
|
|
hide() {},
|
|
isCircularMenuVisible: false,
|
|
isBelowToolbar: false,
|
|
nodeSize: new Vec2(200, 150),
|
|
currentType: {
|
|
module: { kind: 'Builtin' },
|
|
name: 'Current Type',
|
|
},
|
|
icon: 'braces',
|
|
types: [
|
|
{
|
|
module: { kind: 'Builtin' },
|
|
name: 'Example',
|
|
},
|
|
{
|
|
module: { kind: 'Builtin' },
|
|
name: 'Types',
|
|
},
|
|
{
|
|
module: { kind: 'Builtin' },
|
|
name: 'Here',
|
|
},
|
|
],
|
|
updateType() {},
|
|
},
|
|
app,
|
|
)
|
|
})
|