Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Tailwind MegaSpike #6574

Closed
wants to merge 64 commits into from
Closed
Show file tree
Hide file tree
Changes from 44 commits
Commits
Show all changes
64 commits
Select commit Hold shift + click to select a range
a0009b3
wip
bkrmendy Oct 15, 2024
6c51144
Merge branch 'master' of https://github.com/concrete-utopia/utopia in…
bkrmendy Oct 17, 2024
904b33b
placehoolder test
bkrmendy Oct 17, 2024
c08119e
padding default values
bkrmendy Oct 17, 2024
205a05f
Merge branch 'master' of https://github.com/concrete-utopia/utopia in…
bkrmendy Oct 17, 2024
ed1e282
update tailwind style plugin tests
bkrmendy Oct 17, 2024
cb2a4c9
wip
bkrmendy Oct 17, 2024
cf44dd1
Merge branch 'master' of https://github.com/concrete-utopia/utopia in…
bkrmendy Oct 18, 2024
16660b5
fix value serialization issue
bkrmendy Oct 18, 2024
d68fbc0
c'est horrible
bkrmendy Oct 18, 2024
00743e2
tests
bkrmendy Oct 21, 2024
c493375
fix typo in test
bkrmendy Oct 21, 2024
6a0b3bb
remove unused commands
bkrmendy Oct 21, 2024
cd8ea2f
delete more commands
bkrmendy Oct 21, 2024
445fa14
wip - granular plugins
bkrmendy Oct 21, 2024
f22416c
readd conver to absolute command
bkrmendy Oct 21, 2024
70b08a7
Merge branch 'chore/command-cleanup' of https://github.com/concrete-u…
bkrmendy Oct 21, 2024
1f00828
prop setter plugin
bkrmendy Oct 22, 2024
ff6ee3e
move tostring down
bkrmendy Oct 22, 2024
5010da9
get rid of normalization stuff
bkrmendy Oct 22, 2024
19ef8ed
nix tailwind normalization tests
bkrmendy Oct 22, 2024
c738164
Merge branch 'master' of https://github.com/concrete-utopia/utopia in…
bkrmendy Oct 22, 2024
8b1bf1f
only zero some props
bkrmendy Oct 22, 2024
011b807
cleanup, safety & flex stuff
bkrmendy Oct 22, 2024
0662c02
update xengine
bkrmendy Oct 22, 2024
d4dc267
property zeroing v2
bkrmendy Oct 24, 2024
2f77488
stricter type for fixLengthCommand
bkrmendy Oct 24, 2024
ea8ad1b
x
bkrmendy Oct 24, 2024
c4748e7
Merge branch 'master' of https://github.com/concrete-utopia/utopia in…
bkrmendy Oct 24, 2024
9e734d2
more expressive styleinfo
bkrmendy Oct 24, 2024
b68bff6
property zeroing
bkrmendy Oct 24, 2024
629c2cb
zero in strategy dispatch
bkrmendy Oct 25, 2024
5832b1f
workingElement
bkrmendy Oct 25, 2024
028aae1
read props from the project contents
bkrmendy Oct 25, 2024
edcdf24
refactor set-css-length-command
bkrmendy Oct 25, 2024
8d0953f
Merge branch 'master' of https://github.com/concrete-utopia/utopia in…
bkrmendy Oct 25, 2024
44464d8
refacc adjust css length command
bkrmendy Oct 25, 2024
a748b39
whoops
bkrmendy Oct 25, 2024
c86716d
more granular non-editable prop detection
bkrmendy Oct 28, 2024
6338331
stub flex-basis support
bkrmendy Oct 28, 2024
d8291bc
correctly print prop value for tailwind
bkrmendy Oct 28, 2024
83e017b
group classname
bkrmendy Oct 28, 2024
9b3d8a6
group conversion with tailwind
bkrmendy Oct 28, 2024
e63d390
comment
bkrmendy Oct 28, 2024
065c7b6
draw to insert with tailwind
bkrmendy Oct 29, 2024
3e929c8
update tailwind tests for groups
bkrmendy Oct 29, 2024
b7258f9
Revert "draw to insert with tailwind"
bkrmendy Oct 29, 2024
849a8a9
wip - action backed by command
bkrmendy Oct 29, 2024
4083820
Merge branch 'master' of https://github.com/concrete-utopia/utopia in…
bkrmendy Oct 29, 2024
b33edce
comments
bkrmendy Oct 29, 2024
2343871
action backed by command
bkrmendy Oct 29, 2024
9ccca3b
Merge branch 'master' of https://github.com/concrete-utopia/utopia in…
bkrmendy Oct 29, 2024
db571b4
test
bkrmendy Oct 30, 2024
7dd4ea5
singleton + read from element props
bkrmendy Oct 31, 2024
9233717
set prop value with plugin
bkrmendy Nov 4, 2024
4053391
Merge branch 'master' of https://github.com/concrete-utopia/utopia in…
bkrmendy Nov 4, 2024
9cd356c
read width/height with plugin
bkrmendy Nov 4, 2024
7276d7b
style plugin config in element metadata
bkrmendy Nov 4, 2024
0830ea0
Revert "style plugin config in element metadata"
bkrmendy Nov 5, 2024
2e94cbd
jotai store
bkrmendy Nov 5, 2024
0266f94
undo accidental git stash pop
bkrmendy Nov 5, 2024
92627f1
Merge branch 'master' of https://github.com/concrete-utopia/utopia in…
bkrmendy Nov 8, 2024
dabc8b6
more accurate StyleInfo implementation for the inline style
bkrmendy Nov 11, 2024
0f4b889
Merge branch 'master' of https://github.com/concrete-utopia/utopia in…
bkrmendy Nov 11, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions editor/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -171,7 +171,7 @@
"@types/w3c-css-typed-object-model-level-1": "20180410.0.5",
"@use-it/interval": "0.1.3",
"@vercel/stega": "0.1.0",
"@xengine/tailwindcss-class-parser": "1.1.17",
"@xengine/tailwindcss-class-parser": "1.1.18",
"ajv": "6.4.0",
"anser": "2.1.0",
"antd": "4.3.5",
Expand Down Expand Up @@ -426,7 +426,7 @@
"source-map-loader": "0.2.3",
"string-replace-loader": "2.2.0",
"style-loader": "0.18.2",
"tailwindcss": "^3.4.13",
"tailwindcss": "3.4.11",
"tar": "6.0.5",
"terser-webpack-plugin": "5.3.9",
"three": "0.140.2",
Expand Down
45 changes: 38 additions & 7 deletions editor/pnpm-lock.yaml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,7 @@ import { reparentSubjectsForInteractionTarget } from './strategies/reparent-help
import { getReparentTargetUnified } from './strategies/reparent-helpers/reparent-strategy-parent-lookup'
import { gridRearrangeResizeKeyboardStrategy } from './strategies/grid-rearrange-keyboard-strategy'
import createCachedSelector from 're-reselect'
import { getActivePlugin } from '../plugins/style-plugins'
import { getActivePlugin, patchRemovedProperties } from '../plugins/style-plugins'
import {
controlsForGridPlaceholders,
GridControls,
Expand Down Expand Up @@ -495,6 +495,16 @@ export function applyCanvasStrategy(
return strategy.apply(strategyLifecycle)
}

export function applyElementsToRerenderFromStrategyResultAndZeroProps(
editorState: EditorState,
strategyResult: StrategyApplicationResult,
): EditorState {
return applyElementsToRerenderFromStrategyResult(
patchRemovedProperties(editorState),
strategyResult,
)
}

export function applyElementsToRerenderFromStrategyResult(
editorState: EditorState,
strategyResult: StrategyApplicationResult,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -415,7 +415,10 @@ describe('Absolute Move Strategy', () => {
)
})

it('overrides expressions + fires toast', async () => {
// FIXME: this is disabled because the inline style plugin cannot 100% pick
// up the difference between a property not being set and it being an
// expression
xit('overrides expressions + fires toast', async () => {
const editor = await renderTestEditorWithCode(
makeTestProjectCodeWithSnippet(
`
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import {
} from '../../../../core/model/element-metadata-utils'
import { generateUidWithExistingComponents } from '../../../../core/model/element-template-utils'
import {
MarginPropertyPaths,
removeBackgroundProperties,
removeMarginProperties,
removePaddingProperties,
Expand Down Expand Up @@ -127,6 +128,7 @@ import type { Optic } from '../../../../core/shared/optics/optics'
import type { EditorContract } from './contracts/contract-helpers'
import { useRefEditorState } from '../../../editor/store/store-hook'
import { useDispatch } from '../../../editor/store/dispatch-context'
import { deleteProperties } from '../../commands/delete-properties-command'

const GroupImport: Imports = {
'utopia-api': {
Expand Down Expand Up @@ -423,14 +425,9 @@ export function convertFragmentToGroup(
MetadataUtils.findElementByElementPath(metadata, EP.parentPath(elementPath)),
) ?? zeroCanvasRect

const childrenPaths = MetadataUtils.getChildrenPathsOrdered(pathTrees, elementPath)
const { children, uid } = instance.element

// Remove the margins from the children.
const toPropsOptic = traverseArray<JSXElementChild>()
.compose(fromTypeGuard(isJSXElement))
.compose(fromField('props'))
const childrenWithoutMargins = modify(toPropsOptic, removeMarginProperties, children)

const left = instance.childrenBoundingFrame.x - parentBounds.x
const top = instance.childrenBoundingFrame.y - parentBounds.y

Expand All @@ -448,6 +445,7 @@ export function convertFragmentToGroup(
jsxElement(
'Group',
uid,
// TODO: set Tailwind props here
jsxAttributesFromMap({
'data-uid': jsExpressionValue(uid, emptyComments),
style: jsExpressionValue(
Expand All @@ -459,13 +457,14 @@ export function convertFragmentToGroup(
emptyComments,
),
}),
childrenWithoutMargins,
children,
),
{
indexPosition: absolute(MetadataUtils.getIndexInParent(metadata, pathTrees, elementPath)),
importsToAdd: GroupImport,
},
),
...childrenPaths.map((childPath) => deleteProperties('always', childPath, MarginPropertyPaths)),
...offsetChildrenByDelta(instance.childInstances, instance.childrenBoundingFrame),
]
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,9 @@ import type { ProjectContentTreeRoot } from '../../../../components/assets'
import {
trueUpGroupElementChanged,
type AllElementProps,
trueUpChildrenOfGroupChanged,
} from '../../../../components/editor/store/editor-state'
import { getLayoutProperty } from '../../../../core/layout/getLayoutProperty'
import type { StyleLayoutProp } from '../../../../core/layout/layout-helpers-new'
import type { LayoutPinnedProp, StyleLayoutProp } from '../../../../core/layout/layout-helpers-new'
import type { PropsOrJSXAttributes } from '../../../../core/model/element-metadata-utils'
import {
MetadataUtils,
Expand Down Expand Up @@ -551,7 +550,7 @@ export function isEmptyGroup(metadata: ElementInstanceMetadataMap, path: Element
)
}

function fixLengthCommand(path: ElementPath, prop: StyleLayoutProp, size: number): CanvasCommand {
function fixLengthCommand(path: ElementPath, prop: LayoutPinnedProp, size: number): CanvasCommand {
return setCssLengthProperty(
'always',
path,
Expand Down
Original file line number Diff line number Diff line change
@@ -1,7 +1,16 @@
import * as EP from '../../../../core/shared/element-path'
import { assertNever } from '../../../../core/shared/utils'
import { TailwindConfigPath } from '../../../../core/tailwind/tailwind-config'
import { createModifiedProject } from '../../../../sample-projects/sample-project-utils.test-utils'
import type { Modifiers } from '../../../../utils/modifiers'
import { cmdModifier, shiftModifier } from '../../../../utils/modifiers'
import { expectSingleUndo2Saves, wait } from '../../../../utils/utils.test-utils'
import { cmdModifier } from '../../../../utils/modifiers'
import {
expectSingleUndo2Saves,
selectComponentsForTest,
setFeatureForBrowserTestsUseInDescribeBlockOnly,
wait,
} from '../../../../utils/utils.test-utils'
import { StoryboardFilePath } from '../../../editor/store/editor-state'
import { cssNumber } from '../../../inspector/common/css-utils'
import type { EdgePiece } from '../../canvas-types'
import { isHorizontalEdgePiece } from '../../canvas-types'
Expand Down Expand Up @@ -39,6 +48,7 @@ import {
getPrintedUiJsCode,
makeTestProjectCodeWithSnippet,
renderTestEditorWithCode,
renderTestEditorWithModel,
} from '../../ui-jsx.test-utils'
import { PaddingTearThreshold, SetPaddingStrategyName } from './set-padding-strategy'

Expand Down Expand Up @@ -489,6 +499,7 @@ describe('Padding resize strategy', () => {
)
})

// FIXME: this test fails because of property zeroing
it('paddingTop can be removed by dragging when longhand props are present', async () => {
const dragDeltaToZero = -100
const editor = await renderTestEditorWithCode(
Expand Down Expand Up @@ -745,6 +756,88 @@ describe('Padding resize strategy', () => {
})
})
})

describe('Tailwind', () => {
setFeatureForBrowserTestsUseInDescribeBlockOnly('Tailwind', true)

const TailwindProject = (classes: string) =>
createModifiedProject({
[StoryboardFilePath]: `
import React from 'react'
import { Scene, Storyboard } from 'utopia-api'
export var storyboard = (
<Storyboard data-uid='sb'>
<Scene
id='scene'
commentId='scene'
data-uid='scene'
style={{
width: 700,
height: 759,
position: 'absolute',
left: 212,
top: 128,
}}
>
<div
data-uid='mydiv'
data-testid='mydiv'
className='top-10 left-10 absolute flex flex-row ${classes}'
>
<div className='bg-red-500 w-10 h-10' data-uid='child-1' />
<div className='bg-red-500 w-10 h-10' data-uid='child-2' />
</div>
</Scene>
</Storyboard>
)

`,
[TailwindConfigPath]: `
const TailwindConfig = { }
export default TailwindConfig
`,
'app.css': `
@tailwind base;
@tailwind components;
@tailwind utilities;`,
})

it('can set tailwind padding', async () => {
const editor = await renderTestEditorWithModel(
TailwindProject('p-12'),
'await-first-dom-report',
)
await selectComponentsForTest(editor, [EP.fromString('sb/scene/mydiv')])
await testPaddingResizeForEdge(editor, 50, 'top', 'precise')
await editor.getDispatchFollowUpActionsFinished()
const div = editor.renderedDOM.getByTestId('mydiv')
expect(div.className).toEqual('top-10 left-10 absolute flex flex-row p-[6rem_3rem_3rem_3rem]')
})

it('can remove tailwind padding', async () => {
const editor = await renderTestEditorWithModel(
TailwindProject('p-4'),
'await-first-dom-report',
)
await selectComponentsForTest(editor, [EP.fromString('sb/scene/mydiv')])
await testPaddingResizeForEdge(editor, -150, 'top', 'precise')
await editor.getDispatchFollowUpActionsFinished()
const div = editor.renderedDOM.getByTestId('mydiv')
expect(div.className).toEqual('top-10 left-10 absolute flex flex-row pb-4 pl-4 pr-4')
})

it('can set tailwind padding longhand', async () => {
const editor = await renderTestEditorWithModel(
TailwindProject('pt-12'),
'await-first-dom-report',
)
await selectComponentsForTest(editor, [EP.fromString('sb/scene/mydiv')])
await testPaddingResizeForEdge(editor, 50, 'top', 'precise')
await editor.getDispatchFollowUpActionsFinished()
const div = editor.renderedDOM.getByTestId('mydiv')
expect(div.className).toEqual('top-10 left-10 absolute flex flex-row pt-24')
})
})
})

async function testAdjustIndividualPaddingValue(edge: EdgePiece, precision: AdjustPrecision) {
Expand Down
Loading
Loading