- web/: Vue 3 + Vite + UnoCSS + Pinia, dark tactical theme (amber/#0d1117) - AppNav, ListingCard, SearchView with filters/sort, composables (useSnipeMode, useKonamiCode, useMotion), Pinia search store - Steal shimmer, auction countdown, Snipe Mode easter egg all native in Vue - docker/web/: nginx + multi-stage Dockerfile (node build → nginx serve) - compose.yml: api (8510) + web (8509) services - Dockerfile CMD updated to uvicorn for upcoming FastAPI layer - Clean build: 0 TS errors, 380 modules
42 lines
738 B
JavaScript
42 lines
738 B
JavaScript
'use strict'
|
|
|
|
let Warning = require('./warning')
|
|
|
|
class Result {
|
|
get content() {
|
|
return this.css
|
|
}
|
|
|
|
constructor(processor, root, opts) {
|
|
this.processor = processor
|
|
this.messages = []
|
|
this.root = root
|
|
this.opts = opts
|
|
this.css = ''
|
|
this.map = undefined
|
|
}
|
|
|
|
toString() {
|
|
return this.css
|
|
}
|
|
|
|
warn(text, opts = {}) {
|
|
if (!opts.plugin) {
|
|
if (this.lastPlugin && this.lastPlugin.postcssPlugin) {
|
|
opts.plugin = this.lastPlugin.postcssPlugin
|
|
}
|
|
}
|
|
|
|
let warning = new Warning(text, opts)
|
|
this.messages.push(warning)
|
|
|
|
return warning
|
|
}
|
|
|
|
warnings() {
|
|
return this.messages.filter(i => i.type === 'warning')
|
|
}
|
|
}
|
|
|
|
module.exports = Result
|
|
Result.default = Result
|