or run

npx @tessl/cli init
Log in

Version

Tile

Overview

Evals

Files

Files

docs

auto-detection.mdcli-interface.mdconfiguration.mdcss-minification.mdhtml-minification.mdimage-processing.mdindex.mdjavascript-minification.md

css-minification.mddocs/

0

# CSS Minification

1

2

Advanced CSS minification with support for multiple backends and automatic base64 image inlining for optimized web assets.

3

4

## Capabilities

5

6

### CSS Minifier Function

7

8

Minifies CSS data using configurable CSS minifiers with automatic image inlining.

9

10

```javascript { .api }

11

/**

12

* Minifies CSS data using configurable CSS minifiers

13

* @param data - CSS source code to minify

14

* @param userOptions - Configuration options for CSS and image processing

15

* @returns Promise resolving to minified CSS code

16

*/

17

function minify.css(data: string, userOptions?: MinifyOptions): Promise<string>;

18

19

interface MinifyOptions {

20

css?: {

21

type?: 'lightningcss' | 'clean-css';

22

'clean-css'?: CleanCSSOptions;

23

};

24

img?: {

25

maxSize?: number; // Default: 102400 (100KB)

26

};

27

}

28

```

29

30

**Usage Examples:**

31

32

```javascript

33

import { minify } from "minify";

34

35

// Default minification using lightningcss

36

const css = `

37

body {

38

color: '#FFFFFF';

39

margin: 0px;

40

}

41

`;

42

const minified = await minify.css(css);

43

// Result: "body{color:\"#FFFFFF\";margin:0}"

44

45

// Using clean-css

46

const cleanResult = await minify.css(css, {

47

css: {

48

type: 'clean-css',

49

'clean-css': {

50

level: 2,

51

compatibility: '*'

52

}

53

}

54

});

55

56

// With image inlining options

57

const withImages = await minify.css(cssWithImages, {

58

css: {

59

type: 'clean-css'

60

},

61

img: {

62

maxSize: 50000 // 50KB limit for base64 inlining

63

}

64

});

65

```

66

67

## CSS Minifier Backends

68

69

### LightningCSS (Default)

70

71

Modern, fast CSS minifier written in Rust with excellent performance.

72

73

```javascript { .api }

74

// LightningCSS uses internal configuration

75

// No direct options exposure in minify package

76

interface LightningCSSMinification {

77

minify: true; // Always enabled

78

// Internal optimization settings managed automatically

79

}

80

```

81

82

**Usage:**

83

84

```javascript

85

// Default behavior - no options needed

86

const result = await minify.css(cssCode);

87

88

// Explicit selection

89

const result = await minify.css(cssCode, {

90

css: {

91

type: 'lightningcss'

92

}

93

});

94

```

95

96

### Clean-CSS

97

98

Feature-rich CSS minifier with extensive configuration options and compatibility settings.

99

100

```javascript { .api }

101

interface CleanCSSOptions {

102

level?: number | object; // Optimization level (0, 1, 2)

103

compatibility?: string | object; // Browser compatibility settings

104

format?: string | object; // Output formatting options

105

inline?: string[]; // Files to inline

106

rebase?: boolean; // URL rebasing

107

specialComments?: string | number; // Special comment handling

108

sourceMap?: boolean; // Source map generation

109

110

// Level-specific options

111

level?: {

112

1?: {

113

cleanupCharsets?: boolean;

114

normalizeUrls?: boolean;

115

optimizeBackground?: boolean;

116

optimizeBorderRadius?: boolean;

117

optimizeFilter?: boolean;

118

optimizeFont?: boolean;

119

optimizeFontWeight?: boolean;

120

optimizeOutline?: boolean;

121

removeEmpty?: boolean;

122

removeNegativePaddings?: boolean;

123

removeQuotes?: boolean;

124

removeWhitespace?: boolean;

125

replaceMultipleZeros?: boolean;

126

replaceTimeUnits?: boolean;

127

replaceZeroUnits?: boolean;

128

roundingPrecision?: boolean | number;

129

selectorsSortingMethod?: string;

130

specialComments?: string | number;

131

tidyAtRules?: boolean;

132

tidyBlockScopes?: boolean;

133

tidySelectors?: boolean;

134

};

135

2?: {

136

mergeAdjacentRules?: boolean;

137

mergeIntoShorthands?: boolean;

138

mergeMedia?: boolean;

139

mergeNonAdjacentRules?: boolean;

140

mergeSemantically?: boolean;

141

overrideProperties?: boolean;

142

removeEmpty?: boolean;

143

reduceNonAdjacentRules?: boolean;

144

removeDuplicateFontRules?: boolean;

145

removeDuplicateMediaBlocks?: boolean;

146

removeDuplicateRules?: boolean;

147

removeUnusedAtRules?: boolean;

148

restructureRules?: boolean;

149

skipProperties?: string[];

150

};

151

};

152

}

153

```

