@bookklik/senangstart-css 0.1.4 → 0.1.8
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/.github/workflows/deploy-docs.yml +7 -1
- package/dist/senangstart-css.js +1436 -14
- package/dist/senangstart-css.min.js +1159 -10
- package/docs/.vitepress/config.js +624 -18
- package/docs/.vitepress/theme/custom.css +0 -1
- package/docs/SYNTAX-REFERENCE.md +1555 -0
- package/docs/guide/preflight.md +139 -0
- package/docs/index.md +8 -20
- package/docs/ms/guide/preflight.md +139 -0
- package/docs/ms/index.md +8 -20
- package/docs/ms/reference/colors.md +45 -45
- package/docs/ms/reference/layout/align-content.md +35 -0
- package/docs/ms/reference/layout/align-items.md +33 -0
- package/docs/ms/reference/layout/align-self.md +34 -0
- package/docs/ms/reference/layout/aspect-ratio.md +40 -0
- package/docs/ms/reference/layout/border-collapse.md +30 -0
- package/docs/ms/reference/layout/border-spacing.md +39 -0
- package/docs/ms/reference/layout/box-sizing.md +30 -0
- package/docs/ms/reference/layout/caption-side.md +30 -0
- package/docs/ms/reference/layout/columns.md +30 -0
- package/docs/ms/reference/layout/container.md +29 -0
- package/docs/ms/reference/layout/display.md +60 -0
- package/docs/ms/reference/layout/flex-basis.md +38 -0
- package/docs/ms/reference/layout/flex-direction.md +33 -0
- package/docs/ms/reference/layout/flex-items.md +32 -0
- package/docs/ms/reference/layout/flex-wrap.md +31 -0
- package/docs/ms/reference/layout/flex.md +40 -0
- package/docs/ms/reference/layout/float-clear.md +32 -0
- package/docs/ms/reference/layout/grid-auto-flow.md +33 -0
- package/docs/ms/reference/layout/grid-auto-sizing.md +32 -0
- package/docs/ms/reference/layout/grid-column-span.md +31 -0
- package/docs/ms/reference/layout/grid-columns.md +32 -0
- package/docs/ms/reference/layout/grid-row-span.md +30 -0
- package/docs/ms/reference/layout/grid-rows.md +31 -0
- package/docs/ms/reference/layout/inset.md +44 -0
- package/docs/ms/reference/layout/isolation.md +30 -0
- package/docs/ms/reference/layout/justify-content.md +36 -0
- package/docs/ms/reference/layout/justify-items.md +32 -0
- package/docs/ms/reference/layout/justify-self.md +33 -0
- package/docs/ms/reference/layout/object-fit.md +33 -0
- package/docs/ms/reference/layout/object-position.md +45 -0
- package/docs/ms/reference/layout/order.md +32 -0
- package/docs/ms/reference/layout/overflow.md +34 -0
- package/docs/ms/reference/layout/overscroll.md +31 -0
- package/docs/ms/reference/layout/place-content.md +35 -0
- package/docs/ms/reference/layout/place-items.md +32 -0
- package/docs/ms/reference/layout/place-self.md +33 -0
- package/docs/ms/reference/layout/position.md +34 -0
- package/docs/ms/reference/layout/shorthand-alignment.md +34 -0
- package/docs/ms/reference/layout/table-layout.md +30 -0
- package/docs/ms/reference/layout/visibility.md +30 -0
- package/docs/ms/reference/layout/z-index.md +33 -0
- package/docs/ms/reference/layout.md +53 -95
- package/docs/ms/reference/space/arbitrary-values.md +32 -0
- package/docs/ms/reference/space/gap.md +44 -0
- package/docs/ms/reference/space/height.md +44 -0
- package/docs/ms/reference/space/margin.md +49 -0
- package/docs/ms/reference/space/padding.md +49 -0
- package/docs/ms/reference/space/scale-reference.md +43 -0
- package/docs/ms/reference/space/sizing.md +27 -0
- package/docs/ms/reference/space/width.md +45 -0
- package/docs/ms/reference/space.md +15 -99
- package/docs/ms/reference/spacing.md +22 -8
- package/docs/ms/reference/visual/accent-color.md +31 -0
- package/docs/ms/reference/visual/animation-builtin.md +41 -0
- package/docs/ms/reference/visual/animation-delay.md +41 -0
- package/docs/ms/reference/visual/animation-direction.md +32 -0
- package/docs/ms/reference/visual/animation-duration.md +43 -0
- package/docs/ms/reference/visual/animation-fill.md +32 -0
- package/docs/ms/reference/visual/animation-iteration.md +30 -0
- package/docs/ms/reference/visual/animation-play.md +30 -0
- package/docs/ms/reference/visual/appearance.md +30 -0
- package/docs/ms/reference/visual/backdrop-blur.md +43 -0
- package/docs/ms/reference/visual/backdrop-brightness.md +41 -0
- package/docs/ms/reference/visual/backdrop-contrast.md +41 -0
- package/docs/ms/reference/visual/backdrop-grayscale.md +39 -0
- package/docs/ms/reference/visual/backdrop-hue-rotate.md +39 -0
- package/docs/ms/reference/visual/backdrop-invert.md +39 -0
- package/docs/ms/reference/visual/backdrop-opacity.md +39 -0
- package/docs/ms/reference/visual/backdrop-saturate.md +41 -0
- package/docs/ms/reference/visual/backdrop-sepia.md +39 -0
- package/docs/ms/reference/visual/background-attachment.md +31 -0
- package/docs/ms/reference/visual/background-blend-mode.md +34 -0
- package/docs/ms/reference/visual/background-clip.md +32 -0
- package/docs/ms/reference/visual/background-color.md +33 -0
- package/docs/ms/reference/visual/background-image.md +41 -0
- package/docs/ms/reference/visual/background-origin.md +31 -0
- package/docs/ms/reference/visual/background-position.md +45 -0
- package/docs/ms/reference/visual/background-repeat.md +34 -0
- package/docs/ms/reference/visual/background-size.md +39 -0
- package/docs/ms/reference/visual/background.md +13 -0
- package/docs/ms/reference/visual/blend-modes.md +34 -0
- package/docs/ms/reference/visual/border-radius.md +34 -0
- package/docs/ms/reference/visual/border-style.md +33 -0
- package/docs/ms/reference/visual/border-width.md +44 -0
- package/docs/ms/reference/visual/border.md +43 -0
- package/docs/ms/reference/visual/box-shadow.md +33 -0
- package/docs/ms/reference/visual/caret-color.md +31 -0
- package/docs/ms/reference/visual/color-scheme.md +31 -0
- package/docs/ms/reference/visual/cursor.md +37 -0
- package/docs/ms/reference/visual/field-sizing.md +30 -0
- package/docs/ms/reference/visual/fill.md +38 -0
- package/docs/ms/reference/visual/filter-blur.md +43 -0
- package/docs/ms/reference/visual/filter-brightness.md +41 -0
- package/docs/ms/reference/visual/filter-contrast.md +41 -0
- package/docs/ms/reference/visual/filter-drop-shadow.md +42 -0
- package/docs/ms/reference/visual/filter-grayscale.md +39 -0
- package/docs/ms/reference/visual/filter-hue-rotate.md +39 -0
- package/docs/ms/reference/visual/filter-invert.md +39 -0
- package/docs/ms/reference/visual/filter-saturate.md +41 -0
- package/docs/ms/reference/visual/filter-sepia.md +39 -0
- package/docs/ms/reference/visual/font-family.md +31 -0
- package/docs/ms/reference/visual/font-smoothing.md +30 -0
- package/docs/ms/reference/visual/font-style.md +30 -0
- package/docs/ms/reference/visual/font-variant-numeric.md +35 -0
- package/docs/ms/reference/visual/font-weight.md +31 -0
- package/docs/ms/reference/visual/forced-color-adjust.md +30 -0
- package/docs/ms/reference/visual/hyphens.md +31 -0
- package/docs/ms/reference/visual/letter-spacing.md +42 -0
- package/docs/ms/reference/visual/line-clamp.md +40 -0
- package/docs/ms/reference/visual/line-height.md +42 -0
- package/docs/ms/reference/visual/list-style.md +34 -0
- package/docs/ms/reference/visual/mask.md +39 -0
- package/docs/ms/reference/visual/opacity.md +33 -0
- package/docs/ms/reference/visual/outline.md +31 -0
- package/docs/ms/reference/visual/pointer-events.md +30 -0
- package/docs/ms/reference/visual/resize.md +32 -0
- package/docs/ms/reference/visual/scroll-behavior.md +30 -0
- package/docs/ms/reference/visual/scroll-margin.md +41 -0
- package/docs/ms/reference/visual/scroll-padding.md +41 -0
- package/docs/ms/reference/visual/scroll-snap-align.md +32 -0
- package/docs/ms/reference/visual/scroll-snap-stop.md +30 -0
- package/docs/ms/reference/visual/scroll-snap-type.md +34 -0
- package/docs/ms/reference/visual/state-prefixes.md +37 -0
- package/docs/ms/reference/visual/stroke-width.md +39 -0
- package/docs/ms/reference/visual/stroke.md +38 -0
- package/docs/ms/reference/visual/text-alignment.md +32 -0
- package/docs/ms/reference/visual/text-color.md +41 -0
- package/docs/ms/reference/visual/text-decoration.md +32 -0
- package/docs/ms/reference/visual/text-indent.md +37 -0
- package/docs/ms/reference/visual/text-overflow.md +31 -0
- package/docs/ms/reference/visual/text-shadow.md +40 -0
- package/docs/ms/reference/visual/text-size.md +32 -0
- package/docs/ms/reference/visual/text-transform.md +32 -0
- package/docs/ms/reference/visual/text-wrap.md +32 -0
- package/docs/ms/reference/visual/touch-action.md +36 -0
- package/docs/ms/reference/visual/transform-backface.md +30 -0
- package/docs/ms/reference/visual/transform-origin.md +45 -0
- package/docs/ms/reference/visual/transform-perspective-origin.md +45 -0
- package/docs/ms/reference/visual/transform-perspective.md +43 -0
- package/docs/ms/reference/visual/transform-rotate.md +40 -0
- package/docs/ms/reference/visual/transform-scale.md +43 -0
- package/docs/ms/reference/visual/transform-skew.md +40 -0
- package/docs/ms/reference/visual/transform-style.md +30 -0
- package/docs/ms/reference/visual/transform-translate.md +39 -0
- package/docs/ms/reference/visual/transition-delay.md +41 -0
- package/docs/ms/reference/visual/transition-duration.md +43 -0
- package/docs/ms/reference/visual/transition-property.md +34 -0
- package/docs/ms/reference/visual/transition-timing.md +40 -0
- package/docs/ms/reference/visual/typography-keywords.md +81 -0
- package/docs/ms/reference/visual/user-select.md +32 -0
- package/docs/ms/reference/visual/vertical-align.md +36 -0
- package/docs/ms/reference/visual/whitespace.md +34 -0
- package/docs/ms/reference/visual/will-change.md +33 -0
- package/docs/ms/reference/visual/word-break.md +32 -0
- package/docs/ms/reference/visual.md +145 -148
- package/docs/public/assets/senangstart-css.min.js +1545 -0
- package/docs/reference/layout/align-content.md +35 -0
- package/docs/reference/layout/align-items.md +33 -0
- package/docs/reference/layout/align-self.md +34 -0
- package/docs/reference/layout/aspect-ratio.md +40 -0
- package/docs/reference/layout/border-collapse.md +30 -0
- package/docs/reference/layout/border-spacing.md +39 -0
- package/docs/reference/layout/box-sizing.md +30 -0
- package/docs/reference/layout/caption-side.md +30 -0
- package/docs/reference/layout/columns.md +30 -0
- package/docs/reference/layout/container.md +29 -0
- package/docs/reference/layout/display.md +60 -0
- package/docs/reference/layout/flex-basis.md +38 -0
- package/docs/reference/layout/flex-direction.md +33 -0
- package/docs/reference/layout/flex-items.md +32 -0
- package/docs/reference/layout/flex-wrap.md +31 -0
- package/docs/reference/layout/flex.md +40 -0
- package/docs/reference/layout/float-clear.md +32 -0
- package/docs/reference/layout/grid-auto-flow.md +33 -0
- package/docs/reference/layout/grid-auto-sizing.md +32 -0
- package/docs/reference/layout/grid-column-span.md +31 -0
- package/docs/reference/layout/grid-columns.md +32 -0
- package/docs/reference/layout/grid-row-span.md +30 -0
- package/docs/reference/layout/grid-rows.md +31 -0
- package/docs/reference/layout/inset.md +44 -0
- package/docs/reference/layout/isolation.md +30 -0
- package/docs/reference/layout/justify-content.md +36 -0
- package/docs/reference/layout/justify-items.md +32 -0
- package/docs/reference/layout/justify-self.md +33 -0
- package/docs/reference/layout/object-fit.md +33 -0
- package/docs/reference/layout/object-position.md +45 -0
- package/docs/reference/layout/order.md +32 -0
- package/docs/reference/layout/overflow.md +34 -0
- package/docs/reference/layout/overscroll.md +31 -0
- package/docs/reference/layout/place-content.md +35 -0
- package/docs/reference/layout/place-items.md +32 -0
- package/docs/reference/layout/place-self.md +33 -0
- package/docs/reference/layout/position.md +34 -0
- package/docs/reference/layout/shorthand-alignment.md +34 -0
- package/docs/reference/layout/table-layout.md +30 -0
- package/docs/reference/layout/visibility.md +30 -0
- package/docs/reference/layout/z-index.md +33 -0
- package/docs/reference/layout.md +60 -102
- package/docs/reference/space/arbitrary-values.md +39 -0
- package/docs/reference/space/gap.md +44 -0
- package/docs/reference/space/height.md +44 -0
- package/docs/reference/space/margin.md +49 -0
- package/docs/reference/space/padding.md +49 -0
- package/docs/reference/space/scale-reference.md +43 -0
- package/docs/reference/space/width.md +45 -0
- package/docs/reference/space.md +14 -98
- package/docs/reference/spacing.md +22 -8
- package/docs/reference/visual/accent-color.md +31 -0
- package/docs/reference/visual/animation-builtin.md +41 -0
- package/docs/reference/visual/animation-delay.md +41 -0
- package/docs/reference/visual/animation-direction.md +32 -0
- package/docs/reference/visual/animation-duration.md +43 -0
- package/docs/reference/visual/animation-fill.md +32 -0
- package/docs/reference/visual/animation-iteration.md +30 -0
- package/docs/reference/visual/animation-play.md +30 -0
- package/docs/reference/visual/appearance.md +30 -0
- package/docs/reference/visual/backdrop-blur.md +43 -0
- package/docs/reference/visual/backdrop-brightness.md +41 -0
- package/docs/reference/visual/backdrop-contrast.md +41 -0
- package/docs/reference/visual/backdrop-grayscale.md +39 -0
- package/docs/reference/visual/backdrop-hue-rotate.md +39 -0
- package/docs/reference/visual/backdrop-invert.md +39 -0
- package/docs/reference/visual/backdrop-opacity.md +39 -0
- package/docs/reference/visual/backdrop-saturate.md +41 -0
- package/docs/reference/visual/backdrop-sepia.md +39 -0
- package/docs/reference/visual/background-attachment.md +31 -0
- package/docs/reference/visual/background-blend-mode.md +34 -0
- package/docs/reference/visual/background-clip.md +32 -0
- package/docs/reference/visual/background-color.md +33 -0
- package/docs/reference/visual/background-image.md +41 -0
- package/docs/reference/visual/background-origin.md +31 -0
- package/docs/reference/visual/background-position.md +45 -0
- package/docs/reference/visual/background-repeat.md +34 -0
- package/docs/reference/visual/background-size.md +39 -0
- package/docs/reference/visual/blend-modes.md +34 -0
- package/docs/reference/visual/border-radius.md +34 -0
- package/docs/reference/visual/border-style.md +33 -0
- package/docs/reference/visual/border-width.md +44 -0
- package/docs/reference/visual/border.md +43 -0
- package/docs/reference/visual/box-shadow.md +33 -0
- package/docs/reference/visual/caret-color.md +31 -0
- package/docs/reference/visual/color-scheme.md +31 -0
- package/docs/reference/visual/cursor.md +37 -0
- package/docs/reference/visual/field-sizing.md +30 -0
- package/docs/reference/visual/fill.md +38 -0
- package/docs/reference/visual/filter-blur.md +43 -0
- package/docs/reference/visual/filter-brightness.md +41 -0
- package/docs/reference/visual/filter-contrast.md +41 -0
- package/docs/reference/visual/filter-drop-shadow.md +42 -0
- package/docs/reference/visual/filter-grayscale.md +39 -0
- package/docs/reference/visual/filter-hue-rotate.md +39 -0
- package/docs/reference/visual/filter-invert.md +39 -0
- package/docs/reference/visual/filter-saturate.md +41 -0
- package/docs/reference/visual/filter-sepia.md +39 -0
- package/docs/reference/visual/font-family.md +31 -0
- package/docs/reference/visual/font-smoothing.md +30 -0
- package/docs/reference/visual/font-style.md +30 -0
- package/docs/reference/visual/font-variant-numeric.md +35 -0
- package/docs/reference/visual/font-weight.md +31 -0
- package/docs/reference/visual/forced-color-adjust.md +30 -0
- package/docs/reference/visual/hyphens.md +31 -0
- package/docs/reference/visual/letter-spacing.md +42 -0
- package/docs/reference/visual/line-clamp.md +40 -0
- package/docs/reference/visual/line-height.md +42 -0
- package/docs/reference/visual/list-style.md +34 -0
- package/docs/reference/visual/mask.md +39 -0
- package/docs/reference/visual/opacity.md +33 -0
- package/docs/reference/visual/outline.md +31 -0
- package/docs/reference/visual/pointer-events.md +30 -0
- package/docs/reference/visual/resize.md +32 -0
- package/docs/reference/visual/scroll-behavior.md +30 -0
- package/docs/reference/visual/scroll-margin.md +41 -0
- package/docs/reference/visual/scroll-padding.md +41 -0
- package/docs/reference/visual/scroll-snap-align.md +32 -0
- package/docs/reference/visual/scroll-snap-stop.md +30 -0
- package/docs/reference/visual/scroll-snap-type.md +34 -0
- package/docs/reference/visual/state-prefixes.md +37 -0
- package/docs/reference/visual/stroke-width.md +39 -0
- package/docs/reference/visual/stroke.md +38 -0
- package/docs/reference/visual/text-alignment.md +32 -0
- package/docs/reference/visual/text-color.md +41 -0
- package/docs/reference/visual/text-decoration.md +32 -0
- package/docs/reference/visual/text-indent.md +37 -0
- package/docs/reference/visual/text-overflow.md +31 -0
- package/docs/reference/visual/text-shadow.md +40 -0
- package/docs/reference/visual/text-size.md +32 -0
- package/docs/reference/visual/text-transform.md +32 -0
- package/docs/reference/visual/text-wrap.md +32 -0
- package/docs/reference/visual/touch-action.md +36 -0
- package/docs/reference/visual/transform-backface.md +30 -0
- package/docs/reference/visual/transform-origin.md +45 -0
- package/docs/reference/visual/transform-perspective-origin.md +45 -0
- package/docs/reference/visual/transform-perspective.md +43 -0
- package/docs/reference/visual/transform-rotate.md +40 -0
- package/docs/reference/visual/transform-scale.md +43 -0
- package/docs/reference/visual/transform-skew.md +40 -0
- package/docs/reference/visual/transform-style.md +30 -0
- package/docs/reference/visual/transform-translate.md +39 -0
- package/docs/reference/visual/transition-delay.md +41 -0
- package/docs/reference/visual/transition-duration.md +43 -0
- package/docs/reference/visual/transition-property.md +34 -0
- package/docs/reference/visual/transition-timing.md +40 -0
- package/docs/reference/visual/typography-keywords.md +81 -0
- package/docs/reference/visual/user-select.md +32 -0
- package/docs/reference/visual/vertical-align.md +36 -0
- package/docs/reference/visual/whitespace.md +34 -0
- package/docs/reference/visual/will-change.md +33 -0
- package/docs/reference/visual/word-break.md +32 -0
- package/docs/reference/visual.md +151 -154
- package/docs/syntax-reference.json +1973 -0
- package/package.json +12 -4
- package/playground/index.html +78 -0
- package/playground/jit-test.html +384 -0
- package/scripts/extract-syntax.js +152 -0
- package/scripts/generate-docs.js +352 -0
- package/src/cdn/jit.js +1436 -14
- package/src/cli/commands/build.js +5 -0
- package/src/cli/index.js +2 -0
- package/src/compiler/generators/css.js +1537 -25
- package/src/compiler/generators/preflight.js +379 -0
- package/src/config/defaults.js +19 -1
- package/src/definitions/index.js +153 -0
- package/src/definitions/layout-alignment.js +257 -0
- package/src/definitions/layout-flex.js +209 -0
- package/src/definitions/layout-grid.js +150 -0
- package/src/definitions/layout-positioning.js +89 -0
- package/src/definitions/layout-table.js +98 -0
- package/src/definitions/layout-utilities.js +262 -0
- package/src/definitions/layout.js +195 -0
- package/src/definitions/space.js +164 -0
- package/src/definitions/visual-backgrounds.js +423 -0
- package/src/definitions/visual-borders.js +111 -0
- package/src/definitions/visual-filters.js +204 -0
- package/src/definitions/visual-interactivity.js +292 -0
- package/src/definitions/visual-svg.js +80 -0
- package/src/definitions/visual-transform3d.js +159 -0
- package/src/definitions/visual-transforms.js +142 -0
- package/src/definitions/visual-transitions.js +277 -0
- package/src/definitions/visual-typography.js +386 -0
- package/src/definitions/visual.js +542 -0
- package/tests/helpers/test-utils.js +144 -0
- package/tests/integration/compiler.test.js +247 -0
- package/tests/sync/docs-sync.test.js +364 -0
- package/tests/unit/compiler/generators/css.test.js +719 -0
- package/tests/unit/compiler/parser.test.js +244 -0
- package/tests/unit/compiler/tokenizer.test.js +305 -0
- package/tests/unit/config/defaults.test.js +168 -0
- package/docs/.vitepress/cache/deps/_metadata.json +0 -31
- package/docs/.vitepress/cache/deps/chunk-LE5NDSFD.js +0 -12824
- package/docs/.vitepress/cache/deps/chunk-LE5NDSFD.js.map +0 -7
- package/docs/.vitepress/cache/deps/package.json +0 -3
- package/docs/.vitepress/cache/deps/vitepress___@vue_devtools-api.js +0 -4505
- package/docs/.vitepress/cache/deps/vitepress___@vue_devtools-api.js.map +0 -7
- package/docs/.vitepress/cache/deps/vitepress___@vueuse_core.js +0 -9731
- package/docs/.vitepress/cache/deps/vitepress___@vueuse_core.js.map +0 -7
- package/docs/.vitepress/cache/deps/vue.js +0 -347
- package/docs/.vitepress/cache/deps/vue.js.map +0 -7
- package/docs/.vitepress/dist/404.html +0 -22
- package/docs/.vitepress/dist/assets/app.DBXoyO4w.js +0 -1
- package/docs/.vitepress/dist/assets/chunks/framework.I305HrzY.js +0 -19
- package/docs/.vitepress/dist/assets/chunks/theme.CaXH1t3X.js +0 -1
- package/docs/.vitepress/dist/assets/examples_cards.md.BCzaqSD6.js +0 -84
- package/docs/.vitepress/dist/assets/examples_cards.md.BCzaqSD6.lean.js +0 -1
- package/docs/.vitepress/dist/assets/examples_forms.md.DOjr9LrG.js +0 -169
- package/docs/.vitepress/dist/assets/examples_forms.md.DOjr9LrG.lean.js +0 -1
- package/docs/.vitepress/dist/assets/examples_hero.md.CAorji-Y.js +0 -118
- package/docs/.vitepress/dist/assets/examples_hero.md.CAorji-Y.lean.js +0 -1
- package/docs/.vitepress/dist/assets/examples_index.md.BjUNsTob.js +0 -52
- package/docs/.vitepress/dist/assets/examples_index.md.BjUNsTob.lean.js +0 -1
- package/docs/.vitepress/dist/assets/examples_navigation.md.DvL-Yv_5.js +0 -106
- package/docs/.vitepress/dist/assets/examples_navigation.md.DvL-Yv_5.lean.js +0 -1
- package/docs/.vitepress/dist/assets/guide_cdn.md.Bbb7-icp.js +0 -30
- package/docs/.vitepress/dist/assets/guide_cdn.md.Bbb7-icp.lean.js +0 -1
- package/docs/.vitepress/dist/assets/guide_cli.md.yLsOZ7NL.js +0 -44
- package/docs/.vitepress/dist/assets/guide_cli.md.yLsOZ7NL.lean.js +0 -1
- package/docs/.vitepress/dist/assets/guide_configuration.md.DN4FfKw4.js +0 -79
- package/docs/.vitepress/dist/assets/guide_configuration.md.DN4FfKw4.lean.js +0 -1
- package/docs/.vitepress/dist/assets/guide_dark-mode.md.D6UJvQtM.js +0 -69
- package/docs/.vitepress/dist/assets/guide_dark-mode.md.D6UJvQtM.lean.js +0 -1
- package/docs/.vitepress/dist/assets/guide_getting-started.md.K5nA8wXY.js +0 -47
- package/docs/.vitepress/dist/assets/guide_getting-started.md.K5nA8wXY.lean.js +0 -1
- package/docs/.vitepress/dist/assets/guide_index.md.B0lRU150.js +0 -3
- package/docs/.vitepress/dist/assets/guide_index.md.B0lRU150.lean.js +0 -1
- package/docs/.vitepress/dist/assets/guide_natural-scale.md.vvauT7U1.js +0 -22
- package/docs/.vitepress/dist/assets/guide_natural-scale.md.vvauT7U1.lean.js +0 -1
- package/docs/.vitepress/dist/assets/guide_philosophy.md.mOb9kp32.js +0 -7
- package/docs/.vitepress/dist/assets/guide_philosophy.md.mOb9kp32.lean.js +0 -1
- package/docs/.vitepress/dist/assets/guide_responsive.md.C7cF-4cR.js +0 -57
- package/docs/.vitepress/dist/assets/guide_responsive.md.C7cF-4cR.lean.js +0 -1
- package/docs/.vitepress/dist/assets/guide_states.md.CwtGEGHB.js +0 -77
- package/docs/.vitepress/dist/assets/guide_states.md.CwtGEGHB.lean.js +0 -1
- package/docs/.vitepress/dist/assets/guide_tri-attribute.md.CpjJLEMP.js +0 -45
- package/docs/.vitepress/dist/assets/guide_tri-attribute.md.CpjJLEMP.lean.js +0 -1
- package/docs/.vitepress/dist/assets/index.md.mYp6_S5X.js +0 -7
- package/docs/.vitepress/dist/assets/index.md.mYp6_S5X.lean.js +0 -1
- package/docs/.vitepress/dist/assets/inter-italic-cyrillic-ext.r48I6akx.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-italic-cyrillic.By2_1cv3.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-italic-greek-ext.1u6EdAuj.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-italic-greek.DJ8dCoTZ.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-italic-latin-ext.CN1xVJS-.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-italic-latin.C2AdPX0b.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-italic-vietnamese.BSbpV94h.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-roman-cyrillic-ext.BBPuwvHQ.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-roman-cyrillic.C5lxZ8CY.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-roman-greek-ext.CqjqNYQ-.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-roman-greek.BBVDIX6e.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-roman-latin-ext.4ZJIpNVo.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-roman-latin.Di8DUHzh.woff2 +0 -0
- package/docs/.vitepress/dist/assets/inter-roman-vietnamese.BjW4sHH5.woff2 +0 -0
- package/docs/.vitepress/dist/assets/ms_examples_cards.md.CaE5JNAs.js +0 -84
- package/docs/.vitepress/dist/assets/ms_examples_cards.md.CaE5JNAs.lean.js +0 -1
- package/docs/.vitepress/dist/assets/ms_examples_forms.md.VvDzMzxF.js +0 -169
- package/docs/.vitepress/dist/assets/ms_examples_forms.md.VvDzMzxF.lean.js +0 -1
- package/docs/.vitepress/dist/assets/ms_examples_hero.md.DC4c3kKW.js +0 -118
- package/docs/.vitepress/dist/assets/ms_examples_hero.md.DC4c3kKW.lean.js +0 -1
- package/docs/.vitepress/dist/assets/ms_examples_index.md.C13ShcjA.js +0 -52
- package/docs/.vitepress/dist/assets/ms_examples_index.md.C13ShcjA.lean.js +0 -1
- package/docs/.vitepress/dist/assets/ms_examples_navigation.md.BPtVjKbk.js +0 -106
- package/docs/.vitepress/dist/assets/ms_examples_navigation.md.BPtVjKbk.lean.js +0 -1
- package/docs/.vitepress/dist/assets/ms_guide_cdn.md.tZFpEjTS.js +0 -30
- package/docs/.vitepress/dist/assets/ms_guide_cdn.md.tZFpEjTS.lean.js +0 -1
- package/docs/.vitepress/dist/assets/ms_guide_cli.md.DBjxv3-o.js +0 -44
- package/docs/.vitepress/dist/assets/ms_guide_cli.md.DBjxv3-o.lean.js +0 -1
- package/docs/.vitepress/dist/assets/ms_guide_configuration.md.CyYNqREm.js +0 -79
- package/docs/.vitepress/dist/assets/ms_guide_configuration.md.CyYNqREm.lean.js +0 -1
- package/docs/.vitepress/dist/assets/ms_guide_dark-mode.md.DWDWvzzv.js +0 -69
- package/docs/.vitepress/dist/assets/ms_guide_dark-mode.md.DWDWvzzv.lean.js +0 -1
- package/docs/.vitepress/dist/assets/ms_guide_getting-started.md.WoQwRhlY.js +0 -47
- package/docs/.vitepress/dist/assets/ms_guide_getting-started.md.WoQwRhlY.lean.js +0 -1
- package/docs/.vitepress/dist/assets/ms_guide_index.md.pHpXZMmU.js +0 -3
- package/docs/.vitepress/dist/assets/ms_guide_index.md.pHpXZMmU.lean.js +0 -1
- package/docs/.vitepress/dist/assets/ms_guide_natural-scale.md.BiUfU-TH.js +0 -22
- package/docs/.vitepress/dist/assets/ms_guide_natural-scale.md.BiUfU-TH.lean.js +0 -1
- package/docs/.vitepress/dist/assets/ms_guide_philosophy.md.hf3SG2Ts.js +0 -7
- package/docs/.vitepress/dist/assets/ms_guide_philosophy.md.hf3SG2Ts.lean.js +0 -1
- package/docs/.vitepress/dist/assets/ms_guide_responsive.md.C4yS3zzM.js +0 -57
- package/docs/.vitepress/dist/assets/ms_guide_responsive.md.C4yS3zzM.lean.js +0 -1
- package/docs/.vitepress/dist/assets/ms_guide_states.md.DkDEjPdC.js +0 -77
- package/docs/.vitepress/dist/assets/ms_guide_states.md.DkDEjPdC.lean.js +0 -1
- package/docs/.vitepress/dist/assets/ms_guide_tri-attribute.md.C3Es_V5J.js +0 -45
- package/docs/.vitepress/dist/assets/ms_guide_tri-attribute.md.C3Es_V5J.lean.js +0 -1
- package/docs/.vitepress/dist/assets/ms_index.md.Bmo9il08.js +0 -7
- package/docs/.vitepress/dist/assets/ms_index.md.Bmo9il08.lean.js +0 -1
- package/docs/.vitepress/dist/assets/ms_reference_breakpoints.md.DR7i_--b.js +0 -48
- package/docs/.vitepress/dist/assets/ms_reference_breakpoints.md.DR7i_--b.lean.js +0 -1
- package/docs/.vitepress/dist/assets/ms_reference_colors.md.06ZYiMcJ.js +0 -17
- package/docs/.vitepress/dist/assets/ms_reference_colors.md.06ZYiMcJ.lean.js +0 -1
- package/docs/.vitepress/dist/assets/ms_reference_layout.md.NGL6A5SR.js +0 -13
- package/docs/.vitepress/dist/assets/ms_reference_layout.md.NGL6A5SR.lean.js +0 -1
- package/docs/.vitepress/dist/assets/ms_reference_space.md.BG5YQ-09.js +0 -24
- package/docs/.vitepress/dist/assets/ms_reference_space.md.BG5YQ-09.lean.js +0 -1
- package/docs/.vitepress/dist/assets/ms_reference_spacing.md.XmXLLPOZ.js +0 -32
- package/docs/.vitepress/dist/assets/ms_reference_spacing.md.XmXLLPOZ.lean.js +0 -1
- package/docs/.vitepress/dist/assets/ms_reference_visual.md.BVOlkEqc.js +0 -22
- package/docs/.vitepress/dist/assets/ms_reference_visual.md.BVOlkEqc.lean.js +0 -1
- package/docs/.vitepress/dist/assets/reference_breakpoints.md.BRbG8Fzi.js +0 -48
- package/docs/.vitepress/dist/assets/reference_breakpoints.md.BRbG8Fzi.lean.js +0 -1
- package/docs/.vitepress/dist/assets/reference_colors.md.C7j7dSO1.js +0 -17
- package/docs/.vitepress/dist/assets/reference_colors.md.C7j7dSO1.lean.js +0 -1
- package/docs/.vitepress/dist/assets/reference_layout.md.BWJ5NxSp.js +0 -13
- package/docs/.vitepress/dist/assets/reference_layout.md.BWJ5NxSp.lean.js +0 -1
- package/docs/.vitepress/dist/assets/reference_space.md.DCsqfTWb.js +0 -24
- package/docs/.vitepress/dist/assets/reference_space.md.DCsqfTWb.lean.js +0 -1
- package/docs/.vitepress/dist/assets/reference_spacing.md.BInFD8gd.js +0 -32
- package/docs/.vitepress/dist/assets/reference_spacing.md.BInFD8gd.lean.js +0 -1
- package/docs/.vitepress/dist/assets/reference_visual.md.BRK7S9T1.js +0 -22
- package/docs/.vitepress/dist/assets/reference_visual.md.BRK7S9T1.lean.js +0 -1
- package/docs/.vitepress/dist/assets/style.D82StYDI.css +0 -1
- package/docs/.vitepress/dist/examples/cards.html +0 -108
- package/docs/.vitepress/dist/examples/forms.html +0 -193
- package/docs/.vitepress/dist/examples/hero.html +0 -142
- package/docs/.vitepress/dist/examples/index.html +0 -76
- package/docs/.vitepress/dist/examples/navigation.html +0 -130
- package/docs/.vitepress/dist/guide/cdn.html +0 -54
- package/docs/.vitepress/dist/guide/cli.html +0 -68
- package/docs/.vitepress/dist/guide/configuration.html +0 -103
- package/docs/.vitepress/dist/guide/dark-mode.html +0 -93
- package/docs/.vitepress/dist/guide/getting-started.html +0 -71
- package/docs/.vitepress/dist/guide/index.html +0 -27
- package/docs/.vitepress/dist/guide/natural-scale.html +0 -46
- package/docs/.vitepress/dist/guide/philosophy.html +0 -31
- package/docs/.vitepress/dist/guide/responsive.html +0 -81
- package/docs/.vitepress/dist/guide/states.html +0 -101
- package/docs/.vitepress/dist/guide/tri-attribute.html +0 -69
- package/docs/.vitepress/dist/hashmap.json +0 -1
- package/docs/.vitepress/dist/index.html +0 -31
- package/docs/.vitepress/dist/ms/examples/cards.html +0 -108
- package/docs/.vitepress/dist/ms/examples/forms.html +0 -193
- package/docs/.vitepress/dist/ms/examples/hero.html +0 -142
- package/docs/.vitepress/dist/ms/examples/index.html +0 -76
- package/docs/.vitepress/dist/ms/examples/navigation.html +0 -130
- package/docs/.vitepress/dist/ms/guide/cdn.html +0 -54
- package/docs/.vitepress/dist/ms/guide/cli.html +0 -68
- package/docs/.vitepress/dist/ms/guide/configuration.html +0 -103
- package/docs/.vitepress/dist/ms/guide/dark-mode.html +0 -93
- package/docs/.vitepress/dist/ms/guide/getting-started.html +0 -71
- package/docs/.vitepress/dist/ms/guide/index.html +0 -27
- package/docs/.vitepress/dist/ms/guide/natural-scale.html +0 -46
- package/docs/.vitepress/dist/ms/guide/philosophy.html +0 -31
- package/docs/.vitepress/dist/ms/guide/responsive.html +0 -81
- package/docs/.vitepress/dist/ms/guide/states.html +0 -101
- package/docs/.vitepress/dist/ms/guide/tri-attribute.html +0 -69
- package/docs/.vitepress/dist/ms/index.html +0 -31
- package/docs/.vitepress/dist/ms/reference/breakpoints.html +0 -72
- package/docs/.vitepress/dist/ms/reference/colors.html +0 -41
- package/docs/.vitepress/dist/ms/reference/layout.html +0 -37
- package/docs/.vitepress/dist/ms/reference/space.html +0 -48
- package/docs/.vitepress/dist/ms/reference/spacing.html +0 -56
- package/docs/.vitepress/dist/ms/reference/visual.html +0 -46
- package/docs/.vitepress/dist/reference/breakpoints.html +0 -72
- package/docs/.vitepress/dist/reference/colors.html +0 -41
- package/docs/.vitepress/dist/reference/layout.html +0 -37
- package/docs/.vitepress/dist/reference/space.html +0 -48
- package/docs/.vitepress/dist/reference/spacing.html +0 -56
- package/docs/.vitepress/dist/reference/visual.html +0 -46
- package/docs/.vitepress/dist/vp-icons.css +0 -1
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SenangStart CSS - SVG Utility Definitions
|
|
3
|
+
* Fill, stroke, stroke-width for SVG elements
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
// ======================
|
|
7
|
+
// SVG FILL
|
|
8
|
+
// ======================
|
|
9
|
+
|
|
10
|
+
export const svgFill = {
|
|
11
|
+
name: 'fill',
|
|
12
|
+
property: 'visual',
|
|
13
|
+
syntax: 'visual="fill:[color]"',
|
|
14
|
+
description: 'Set SVG fill color',
|
|
15
|
+
descriptionMs: 'Tetapkan warna pengisian SVG',
|
|
16
|
+
category: 'visual',
|
|
17
|
+
usesScale: 'colors',
|
|
18
|
+
supportsArbitrary: true,
|
|
19
|
+
values: [
|
|
20
|
+
{ value: 'none', css: 'fill: none;', description: 'No fill', descriptionMs: 'Tiada pengisian' },
|
|
21
|
+
{ value: 'current', css: 'fill: currentColor;', description: 'Current color', descriptionMs: 'Warna semasa' }
|
|
22
|
+
],
|
|
23
|
+
examples: [
|
|
24
|
+
{ code: '<svg visual="fill:primary">...</svg>', description: 'Primary fill' }
|
|
25
|
+
]
|
|
26
|
+
};
|
|
27
|
+
|
|
28
|
+
// ======================
|
|
29
|
+
// SVG STROKE
|
|
30
|
+
// ======================
|
|
31
|
+
|
|
32
|
+
export const svgStroke = {
|
|
33
|
+
name: 'stroke',
|
|
34
|
+
property: 'visual',
|
|
35
|
+
syntax: 'visual="stroke:[color]"',
|
|
36
|
+
description: 'Set SVG stroke color',
|
|
37
|
+
descriptionMs: 'Tetapkan warna gurisan SVG',
|
|
38
|
+
category: 'visual',
|
|
39
|
+
usesScale: 'colors',
|
|
40
|
+
supportsArbitrary: true,
|
|
41
|
+
values: [
|
|
42
|
+
{ value: 'none', css: 'stroke: none;', description: 'No stroke', descriptionMs: 'Tiada gurisan' },
|
|
43
|
+
{ value: 'current', css: 'stroke: currentColor;', description: 'Current color', descriptionMs: 'Warna semasa' }
|
|
44
|
+
],
|
|
45
|
+
examples: [
|
|
46
|
+
{ code: '<svg visual="stroke:primary stroke-w:2">...</svg>', description: 'Primary stroke' }
|
|
47
|
+
]
|
|
48
|
+
};
|
|
49
|
+
|
|
50
|
+
// ======================
|
|
51
|
+
// SVG STROKE WIDTH
|
|
52
|
+
// ======================
|
|
53
|
+
|
|
54
|
+
export const svgStrokeWidth = {
|
|
55
|
+
name: 'stroke-width',
|
|
56
|
+
property: 'visual',
|
|
57
|
+
syntax: 'visual="stroke-w:[value]"',
|
|
58
|
+
description: 'Set SVG stroke width',
|
|
59
|
+
descriptionMs: 'Tetapkan lebar gurisan SVG',
|
|
60
|
+
category: 'visual',
|
|
61
|
+
supportsArbitrary: true,
|
|
62
|
+
dynamic: true,
|
|
63
|
+
values: [
|
|
64
|
+
{ value: '0', css: 'stroke-width: 0;', description: 'No stroke', descriptionMs: 'Tiada gurisan' },
|
|
65
|
+
{ value: '1', css: 'stroke-width: 1px;', description: '1px stroke', descriptionMs: 'Gurisan 1px' },
|
|
66
|
+
{ value: '2', css: 'stroke-width: 2px;', description: '2px stroke', descriptionMs: 'Gurisan 2px' }
|
|
67
|
+
],
|
|
68
|
+
examples: [
|
|
69
|
+
{ code: '<svg visual="stroke:black stroke-w:2">...</svg>', description: '2px stroke' }
|
|
70
|
+
]
|
|
71
|
+
};
|
|
72
|
+
|
|
73
|
+
// Export all SVG definitions
|
|
74
|
+
export const svgDefinitions = {
|
|
75
|
+
svgFill,
|
|
76
|
+
svgStroke,
|
|
77
|
+
svgStrokeWidth
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
export default svgDefinitions;
|
|
@@ -0,0 +1,159 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SenangStart CSS - 3D Transform Utility Definitions
|
|
3
|
+
* Perspective, backface, and 3D transform utilities
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
// ======================
|
|
7
|
+
// PERSPECTIVE
|
|
8
|
+
// ======================
|
|
9
|
+
|
|
10
|
+
export const perspective = {
|
|
11
|
+
name: 'transform-perspective',
|
|
12
|
+
property: 'visual',
|
|
13
|
+
syntax: 'visual="perspective:[value]"',
|
|
14
|
+
description: 'Set 3D perspective',
|
|
15
|
+
descriptionMs: 'Tetapkan perspektif 3D',
|
|
16
|
+
category: 'visual',
|
|
17
|
+
supportsArbitrary: true,
|
|
18
|
+
values: [
|
|
19
|
+
{ value: 'none', css: 'perspective: none;', description: 'No perspective', descriptionMs: 'Tiada perspektif' },
|
|
20
|
+
{ value: 'dramatic', css: 'perspective: 100px;', description: 'Dramatic perspective', descriptionMs: 'Perspektif dramatik' },
|
|
21
|
+
{ value: 'near', css: 'perspective: 300px;', description: 'Near perspective', descriptionMs: 'Perspektif dekat' },
|
|
22
|
+
{ value: 'normal', css: 'perspective: 500px;', description: 'Normal perspective', descriptionMs: 'Perspektif normal' },
|
|
23
|
+
{ value: 'midrange', css: 'perspective: 800px;', description: 'Midrange perspective', descriptionMs: 'Perspektif pertengahan' },
|
|
24
|
+
{ value: 'far', css: 'perspective: 1000px;', description: 'Far perspective', descriptionMs: 'Perspektif jauh' },
|
|
25
|
+
{ value: 'distant', css: 'perspective: 1200px;', description: 'Distant perspective', descriptionMs: 'Perspektif jauh sekali' }
|
|
26
|
+
],
|
|
27
|
+
examples: [
|
|
28
|
+
{ code: '<div visual="perspective:normal">3D container</div>', description: 'Normal perspective' }
|
|
29
|
+
]
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
// ======================
|
|
33
|
+
// PERSPECTIVE ORIGIN
|
|
34
|
+
// ======================
|
|
35
|
+
|
|
36
|
+
export const perspectiveOrigin = {
|
|
37
|
+
name: 'transform-perspective-origin',
|
|
38
|
+
property: 'visual',
|
|
39
|
+
syntax: 'visual="perspective-origin:[value]"',
|
|
40
|
+
description: 'Set perspective origin point',
|
|
41
|
+
descriptionMs: 'Tetapkan titik asal perspektif',
|
|
42
|
+
category: 'visual',
|
|
43
|
+
supportsArbitrary: true,
|
|
44
|
+
values: [
|
|
45
|
+
{ value: 'center', css: 'perspective-origin: center;', description: 'Center origin', descriptionMs: 'Asal tengah' },
|
|
46
|
+
{ value: 'top', css: 'perspective-origin: top;', description: 'Top origin', descriptionMs: 'Asal atas' },
|
|
47
|
+
{ value: 'bottom', css: 'perspective-origin: bottom;', description: 'Bottom origin', descriptionMs: 'Asal bawah' },
|
|
48
|
+
{ value: 'left', css: 'perspective-origin: left;', description: 'Left origin', descriptionMs: 'Asal kiri' },
|
|
49
|
+
{ value: 'right', css: 'perspective-origin: right;', description: 'Right origin', descriptionMs: 'Asal kanan' },
|
|
50
|
+
{ value: 'top-left', css: 'perspective-origin: top left;', description: 'Top left', descriptionMs: 'Atas kiri' },
|
|
51
|
+
{ value: 'top-right', css: 'perspective-origin: top right;', description: 'Top right', descriptionMs: 'Atas kanan' },
|
|
52
|
+
{ value: 'bottom-left', css: 'perspective-origin: bottom left;', description: 'Bottom left', descriptionMs: 'Bawah kiri' },
|
|
53
|
+
{ value: 'bottom-right', css: 'perspective-origin: bottom right;', description: 'Bottom right', descriptionMs: 'Bawah kanan' }
|
|
54
|
+
],
|
|
55
|
+
examples: [
|
|
56
|
+
{ code: '<div visual="perspective-origin:top">Top origin</div>', description: 'Top origin' }
|
|
57
|
+
]
|
|
58
|
+
};
|
|
59
|
+
|
|
60
|
+
// ======================
|
|
61
|
+
// TRANSFORM STYLE
|
|
62
|
+
// ======================
|
|
63
|
+
|
|
64
|
+
export const transformStyle = {
|
|
65
|
+
name: 'transform-style',
|
|
66
|
+
property: 'visual',
|
|
67
|
+
syntax: 'visual="transform-style:[value]"',
|
|
68
|
+
description: 'Set 3D transform style',
|
|
69
|
+
descriptionMs: 'Tetapkan gaya transform 3D',
|
|
70
|
+
category: 'visual',
|
|
71
|
+
values: [
|
|
72
|
+
{ value: 'flat', css: 'transform-style: flat;', description: 'Flat rendering', descriptionMs: 'Persembahan rata' },
|
|
73
|
+
{ value: 'preserve-3d', css: 'transform-style: preserve-3d;', description: 'Preserve 3D', descriptionMs: 'Kekalkan 3D' }
|
|
74
|
+
],
|
|
75
|
+
examples: [
|
|
76
|
+
{ code: '<div visual="transform-style:preserve-3d">3D space</div>', description: 'Preserve 3D' }
|
|
77
|
+
]
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
// ======================
|
|
81
|
+
// BACKFACE VISIBILITY
|
|
82
|
+
// ======================
|
|
83
|
+
|
|
84
|
+
export const backfaceVisibility = {
|
|
85
|
+
name: 'transform-backface',
|
|
86
|
+
property: 'visual',
|
|
87
|
+
syntax: 'visual="backface:[value]"',
|
|
88
|
+
description: 'Control backface visibility',
|
|
89
|
+
descriptionMs: 'Kawal keterlihatan belakang',
|
|
90
|
+
category: 'visual',
|
|
91
|
+
values: [
|
|
92
|
+
{ value: 'visible', css: 'backface-visibility: visible;', description: 'Backface visible', descriptionMs: 'Belakang kelihatan' },
|
|
93
|
+
{ value: 'hidden', css: 'backface-visibility: hidden;', description: 'Backface hidden', descriptionMs: 'Belakang tersembunyi' }
|
|
94
|
+
],
|
|
95
|
+
examples: [
|
|
96
|
+
{ code: '<div visual="backface:hidden">Hidden when rotated</div>', description: 'Hide backface' }
|
|
97
|
+
]
|
|
98
|
+
};
|
|
99
|
+
|
|
100
|
+
// ======================
|
|
101
|
+
// MASK
|
|
102
|
+
// ======================
|
|
103
|
+
|
|
104
|
+
export const mask = {
|
|
105
|
+
name: 'mask',
|
|
106
|
+
property: 'visual',
|
|
107
|
+
syntax: 'visual="mask:[value]"',
|
|
108
|
+
description: 'Apply mask to element',
|
|
109
|
+
descriptionMs: 'Terapkan topeng pada elemen',
|
|
110
|
+
category: 'visual',
|
|
111
|
+
supportsArbitrary: true,
|
|
112
|
+
values: [
|
|
113
|
+
{ value: 'none', css: 'mask-image: none;', description: 'No mask', descriptionMs: 'Tiada topeng' },
|
|
114
|
+
{ value: 'fade-y', css: 'mask-image: linear-gradient(to bottom, transparent, black 10%, black 90%, transparent);', description: 'Vertical fade', descriptionMs: 'Pudar menegak' },
|
|
115
|
+
{ value: 'fade-x', css: 'mask-image: linear-gradient(to right, transparent, black 10%, black 90%, transparent);', description: 'Horizontal fade', descriptionMs: 'Pudar mendatar' }
|
|
116
|
+
],
|
|
117
|
+
examples: [
|
|
118
|
+
{ code: '<div visual="mask:fade-y">Faded edges</div>', description: 'Vertical fade mask' }
|
|
119
|
+
]
|
|
120
|
+
};
|
|
121
|
+
|
|
122
|
+
// ======================
|
|
123
|
+
// STATE PREFIXES
|
|
124
|
+
// ======================
|
|
125
|
+
|
|
126
|
+
export const statePrefixes = {
|
|
127
|
+
name: 'state-prefixes',
|
|
128
|
+
property: 'visual',
|
|
129
|
+
syntax: 'visual="hover:... focus:... active:..."',
|
|
130
|
+
description: 'Apply styles on specific states',
|
|
131
|
+
descriptionMs: 'Terapkan gaya pada keadaan tertentu',
|
|
132
|
+
category: 'visual',
|
|
133
|
+
values: [
|
|
134
|
+
{ value: 'hover:', css: ':hover', description: 'On hover', descriptionMs: 'Pada hover' },
|
|
135
|
+
{ value: 'focus:', css: ':focus', description: 'On focus', descriptionMs: 'Pada fokus' },
|
|
136
|
+
{ value: 'active:', css: ':active', description: 'On active', descriptionMs: 'Pada aktif' },
|
|
137
|
+
{ value: 'disabled:', css: ':disabled', description: 'When disabled', descriptionMs: 'Apabila dilumpuhkan' },
|
|
138
|
+
{ value: 'visited:', css: ':visited', description: 'When visited', descriptionMs: 'Apabila dilawati' },
|
|
139
|
+
{ value: 'first:', css: ':first-child', description: 'First child', descriptionMs: 'Anak pertama' },
|
|
140
|
+
{ value: 'last:', css: ':last-child', description: 'Last child', descriptionMs: 'Anak terakhir' },
|
|
141
|
+
{ value: 'odd:', css: ':nth-child(odd)', description: 'Odd children', descriptionMs: 'Anak ganjil' },
|
|
142
|
+
{ value: 'even:', css: ':nth-child(even)', description: 'Even children', descriptionMs: 'Anak genap' }
|
|
143
|
+
],
|
|
144
|
+
examples: [
|
|
145
|
+
{ code: '<button visual="hover:bg:primary focus:outline:primary">Interactive button</button>', description: 'State prefixes' }
|
|
146
|
+
]
|
|
147
|
+
};
|
|
148
|
+
|
|
149
|
+
// Export all 3D transform definitions
|
|
150
|
+
export const transform3dDefinitions = {
|
|
151
|
+
perspective,
|
|
152
|
+
perspectiveOrigin,
|
|
153
|
+
transformStyle,
|
|
154
|
+
backfaceVisibility,
|
|
155
|
+
mask,
|
|
156
|
+
statePrefixes
|
|
157
|
+
};
|
|
158
|
+
|
|
159
|
+
export default transform3dDefinitions;
|
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SenangStart CSS - Transform Utility Definitions
|
|
3
|
+
* Scale, rotate, translate, skew, origin
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
// ======================
|
|
7
|
+
// TRANSFORM - SCALE
|
|
8
|
+
// ======================
|
|
9
|
+
|
|
10
|
+
export const transformScale = {
|
|
11
|
+
name: 'transform-scale',
|
|
12
|
+
property: 'visual',
|
|
13
|
+
syntax: 'visual="scale:[value]"',
|
|
14
|
+
description: 'Scale element',
|
|
15
|
+
descriptionMs: 'Skala elemen',
|
|
16
|
+
category: 'visual',
|
|
17
|
+
supportsArbitrary: true,
|
|
18
|
+
dynamic: true,
|
|
19
|
+
values: [
|
|
20
|
+
{ value: '0', css: 'transform: scale(0);', description: 'Scale to 0', descriptionMs: 'Skala ke 0' },
|
|
21
|
+
{ value: '50', css: 'transform: scale(0.5);', description: 'Scale to 50%', descriptionMs: 'Skala ke 50%' },
|
|
22
|
+
{ value: '75', css: 'transform: scale(0.75);', description: 'Scale to 75%', descriptionMs: 'Skala ke 75%' },
|
|
23
|
+
{ value: '100', css: 'transform: scale(1);', description: 'Normal scale', descriptionMs: 'Skala normal' },
|
|
24
|
+
{ value: '110', css: 'transform: scale(1.1);', description: 'Scale to 110%', descriptionMs: 'Skala ke 110%' },
|
|
25
|
+
{ value: '125', css: 'transform: scale(1.25);', description: 'Scale to 125%', descriptionMs: 'Skala ke 125%' },
|
|
26
|
+
{ value: '150', css: 'transform: scale(1.5);', description: 'Scale to 150%', descriptionMs: 'Skala ke 150%' }
|
|
27
|
+
],
|
|
28
|
+
examples: [
|
|
29
|
+
{ code: '<div visual="transition:transform hover:scale:110">Hover to grow</div>', description: 'Scale on hover' }
|
|
30
|
+
]
|
|
31
|
+
};
|
|
32
|
+
|
|
33
|
+
// ======================
|
|
34
|
+
// TRANSFORM - ROTATE
|
|
35
|
+
// ======================
|
|
36
|
+
|
|
37
|
+
export const transformRotate = {
|
|
38
|
+
name: 'transform-rotate',
|
|
39
|
+
property: 'visual',
|
|
40
|
+
syntax: 'visual="rotate:[degrees]"',
|
|
41
|
+
description: 'Rotate element',
|
|
42
|
+
descriptionMs: 'Putar elemen',
|
|
43
|
+
category: 'visual',
|
|
44
|
+
supportsArbitrary: true,
|
|
45
|
+
dynamic: true,
|
|
46
|
+
values: [
|
|
47
|
+
{ value: '0', css: 'transform: rotate(0deg);', description: 'No rotation', descriptionMs: 'Tiada putaran' },
|
|
48
|
+
{ value: '45', css: 'transform: rotate(45deg);', description: '45° rotation', descriptionMs: 'Putaran 45°' },
|
|
49
|
+
{ value: '90', css: 'transform: rotate(90deg);', description: '90° rotation', descriptionMs: 'Putaran 90°' },
|
|
50
|
+
{ value: '180', css: 'transform: rotate(180deg);', description: '180° rotation', descriptionMs: 'Putaran 180°' }
|
|
51
|
+
],
|
|
52
|
+
examples: [
|
|
53
|
+
{ code: '<div visual="rotate:45">Rotated 45 degrees</div>', description: '45 degree rotation' }
|
|
54
|
+
]
|
|
55
|
+
};
|
|
56
|
+
|
|
57
|
+
// ======================
|
|
58
|
+
// TRANSFORM - TRANSLATE
|
|
59
|
+
// ======================
|
|
60
|
+
|
|
61
|
+
export const transformTranslate = {
|
|
62
|
+
name: 'transform-translate',
|
|
63
|
+
property: 'visual',
|
|
64
|
+
syntax: 'visual="translate-x:[value]" or visual="translate-y:[value]"',
|
|
65
|
+
description: 'Translate element position',
|
|
66
|
+
descriptionMs: 'Alihkan kedudukan elemen',
|
|
67
|
+
category: 'visual',
|
|
68
|
+
usesScale: 'spacing',
|
|
69
|
+
supportsArbitrary: true,
|
|
70
|
+
dynamic: true,
|
|
71
|
+
values: [
|
|
72
|
+
{ value: '0', css: 'transform: translateX(0);', description: 'No translation', descriptionMs: 'Tiada alihan' },
|
|
73
|
+
{ value: 'full', css: 'transform: translateX(100%);', description: 'Full width', descriptionMs: 'Lebar penuh' },
|
|
74
|
+
{ value: '1/2', css: 'transform: translateX(50%);', description: 'Half width', descriptionMs: 'Separuh lebar' }
|
|
75
|
+
],
|
|
76
|
+
examples: [
|
|
77
|
+
{ code: '<div visual="translate-x:full">Moved right</div>', description: 'Translate right' }
|
|
78
|
+
]
|
|
79
|
+
};
|
|
80
|
+
|
|
81
|
+
// ======================
|
|
82
|
+
// TRANSFORM - SKEW
|
|
83
|
+
// ======================
|
|
84
|
+
|
|
85
|
+
export const transformSkew = {
|
|
86
|
+
name: 'transform-skew',
|
|
87
|
+
property: 'visual',
|
|
88
|
+
syntax: 'visual="skew-x:[degrees]" or visual="skew-y:[degrees]"',
|
|
89
|
+
description: 'Skew element',
|
|
90
|
+
descriptionMs: 'Condongkan elemen',
|
|
91
|
+
category: 'visual',
|
|
92
|
+
supportsArbitrary: true,
|
|
93
|
+
dynamic: true,
|
|
94
|
+
values: [
|
|
95
|
+
{ value: '0', css: 'transform: skewX(0deg);', description: 'No skew', descriptionMs: 'Tiada condong' },
|
|
96
|
+
{ value: '3', css: 'transform: skewX(3deg);', description: '3° skew', descriptionMs: 'Condong 3°' },
|
|
97
|
+
{ value: '6', css: 'transform: skewX(6deg);', description: '6° skew', descriptionMs: 'Condong 6°' },
|
|
98
|
+
{ value: '12', css: 'transform: skewX(12deg);', description: '12° skew', descriptionMs: 'Condong 12°' }
|
|
99
|
+
],
|
|
100
|
+
examples: [
|
|
101
|
+
{ code: '<div visual="skew-x:6">Skewed element</div>', description: 'Skew 6 degrees' }
|
|
102
|
+
]
|
|
103
|
+
};
|
|
104
|
+
|
|
105
|
+
// ======================
|
|
106
|
+
// TRANSFORM ORIGIN
|
|
107
|
+
// ======================
|
|
108
|
+
|
|
109
|
+
export const transformOrigin = {
|
|
110
|
+
name: 'transform-origin',
|
|
111
|
+
property: 'visual',
|
|
112
|
+
syntax: 'visual="origin:[value]"',
|
|
113
|
+
description: 'Set transform origin point',
|
|
114
|
+
descriptionMs: 'Tetapkan titik asal transformasi',
|
|
115
|
+
category: 'visual',
|
|
116
|
+
supportsArbitrary: true,
|
|
117
|
+
values: [
|
|
118
|
+
{ value: 'center', css: 'transform-origin: center;', description: 'Center origin', descriptionMs: 'Asal tengah' },
|
|
119
|
+
{ value: 'top', css: 'transform-origin: top;', description: 'Top origin', descriptionMs: 'Asal atas' },
|
|
120
|
+
{ value: 'top-right', css: 'transform-origin: top right;', description: 'Top right', descriptionMs: 'Atas kanan' },
|
|
121
|
+
{ value: 'right', css: 'transform-origin: right;', description: 'Right origin', descriptionMs: 'Asal kanan' },
|
|
122
|
+
{ value: 'bottom-right', css: 'transform-origin: bottom right;', description: 'Bottom right', descriptionMs: 'Bawah kanan' },
|
|
123
|
+
{ value: 'bottom', css: 'transform-origin: bottom;', description: 'Bottom origin', descriptionMs: 'Asal bawah' },
|
|
124
|
+
{ value: 'bottom-left', css: 'transform-origin: bottom left;', description: 'Bottom left', descriptionMs: 'Bawah kiri' },
|
|
125
|
+
{ value: 'left', css: 'transform-origin: left;', description: 'Left origin', descriptionMs: 'Asal kiri' },
|
|
126
|
+
{ value: 'top-left', css: 'transform-origin: top left;', description: 'Top left', descriptionMs: 'Atas kiri' }
|
|
127
|
+
],
|
|
128
|
+
examples: [
|
|
129
|
+
{ code: '<div visual="rotate:45 origin:top-left">Rotate from corner</div>', description: 'Rotate from corner' }
|
|
130
|
+
]
|
|
131
|
+
};
|
|
132
|
+
|
|
133
|
+
// Export all transform definitions
|
|
134
|
+
export const transformDefinitions = {
|
|
135
|
+
transformScale,
|
|
136
|
+
transformRotate,
|
|
137
|
+
transformTranslate,
|
|
138
|
+
transformSkew,
|
|
139
|
+
transformOrigin
|
|
140
|
+
};
|
|
141
|
+
|
|
142
|
+
export default transformDefinitions;
|
|
@@ -0,0 +1,277 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SenangStart CSS - Transition & Animation Utility Definitions
|
|
3
|
+
* Transition properties, duration, timing, delay, and animations
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
// ======================
|
|
7
|
+
// TRANSITION PROPERTY
|
|
8
|
+
// ======================
|
|
9
|
+
|
|
10
|
+
export const transitionProperty = {
|
|
11
|
+
name: 'transition-property',
|
|
12
|
+
property: 'visual',
|
|
13
|
+
syntax: 'visual="transition:[value]"',
|
|
14
|
+
description: 'Set transition properties',
|
|
15
|
+
descriptionMs: 'Tetapkan properti peralihan',
|
|
16
|
+
category: 'visual',
|
|
17
|
+
values: [
|
|
18
|
+
{ value: 'none', css: 'transition-property: none;', description: 'No transition', descriptionMs: 'Tiada peralihan' },
|
|
19
|
+
{ value: 'all', css: 'transition-property: all; transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1); transition-duration: 150ms;', description: 'All properties', descriptionMs: 'Semua properti' },
|
|
20
|
+
{ value: 'colors', css: 'transition-property: color, background-color, border-color; transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1); transition-duration: 150ms;', description: 'Color properties', descriptionMs: 'Properti warna' },
|
|
21
|
+
{ value: 'opacity', css: 'transition-property: opacity; transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1); transition-duration: 150ms;', description: 'Opacity only', descriptionMs: 'Kelegapan sahaja' },
|
|
22
|
+
{ value: 'shadow', css: 'transition-property: box-shadow; transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1); transition-duration: 150ms;', description: 'Shadow only', descriptionMs: 'Bayang sahaja' },
|
|
23
|
+
{ value: 'transform', css: 'transition-property: transform; transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1); transition-duration: 150ms;', description: 'Transform only', descriptionMs: 'Transformasi sahaja' }
|
|
24
|
+
],
|
|
25
|
+
examples: [
|
|
26
|
+
{ code: '<button visual="transition:all hover:bg:primary">Smooth hover</button>', description: 'Smooth transition' }
|
|
27
|
+
]
|
|
28
|
+
};
|
|
29
|
+
|
|
30
|
+
// ======================
|
|
31
|
+
// TRANSITION DURATION
|
|
32
|
+
// ======================
|
|
33
|
+
|
|
34
|
+
export const transitionDuration = {
|
|
35
|
+
name: 'transition-duration',
|
|
36
|
+
property: 'visual',
|
|
37
|
+
syntax: 'visual="duration:[value]"',
|
|
38
|
+
description: 'Set transition duration',
|
|
39
|
+
descriptionMs: 'Tetapkan tempoh peralihan',
|
|
40
|
+
category: 'visual',
|
|
41
|
+
supportsArbitrary: true,
|
|
42
|
+
values: [
|
|
43
|
+
{ value: 'instant', css: 'transition-duration: 75ms;', description: '75ms', descriptionMs: '75ms' },
|
|
44
|
+
{ value: 'quick', css: 'transition-duration: 100ms;', description: '100ms', descriptionMs: '100ms' },
|
|
45
|
+
{ value: 'fast', css: 'transition-duration: 150ms;', description: '150ms', descriptionMs: '150ms' },
|
|
46
|
+
{ value: 'normal', css: 'transition-duration: 200ms;', description: '200ms', descriptionMs: '200ms' },
|
|
47
|
+
{ value: 'slow', css: 'transition-duration: 300ms;', description: '300ms', descriptionMs: '300ms' },
|
|
48
|
+
{ value: 'slower', css: 'transition-duration: 500ms;', description: '500ms', descriptionMs: '500ms' },
|
|
49
|
+
{ value: 'lazy', css: 'transition-duration: 700ms;', description: '700ms', descriptionMs: '700ms' }
|
|
50
|
+
],
|
|
51
|
+
examples: [
|
|
52
|
+
{ code: '<div visual="transition:all duration:slow">Slow transition</div>', description: 'Slow duration' }
|
|
53
|
+
]
|
|
54
|
+
};
|
|
55
|
+
|
|
56
|
+
// ======================
|
|
57
|
+
// TRANSITION TIMING
|
|
58
|
+
// ======================
|
|
59
|
+
|
|
60
|
+
export const transitionTiming = {
|
|
61
|
+
name: 'transition-timing',
|
|
62
|
+
property: 'visual',
|
|
63
|
+
syntax: 'visual="ease:[value]"',
|
|
64
|
+
description: 'Set transition timing function',
|
|
65
|
+
descriptionMs: 'Tetapkan fungsi masa peralihan',
|
|
66
|
+
category: 'visual',
|
|
67
|
+
supportsArbitrary: true,
|
|
68
|
+
values: [
|
|
69
|
+
{ value: 'linear', css: 'transition-timing-function: linear;', description: 'Linear timing', descriptionMs: 'Masa linear' },
|
|
70
|
+
{ value: 'in', css: 'transition-timing-function: cubic-bezier(0.4, 0, 1, 1);', description: 'Ease in', descriptionMs: 'Memasuki mudah' },
|
|
71
|
+
{ value: 'out', css: 'transition-timing-function: cubic-bezier(0, 0, 0.2, 1);', description: 'Ease out', descriptionMs: 'Keluar mudah' },
|
|
72
|
+
{ value: 'in-out', css: 'transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);', description: 'Ease in-out', descriptionMs: 'Masuk-keluar mudah' }
|
|
73
|
+
],
|
|
74
|
+
examples: [
|
|
75
|
+
{ code: '<div visual="transition:all ease:out">Ease out effect</div>', description: 'Ease out timing' }
|
|
76
|
+
]
|
|
77
|
+
};
|
|
78
|
+
|
|
79
|
+
// ======================
|
|
80
|
+
// TRANSITION DELAY
|
|
81
|
+
// ======================
|
|
82
|
+
|
|
83
|
+
export const transitionDelay = {
|
|
84
|
+
name: 'transition-delay',
|
|
85
|
+
property: 'visual',
|
|
86
|
+
syntax: 'visual="delay:[value]"',
|
|
87
|
+
description: 'Set transition delay',
|
|
88
|
+
descriptionMs: 'Tetapkan kelewatan peralihan',
|
|
89
|
+
category: 'visual',
|
|
90
|
+
supportsArbitrary: true,
|
|
91
|
+
values: [
|
|
92
|
+
{ value: 'instant', css: 'transition-delay: 75ms;', description: '75ms delay', descriptionMs: 'Kelewatan 75ms' },
|
|
93
|
+
{ value: 'quick', css: 'transition-delay: 100ms;', description: '100ms delay', descriptionMs: 'Kelewatan 100ms' },
|
|
94
|
+
{ value: 'fast', css: 'transition-delay: 150ms;', description: '150ms delay', descriptionMs: 'Kelewatan 150ms' },
|
|
95
|
+
{ value: 'normal', css: 'transition-delay: 200ms;', description: '200ms delay', descriptionMs: 'Kelewatan 200ms' },
|
|
96
|
+
{ value: 'slow', css: 'transition-delay: 300ms;', description: '300ms delay', descriptionMs: 'Kelewatan 300ms' }
|
|
97
|
+
],
|
|
98
|
+
examples: [
|
|
99
|
+
{ code: '<div visual="transition:all delay:slow">Delayed transition</div>', description: 'Delayed start' }
|
|
100
|
+
]
|
|
101
|
+
};
|
|
102
|
+
|
|
103
|
+
// ======================
|
|
104
|
+
// ANIMATION
|
|
105
|
+
// ======================
|
|
106
|
+
|
|
107
|
+
export const animation = {
|
|
108
|
+
name: 'animation-builtin',
|
|
109
|
+
property: 'visual',
|
|
110
|
+
syntax: 'visual="animate:[value]"',
|
|
111
|
+
description: 'Apply built-in animations',
|
|
112
|
+
descriptionMs: 'Terapkan animasi terbina dalam',
|
|
113
|
+
category: 'visual',
|
|
114
|
+
supportsArbitrary: true,
|
|
115
|
+
values: [
|
|
116
|
+
{ value: 'none', css: 'animation: none;', description: 'No animation', descriptionMs: 'Tiada animasi' },
|
|
117
|
+
{ value: 'spin', css: 'animation: spin 1s linear infinite;', description: 'Spinning', descriptionMs: 'Berpusing' },
|
|
118
|
+
{ value: 'ping', css: 'animation: ping 1s cubic-bezier(0, 0, 0.2, 1) infinite;', description: 'Ping effect', descriptionMs: 'Kesan ping' },
|
|
119
|
+
{ value: 'pulse', css: 'animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;', description: 'Pulsing', descriptionMs: 'Berdenyut' },
|
|
120
|
+
{ value: 'bounce', css: 'animation: bounce 1s infinite;', description: 'Bouncing', descriptionMs: 'Melantun' }
|
|
121
|
+
],
|
|
122
|
+
examples: [
|
|
123
|
+
{ code: '<div visual="animate:spin">Loading...</div>', description: 'Spinning loader' }
|
|
124
|
+
]
|
|
125
|
+
};
|
|
126
|
+
|
|
127
|
+
// ======================
|
|
128
|
+
// ANIMATION DURATION
|
|
129
|
+
// ======================
|
|
130
|
+
|
|
131
|
+
export const animationDuration = {
|
|
132
|
+
name: 'animation-duration',
|
|
133
|
+
property: 'visual',
|
|
134
|
+
syntax: 'visual="animation-duration:[value]"',
|
|
135
|
+
description: 'Set animation duration',
|
|
136
|
+
descriptionMs: 'Tetapkan tempoh animasi',
|
|
137
|
+
category: 'visual',
|
|
138
|
+
supportsArbitrary: true,
|
|
139
|
+
values: [
|
|
140
|
+
{ value: 'instant', css: 'animation-duration: 75ms;', description: '75ms', descriptionMs: '75ms' },
|
|
141
|
+
{ value: 'quick', css: 'animation-duration: 100ms;', description: '100ms', descriptionMs: '100ms' },
|
|
142
|
+
{ value: 'fast', css: 'animation-duration: 150ms;', description: '150ms', descriptionMs: '150ms' },
|
|
143
|
+
{ value: 'normal', css: 'animation-duration: 200ms;', description: '200ms', descriptionMs: '200ms' },
|
|
144
|
+
{ value: 'slow', css: 'animation-duration: 300ms;', description: '300ms', descriptionMs: '300ms' },
|
|
145
|
+
{ value: 'slower', css: 'animation-duration: 500ms;', description: '500ms', descriptionMs: '500ms' },
|
|
146
|
+
{ value: 'lazy', css: 'animation-duration: 700ms;', description: '700ms', descriptionMs: '700ms' }
|
|
147
|
+
],
|
|
148
|
+
examples: [
|
|
149
|
+
{ code: '<div visual="animate:spin animation-duration:slow">Slow spin</div>', description: 'Slow animation' }
|
|
150
|
+
]
|
|
151
|
+
};
|
|
152
|
+
|
|
153
|
+
// ======================
|
|
154
|
+
// ANIMATION DELAY
|
|
155
|
+
// ======================
|
|
156
|
+
|
|
157
|
+
export const animationDelay = {
|
|
158
|
+
name: 'animation-delay',
|
|
159
|
+
property: 'visual',
|
|
160
|
+
syntax: 'visual="animation-delay:[value]"',
|
|
161
|
+
description: 'Set animation delay',
|
|
162
|
+
descriptionMs: 'Tetapkan kelewatan animasi',
|
|
163
|
+
category: 'visual',
|
|
164
|
+
supportsArbitrary: true,
|
|
165
|
+
values: [
|
|
166
|
+
{ value: 'instant', css: 'animation-delay: 75ms;', description: '75ms delay', descriptionMs: 'Kelewatan 75ms' },
|
|
167
|
+
{ value: 'quick', css: 'animation-delay: 100ms;', description: '100ms delay', descriptionMs: 'Kelewatan 100ms' },
|
|
168
|
+
{ value: 'fast', css: 'animation-delay: 150ms;', description: '150ms delay', descriptionMs: 'Kelewatan 150ms' },
|
|
169
|
+
{ value: 'normal', css: 'animation-delay: 200ms;', description: '200ms delay', descriptionMs: 'Kelewatan 200ms' },
|
|
170
|
+
{ value: 'slow', css: 'animation-delay: 300ms;', description: '300ms delay', descriptionMs: 'Kelewatan 300ms' }
|
|
171
|
+
],
|
|
172
|
+
examples: [
|
|
173
|
+
{ code: '<div visual="animate:bounce animation-delay:slow">Delayed bounce</div>', description: 'Delayed animation' }
|
|
174
|
+
]
|
|
175
|
+
};
|
|
176
|
+
|
|
177
|
+
// ======================
|
|
178
|
+
// ANIMATION ITERATION
|
|
179
|
+
// ======================
|
|
180
|
+
|
|
181
|
+
export const animationIteration = {
|
|
182
|
+
name: 'animation-iteration',
|
|
183
|
+
property: 'visual',
|
|
184
|
+
syntax: 'visual="animation-iteration:[value]"',
|
|
185
|
+
description: 'Set animation iteration count',
|
|
186
|
+
descriptionMs: 'Tetapkan bilangan ulangan animasi',
|
|
187
|
+
category: 'visual',
|
|
188
|
+
dynamic: true,
|
|
189
|
+
values: [
|
|
190
|
+
{ value: '1', css: 'animation-iteration-count: 1;', description: 'Once', descriptionMs: 'Sekali' },
|
|
191
|
+
{ value: 'infinite', css: 'animation-iteration-count: infinite;', description: 'Forever', descriptionMs: 'Selamanya' }
|
|
192
|
+
],
|
|
193
|
+
examples: [
|
|
194
|
+
{ code: '<div visual="animate:bounce animation-iteration:1">Bounce once</div>', description: 'Single iteration' }
|
|
195
|
+
]
|
|
196
|
+
};
|
|
197
|
+
|
|
198
|
+
// ======================
|
|
199
|
+
// ANIMATION DIRECTION
|
|
200
|
+
// ======================
|
|
201
|
+
|
|
202
|
+
export const animationDirection = {
|
|
203
|
+
name: 'animation-direction',
|
|
204
|
+
property: 'visual',
|
|
205
|
+
syntax: 'visual="animation-direction:[value]"',
|
|
206
|
+
description: 'Set animation direction',
|
|
207
|
+
descriptionMs: 'Tetapkan arah animasi',
|
|
208
|
+
category: 'visual',
|
|
209
|
+
values: [
|
|
210
|
+
{ value: 'normal', css: 'animation-direction: normal;', description: 'Normal direction', descriptionMs: 'Arah normal' },
|
|
211
|
+
{ value: 'reverse', css: 'animation-direction: reverse;', description: 'Reverse direction', descriptionMs: 'Arah terbalik' },
|
|
212
|
+
{ value: 'alternate', css: 'animation-direction: alternate;', description: 'Alternate direction', descriptionMs: 'Arah berselang' },
|
|
213
|
+
{ value: 'alternate-reverse', css: 'animation-direction: alternate-reverse;', description: 'Alternate reverse', descriptionMs: 'Berselang terbalik' }
|
|
214
|
+
],
|
|
215
|
+
examples: [
|
|
216
|
+
{ code: '<div visual="animate:bounce animation-direction:alternate">Alternating</div>', description: 'Alternate direction' }
|
|
217
|
+
]
|
|
218
|
+
};
|
|
219
|
+
|
|
220
|
+
// ======================
|
|
221
|
+
// ANIMATION FILL MODE
|
|
222
|
+
// ======================
|
|
223
|
+
|
|
224
|
+
export const animationFill = {
|
|
225
|
+
name: 'animation-fill',
|
|
226
|
+
property: 'visual',
|
|
227
|
+
syntax: 'visual="animation-fill:[value]"',
|
|
228
|
+
description: 'Set animation fill mode',
|
|
229
|
+
descriptionMs: 'Tetapkan mod pengisian animasi',
|
|
230
|
+
category: 'visual',
|
|
231
|
+
values: [
|
|
232
|
+
{ value: 'none', css: 'animation-fill-mode: none;', description: 'No fill', descriptionMs: 'Tiada pengisian' },
|
|
233
|
+
{ value: 'forwards', css: 'animation-fill-mode: forwards;', description: 'Keep end state', descriptionMs: 'Kekalkan keadaan akhir' },
|
|
234
|
+
{ value: 'backwards', css: 'animation-fill-mode: backwards;', description: 'Apply start state', descriptionMs: 'Terapkan keadaan mula' },
|
|
235
|
+
{ value: 'both', css: 'animation-fill-mode: both;', description: 'Both directions', descriptionMs: 'Kedua-dua arah' }
|
|
236
|
+
],
|
|
237
|
+
examples: [
|
|
238
|
+
{ code: '<div visual="animate:bounce animation-fill:forwards">Stays at end</div>', description: 'Keep final position' }
|
|
239
|
+
]
|
|
240
|
+
};
|
|
241
|
+
|
|
242
|
+
// ======================
|
|
243
|
+
// ANIMATION PLAY STATE
|
|
244
|
+
// ======================
|
|
245
|
+
|
|
246
|
+
export const animationPlay = {
|
|
247
|
+
name: 'animation-play',
|
|
248
|
+
property: 'visual',
|
|
249
|
+
syntax: 'visual="animation-play:[value]"',
|
|
250
|
+
description: 'Control animation play state',
|
|
251
|
+
descriptionMs: 'Kawal keadaan main animasi',
|
|
252
|
+
category: 'visual',
|
|
253
|
+
values: [
|
|
254
|
+
{ value: 'running', css: 'animation-play-state: running;', description: 'Animation running', descriptionMs: 'Animasi berjalan' },
|
|
255
|
+
{ value: 'paused', css: 'animation-play-state: paused;', description: 'Animation paused', descriptionMs: 'Animasi dijeda' }
|
|
256
|
+
],
|
|
257
|
+
examples: [
|
|
258
|
+
{ code: '<div visual="animate:spin hover:animation-play:paused">Pause on hover</div>', description: 'Pause on hover' }
|
|
259
|
+
]
|
|
260
|
+
};
|
|
261
|
+
|
|
262
|
+
// Export all transition/animation definitions
|
|
263
|
+
export const transitionDefinitions = {
|
|
264
|
+
transitionProperty,
|
|
265
|
+
transitionDuration,
|
|
266
|
+
transitionTiming,
|
|
267
|
+
transitionDelay,
|
|
268
|
+
animation,
|
|
269
|
+
animationDuration,
|
|
270
|
+
animationDelay,
|
|
271
|
+
animationIteration,
|
|
272
|
+
animationDirection,
|
|
273
|
+
animationFill,
|
|
274
|
+
animationPlay
|
|
275
|
+
};
|
|
276
|
+
|
|
277
|
+
export default transitionDefinitions;
|