import test, { expect } from '@playwright/test' import { createTypebots, parseDefaultBlockWithStep, } from '../../services/database' import { defaultTextInputOptions, InputStepType } from 'models' import { typebotViewer } from '../../services/selectorUtils' const typebotId = 'text-input-step' test.describe('Text input step', () => { test('options should work', async ({ page }) => { await createTypebots([ { id: typebotId, ...parseDefaultBlockWithStep({ type: InputStepType.TEXT, options: defaultTextInputOptions, }), }, ]) await page.goto(`/typebots/${typebotId}/edit`) await page.click('text=Preview') await expect( typebotViewer(page).locator( `input[placeholder="${defaultTextInputOptions.labels.placeholder}"]` ) ).toHaveAttribute('type', 'text') await expect(typebotViewer(page).locator(`button`)).toBeDisabled() await page.click(`text=${defaultTextInputOptions.labels.placeholder}`) await page.fill('#placeholder', 'Your name...') await page.fill('#button', 'Go') await page.click('text=Long text?') await page.click('text=Restart') await expect( typebotViewer(page).locator(`textarea[placeholder="Your name..."]`) ).toBeVisible() await expect(typebotViewer(page).locator(`text=Go`)).toBeVisible() }) })