154

155

**Usage:**

156

157

```javascript

158

const result = await minify.css(cssCode, {

159

css: {

160

type: 'clean-css',

161

'clean-css': {

162

level: {

163

1: {

164

specialComments: 0, // Remove all comments

165

removeWhitespace: true

166

},

167

2: {

168

mergeAdjacentRules: true,

169

removeEmpty: true,

170

removeDuplicateRules: true

171

}

172

},

173

compatibility: {

174

properties: {

175

colors: false, // Disable color optimizations

176

ieFilters: true // Keep IE filters

177

}

178

}

179

}

180

}

181

});

182

```

183

184

## Image Inlining

185

186

Automatic base64 image inlining for CSS assets to reduce HTTP requests.

187

188

```javascript { .api }

189

interface ImageInliningOptions {

190

maxSize?: number; // Maximum file size for inlining (bytes)

191

}

192

193

// Default options

194

const defaultImageOptions = {

195

maxSize: 102400 // 100KB

196

};

197

```

198

199

**Image Inlining Process:**

200

201

1. Parses CSS for `url()` references to images

202

2. Checks image file size against `maxSize` threshold

203

3. Converts eligible images to base64 data URIs

204

4. Replaces original URLs with inline data URIs

205

206

**Usage:**

207

208

```javascript

209

// CSS with image references

210

const cssWithImages = `

211

.header {

212

background-image: url('logo.png');

213

}

214

.icon {

215

background: url('../icons/star.svg');

216

}

217

`;

218

219

// Configure image inlining

220

const result = await minify.css(cssWithImages, {

221

img: {

222

maxSize: 50000 // 50KB limit

223

}

224

});

225

226

// Result includes inlined images:

227

// .header{background-image:url(...)}

228

```

229

230

## File-based CSS Processing

231

232

When processing CSS files (not just strings), automatic image inlining is applied.

233

234

```javascript

235

// File processing automatically includes image inlining

236

const minifiedCSS = await minify('./styles.css', {

237

css: {

238

type: 'clean-css'

239

},

240

img: {

241

maxSize: 25000 // 25KB limit for images

242

}

243

});

244

```

245

246

## Error Handling

247

248

CSS minification handles various error conditions:

249

250

- **Invalid CSS**: Syntax errors in CSS are caught and reported

251

- **Missing Data**: Throws assertion error if data parameter is empty

252

- **Clean-CSS Errors**: Validation and processing errors from clean-css are propagated

253

- **Image Processing Errors**: File access and conversion errors for image inlining

254

- **Configuration Errors**: Invalid options are validated and reported

255

256

**Error Examples:**

257

258

```javascript

259

// Empty data validation

260

try {

261

await minify.css("");

262

} catch (error) {

263

console.log(error); // AssertionError

264

}

265

266

// Clean-CSS specific errors

267

try {

268

await minify.css('@import "missing.css";', {

269

css: { type: 'clean-css' }

270

});

271

} catch (error) {

272

console.log(error); // 'Ignoring local @import of "missing.css" as resource is missing.'

273

}

274

275

// Image processing errors

276

try {

277

await minify.css('.bg { background: url("nonexistent.png"); }');

278

} catch (error) {

279

console.log(error.message); // File access error

280

}

281

```