1.0.9 • Published 4 years ago

vite-plugin-less-vars-generator v1.0.9

Weekly downloads
-
License
MIT
Repository
github
Last release
4 years ago

vite-plugin-less-vars-generator

Less vars generator plugin for vite, export vars as js object.

Install

npm install vite-plugin-less-vars-generator --save-dev
# or
yarn add vite-plugin-less-vars-generator --dev

Usage

vite.config.js

import { defineConfig } from "vite";
import lessVarsPlugin from "vite-plugin-less-vars-generator";

export default defineConfig({
  plugins: [
    vue(),
    lessVarsPlugin({ lessPath: "./src/styles/var.less" }),
  ],
});

Options

param nametypedescriptionexample
lessPathstringless vars define absolute file path./src/styles/var.less

Demo in vue3

src/styles/var.less

@color-primary: #ed6e00;
@color-bg: #f8f8f8;
@color-desc: #999999;
@color-text-primary: #464646;
@color-text-desc: #8f8f8f;
@color-link: #4295ff;
@color-border: #e4e4e4;
@color-white: #ffffff;
@color-red: red;

@font-size-base: 14px;
@font-size-small: @font-size-base * 0.8;

@gutter-xlarge: @gutter-base * 1.4;
@gutter-large: @gutter-base * 1.2;
@gutter-base: 8px;
@gutter-small: @gutter-base * 0.8;
@gutter-xsmall: @gutter-base * 0.6;

vite.config.ts

import { defineConfig } from "vite";
import vue from "@vitejs/plugin-vue";
import path from "path";

import lessVarsPlugin from "vite-plugin-less-vars-generator";

export default defineConfig({
  plugins: [
    vue(),
    lessVarsPlugin({ lessPath: path.join(__dirname, "src/styles/var.less") }),
  ],
});

generate If the less variable definition file changes, you need to recompile

yarn dev

In project root path 'src/styles/', generated a 'index.ts' file

export const colorPrimary = '#ed6e00';
export const colorBg = '#f8f8f8';
export const colorDesc = '#999999';
export const colorTextPrimary = '#464646';
export const colorTextDesc = '#8f8f8f';
export const colorLink = '#4295ff';
export const colorBorder = '#e4e4e4';
export const colorWhite = '#ffffff';
export const colorRed = 'red';
export const fontSizeBase = '14px';
export const fontSizeSmall = '14px * 0.8;';
export const gutterXlarge = '8px * 1.4;';
export const gutterLarge = '8px * 1.2;';
export const gutterBase = '8px';
export const gutterSmall = '8px * 0.8;';
export const gutterXsmall = '8px * 0.6;';
1.0.9

4 years ago

1.0.8

4 years ago

1.0.7

4 years ago

1.0.6

4 years ago

1.0.5

4 years ago

1.0.4

4 years ago

1.0.3

4 years ago

1.0.1

4 years ago

1.0.0

4 years ago