This library is my attemp to port shadcn ui to Phoenix Liveview Component.
In Construction: Salad UI is in its early stages. Expect breaking changes in minor releases until 1.0 is ready! 🚀
- Adding salad_uito your list of dependencies inmix.exs:
def deps do
  [
    {:salad_ui, "~> 0.7.0"}
  ]
end- Add custom color
- Goto https://ui.shadcn.com/themes.
- Choose a color → Copy code → Paste to your app.cssfile
- Create new file tailwind.colors.jsonin your assets directory and paste following content
{
  "accent": {
    "DEFAULT": "hsl(var(--accent))",
    "foreground": "hsl(var(--accent-foreground))"
  },
  "background": "hsl(var(--background))",
  "border": "hsl(var(--border))",
  "card": {
    "DEFAULT": "hsl(var(--card))",
    "foreground": "hsl(var(--card-foreground))"
  },
  "destructive": {
    "DEFAULT": "hsl(var(--destructive))",
    "foreground": "hsl(var(--destructive-foreground))"
  },
  "foreground": "hsl(var(--foreground))",
  "input": "hsl(var(--input))",
  "muted": {
    "DEFAULT": "hsl(var(--muted))",
    "foreground": "hsl(var(--muted-foreground))"
  },
  "popover": {
    "DEFAULT": "hsl(var(--popover))",
    "foreground": "hsl(var(--popover-foreground))"
  },
  "primary": {
    "DEFAULT": "hsl(var(--primary))",
    "foreground": "hsl(var(--primary-foreground))"
  },
  "ring": "hsl(var(--ring))",
  "secondary": {
    "DEFAULT": "hsl(var(--secondary))",
    "foreground": "hsl(var(--secondary-foreground))"
  }
}- Configure tailwind
- Tell tailwind to extract class from SaladUI
- Add custom color
- Add tailwind plugin
module.exports = {
  content: [
    "../deps/salad_ui/lib/**/*.ex",
    ],
  theme: {
    extend: {
      colors: require("./tailwind.colors.json"),
    },
  },
  plugins: [
    require("@tailwindcss/typography"),
    require("tailwindcss-animate"),
    ...
  ]
}- Install tailwindcss-animate
cd assets
npm i -D tailwindcss-animate
# or yarn
yarn add -D tailwindcss-animate
- Configure tailsSaladUI usetailsto properly merge Tailwindcss classes
# config/config.exs
config :tails, colors_file: Path.join(File.cwd!(), "assets/tailwind.colors.json")- Add javascript to handle event from server
This add ability to execute client action from server. It's similar to JS.exec/2. Thanks to this post from fly.io.
Add this code snippet to the end of app.js
window.addEventListener("phx:js-exec", ({ detail }) => {
  document.querySelectorAll(detail.to).forEach((el) => {
    liveSocket.execJS(el, el.getAttribute(detail.attr));
  });
});Then from server side, you can close an opening sheet like this.
  @impl true
  def handle_event("update", params, socket) do
    # your logic
    {:noreply, push_event(socket, "js-exec", %{to: "#my-sheet", attr: "phx-hide-sheet"})}
  end- Some tweaks Thanks to @ahacking
- To make dark and light mode work correctly, add following to your app.css
body {
    @apply bg-background text-foreground;
}- In case border color not working correctly, add following to your app.css
@layer base {
    * {
        @apply border-border !important;
    }- Config custom error translate function
config :salad_ui, :error_translator_function, {MyAppWeb.CoreComponents, :translate_error}Here is how to start develop SaladUI on local machine.
- Clone this repo
- Clone https://github.com/bluzky/salad_storybookin the same directory withSaladUI
- Start storybook
cd salad_storybook
mix phx.serverIn your project folder make sure the dependencies are installed by running mix deps.get, then once completed you can run:
- mix testto run tests once or,
- mix test.watchto watch file and run tests on file changes.
To run the failing tests only, just run mix test.watch --stale.
It's also important to note that you must format your code with mix format before sending a pull request, otherwise the build in github will fail.
- Accordion
- ✅ Alert
- Alert Dialog
- ✅ Avatar
- ✅ Badge
- ✅ Breadcrumb
- ✅ Button
- ✅ Card
- Carousel
- ✅ Checkbox
- Collapsible
- Combobox
- Command
- Context Menu
- ✅ Dialog
- Drawer
- ✅ Dropdown Menu
- ✅ Form
- ✅ Hover Card
- ✅ Input
- Input OTP
- ✅ Label
- ✅ Pagination
- Popover
- ✅ Progress
- ✅ Radio Group
- ✅ Scroll Area
- ✅ Select
- ✅ Separator
- ✅ Sheet
- ✅ Skeleton
- ✅ Slider
- ✅ Switch
- ✅ Table
- ✅ Tabs
- ✅ Textarea
- ✅ Tooltip
- ✅ Toggle
- ✅ Toggle Group
This project could not be available without these awesome works:
- tailwind cssan awesome css utility project
- tailsfor merging tailwind class
- shadcn/uiwhich this project is inspired from
- Phoenix Frameworkof course