mirror of
https://github.com/tabler/tabler.git
synced 2025-12-22 18:04:26 +04:00
Compare commits
1 Commits
dev-docs-f
...
changeset-
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
2d320870f5 |
@@ -1,6 +1,11 @@
|
|||||||
>= 1%
|
>= 1%
|
||||||
last 2 versions
|
last 1 major version
|
||||||
Firefox ESR
|
|
||||||
not dead
|
not dead
|
||||||
safari >= 15.4
|
Chrome >= 60
|
||||||
iOS >= 15.4
|
Firefox >= 60
|
||||||
|
Edge >= 15.15063
|
||||||
|
Explorer 11
|
||||||
|
iOS >= 10
|
||||||
|
Safari >= 10
|
||||||
|
Android >= 6
|
||||||
|
not ExplorerMobile <= 11
|
||||||
|
|||||||
57
.build/download-images.js
Normal file
57
.build/download-images.js
Normal file
@@ -0,0 +1,57 @@
|
|||||||
|
#!/usr/bin/env node
|
||||||
|
|
||||||
|
'use strict'
|
||||||
|
|
||||||
|
const fs = require('node:fs')
|
||||||
|
const path = require('node:path')
|
||||||
|
const request = require('request')
|
||||||
|
const filePath = path.join(__dirname, '../src/pages/_data/photos.json')
|
||||||
|
|
||||||
|
const photos = JSON.parse(fs.readFileSync(filePath, 'utf8'))
|
||||||
|
|
||||||
|
const urlTitle = (str) => {
|
||||||
|
str = str
|
||||||
|
.toLowerCase()
|
||||||
|
.replaceAll('&', 'and')
|
||||||
|
.replace(/[^[a-z0-9-]/g, '-')
|
||||||
|
.replace(/-+/g, '-')
|
||||||
|
|
||||||
|
return str
|
||||||
|
}
|
||||||
|
|
||||||
|
const download = function (uri, filename, callback, error) {
|
||||||
|
request.head(uri, function (err, res, body) {
|
||||||
|
request(uri).pipe(fs.createWriteStream(filename))
|
||||||
|
.on('close', callback)
|
||||||
|
.on('error', error)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
async function downloadPhotos() {
|
||||||
|
for (const key in photos) {
|
||||||
|
const photo = photos[key]
|
||||||
|
|
||||||
|
let filename, i = 1;
|
||||||
|
|
||||||
|
do {
|
||||||
|
filename = `${urlTitle(photo['title'])}${i > 1 ? `-${i}` : ''}.jpg`
|
||||||
|
i++
|
||||||
|
} while (fs.existsSync(path.join(__dirname, `../src/static/photos/${filename}`)))
|
||||||
|
|
||||||
|
await new Promise((resolve, reject) => {
|
||||||
|
download(photo['path'], path.join(__dirname, `../src/static/photos/${filename}`), function () {
|
||||||
|
resolve()
|
||||||
|
}, function () {
|
||||||
|
reject()
|
||||||
|
});
|
||||||
|
})
|
||||||
|
|
||||||
|
photos[key]['file'] = filename
|
||||||
|
photos[key]['horizontal'] = photo['width'] > photo['height']
|
||||||
|
}
|
||||||
|
|
||||||
|
fs.writeFileSync(filePath, JSON.stringify(photos))
|
||||||
|
}
|
||||||
|
|
||||||
|
downloadPhotos();
|
||||||
|
|
||||||
37
.build/import-icons.js
Normal file
37
.build/import-icons.js
Normal file
@@ -0,0 +1,37 @@
|
|||||||
|
#!/usr/bin/env node
|
||||||
|
|
||||||
|
'use strict'
|
||||||
|
|
||||||
|
const fs = require('fs'),
|
||||||
|
path = require('path');
|
||||||
|
|
||||||
|
const iconsTags = require('../node_modules/@tabler/icons/icons.json'),
|
||||||
|
iconsPkg = require('../node_modules/@tabler/icons/package.json');
|
||||||
|
|
||||||
|
const prepareSvgFile = (svg) => {
|
||||||
|
return svg.replace(/\n/g, '').replace(/>\s+</g, '><').replace(/\s+/g, ' ')
|
||||||
|
}
|
||||||
|
|
||||||
|
let svgList = {}
|
||||||
|
for (let iconName in iconsTags) {
|
||||||
|
let iconData = iconsTags[iconName]
|
||||||
|
svgList[iconName] = {
|
||||||
|
name: iconName,
|
||||||
|
svg: {
|
||||||
|
outline: iconData.styles.outline ? prepareSvgFile(fs.readFileSync(path.join(__dirname, `../node_modules/@tabler/icons/icons/outline/${iconName}.svg`), 'utf8')) : null,
|
||||||
|
filled: iconData.styles.filled ? prepareSvgFile(fs.readFileSync(path.join(__dirname, `../node_modules/@tabler/icons/icons/filled/${iconName}.svg`), 'utf8')) : null,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fs.writeFileSync(
|
||||||
|
path.join(__dirname, `../src/pages/_data/icons-info.json`),
|
||||||
|
JSON.stringify({
|
||||||
|
version: iconsPkg.version,
|
||||||
|
count: Object.values(svgList).reduce((acc, icon) => {
|
||||||
|
return acc + (icon.svg.outline ? 1 : 0) + (icon.svg.filled ? 1 : 0)
|
||||||
|
}, 0)
|
||||||
|
})
|
||||||
|
)
|
||||||
|
|
||||||
|
fs.writeFileSync(path.join(__dirname, `../src/pages/_data/icons.json`), JSON.stringify(svgList))
|
||||||
44
.build/import-illustrations.js
Normal file
44
.build/import-illustrations.js
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
#!/usr/bin/env node
|
||||||
|
|
||||||
|
'use strict'
|
||||||
|
|
||||||
|
const fs = require('fs'),
|
||||||
|
path = require('path'),
|
||||||
|
glob = require('glob');
|
||||||
|
|
||||||
|
const illustrations = glob
|
||||||
|
.sync(path.join(__dirname, `../src/static/illustrations/light/*.png`))
|
||||||
|
.map((file) => {
|
||||||
|
return path.basename(file, '.png')
|
||||||
|
})
|
||||||
|
|
||||||
|
fs.writeFileSync(
|
||||||
|
path.join(__dirname, `../src/pages/_data/illustrations.json`),
|
||||||
|
JSON.stringify(illustrations)
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
// let i = {}
|
||||||
|
// const dirs = ['light', 'dark', 'autodark']
|
||||||
|
// const ilustrations = ['not-found', 'computer-fix', 'boy-with-key', 'boy-girl']
|
||||||
|
|
||||||
|
// for(const dir of dirs) {
|
||||||
|
// i[dir] = {}
|
||||||
|
|
||||||
|
// for(const ilustration of ilustrations) {
|
||||||
|
// let svg = fs.readFileSync(path.join(__dirname, `../src/pages/_free-illustrations/${dir}/${ilustration}.svg`), 'utf8')
|
||||||
|
|
||||||
|
// svg = svg
|
||||||
|
// .replace(/\n+/g, ' ')
|
||||||
|
// .replace(/>\s+</g, '><')
|
||||||
|
// .replace(/\s+/g, ' ')
|
||||||
|
// .replace(/^[\n\s-]+/, '')
|
||||||
|
|
||||||
|
// i[dir][ilustration] = svg
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
|
||||||
|
// fs.writeFileSync(
|
||||||
|
// path.join(__dirname, `../src/pages/_data/free-illustrations.json`),
|
||||||
|
// JSON.stringify(i)
|
||||||
|
// )
|
||||||
36
.build/reformat-mdx.js
Normal file
36
.build/reformat-mdx.js
Normal file
@@ -0,0 +1,36 @@
|
|||||||
|
#!/usr/bin/env node
|
||||||
|
|
||||||
|
'use strict'
|
||||||
|
|
||||||
|
const fs = require('fs'),
|
||||||
|
path = require('path'),
|
||||||
|
glob = require('glob'),
|
||||||
|
beautifyHtml = require('js-beautify').html;
|
||||||
|
|
||||||
|
const docs = glob
|
||||||
|
.sync(path.join(__dirname, `../docs/**/*.mdx`))
|
||||||
|
|
||||||
|
docs.forEach((file, i) => {
|
||||||
|
const oldContent = fs.readFileSync(file, 'utf8')
|
||||||
|
|
||||||
|
// get codeblocks from markdown
|
||||||
|
const content = oldContent.replace(/(```([a-z0-9]+).*?\n)(.*?)(```)/gs, (m, m1, m2, m3, m4) => {
|
||||||
|
if (m2 === 'html') {
|
||||||
|
let m3m = beautifyHtml(m3, {
|
||||||
|
"indent_size": 2,
|
||||||
|
"indent_char": " ",
|
||||||
|
}).trim();
|
||||||
|
|
||||||
|
// remove empty lines
|
||||||
|
m3m = m3m.replace(/^\s*[\r\n]/gm, '');
|
||||||
|
|
||||||
|
return m1 + m3m + "\n" + m4;
|
||||||
|
}
|
||||||
|
return m
|
||||||
|
})
|
||||||
|
|
||||||
|
if (content !== oldContent) {
|
||||||
|
fs.writeFileSync(file, content, 'utf8')
|
||||||
|
console.log(`Reformatted ${file}`)
|
||||||
|
}
|
||||||
|
})
|
||||||
@@ -1,63 +0,0 @@
|
|||||||
#!/usr/bin/env node
|
|
||||||
|
|
||||||
'use strict'
|
|
||||||
|
|
||||||
import { readFileSync, writeFileSync } from 'node:fs';
|
|
||||||
import { join, dirname } from 'node:path';
|
|
||||||
import { fileURLToPath } from 'node:url'
|
|
||||||
import { sync } from 'glob';
|
|
||||||
import * as prettier from "prettier";
|
|
||||||
|
|
||||||
const __dirname = dirname(fileURLToPath(import.meta.url))
|
|
||||||
|
|
||||||
const docs = sync(join(__dirname, '..', 'docs', '**', '*.md'))
|
|
||||||
|
|
||||||
async function formatHTML(htmlString) {
|
|
||||||
try {
|
|
||||||
const formattedHtml = await prettier.format(htmlString, {
|
|
||||||
parser: "html",
|
|
||||||
printWidth: 100,
|
|
||||||
});
|
|
||||||
return formattedHtml;
|
|
||||||
} catch (error) {
|
|
||||||
console.error("Error formatting HTML:", error);
|
|
||||||
return htmlString; // Return original in case of an error
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
async function replaceAsync(str, regex, asyncFn) {
|
|
||||||
const matches = [...str.matchAll(regex)];
|
|
||||||
|
|
||||||
const replacements = await Promise.all(
|
|
||||||
matches.map(async (match) => asyncFn(...match))
|
|
||||||
);
|
|
||||||
|
|
||||||
let result = str;
|
|
||||||
matches.forEach((match, i) => {
|
|
||||||
result = result.replace(match[0], replacements[i]);
|
|
||||||
});
|
|
||||||
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (const file of docs) {
|
|
||||||
const oldContent = readFileSync(file, 'utf8')
|
|
||||||
|
|
||||||
// get codeblocks from markdown
|
|
||||||
const content = await replaceAsync(oldContent, /(```([a-z0-9]+).*?\n)(.*?)(```)/gs, async (m, m1, m2, m3, m4) => {
|
|
||||||
if (m2 === 'html') {
|
|
||||||
m3 = await formatHTML(m3);
|
|
||||||
|
|
||||||
// remove empty lines
|
|
||||||
m3 = m3.replace(/^\s*[\r\n]/gm, '');
|
|
||||||
|
|
||||||
return m1 + m3.trim() + "\n" + m4;
|
|
||||||
}
|
|
||||||
return m.trim();
|
|
||||||
})
|
|
||||||
|
|
||||||
if (content !== oldContent) {
|
|
||||||
writeFileSync(file, content, 'utf8')
|
|
||||||
console.log(`Reformatted ${file}`)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
26
.build/unused-files.js
Normal file
26
.build/unused-files.js
Normal file
@@ -0,0 +1,26 @@
|
|||||||
|
const glob = require('glob');
|
||||||
|
const fs = require('fs')
|
||||||
|
const path = require('path')
|
||||||
|
|
||||||
|
const srcDir = path.join(__dirname, '../src')
|
||||||
|
|
||||||
|
let foundFiles = []
|
||||||
|
glob.sync(`${srcDir}/pages/**/*.{html,md}`).forEach((file) => {
|
||||||
|
let fileContent = fs.readFileSync(file)
|
||||||
|
|
||||||
|
fileContent.toString().replace(/\{% include(_cached)? "([a-z0-9\/_-]+\.html)"/g, (f, c, filename) => {
|
||||||
|
filename = `${srcDir}/pages/_includes/${filename}`
|
||||||
|
|
||||||
|
if (!foundFiles.includes(filename)) {
|
||||||
|
foundFiles.push(filename)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
})
|
||||||
|
|
||||||
|
let includeFiles = glob.sync(`${srcDir}/pages/_includes/**/*.html`)
|
||||||
|
|
||||||
|
includeFiles.forEach((file) => {
|
||||||
|
if (!foundFiles.includes(file)) {
|
||||||
|
console.log('file', file)
|
||||||
|
}
|
||||||
|
})
|
||||||
@@ -1,30 +0,0 @@
|
|||||||
#!/usr/bin/env node
|
|
||||||
|
|
||||||
import AdmZip from 'adm-zip';
|
|
||||||
import path from 'path';
|
|
||||||
import { fileURLToPath } from 'url';
|
|
||||||
import { readFileSync } from 'fs';
|
|
||||||
|
|
||||||
// Get __dirname in ESM
|
|
||||||
const __dirname = path.dirname(fileURLToPath(import.meta.url))
|
|
||||||
|
|
||||||
const pkg = JSON.parse(
|
|
||||||
readFileSync(path.join(__dirname, '../core', 'package.json'), 'utf8')
|
|
||||||
)
|
|
||||||
|
|
||||||
// Create zip instance and add folder
|
|
||||||
const zip = new AdmZip();
|
|
||||||
zip.addLocalFolder(path.join(__dirname, '../preview/dist'), 'dashboard');
|
|
||||||
|
|
||||||
zip.addLocalFile(path.join(__dirname, '../preview/static', 'og.png'), '.', 'preview.png');
|
|
||||||
|
|
||||||
zip.addFile("documentation.url", Buffer.from("[InternetShortcut]\nURL = https://tabler.io/docs"));
|
|
||||||
|
|
||||||
|
|
||||||
// Folder to zip and output path
|
|
||||||
const outputZipPath = path.join(__dirname, '../packages-zip', `tabler-${pkg.version}.zip`);
|
|
||||||
|
|
||||||
// Write the zip file
|
|
||||||
zip.writeZip(outputZipPath);
|
|
||||||
|
|
||||||
console.log(`Zipped folder to ${outputZipPath}`);
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/core": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Update illustrations to v1.7
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/core": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Add SRI hashes to scripts and styles
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/docs": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Improve Introduction, Base, Layout and Plugins sections in documentation
|
|
||||||
@@ -3,18 +3,8 @@
|
|||||||
"changelog": "@changesets/cli/changelog",
|
"changelog": "@changesets/cli/changelog",
|
||||||
"commit": false,
|
"commit": false,
|
||||||
"fixed": [],
|
"fixed": [],
|
||||||
"linked": [
|
"linked": [],
|
||||||
[
|
|
||||||
"@tabler/core",
|
|
||||||
"@tabler/preview",
|
|
||||||
"@tabler/docs"
|
|
||||||
]
|
|
||||||
],
|
|
||||||
"access": "public",
|
"access": "public",
|
||||||
"baseBranch": "dev",
|
"baseBranch": "main",
|
||||||
"ignore": [],
|
"ignore": []
|
||||||
"privatePackages": {
|
|
||||||
"version": true,
|
|
||||||
"tag": false
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/core": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Fix colour picker preview page not displaying correctly
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/docs": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Fix input mask example in docs
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/core": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Update icons to v3.31.0
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/docs": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Fix broken links to other docs section and tabler.io website; improve some labels.
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/core": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Add "text features" menu item
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/core": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Refactor SCSS variable names for shadows
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/core": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Correct `aria-label` of app menu link
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/docs": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Fix links in Tabler Emails introduction, improve "How to contribute" and other small fixes
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/docs": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Fix switch icon examples with filled icons in documentation
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/core": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Fix some marketing site rows overflowing on mobile
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
Add missing metadata for Tabler Documentation
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/core": minor
|
|
||||||
---
|
|
||||||
|
|
||||||
Add new charts to dashboard pages
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/docs": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Use primary color for `::selection` inside `<code>` in docs
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/core": "patch"
|
|
||||||
---
|
|
||||||
|
|
||||||
Improve card footer layout and enhance entry display format in invoices
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/core": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Fix color badge in navbar menu
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/core": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Add clipboard functionality to Tabler documentation
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/docs": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Fix documentation: remove duplicated code examples; increase height of dropdown examples; fix some links
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/docs": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Fix ribbon component in the documentation
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/core": "patch"
|
|
||||||
---
|
|
||||||
|
|
||||||
Fix colour swatches on small screens
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/core": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Add missing `tw` entry in `flags.json`
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/core": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Delete missing demo RTL style
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/core": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Enhance dropdown components for better accessibility
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
Fix broken RTL preview
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/core": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Remove unnecessary `!important` from body padding
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/docs": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Fix incorrect label text on form elements docs page
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/docs": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Use tabs-package include to show webfont install steps
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/docs": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Demonstrate sticky header table more clearly in docs
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/core": minor
|
|
||||||
---
|
|
||||||
|
|
||||||
Add new form layout page
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/docs": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Replace non-existent Vimeo file and enhance the inline player documentation
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/docs": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Exclude headings in the carousel and modal examples from ToC
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/docs": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Exclude headings inside `.example` from the Table of Contents
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/docs": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Change WYSIWYG title to uppercase
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/core": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Fix missing border-radius to `.card-header-tabs`
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/docs": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Add missing `.steps-vertical` classes in docs
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/docs": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Use color-input examples in documentation
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
Add URL for local dev version of docs app to README
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/docs": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Fix `src` links to images in README and getting-started docs page
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
---
|
|
||||||
"@tabler/docs": patch
|
|
||||||
---
|
|
||||||
|
|
||||||
Add documentation for 3rd-party libraries and resources
|
|
||||||
67
.github/workflows/argos.yml
vendored
67
.github/workflows/argos.yml
vendored
@@ -1,67 +0,0 @@
|
|||||||
name: Argos Tests
|
|
||||||
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- dev
|
|
||||||
pull_request:
|
|
||||||
paths:
|
|
||||||
- 'preview/**/*.js'
|
|
||||||
- 'preview/**/*.html'
|
|
||||||
- 'preview/**/*.scss'
|
|
||||||
- 'core/**/*.js'
|
|
||||||
- 'core/**/*.scss'
|
|
||||||
|
|
||||||
env:
|
|
||||||
NODE: 20
|
|
||||||
|
|
||||||
permissions:
|
|
||||||
contents: read
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
test:
|
|
||||||
timeout-minutes: 60
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
# if: github.event.pull_request.draft == false
|
|
||||||
if: false
|
|
||||||
steps:
|
|
||||||
- name: Clone repository
|
|
||||||
uses: actions/checkout@v4
|
|
||||||
|
|
||||||
- name: Cache turbo build setup
|
|
||||||
uses: actions/cache@v4
|
|
||||||
with:
|
|
||||||
path: .turbo
|
|
||||||
key: ${{ runner.os }}-turbo-${{ github.sha }}
|
|
||||||
restore-keys: |
|
|
||||||
${{ runner.os }}-turbo-
|
|
||||||
|
|
||||||
- name: Set up Node.js
|
|
||||||
uses: actions/setup-node@v4
|
|
||||||
with:
|
|
||||||
node-version: "${{ env.NODE }}"
|
|
||||||
|
|
||||||
- name: Install PNPM
|
|
||||||
uses: pnpm/action-setup@v4
|
|
||||||
|
|
||||||
- name: Get installed Playwright version
|
|
||||||
id: playwright-version
|
|
||||||
run: echo "PLAYWRIGHT_VERSION=$(node -e "console.log(require('./package.json').devDependencies['@playwright/test'])")" >> $GITHUB_ENV
|
|
||||||
|
|
||||||
- name: Cache playwright binaries
|
|
||||||
uses: actions/cache@v4
|
|
||||||
id: playwright-cache
|
|
||||||
with:
|
|
||||||
path: |
|
|
||||||
~/.cache/ms-playwright
|
|
||||||
key: ${{ runner.os }}-playwright-${{ env.PLAYWRIGHT_VERSION }}
|
|
||||||
|
|
||||||
- name: Install pnpm dependencies
|
|
||||||
run: pnpm install
|
|
||||||
|
|
||||||
- name: Install Playwright Browsers
|
|
||||||
run: pnpm exec playwright install --with-deps
|
|
||||||
if: steps.playwright-cache.outputs.cache-hit != 'true'
|
|
||||||
|
|
||||||
- name: Run Playwright tests
|
|
||||||
run: pnpm run playwright
|
|
||||||
13
.github/workflows/bundlewatch.yml
vendored
13
.github/workflows/bundlewatch.yml
vendored
@@ -19,14 +19,6 @@ jobs:
|
|||||||
- name: Clone repository
|
- name: Clone repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
- name: Cache turbo build setup
|
|
||||||
uses: actions/cache@v4
|
|
||||||
with:
|
|
||||||
path: .turbo
|
|
||||||
key: ${{ runner.os }}-turbo-${{ github.sha }}
|
|
||||||
restore-keys: |
|
|
||||||
${{ runner.os }}-turbo-
|
|
||||||
|
|
||||||
- name: Set up Node.js
|
- name: Set up Node.js
|
||||||
uses: actions/setup-node@v4
|
uses: actions/setup-node@v4
|
||||||
with:
|
with:
|
||||||
@@ -34,6 +26,8 @@ jobs:
|
|||||||
|
|
||||||
- name: Install PNPM
|
- name: Install PNPM
|
||||||
uses: pnpm/action-setup@v4
|
uses: pnpm/action-setup@v4
|
||||||
|
with:
|
||||||
|
version: 8
|
||||||
|
|
||||||
- name: Set up Bundler
|
- name: Set up Bundler
|
||||||
uses: ruby/setup-ruby@v1
|
uses: ruby/setup-ruby@v1
|
||||||
@@ -44,6 +38,9 @@ jobs:
|
|||||||
- name: Install pnpm dependencies
|
- name: Install pnpm dependencies
|
||||||
run: pnpm install --no-frozen-lockfile
|
run: pnpm install --no-frozen-lockfile
|
||||||
|
|
||||||
|
- name: Run build
|
||||||
|
run: pnpm run build
|
||||||
|
|
||||||
- name: Run bundlewatch
|
- name: Run bundlewatch
|
||||||
run: pnpm run bundlewatch
|
run: pnpm run bundlewatch
|
||||||
env:
|
env:
|
||||||
|
|||||||
5
.github/workflows/lockfiles.yaml
vendored
5
.github/workflows/lockfiles.yaml
vendored
@@ -1,7 +1,6 @@
|
|||||||
name: Changed lock files
|
name: Changed lock files
|
||||||
on:
|
on:
|
||||||
pull_request_target:
|
pull_request: null
|
||||||
types: [opened, reopened]
|
|
||||||
|
|
||||||
permissions:
|
permissions:
|
||||||
pull-requests: read
|
pull-requests: read
|
||||||
@@ -15,7 +14,7 @@ jobs:
|
|||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
- name: Prevent lock file change
|
- name: Prevent lock file change
|
||||||
uses: xalvarez/prevent-file-change-action@v2
|
uses: xalvarez/prevent-file-change-action@v1
|
||||||
with:
|
with:
|
||||||
githubToken: ${{ secrets.GITHUB_TOKEN }}
|
githubToken: ${{ secrets.GITHUB_TOKEN }}
|
||||||
pattern: Gemfile.lock|pnpm-lock.json
|
pattern: Gemfile.lock|pnpm-lock.json
|
||||||
|
|||||||
3
.github/workflows/release.yml
vendored
3
.github/workflows/release.yml
vendored
@@ -3,6 +3,7 @@ name: Release
|
|||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
branches:
|
branches:
|
||||||
|
- main
|
||||||
- dev
|
- dev
|
||||||
|
|
||||||
permissions:
|
permissions:
|
||||||
@@ -30,6 +31,8 @@ jobs:
|
|||||||
|
|
||||||
- name: Install PNPM
|
- name: Install PNPM
|
||||||
uses: pnpm/action-setup@v4
|
uses: pnpm/action-setup@v4
|
||||||
|
with:
|
||||||
|
version: 8
|
||||||
|
|
||||||
- name: Install Dependencies
|
- name: Install Dependencies
|
||||||
run: pnpm install
|
run: pnpm install
|
||||||
|
|||||||
13
.github/workflows/test.yml
vendored
13
.github/workflows/test.yml
vendored
@@ -1,7 +1,8 @@
|
|||||||
name: Test build
|
name: Test build
|
||||||
|
|
||||||
on:
|
on:
|
||||||
pull_request: null
|
pull_request:
|
||||||
|
types: [ opened, reopened ]
|
||||||
|
|
||||||
env:
|
env:
|
||||||
NODE: 20
|
NODE: 20
|
||||||
@@ -16,14 +17,6 @@ jobs:
|
|||||||
- name: Clone repository
|
- name: Clone repository
|
||||||
uses: actions/checkout@v4
|
uses: actions/checkout@v4
|
||||||
|
|
||||||
- name: Cache turbo build setup
|
|
||||||
uses: actions/cache@v4
|
|
||||||
with:
|
|
||||||
path: .turbo
|
|
||||||
key: ${{ runner.os }}-turbo-${{ github.sha }}
|
|
||||||
restore-keys: |
|
|
||||||
${{ runner.os }}-turbo-
|
|
||||||
|
|
||||||
- name: Set up Node.js
|
- name: Set up Node.js
|
||||||
uses: actions/setup-node@v4
|
uses: actions/setup-node@v4
|
||||||
with:
|
with:
|
||||||
@@ -31,6 +24,8 @@ jobs:
|
|||||||
|
|
||||||
- name: Install PNPM
|
- name: Install PNPM
|
||||||
uses: pnpm/action-setup@v4
|
uses: pnpm/action-setup@v4
|
||||||
|
with:
|
||||||
|
version: 8
|
||||||
|
|
||||||
- run: node --version
|
- run: node --version
|
||||||
|
|
||||||
|
|||||||
10
.gitignore
vendored
10
.gitignore
vendored
@@ -19,21 +19,17 @@ node_modules/
|
|||||||
/svg-tmp/
|
/svg-tmp/
|
||||||
/components/
|
/components/
|
||||||
/percy.sh
|
/percy.sh
|
||||||
/preview/pages/playground.html
|
/src/pages/playground.html
|
||||||
/preview/pages/screenshot.html
|
/src/pages/playground-*.html
|
||||||
/preview/pages/screenshot-*.html
|
/src/pages/features.html
|
||||||
/preview/pages/playground-*.html
|
|
||||||
/preview/pages/features.html
|
|
||||||
|
|
||||||
.pnp.loader.mjs
|
.pnp.loader.mjs
|
||||||
.pnp.cjs
|
.pnp.cjs
|
||||||
.yarn
|
.yarn
|
||||||
.next
|
.next
|
||||||
.vercel
|
.vercel
|
||||||
.turbo
|
|
||||||
package-lock.json
|
package-lock.json
|
||||||
|
|
||||||
demo/
|
demo/
|
||||||
dist/
|
dist/
|
||||||
packages-zip/
|
packages-zip/
|
||||||
.env
|
|
||||||
@@ -1,7 +1,7 @@
|
|||||||
{
|
{
|
||||||
"bracketSpacing": true,
|
"bracketSpacing": true,
|
||||||
"jsxSingleQuote": false,
|
"jsxSingleQuote": false,
|
||||||
"printWidth": 320,
|
"printWidth": 240,
|
||||||
"proseWrap": "always",
|
"proseWrap": "always",
|
||||||
"semi": false,
|
"semi": false,
|
||||||
"singleQuote": false,
|
"singleQuote": false,
|
||||||
|
|||||||
16
.vscode/settings.json
vendored
16
.vscode/settings.json
vendored
@@ -1,12 +1,14 @@
|
|||||||
{
|
{
|
||||||
"files.exclude": {
|
"files.exclude": {
|
||||||
"**/.git": true,
|
"**/.git": false,
|
||||||
"**/.svn": true,
|
"**/.svn": false,
|
||||||
"**/.hg": true,
|
"**/.hg": false,
|
||||||
"**/CVS": true,
|
"**/CVS": false,
|
||||||
"**/.DS_Store": true,
|
"**/.DS_Store": false,
|
||||||
"**/Thumbs.db": true,
|
"**/Thumbs.db": false,
|
||||||
"**/.idea/": true
|
"**/.idea/": false,
|
||||||
|
"dist": false,
|
||||||
|
"demo": false
|
||||||
},
|
},
|
||||||
"explorerExclude.backup": {}
|
"explorerExclude.backup": {}
|
||||||
}
|
}
|
||||||
@@ -1,77 +1,10 @@
|
|||||||
# @tabler/core
|
# Changelog
|
||||||
|
|
||||||
## 1.2.0
|
## 1.0.1
|
||||||
|
|
||||||
### Minor Changes
|
|
||||||
|
|
||||||
- c59bc9d: Add gradient background utilities
|
|
||||||
- f9e4da2: Add new apps card with brand icons in navbar
|
|
||||||
- 92a3afe: Replaced TinyMCE with HugeRTE to address license violation
|
|
||||||
- 199f39a: Update Bootstrap to version 5.3.5
|
|
||||||
- 9bbcb99: Add theme settings wizard
|
|
||||||
- b17b488: Add steps light colors
|
|
||||||
- 215eaa4: Add Turbo library integration
|
|
||||||
|
|
||||||
### Patch Changes
|
### Patch Changes
|
||||||
|
|
||||||
- aea3b0a: Rollback accordion component structure
|
|
||||||
- 3fc7b84: Add space between page numbers in pagination
|
|
||||||
- 2f8a372: Add Bootstrap components to Tabler JS
|
|
||||||
- 9fceadd: Fix tooltip colors in vector maps
|
|
||||||
- 44250db: Update avatar size variable to support list size configuration
|
|
||||||
- be1f3d1: Fix broken shape in South Korea flag
|
|
||||||
- c20d076: Refactor `border-radius` in components to use CSS variables
|
|
||||||
- 042e50f: Update disabled color variables in navbars
|
|
||||||
- 473fa38: Apply border radius to `tom-select` on focus
|
|
||||||
- 8646192: Add avatars page with various demos of avatars
|
|
||||||
- 922bb03: Minor spelling and grammar improvements to emails docs
|
|
||||||
- 44250db: Update avatar size variable to support list size configuration
|
|
||||||
- ddcd3a7: Refactor SCSS for alerts and close button styles
|
|
||||||
- e3d68d6: Fix `autosize` and `input mask` plugins to use window scope
|
|
||||||
- 4846828: Fix scrollbar color mixin to use body color variable
|
|
||||||
- 6b6617a: Improve README
|
|
||||||
- 94bea00: Make scrollbar track transparent
|
|
||||||
- e14e492: Fix scrollbar jumps when content is higher than screen
|
|
||||||
- 6d6d1bd: Add responsive font size for form controls on mobile devices
|
|
||||||
- 6c566cf: Add new advanced table example
|
|
||||||
|
|
||||||
## 1.1.1
|
|
||||||
|
|
||||||
### Patch Changes
|
|
||||||
|
|
||||||
- f29c911: Fix Documentation structure
|
|
||||||
|
|
||||||
## 1.1.0
|
|
||||||
|
|
||||||
### Minor Changes
|
|
||||||
|
|
||||||
- a2640e2: Add Playwright configuration and visual regression tests
|
|
||||||
- d3ae77c: Enable `scrollSpy` in `countup` module
|
|
||||||
- bd3d959: Refactor SCSS files to replace divide function with calc
|
|
||||||
- cb278c7: Add Segmented Control component
|
|
||||||
- b47725d: Add new text features page with mentions: user, color and app.
|
|
||||||
- b4b4d1a: Add Scroll Spy page
|
|
||||||
- 9cd5327: Update border radius variables for consistency across components
|
|
||||||
- 4376968: Add Signature Pad feature and signatures page
|
|
||||||
- f95f250: Update color utility classes and replace background colors in pricing table
|
|
||||||
- eaa7f81: Refactored the project into a monorepo, removed Gulp, and introduced a new, more efficient build process.
|
|
||||||
- ea14462: Add documentation for segmented control component
|
|
||||||
- 1edaff4: Add new payment provider (Troy)
|
|
||||||
- edbaa1e: Add selectable table functionality with active background color
|
|
||||||
- 378fba8: Refactor badge styles, remove Bootstrap styles
|
|
||||||
- f3c409f: Refactor alert component styles and markup, remove Bootstrap styles
|
|
||||||
- c240b5a: Refactor accordion component styles and markup, remove Bootstrap styles
|
|
||||||
|
|
||||||
### Patch Changes
|
|
||||||
|
|
||||||
- 687267d: Fix overflow of `label` in a `floating-input`
|
|
||||||
- 06b1dec: Fix size of `apexcharts` tooltip marker
|
|
||||||
- afd0700: Fix apexcharts heatmap example in docs
|
|
||||||
- 78383ef: Fix negative margins in `.navbar-bordered` variant
|
|
||||||
- 11f4487: Use the full license agreement for illustrations in docs
|
- 11f4487: Use the full license agreement for illustrations in docs
|
||||||
- b28ce9f: Fix vertical alignment in single page and error layouts
|
|
||||||
- 24b944c: Fix `.avatar-upload` double borders
|
|
||||||
- ca4ba14: Fixes navbar styles with new hover effects and color variables
|
|
||||||
|
|
||||||
## 1.0.0 - 2025-01-28
|
## 1.0.0 - 2025-01-28
|
||||||
|
|
||||||
@@ -89,8 +22,8 @@
|
|||||||
- be14607: Add new color picker component using `coloris.js` library
|
- be14607: Add new color picker component using `coloris.js` library
|
||||||
- d046570: Update Tabler Icons to version 2.23 with 18 new icons added
|
- d046570: Update Tabler Icons to version 2.23 with 18 new icons added
|
||||||
- 5488c50: New page with payment providers: `payment-providers.html`
|
- 5488c50: New page with payment providers: `payment-providers.html`
|
||||||
- 5488c50: Add support for new payment providers: 2c2p, Adyen, Affirm, Alipay Plus, Allegro Pay, Amazon Pay, Apple Pay, Autopay, Binance USD, Bkash, Cash App, Chime, EasyPaisa, Ethereum, Google Pay, HubSpot, iDeal, Litecoin, Mercado Pago, MetaMask, MoneyGram, OpenSea, Payconiq, Payka, Payline, PayPo, Paysafe, Poli,
|
- 5488c50: Add support for new payment providers: 2c2p, Adyen, Affirm, Alipay Plus, Allegro Pay, Amazon Pay, Apple Pay, Autopay, Binance USD, Bkash, Cash App, Chime, EasyPaisa, Ethereum, Google Pay, HubSpot, iDeal, Litecoin, Mercado Pago,
|
||||||
Revolut Pay, Samsung Pay, Shop Pay, Solana, Spingo, Stax, Tether, True USD, Venmo, WeChat Pay, Wise, Zelle
|
MetaMask, MoneyGram, OpenSea, Payconiq, Payka, Payline, PayPo, Paysafe, Poli, Revolut Pay, Samsung Pay, Shop Pay, Solana, Spingo, Stax, Tether, True USD, Venmo, WeChat Pay, Wise, Zelle
|
||||||
|
|
||||||
### Patch Changes
|
### Patch Changes
|
||||||
|
|
||||||
229
README.md
229
README.md
@@ -1,5 +1,5 @@
|
|||||||
<p align="center">
|
<p align="center">
|
||||||
<a href="https://github.com/tabler/tabler"><img src="https://raw.githubusercontent.com/tabler/tabler/refs/heads/dev/shared/static/logo.svg" alt="A premium and open source dashboard template with a responsive and high-quality UI." width="300"></a><br><br>
|
<a href="https://github.com/tabler/tabler"><img src="https://raw.githubusercontent.com/tabler/tabler/dev/src/static/logo.svg" alt="A premium and open source dashboard template with a responsive and high-quality UI." width="300"></a><br><br>
|
||||||
A premium and open source dashboard template with a responsive and high-quality UI.
|
A premium and open source dashboard template with a responsive and high-quality UI.
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
@@ -15,53 +15,34 @@ A premium and open source dashboard template with a responsive and high-quality
|
|||||||
|
|
||||||
## Sponsors
|
## Sponsors
|
||||||
|
|
||||||
**If you want to support our project and help us grow it, you can [become a sponsor on GitHub](https://github.com/sponsors/codecalm) or just [donate on PayPal](https://paypal.me/codecalm) :)**
|
**If you want to support our project and help me grow it, you can [become a sponsor on GitHub](https://github.com/sponsors/codecalm) or just [donate on PayPal](https://paypal.me/codecalm) :)**
|
||||||
|
|
||||||
<p align="center">
|
<p align="center">
|
||||||
<a href="https://github.com/sponsors/codecalm">
|
<a href="https://github.com/sponsors/codecalm">
|
||||||
<img src="https://cdn.jsdelivr.net/gh/tabler/sponsors@latest/sponsors.svg" alt="Tabler sponsors">
|
<img src="https://cdn.jsdelivr.net/gh/tabler/sponsors@latest/sponsors.svg" alt="Tabler sponsors">
|
||||||
</a>
|
</a>
|
||||||
</p>
|
|
||||||
|
|
||||||
<p align="center">
|
|
||||||
<a href="https://github.com/sponsors/codecalm" target="_blank">
|
|
||||||
<img src="https://raw.githubusercontent.com/tabler/tabler/dev/shared/static/sponsor-banner-homepage.svg" alt="Sponsor Banner">
|
|
||||||
</a>
|
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
## Testing
|
## Testing
|
||||||
|
|
||||||
<p align="center">Visual testing with:</p>
|
|
||||||
|
|
||||||
<p align="center">
|
|
||||||
<a href="https://argos-ci.com/" target="_blank">
|
|
||||||
<picture>
|
|
||||||
<img src="https://github.com/user-attachments/assets/7d231a26-eff5-4fc5-8392-b2a679a7c572" alt="Argos-CI" height="164" />
|
|
||||||
</picture>
|
|
||||||
</a>
|
|
||||||
</p>
|
|
||||||
|
|
||||||
<p align="center">Browser testing via:</p>
|
<p align="center">Browser testing via:</p>
|
||||||
|
|
||||||
<p align="center">
|
<p align="center">
|
||||||
<a href="https://www.lambdatest.com/" target="_blank">
|
<a href="https://www.lambdatest.com/" target="_blank">
|
||||||
<picture>
|
<picture>
|
||||||
<source media="(prefers-color-scheme: dark)" srcset="https://github.com/user-attachments/assets/14dd2a0a-bafe-436e-a6cb-29636278c781">
|
<source media="(prefers-color-scheme: dark)" srcset="https://github.com/user-attachments/assets/14dd2a0a-bafe-436e-a6cb-29636278c781">
|
||||||
<source media="(prefers-color-scheme: light)" srcset="https://github.com/user-attachments/assets/d3dede5a-d702-47c3-bb66-4d887948ed83">
|
<source media="(prefers-color-scheme: light)" srcset="https://github.com/user-attachments/assets/d3dede5a-d702-47c3-bb66-4d887948ed83">
|
||||||
<img src="https://github.com/user-attachments/assets/d3dede5a-d702-47c3-bb66-4d887948ed83" alt="labmdatest" width="296">
|
<img src="https://github.com/user-attachments/assets/d3dede5a-d702-47c3-bb66-4d887948ed83" alt="Tabler Icons preview" width="296">
|
||||||
</picture>
|
</picture>
|
||||||
</a>
|
</a>
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
## 🔎 Preview
|
## 🔎 Preview
|
||||||
|
|
||||||
Tabler is fully responsive and compatible with all modern browsers. Thanks to its modern and user-friendly design you can create a fully functional interface that users will love! Choose the layouts and components you need and customize them to make your design consistent and eye-catching. Every component has been created with attention to detail to make your interface beautiful! <a href="https://preview.tabler.io">Show me a demo</a>
|
Tabler is fully responsive and compatible with all modern browsers. Thanks to its modern and user-friendly design you can create a fully functional interface that users will love! Choose the layouts and components you need and customize them to make your design consistent and eye-catching. Every component has been created with attention to detail to make your interface beautiful! <a href="https://preview.tabler.io">Show me a demo</a>
|
||||||
|
|
||||||
<p align="center">
|
<a href="https://preview.tabler.io" target="_blank"><img src="https://raw.githubusercontent.com/tabler/tabler/dev/src/static/tabler-preview.png" alt="Tabler preview"></a>
|
||||||
<a href="https://preview.tabler.io" target="_blank">
|
|
||||||
<img src="https://raw.githubusercontent.com/tabler/tabler/dev/shared/static/tabler-preview.png" alt="Tabler Preview">
|
|
||||||
</a>
|
|
||||||
</p>
|
|
||||||
|
|
||||||
## 🚀 Features
|
## 🚀 Features
|
||||||
|
|
||||||
@@ -72,30 +53,110 @@ We've created this admin panel for everyone who wants to create templates based
|
|||||||
* **HTML5 & CSS3:** We use only modern web technologies, such as HTML5 and CSS3. Our theme includes some subtle CSS3 animations, which will help you attract attention.
|
* **HTML5 & CSS3:** We use only modern web technologies, such as HTML5 and CSS3. Our theme includes some subtle CSS3 animations, which will help you attract attention.
|
||||||
* **Clean Code:** We followed Bootstrap’s guidelines carefully to make your integration as easy as possible. All code is handwritten and W3C valid.
|
* **Clean Code:** We followed Bootstrap’s guidelines carefully to make your integration as easy as possible. All code is handwritten and W3C valid.
|
||||||
* **Demo pages**: Tabler features over 20 individual pages using various components, which gives you the freedom to choose and combine. All components can vary in color and styling that you can easily modify using Sass. Sky is the limit!
|
* **Demo pages**: Tabler features over 20 individual pages using various components, which gives you the freedom to choose and combine. All components can vary in color and styling that you can easily modify using Sass. Sky is the limit!
|
||||||
|
* **Single Page Application versions:** [Tabler React](https://github.com/tabler/tabler-react) has React components for Tabler.
|
||||||
|
|
||||||
## 📖 Documentation
|
## 📖 Documentation
|
||||||
|
|
||||||
The documentation is available at https://docs.tabler.io/
|
Documentation is available as a part of Tabler preview: https://tabler.io/docs/
|
||||||
|
|
||||||
|
To run the documentation site locally, follow instructions in the [Documentation README](https://github.com/tabler/tabler/blob/dev/site/README.md).
|
||||||
|
|
||||||
## 🪴 Project Activity
|
## 🪴 Project Activity
|
||||||
|
|
||||||
<p align="center">
|

|
||||||
<img src="https://repobeats.axiom.co/api/embed/61d1db34446967b0848af68198a392067e0f5870.svg" alt="Repobeats analytics image" />
|
|
||||||
</p>
|
## 💕 Sponsor Tabler
|
||||||
|
|
||||||
|
<a href="https://github.com/sponsors/codecalm" target="_blank"><img src="/src/static/sponsor-banner-readme.png?raw=true" alt="Sponsor Tabler" /></a>
|
||||||
|
|
||||||
|
|
||||||
|
### Sponsors
|
||||||
|
|
||||||
|
Support this project by becoming a sponsor. Your logo will show up in this README with a link to your website. [Become a sponsor!](https://opencollective.com/tabler#sponsor)
|
||||||
|
|
||||||
|
<a href="https://opencollective.com/tabler/tiers/sponsor/0/website" target="_blank"><img src="https://opencollective.com/tabler/tiers/sponsor/0/avatar.svg" /></a>
|
||||||
|
<a href="https://opencollective.com/tabler/tiers/sponsor/1/website" target="_blank"><img src="https://opencollective.com/tabler/tiers/sponsor/1/avatar.svg" /></a>
|
||||||
|
<a href="https://opencollective.com/tabler/tiers/sponsor/2/website" target="_blank"><img src="https://opencollective.com/tabler/tiers/sponsor/2/avatar.svg" /></a>
|
||||||
|
<a href="https://opencollective.com/tabler/tiers/sponsor/3/website" target="_blank"><img src="https://opencollective.com/tabler/tiers/sponsor/3/avatar.svg" /></a>
|
||||||
|
<a href="https://opencollective.com/tabler/tiers/sponsor/4/website" target="_blank"><img src="https://opencollective.com/tabler/tiers/sponsor/4/avatar.svg" /></a>
|
||||||
|
<a href="https://opencollective.com/tabler/tiers/sponsor/5/website" target="_blank"><img src="https://opencollective.com/tabler/tiers/sponsor/5/avatar.svg" /></a>
|
||||||
|
<a href="https://opencollective.com/tabler/tiers/sponsor/6/website" target="_blank"><img src="https://opencollective.com/tabler/tiers/sponsor/6/avatar.svg" /></a>
|
||||||
|
<a href="https://opencollective.com/tabler/tiers/sponsor/7/website" target="_blank"><img src="https://opencollective.com/tabler/tiers/sponsor/7/avatar.svg" /></a>
|
||||||
|
<a href="https://opencollective.com/tabler/tiers/sponsor/8/website" target="_blank"><img src="https://opencollective.com/tabler/tiers/sponsor/8/avatar.svg" /></a>
|
||||||
|
<a href="https://opencollective.com/tabler/tiers/sponsor/9/website" target="_blank"><img src="https://opencollective.com/tabler/tiers/sponsor/9/avatar.svg" /></a>
|
||||||
|
|
||||||
|
## 📦 Setup environment
|
||||||
|
|
||||||
|
To use our build system and run our documentation locally, you'll need a copy of Tabler's source files. Follow the steps below:
|
||||||
|
|
||||||
|
1. [Install Node.js](https://nodejs.org/download/), which we use to manage our dependencies.
|
||||||
|
2. Navigate to the root `/tabler` directory and run `pnpm install` to install our local dependencies listed in `package.json`.
|
||||||
|
|
||||||
|
**OSX users**:
|
||||||
|
|
||||||
|
```pnpm install```
|
||||||
|
|
||||||
|
and then
|
||||||
|
|
||||||
|
```npm run start```
|
||||||
|
|
||||||
|
|
||||||
|
**Windows users**:
|
||||||
|
|
||||||
|
[Install Git](https://git-scm.com/download/win) in `C:\Program Files\git\bin` directory and run `npm config set script-shell "C:\\Program Files\\git\\bin\\bash.exe"` to change the default shell.
|
||||||
|
|
||||||
|
Once you complete the setup, you'll be able to run the various commands provided from the command line.
|
||||||
|
|
||||||
|
|
||||||
|
## Build locally
|
||||||
|
|
||||||
|
You need to have `pnpm` and `bundler` installed.
|
||||||
|
|
||||||
|
1. From the root `/tabler` directory, run installation in the command line: `pnpm install`
|
||||||
|
2. Then execute `pnpm run start` to start up the application stack.
|
||||||
|
3. Open [http://localhost:3000](http://localhost:3000) in your browser, and voilà.
|
||||||
|
4. Any change in the `/src` directory will build the application and refresh the page.
|
||||||
|
|
||||||
|
**Note**:
|
||||||
|
Run `pnpm run build` for reforms a one off build application without refresh.
|
||||||
|
Open [http://localhost:3001](http://localhost:3001) to configure the Web server.
|
||||||
|
|
||||||
## Installation
|
## Installation
|
||||||
|
|
||||||
### Package Managers
|
Tabler is distributed via npm.
|
||||||
|
|
||||||
Tabler is distributed via npm. You can install it with this or your preferred JavaScript package manager:
|
|
||||||
|
|
||||||
```sh
|
```sh
|
||||||
npm install --save @tabler/core
|
npm install --save @tabler/core
|
||||||
```
|
```
|
||||||
|
|
||||||
|
## Running with Docker
|
||||||
|
|
||||||
|
**Plain Docker**
|
||||||
|
|
||||||
|
If you don't want to install node/npm and the dependencies on your local environment, you can use the provided Dockerfile to build a docker image.
|
||||||
|
This Dockerfile is provided as an example to spin-up a container running Tabler.
|
||||||
|
|
||||||
|
Example of how to use this image:
|
||||||
|
|
||||||
|
1. Build the tabler image : `docker build -t tabler .`
|
||||||
|
2. Run the tabler image while mounting the `src` directory as well as the `_config.yml` file into the container.
|
||||||
|
|
||||||
|
Don't forget to expose the port 3000 so you can browse the website locally.
|
||||||
|
You can also expose the port 3001 to have access to BrowserSync
|
||||||
|
|
||||||
|
```sh
|
||||||
|
docker run -p 3000:3000 -p 3001:3001 -v $(pwd)/src:/app/src -v $(pwd)/_config.yml:/app/_config.yml tabler
|
||||||
|
```
|
||||||
|
|
||||||
|
Now open your browser to [http://localhost:3000](http://localhost:3000). Edit anything in the `src/` folder and watch your browser refresh the page after it has been rebuilt.
|
||||||
|
|
||||||
|
**Docker Compose**
|
||||||
|
|
||||||
|
You can also use the docker compose config from this repo. Use `docker compose build && docker compose up` or `docker compose up --build` to build and start the container. Edit anything in the `src/` folder the same way as with plain docker and access the same URLs and ports in your browser.
|
||||||
|
|
||||||
### CDN support
|
### CDN support
|
||||||
|
|
||||||
All files included in `@tabler/core` npm package are also available over a CDN.
|
All files included in `@tabler/core` npm package are available over a CDN.
|
||||||
|
|
||||||
#### Javascript
|
#### Javascript
|
||||||
|
|
||||||
@@ -109,84 +170,24 @@ All files included in `@tabler/core` npm package are also available over a CDN.
|
|||||||
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@tabler/core@latest/dist/css/tabler.min.css">
|
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@tabler/core@latest/dist/css/tabler.min.css">
|
||||||
```
|
```
|
||||||
|
|
||||||
## Building locally
|
## Feature requests
|
||||||
|
|
||||||
To build a copy of Tabler locally, you have two options. You can either set up your device directly with the development tools required to build Tabler, or if you would prefer not to install all the development dependencies directly onto your device, you can use a Dockerfile that Tabler provides to build a docker image. Instructions follow below.
|
https://tabler.canny.io/feature-requests
|
||||||
|
|
||||||
### First steps: Downloading the Tabler source files
|
|
||||||
|
|
||||||
With either method, the first thing you'll want to do is download a copy of the Tabler source files to your device.
|
|
||||||
|
|
||||||
#### From the Tabler GitHub releases page
|
|
||||||
|
|
||||||
If you don't want to edit the source code once you've downloaded it, and aren't interested in merging future project updates into your copy, you can just download the source files straight from the [Tabler releases on GitHub](https://github.com/tabler/tabler/releases) and extract the contents to a directory called `tabler`.
|
|
||||||
|
|
||||||
#### Cloning with Git
|
|
||||||
|
|
||||||
If you **do** wish to edit the source code after downloading it, for example to contribute changes back to the Tabler project, you'll want to do this by cloning it with Git:
|
|
||||||
1. If you don't have Git installed on your device, download and install it. You can find instructions at [https://git-scm.com/downloads](https://git-scm.com/downloads).
|
|
||||||
2. (Optional) **Windows users:** you could optionally install Git in the `C:\Program Files\git\bin` directory and run `npm config set script-shell "C:\\Program Files\\git\\bin\\bash.exe"` to change the default shell.
|
|
||||||
3. Clone the Tabler project into a folder on your device. Instructions can be found at [cloning a repository](https://docs.github.com/en/repositories/creating-and-managing-repositories/cloning-a-repository).
|
|
||||||
|
|
||||||
### Installing and running development tools directly
|
|
||||||
|
|
||||||
1. [Install Node.js](https://nodejs.org/download/), which we use to manage our dependencies.
|
|
||||||
2. [Install pnpm](https://pnpm.io/installation) (We recommend either by [Using Corepack](https://pnpm.io/installation#using-corepack) or by [Using npm](https://pnpm.io/installation#using-npm))
|
|
||||||
3. From the root `/tabler` directory where you downloaded the Tabler source files, run installation on the command line:
|
|
||||||
```sh
|
|
||||||
pnpm install
|
|
||||||
```
|
|
||||||
4. Then execute the following to start up the application stack:
|
|
||||||
```sh
|
|
||||||
pnpm run start
|
|
||||||
```
|
|
||||||
5. Open [http://localhost:3000](http://localhost:3000) to view the preview website in your browser, or [http://localhost:3010](http://localhost:3010) to view the documentation website - and voilà.
|
|
||||||
Changes to most of the source files of Tabler core, preview and docs will rebuild the application and refresh the page.
|
|
||||||
|
|
||||||
**Note**:
|
|
||||||
If you wish to perform a one-off build without auto-refresh on any changes, you can run:
|
|
||||||
```sh
|
|
||||||
pnpm run build
|
|
||||||
```
|
|
||||||
You can open [http://localhost:3001](http://localhost:3001) to configure the Web server.
|
|
||||||
|
|
||||||
|
|
||||||
### Installing and running development tools with Docker
|
|
||||||
|
|
||||||
**Plain Docker**
|
|
||||||
|
|
||||||
Here is an example of how to use this image:
|
|
||||||
|
|
||||||
1. From the root `/tabler` directory where you downloaded the Tabler source files, build the tabler image:
|
|
||||||
```sh
|
|
||||||
docker build -t tabler .
|
|
||||||
```
|
|
||||||
2. Run the tabler image. The following command mounts the `src` directory into the container, exposes port 3000 to browse the website locally, and exposes port 3001 to automatically sync changes:
|
|
||||||
```sh
|
|
||||||
docker run -p 3000:3000 -p 3001:3001 -v $(pwd)/src:/app/src tabler
|
|
||||||
```
|
|
||||||
3. Open your browser to [http://localhost:3000](http://localhost:3000). Edit anything in the `src/` folder and watch your browser refresh the page after it has been rebuilt.
|
|
||||||
|
|
||||||
**Docker Compose**
|
|
||||||
|
|
||||||
You can also use the docker compose config from this repo. From the root `/tabler` directory where you downloaded the Tabler source files, use `docker compose build && docker compose up` or `docker compose up --build` to build and start the container. Edit anything in the `src/` folder the same way as with plain docker and access the same URLs and ports in your browser.
|
|
||||||
|
|
||||||
## Bugs and feature requests
|
## Bugs and feature requests
|
||||||
|
|
||||||
Found a bug or have a feature request? [Please open a new issue](https://github.com/tabler/tabler/issues/new).
|
Found a bug or have a feature request? [Please open a new issue](https://github.com/tabler/tabler/issues/new).
|
||||||
|
|
||||||
|
|
||||||
## 🤓 Creators
|
## 🤓 Creators
|
||||||
|
|
||||||
**Paweł Kuna**
|
**Paweł Kuna**
|
||||||
|
|
||||||
- <https://x.com/codecalm>
|
- <https://twitter.com/codecalm>
|
||||||
- <https://github.com/codecalm>
|
- <https://github.com/codecalm>
|
||||||
- <https://codecalm.net>
|
- <https://codecalm.net>
|
||||||
|
|
||||||
**Bartłomiej Gawęda**
|
|
||||||
|
|
||||||
- <https://x.com/B_Gaweda>
|
|
||||||
- <https://github.com/BG-Software-BG>
|
|
||||||
|
|
||||||
## 👨🚀 Contributors
|
## 👨🚀 Contributors
|
||||||
|
|
||||||
@@ -194,11 +195,25 @@ This project exists thanks to all the people who contribute.
|
|||||||
|
|
||||||
<img src="https://opencollective.com/tabler/contributors.svg?width=890&button=false" />
|
<img src="https://opencollective.com/tabler/contributors.svg?width=890&button=false" />
|
||||||
|
|
||||||
## Social media
|
## 🌸 Backers
|
||||||
|
|
||||||
Stay up to date by joining our community on <a href="https://x.com/tabler_io" >X</a> and <a href="https://www.facebook.com/tabler.io">Facebook</a>
|
Thank you to all our backers! 🙏 [Become a backer](https://opencollective.com/tabler#backer)
|
||||||
|
|
||||||
|
<a href="https://opencollective.com/tabler#backers" target="_blank"><img src="https://opencollective.com/tabler/tiers/backer.svg?width=890&button=false" /></a>
|
||||||
|
|
||||||
## License
|
## License
|
||||||
|
|
||||||
See the [LICENSE](https://github.com/tabler/tabler/blob/master/LICENSE) file.
|
See the [LICENSE](https://github.com/tabler/tabler/blob/master/LICENSE) file.
|
||||||
|
|
||||||
|
## Contributors ✨
|
||||||
|
|
||||||
|
Thanks goes to these wonderful people ([emoji key](https://allcontributors.org/docs/en/emoji-key)):
|
||||||
|
|
||||||
|
<!-- ALL-CONTRIBUTORS-LIST:START - Do not remove or modify this section -->
|
||||||
|
<!-- prettier-ignore-start -->
|
||||||
|
<!-- markdownlint-disable -->
|
||||||
|
<!-- markdownlint-restore -->
|
||||||
|
<!-- prettier-ignore-end -->
|
||||||
|
<!-- ALL-CONTRIBUTORS-LIST:END -->
|
||||||
|
|
||||||
|
This project follows the [all-contributors](https://github.com/all-contributors/all-contributors) specification. Contributions of any kind welcome!
|
||||||
|
|||||||
@@ -1,46 +0,0 @@
|
|||||||
#!/usr/bin/env node
|
|
||||||
|
|
||||||
'use strict'
|
|
||||||
|
|
||||||
import { readFileSync, writeFileSync } from 'node:fs';
|
|
||||||
import { join, dirname, basename } from 'node:path';
|
|
||||||
import { fileURLToPath } from 'node:url'
|
|
||||||
import { sync } from 'glob';
|
|
||||||
import banner from '../../shared/banner/index.mjs';
|
|
||||||
|
|
||||||
const __dirname = dirname(fileURLToPath(import.meta.url))
|
|
||||||
|
|
||||||
const styles = sync(join(__dirname, '..', 'dist', 'css', '*.css'))
|
|
||||||
|
|
||||||
const plugins = {
|
|
||||||
'tabler-flags': 'Flags',
|
|
||||||
'tabler-flags.rtl': 'Flags RTL',
|
|
||||||
'tabler-marketing': 'Marketing',
|
|
||||||
'tabler-marketing.rtl': 'Marketing RTL',
|
|
||||||
'tabler-payments': 'Payments',
|
|
||||||
'tabler-payments.rtl': 'Payments RTL',
|
|
||||||
'tabler-socials': 'Socials',
|
|
||||||
'tabler-socials.rtl': 'Socials RTL',
|
|
||||||
'tabler-vendors': 'Vendors',
|
|
||||||
'tabler-vendors.rtl': 'Vendors RTL',
|
|
||||||
}
|
|
||||||
|
|
||||||
styles.forEach((file, i) => {
|
|
||||||
const content = readFileSync(file, 'utf8')
|
|
||||||
const filename = basename(file)
|
|
||||||
const pluginKey = Object.keys(plugins).find(plugin => filename.includes(plugin))
|
|
||||||
const plugin = plugins[pluginKey]
|
|
||||||
const regex = /^(@charset ['"][a-zA-Z0-9-]+['"];?)\n?/i
|
|
||||||
|
|
||||||
let newContent = ''
|
|
||||||
|
|
||||||
if (content.match(regex)) {
|
|
||||||
newContent = content.replace(regex, (m, m1) => {
|
|
||||||
return `${m1}\n${banner(plugin)}\n`
|
|
||||||
})
|
|
||||||
} else {
|
|
||||||
newContent = `${banner(plugin)}\n${content}`
|
|
||||||
}
|
|
||||||
|
|
||||||
writeFileSync(file, newContent, 'utf8')
|
|
||||||
})
|
|
||||||
@@ -1,107 +0,0 @@
|
|||||||
const crypto = require('node:crypto');
|
|
||||||
const fs = require('node:fs');
|
|
||||||
const path = require('node:path');
|
|
||||||
const sh = require('shelljs');
|
|
||||||
|
|
||||||
sh.config.fatal = true
|
|
||||||
|
|
||||||
const configFile = path.join(__dirname, '../../shared/data/sri.json')
|
|
||||||
|
|
||||||
const files = [
|
|
||||||
{
|
|
||||||
file: 'dist/css/tabler.min.css',
|
|
||||||
configPropertyName: 'css'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
file: 'dist/css/tabler.rtl.min.css',
|
|
||||||
configPropertyName: 'css-rtl'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
file: 'dist/css/tabler-flags.min.css',
|
|
||||||
configPropertyName: 'css-flags'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
file: 'dist/css/tabler-flags.rtl.min.css',
|
|
||||||
configPropertyName: 'css-flags-rtl'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
file: 'dist/css/tabler-marketing.min.css',
|
|
||||||
configPropertyName: 'css-marketing'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
file: 'dist/css/tabler-marketing.rtl.min.css',
|
|
||||||
configPropertyName: 'css-marketing-rtl'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
file: 'dist/css/tabler-payments.min.css',
|
|
||||||
configPropertyName: 'css-payments'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
file: 'dist/css/tabler-payments.rtl.min.css',
|
|
||||||
configPropertyName: 'css-payments-rtl'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
file: 'dist/css/tabler-props.min.css',
|
|
||||||
configPropertyName: 'css-props'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
file: 'dist/css/tabler-props.rtl.min.css',
|
|
||||||
configPropertyName: 'css-props-rtl'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
file: 'dist/css/tabler-themes.min.css',
|
|
||||||
configPropertyName: 'css-themes'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
file: 'dist/css/tabler-themes.rtl.min.css',
|
|
||||||
configPropertyName: 'css-themes-rtl'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
file: 'dist/css/tabler-socials.min.css',
|
|
||||||
configPropertyName: 'css-socials'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
file: 'dist/css/tabler-socials.rtl.min.css',
|
|
||||||
configPropertyName: 'css-socials-rtl'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
file: 'dist/css/tabler-vendors.min.css',
|
|
||||||
configPropertyName: 'css-vendors'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
file: 'dist/css/tabler-vendors.rtl.min.css',
|
|
||||||
configPropertyName: 'css-vendors-rtl'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
file: 'dist/js/tabler.min.js',
|
|
||||||
configPropertyName: 'js'
|
|
||||||
},
|
|
||||||
{
|
|
||||||
file: 'dist/js/tabler-theme.min.js',
|
|
||||||
configPropertyName: 'js-theme'
|
|
||||||
},
|
|
||||||
// {
|
|
||||||
// file: 'dist/preview/css/demo.min.css',
|
|
||||||
// configPropertyName: 'demo-css'
|
|
||||||
// },
|
|
||||||
// {
|
|
||||||
// file: 'dist/preview/js/demo.min.js',
|
|
||||||
// configPropertyName: 'demo-js'
|
|
||||||
// },
|
|
||||||
]
|
|
||||||
|
|
||||||
for (const { file, configPropertyName } of files) {
|
|
||||||
fs.readFile(path.join(__dirname, '..', file), 'utf8', (error, data) => {
|
|
||||||
if (error) {
|
|
||||||
throw error
|
|
||||||
}
|
|
||||||
|
|
||||||
const algorithm = 'sha384'
|
|
||||||
const hash = crypto.createHash(algorithm).update(data, 'utf8').digest('base64')
|
|
||||||
const integrity = `${algorithm}-${hash}`
|
|
||||||
|
|
||||||
console.log(`${configPropertyName}: ${integrity}`)
|
|
||||||
|
|
||||||
sh.sed('-i', new RegExp(`^(\\s+"${configPropertyName}":\\s+["'])\\S*(["'])`), `$1${integrity}$2`, configFile)
|
|
||||||
})
|
|
||||||
}
|
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
export default context => {
|
|
||||||
return {
|
|
||||||
map: {
|
|
||||||
inline: false,
|
|
||||||
annotation: true,
|
|
||||||
sourcesContent: true
|
|
||||||
},
|
|
||||||
plugins: {
|
|
||||||
autoprefixer: {
|
|
||||||
cascade: false
|
|
||||||
},
|
|
||||||
rtlcss: context.env === 'RTL'
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,47 +0,0 @@
|
|||||||
import path from 'node:path'
|
|
||||||
import process from 'node:process'
|
|
||||||
import { fileURLToPath } from 'node:url'
|
|
||||||
import { babel } from '@rollup/plugin-babel'
|
|
||||||
import { nodeResolve } from '@rollup/plugin-node-resolve'
|
|
||||||
import replace from '@rollup/plugin-replace'
|
|
||||||
import banner from '../../shared/banner/index.mjs'
|
|
||||||
|
|
||||||
const __dirname = path.dirname(fileURLToPath(import.meta.url))
|
|
||||||
|
|
||||||
const ESM = process.env.ESM === 'true'
|
|
||||||
const THEME = process.env.THEME === 'true'
|
|
||||||
|
|
||||||
const external = []
|
|
||||||
const plugins = [
|
|
||||||
babel({
|
|
||||||
exclude: 'node_modules/**',
|
|
||||||
babelHelpers: 'bundled'
|
|
||||||
})
|
|
||||||
]
|
|
||||||
|
|
||||||
plugins.push(
|
|
||||||
replace({
|
|
||||||
'process.env.NODE_ENV': '"production"',
|
|
||||||
preventAssignment: true
|
|
||||||
}),
|
|
||||||
nodeResolve()
|
|
||||||
)
|
|
||||||
|
|
||||||
const destinationFile = `tabler${THEME ? '-theme' : ''}${ESM ? '.esm' : ''}`
|
|
||||||
const rollupConfig = {
|
|
||||||
input: path.resolve(__dirname, `../js/tabler${THEME ? '-theme' : ''}.js`),
|
|
||||||
output: {
|
|
||||||
banner: banner(),
|
|
||||||
file: path.resolve(__dirname, `../dist/js/${destinationFile}.js`),
|
|
||||||
format: ESM ? 'esm' : 'umd',
|
|
||||||
generatedCode: 'es2015'
|
|
||||||
},
|
|
||||||
external,
|
|
||||||
plugins
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!ESM) {
|
|
||||||
rollupConfig.output.name = `tabler${THEME ? '-theme' : ''}`
|
|
||||||
}
|
|
||||||
|
|
||||||
export default rollupConfig
|
|
||||||
@@ -1 +0,0 @@
|
|||||||
<svg xmlns="http://www.w3.org/2000/svg" width="20" height="15" fill="none"><path d="M0,0V15H20V0Z" fill="#f7fcff" fill-rule="evenodd"/><path d="M13.74,7.58a3.66,3.66,0,1,1-3.66-3.7A3.67,3.67,0,0,1,13.74,7.58Z" fill="#e31d1c" fill-rule="evenodd"/><path d="M6.47,6.93c.12.93.29,2,1.72,2.08a1.82,1.82,0,0,0,1.94-1.6,1.81,1.81,0,0,1,2.86-1,1.71,1.71,0,0,1,.74,1.35,3.64,3.64,0,0,1-1.84,3.08,3.73,3.73,0,0,1-4.16-.34A3.84,3.84,0,0,1,6.47,6.93Z" fill="#3d58db" fill-rule="evenodd"/><path d="M4.56,1.28l.57.52L2.48,4.89l-.57-.51Zm.94.84.58.52L3.52,5.69,3,5.17ZM7,3.48,6.44,3,3.88,6l.57.52L7,3.48Zm8.84-2.41-.57.51,1,1.16.57-.51Zm1.77,2.14L17,3.72l1,1.17.57-.52Zm-4.23,0L14,2.74l1,1.17-.57.51Zm2.34,1.62-.57.52,1,1.16.57-.51ZM14.37,2.39l.57-.51,2.77,3.36-.58.52ZM16.28,8.9l-.57-.52-1,1.17.57.52,1-1.17ZM14.6,11,14,10.44l-1,1.17.57.52,1-1.17ZM17.53,10l.58.52-1,1.17-.58-.52Zm-1,2.62-.58-.52-1,1.17.57.52ZM15,11.24l.58.51L14.51,13l-.58-.52Zm2.29-1.57-.58-.51-1,1.24.57.52ZM4,9.31l.58-.52,2.55,2.93-.57.51Zm.6,2.55.57-.51,1.08,1.18-.57.52ZM2.69,10.43,2.12,11l2.57,3,.57-.51Zm.41-.33.57-.52.94,1.1L4,11.19Z" fill="#272727" fill-rule="evenodd"/></svg>
|
|
||||||
|
Before Width: | Height: | Size: 1.1 KiB |
File diff suppressed because one or more lines are too long
|
Before Width: | Height: | Size: 5.4 KiB |
File diff suppressed because one or more lines are too long
|
Before Width: | Height: | Size: 5.4 KiB |
3
core/js/src/bootstrap.js
vendored
3
core/js/src/bootstrap.js
vendored
@@ -1,3 +0,0 @@
|
|||||||
export * as Popper from '@popperjs/core';
|
|
||||||
|
|
||||||
export { Dropdown, Tooltip, Popover, Tab, Toast } from 'bootstrap';
|
|
||||||
@@ -1,23 +0,0 @@
|
|||||||
const elements = document.querySelectorAll('[data-countup]');
|
|
||||||
|
|
||||||
if (elements.length) {
|
|
||||||
elements.forEach(function (element) {
|
|
||||||
let options = {};
|
|
||||||
try {
|
|
||||||
const dataOptions = element.getAttribute('data-countup') ? JSON.parse(element.getAttribute('data-countup')) : {};
|
|
||||||
options = Object.assign({
|
|
||||||
'enableScrollSpy': true
|
|
||||||
}, dataOptions);
|
|
||||||
|
|
||||||
} catch (error) {}
|
|
||||||
|
|
||||||
const value = parseInt(element.innerHTML, 10);
|
|
||||||
|
|
||||||
if (window.countUp && window.countUp.CountUp) {
|
|
||||||
const countUp = new window.countUp.CountUp(element, value, options);
|
|
||||||
if (!countUp.error) {
|
|
||||||
countUp.start();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
@@ -1,35 +0,0 @@
|
|||||||
/**
|
|
||||||
* demo-theme is specifically loaded right after the body and not deferred
|
|
||||||
* to ensure we switch to the chosen dark/light theme as fast as possible.
|
|
||||||
* This will prevent any flashes of the light theme (default) before switching.
|
|
||||||
*/
|
|
||||||
const themeConfig = {
|
|
||||||
"theme": "light",
|
|
||||||
"theme-base": "gray",
|
|
||||||
"theme-font": "sans-serif",
|
|
||||||
"theme-primary": "blue",
|
|
||||||
"theme-radius": "1",
|
|
||||||
}
|
|
||||||
|
|
||||||
const params = new Proxy(new URLSearchParams(window.location.search), {
|
|
||||||
get: (searchParams, prop) => searchParams.get(prop),
|
|
||||||
})
|
|
||||||
|
|
||||||
for (const key in themeConfig) {
|
|
||||||
const param = params[key]
|
|
||||||
let selectedValue
|
|
||||||
|
|
||||||
if (!!param) {
|
|
||||||
localStorage.setItem('tabler-' + key, param)
|
|
||||||
selectedValue = param
|
|
||||||
} else {
|
|
||||||
const storedTheme = localStorage.getItem('tabler-' + key)
|
|
||||||
selectedValue = storedTheme ? storedTheme : themeConfig[key]
|
|
||||||
}
|
|
||||||
|
|
||||||
if (selectedValue !== themeConfig[key]) {
|
|
||||||
document.documentElement.setAttribute('data-bs-' + key, selectedValue)
|
|
||||||
} else {
|
|
||||||
document.documentElement.removeAttribute('data-bs-' + key)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,27 +0,0 @@
|
|||||||
import "./src/autosize"
|
|
||||||
import "./src/countup"
|
|
||||||
import "./src/input-mask"
|
|
||||||
import "./src/dropdown"
|
|
||||||
import "./src/tooltip"
|
|
||||||
import "./src/popover"
|
|
||||||
import "./src/switch-icon"
|
|
||||||
import "./src/tab"
|
|
||||||
import "./src/toast"
|
|
||||||
|
|
||||||
export * as bootstrap from "bootstrap"
|
|
||||||
export * as tabler from "./src/tabler"
|
|
||||||
|
|
||||||
export {
|
|
||||||
Alert,
|
|
||||||
Modal,
|
|
||||||
Toast,
|
|
||||||
Tooltip,
|
|
||||||
Tab,
|
|
||||||
Button,
|
|
||||||
Carousel,
|
|
||||||
Collapse,
|
|
||||||
Dropdown,
|
|
||||||
Popover,
|
|
||||||
ScrollSpy,
|
|
||||||
Offcanvas
|
|
||||||
} from 'bootstrap'
|
|
||||||
@@ -1,152 +0,0 @@
|
|||||||
{
|
|
||||||
"name": "@tabler/core",
|
|
||||||
"version": "1.2.0",
|
|
||||||
"description": "Premium and Open Source dashboard template with responsive and high quality UI.",
|
|
||||||
"homepage": "https://tabler.io",
|
|
||||||
"scripts": {
|
|
||||||
"dev": "pnpm run watch",
|
|
||||||
"build": "pnpm run clean && pnpm run css && pnpm run js && pnpm run copy && pnpm run generate-sri",
|
|
||||||
"clean": "shx rm -rf dist demo",
|
|
||||||
"css": "pnpm run css-compile && pnpm run css-prefix && pnpm run css-rtl && pnpm run css-minify && pnpm run css-banner",
|
|
||||||
"css-compile": "sass scss/:dist/css/ --no-source-map --load-path=node_modules",
|
|
||||||
"css-banner": "node .build/add-banner.mjs",
|
|
||||||
"css-prefix": "postcss --config .build/postcss.config.mjs --replace \"dist/css/*.css\" \"!dist/css/*.rtl*.css\" \"!dist/css/*.min.css\"",
|
|
||||||
"css-rtl": "cross-env NODE_ENV=RTL postcss --config .build/postcss.config.mjs --dir \"dist/css\" --ext \".rtl.css\" \"dist/css/*.css\" \"!dist/css/*.min.css\" \"!dist/css/*.rtl.css\"",
|
|
||||||
"css-minify": "pnpm run css-minify-main && pnpm run css-minify-rtl",
|
|
||||||
"css-minify-main": "cleancss -O1 --format breakWith=lf --with-rebase --source-map --source-map-inline-sources --output dist/css/ --batch --batch-suffix \".min\" \"dist/css/*.css\" \"!dist/css/*.min.css\" \"!dist/css/*rtl*.css\"",
|
|
||||||
"css-minify-rtl": "cleancss -O1 --format breakWith=lf --with-rebase --source-map --source-map-inline-sources --output dist/css/ --batch --batch-suffix \".min\" \"dist/css/*rtl.css\" \"!dist/css/*.min.css\"",
|
|
||||||
"js": "pnpm run js-compile && pnpm run js-minify",
|
|
||||||
"js-compile": "pnpm run js-compile-standalone && pnpm run js-compile-standalone-esm && pnpm run js-compile-theme && pnpm run js-compile-theme-esm",
|
|
||||||
"js-compile-theme-esm": "rollup --environment THEME:true --environment ESM:true --config .build/rollup.config.mjs --sourcemap",
|
|
||||||
"js-compile-theme": "rollup --environment THEME:true --config .build/rollup.config.mjs --sourcemap",
|
|
||||||
"js-compile-standalone": "rollup --config .build/rollup.config.mjs --sourcemap",
|
|
||||||
"js-compile-standalone-esm": "rollup --environment ESM:true --config .build/rollup.config.mjs --sourcemap",
|
|
||||||
"js-minify": "pnpm run js-minify-standalone && pnpm run js-minify-standalone-esm && pnpm run js-minify-theme && pnpm run js-minify-theme-esm",
|
|
||||||
"js-minify-standalone": "terser --compress passes=2 --mangle --comments \"/^!/\" --source-map \"content=dist/js/tabler.js.map,includeSources,url=tabler.min.js.map\" --output dist/js/tabler.min.js dist/js/tabler.js",
|
|
||||||
"js-minify-standalone-esm": "terser --compress passes=2 --mangle --comments \"/^!/\" --source-map \"content=dist/js/tabler.esm.js.map,includeSources,url=tabler.esm.min.js.map\" --output dist/js/tabler.esm.min.js dist/js/tabler.esm.js",
|
|
||||||
"js-minify-theme": "terser --compress passes=2 --mangle --comments \"/^!/\" --source-map \"content=dist/js/tabler-theme.js.map,includeSources,url=tabler-theme.min.js.map\" --output dist/js/tabler-theme.min.js dist/js/tabler-theme.js",
|
|
||||||
"js-minify-theme-esm": "terser --compress passes=2 --mangle --comments \"/^!/\" --source-map \"content=dist/js/tabler-theme.esm.js.map,includeSources,url=tabler-theme.esm.min.js.map\" --output dist/js/tabler-theme.esm.min.js dist/js/tabler-theme.esm.js",
|
|
||||||
"copy": "pnpm run copy-img",
|
|
||||||
"copy-img": "shx mkdir -p dist/img && shx cp -rf img/* dist/img",
|
|
||||||
"watch": "concurrently \"pnpm run watch-css\" \"pnpm run watch-js\"",
|
|
||||||
"watch-css": "nodemon --watch scss/ --ext scss --exec \"pnpm run css-compile && pnpm run css-prefix\"",
|
|
||||||
"watch-js": "nodemon --watch js/ --ext js --exec \"pnpm run js-compile\"",
|
|
||||||
"bundlewatch": "bundlewatch",
|
|
||||||
"generate-sri": "node .build/generate-sri.js",
|
|
||||||
"format:check": "prettier --check src/**/*.{js,scss} --cache",
|
|
||||||
"format:write": "prettier --write src/**/*.{js,scss} --cache"
|
|
||||||
},
|
|
||||||
"repository": {
|
|
||||||
"type": "git",
|
|
||||||
"url": "git+https://github.com/tabler/tabler.git"
|
|
||||||
},
|
|
||||||
"keywords": [
|
|
||||||
"css",
|
|
||||||
"sass",
|
|
||||||
"mobile-first",
|
|
||||||
"responsive",
|
|
||||||
"front-end",
|
|
||||||
"framework",
|
|
||||||
"web"
|
|
||||||
],
|
|
||||||
"author": "codecalm",
|
|
||||||
"license": "MIT",
|
|
||||||
"bugs": {
|
|
||||||
"url": "https://github.com/tabler/tabler/issues"
|
|
||||||
},
|
|
||||||
"funding": {
|
|
||||||
"type": "github",
|
|
||||||
"url": "https://github.com/sponsors/codecalm"
|
|
||||||
},
|
|
||||||
"engines": {
|
|
||||||
"node": ">=20"
|
|
||||||
},
|
|
||||||
"files": [
|
|
||||||
"docs/**/*",
|
|
||||||
"dist/**/*",
|
|
||||||
"js/**/*.{js,map}",
|
|
||||||
"img/**/*.{svg}",
|
|
||||||
"scss/**/*.scss"
|
|
||||||
],
|
|
||||||
"style": "dist/css/tabler.css",
|
|
||||||
"sass": "scss/tabler.scss",
|
|
||||||
"unpkg": "dist/js/tabler.min.js",
|
|
||||||
"umd:main": "dist/js/tabler.min.js",
|
|
||||||
"module": "dist/js/tabler.esm.js",
|
|
||||||
"main": "dist/js/tabler.js",
|
|
||||||
"bundlewatch": {
|
|
||||||
"files": [
|
|
||||||
{
|
|
||||||
"path": "./dist/css/tabler.css",
|
|
||||||
"maxSize": "75 kB"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"path": "./dist/css/tabler.min.css",
|
|
||||||
"maxSize": "70 kB"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"path": "./dist/css/tabler.rtl.css",
|
|
||||||
"maxSize": "75 kB"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"path": "./dist/css/tabler.rtl.min.css",
|
|
||||||
"maxSize": "70 kB"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"path": "./dist/css/tabler-flags.css",
|
|
||||||
"maxSize": "2.5 kB"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"path": "./dist/css/tabler-flags.min.css",
|
|
||||||
"maxSize": "2 kB"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"path": "./dist/css/tabler-payments.css",
|
|
||||||
"maxSize": "2.2 kB"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"path": "./dist/css/tabler-payments.min.css",
|
|
||||||
"maxSize": "2 kB"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"path": "./dist/css/tabler-socials.css",
|
|
||||||
"maxSize": "2 kB"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"path": "./dist/css/tabler-socials.min.css",
|
|
||||||
"maxSize": "2 kB"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"path": "./dist/css/tabler-vendors.css",
|
|
||||||
"maxSize": "7.5 kB"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"path": "./dist/css/tabler-vendors.min.css",
|
|
||||||
"maxSize": "6.5 kB"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"path": "./dist/js/tabler.js",
|
|
||||||
"maxSize": "60 kB"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"path": "./dist/js/tabler.min.js",
|
|
||||||
"maxSize": "45 kB"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"path": "./dist/js/tabler.esm.js",
|
|
||||||
"maxSize": "60 kB"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"path": "./dist/js/tabler.esm.min.js",
|
|
||||||
"maxSize": "45 kB"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
},
|
|
||||||
"dependencies": {
|
|
||||||
"@popperjs/core": "^2.11.8",
|
|
||||||
"bootstrap": "5.3.6"
|
|
||||||
},
|
|
||||||
"directories": {
|
|
||||||
"doc": "docs"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,91 +0,0 @@
|
|||||||
@import "config";
|
|
||||||
|
|
||||||
:root,
|
|
||||||
:host {
|
|
||||||
/** Fonts */
|
|
||||||
--#{$prefix}font-monospace: #{$font-family-monospace};
|
|
||||||
--#{$prefix}font-sans-serif: #{$font-family-sans-serif};
|
|
||||||
--#{$prefix}font-serif: #{$font-family-serif};
|
|
||||||
--#{$prefix}font-comic: #{$font-family-comic};
|
|
||||||
|
|
||||||
/** Gray colors */
|
|
||||||
--#{$prefix}gray-50: #{$gray-50};
|
|
||||||
--#{$prefix}gray-100: #{$gray-100};
|
|
||||||
--#{$prefix}gray-200: #{$gray-200};
|
|
||||||
--#{$prefix}gray-300: #{$gray-300};
|
|
||||||
--#{$prefix}gray-400: #{$gray-400};
|
|
||||||
--#{$prefix}gray-500: #{$gray-500};
|
|
||||||
--#{$prefix}gray-600: #{$gray-600};
|
|
||||||
--#{$prefix}gray-700: #{$gray-700};
|
|
||||||
--#{$prefix}gray-800: #{$gray-800};
|
|
||||||
--#{$prefix}gray-900: #{$gray-900};
|
|
||||||
--#{$prefix}gray-950: #{$gray-950};
|
|
||||||
|
|
||||||
--#{$prefix}white: #{$white};
|
|
||||||
--#{$prefix}black: #{$black};
|
|
||||||
--#{$prefix}dark: #{$dark};
|
|
||||||
--#{$prefix}light: #{$light};
|
|
||||||
|
|
||||||
/** Brand colors */
|
|
||||||
--#{$prefix}brand: #{$primary};
|
|
||||||
|
|
||||||
/** Theme colors */
|
|
||||||
@each $name, $color in map-merge($theme-colors, $social-colors) {
|
|
||||||
--#{$prefix}#{$name}: #{$color};
|
|
||||||
--#{$prefix}#{$name}-rgb: #{to-rgb($color)};
|
|
||||||
--#{$prefix}#{$name}-fg: #{if(contrast-ratio($color) > $min-contrast-ratio, var(--#{$prefix}light), var(--#{$prefix}dark))};
|
|
||||||
--#{$prefix}#{$name}-darken: #{theme-color-darker($color)};
|
|
||||||
--#{$prefix}#{$name}-darken: color-mix(in oklab, var(--#{$prefix}#{$name}), transparent 20%);
|
|
||||||
--#{$prefix}#{$name}-lt: #{theme-color-lighter($color)};
|
|
||||||
--#{$prefix}#{$name}-lt: color-mix(in oklab, var(--#{$prefix}#{$name}) 10%, transparent);
|
|
||||||
--#{$prefix}#{$name}-200: color-mix(in oklab, var(--#{$prefix}#{$name}) 20%, transparent);
|
|
||||||
--#{$prefix}#{$name}-lt-rgb: #{to-rgb(theme-color-lighter($color))};
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Gray colors */
|
|
||||||
@each $name, $color in $gray-colors {
|
|
||||||
--#{$prefix}#{$name}-fg: #{if(contrast-ratio($color, white) > $min-contrast-ratio, var(--#{$prefix}white), var(--#{$prefix}body-color))};
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Spacers */
|
|
||||||
@each $name, $value in $spacers {
|
|
||||||
--#{$prefix}spacer-#{$name}: #{$value};
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Font sizes */
|
|
||||||
@each $name, $value in $font-weights {
|
|
||||||
--#{$prefix}font-weight-#{$name}: #{$value};
|
|
||||||
}
|
|
||||||
|
|
||||||
@each $name, $value in $font-sizes {
|
|
||||||
--#{$prefix}font-size-h#{$name}: #{$value};
|
|
||||||
}
|
|
||||||
|
|
||||||
@each $name, $value in $line-heights {
|
|
||||||
--#{$prefix}line-height-#{$name}: #{$value};
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Shadows */
|
|
||||||
@each $name, $value in $box-shadows {
|
|
||||||
--#{$prefix}shadow#{if($name, '-#{$name}', '')}: #{$value};
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Border radiuses */
|
|
||||||
--#{$prefix}border-radius-scale: 1;
|
|
||||||
@each $name, $value in $border-radiuses {
|
|
||||||
@if $name {
|
|
||||||
--#{$prefix}border-radius-#{$name}: calc(#{$value} * var(--#{$prefix}border-radius-scale, 1));
|
|
||||||
} @else {
|
|
||||||
--#{$prefix}border-radius: #{$value};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Backdrops */
|
|
||||||
--#{$prefix}backdrop-opacity: #{$backdrop-opacity};
|
|
||||||
--#{$prefix}backdrop-bg: var(--#{$prefix}bg-surface-dark);
|
|
||||||
@each $name, $value in $backdrops {
|
|
||||||
--#{$prefix}backdrop-bg#{if($name, '-#{$name}', '')}: #{$value};
|
|
||||||
}
|
|
||||||
--#{$prefix}backdrop-blur: #{$backdrop-blur};
|
|
||||||
--#{$prefix}backdrop-filter: blur(var(--#{$prefix}backdrop-blur));
|
|
||||||
}
|
|
||||||
@@ -1,143 +0,0 @@
|
|||||||
//
|
|
||||||
// Clearfix
|
|
||||||
//
|
|
||||||
.clearfix {
|
|
||||||
@include clearfix();
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// Text truncation
|
|
||||||
//
|
|
||||||
.text-truncate {
|
|
||||||
@include text-truncate();
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// Vertical rule
|
|
||||||
//
|
|
||||||
.vr {
|
|
||||||
display: inline-block;
|
|
||||||
align-self: stretch;
|
|
||||||
width: $vr-border-width;
|
|
||||||
min-height: 1em;
|
|
||||||
background-color: currentcolor;
|
|
||||||
opacity: $hr-opacity;
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// Stretched link
|
|
||||||
//
|
|
||||||
.stretched-link {
|
|
||||||
&::#{$stretched-link-pseudo-element} {
|
|
||||||
position: absolute;
|
|
||||||
top: 0;
|
|
||||||
right: 0;
|
|
||||||
bottom: 0;
|
|
||||||
left: 0;
|
|
||||||
z-index: $stretched-link-z-index;
|
|
||||||
content: "";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// Visually hidden
|
|
||||||
//
|
|
||||||
.visually-hidden,
|
|
||||||
.visually-hidden-focusable:not(:focus):not(:focus-within) {
|
|
||||||
@include visually-hidden();
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// Stacks
|
|
||||||
//
|
|
||||||
.hstack {
|
|
||||||
display: flex;
|
|
||||||
flex-direction: row;
|
|
||||||
align-items: center;
|
|
||||||
align-self: stretch;
|
|
||||||
}
|
|
||||||
|
|
||||||
.vstack {
|
|
||||||
display: flex;
|
|
||||||
flex: 1 1 auto;
|
|
||||||
flex-direction: column;
|
|
||||||
align-self: stretch;
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// Position
|
|
||||||
//
|
|
||||||
// Shorthand
|
|
||||||
|
|
||||||
.fixed-top {
|
|
||||||
position: fixed;
|
|
||||||
top: 0;
|
|
||||||
right: 0;
|
|
||||||
left: 0;
|
|
||||||
z-index: $zindex-fixed;
|
|
||||||
}
|
|
||||||
|
|
||||||
.fixed-bottom {
|
|
||||||
position: fixed;
|
|
||||||
right: 0;
|
|
||||||
bottom: 0;
|
|
||||||
left: 0;
|
|
||||||
z-index: $zindex-fixed;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Responsive sticky top and bottom
|
|
||||||
@each $breakpoint in map-keys($grid-breakpoints) {
|
|
||||||
@include media-breakpoint-up($breakpoint) {
|
|
||||||
$infix: breakpoint-infix($breakpoint, $grid-breakpoints);
|
|
||||||
|
|
||||||
.sticky#{$infix}-top {
|
|
||||||
position: sticky;
|
|
||||||
top: 0;
|
|
||||||
z-index: $zindex-sticky;
|
|
||||||
}
|
|
||||||
|
|
||||||
.sticky#{$infix}-bottom {
|
|
||||||
position: sticky;
|
|
||||||
bottom: 0;
|
|
||||||
z-index: $zindex-sticky;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// Aspect ratio
|
|
||||||
//
|
|
||||||
.ratio {
|
|
||||||
position: relative;
|
|
||||||
width: 100%;
|
|
||||||
|
|
||||||
&::before {
|
|
||||||
display: block;
|
|
||||||
padding-top: var(--#{$prefix}aspect-ratio);
|
|
||||||
content: "";
|
|
||||||
}
|
|
||||||
|
|
||||||
> * {
|
|
||||||
position: absolute;
|
|
||||||
top: 0;
|
|
||||||
left: 0;
|
|
||||||
width: 100%;
|
|
||||||
height: 100%;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@each $key, $ratio in $aspect-ratios {
|
|
||||||
.ratio-#{$key} {
|
|
||||||
--#{$prefix}aspect-ratio: #{$ratio};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// Focus ring
|
|
||||||
//
|
|
||||||
.focus-ring:focus {
|
|
||||||
outline: 0;
|
|
||||||
// By default, there is no `--bs-focus-ring-x`, `--bs-focus-ring-y`, or `--bs-focus-ring-blur`, but we provide CSS variables with fallbacks to initial `0` values
|
|
||||||
box-shadow: var(--#{$prefix}focus-ring-x, 0) var(--#{$prefix}focus-ring-y, 0) var(--#{$prefix}focus-ring-blur, 0) var(--#{$prefix}focus-ring-width) var(--#{$prefix}focus-ring-color);
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -1,74 +0,0 @@
|
|||||||
@use "sass:color";
|
|
||||||
|
|
||||||
// stylelint-disable declaration-no-important
|
|
||||||
|
|
||||||
@if $enable-dark-mode {
|
|
||||||
:root {
|
|
||||||
&:not(.theme-dark):not([data-bs-theme="dark"]) {
|
|
||||||
.hide-theme-light {
|
|
||||||
display: none !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.img-dark {
|
|
||||||
display: none !important;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
&.theme-dark,
|
|
||||||
&[data-bs-theme="dark"] {
|
|
||||||
.hide-theme-dark {
|
|
||||||
display: none !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.img-light {
|
|
||||||
display: none !important;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@include color-mode(dark, true) {
|
|
||||||
color-scheme: dark;
|
|
||||||
--#{$prefix}body-color: var(--#{$prefix}gray-200);
|
|
||||||
--#{$prefix}secondary: var(--#{$prefix}gray-400);
|
|
||||||
|
|
||||||
--#{$prefix}body-bg: var(--#{$prefix}gray-900);
|
|
||||||
--#{$prefix}emphasis-color: #{$body-emphasis-color-dark};
|
|
||||||
--#{$prefix}emphasis-color-rgb: #{to-rgb($body-emphasis-color-dark)};
|
|
||||||
|
|
||||||
--#{$prefix}bg-forms: var(--#{$prefix}gray-900);
|
|
||||||
--#{$prefix}bg-surface: var(--#{$prefix}gray-800);
|
|
||||||
--#{$prefix}bg-surface-inverted: var(--#{$prefix}gray-100);
|
|
||||||
--#{$prefix}bg-surface-secondary: var(--#{$prefix}gray-900);
|
|
||||||
--#{$prefix}bg-surface-tertiary: var(--#{$prefix}gray-800);
|
|
||||||
|
|
||||||
--#{$prefix}text-inverted: var(--#{$prefix}gray-800);
|
|
||||||
|
|
||||||
--#{$prefix}link-color: var(--#{$prefix}primary);
|
|
||||||
--#{$prefix}link-hover-color: color-mix(in srgb, var(--#{$prefix}primary), black 20%);
|
|
||||||
|
|
||||||
--#{$prefix}active-bg: #{$lighten-dark};
|
|
||||||
--#{$prefix}disabled-color: #{color-transparent(var(--#{$prefix}body-color), .4)};
|
|
||||||
|
|
||||||
--#{$prefix}border-color: var(--#{$prefix}gray-700);
|
|
||||||
--#{$prefix}border-color-translucent: var(
|
|
||||||
--#{$prefix}dark-mode-border-color-translucent
|
|
||||||
);
|
|
||||||
--#{$prefix}border-dark-color: var(--#{$prefix}dark-mode-border-dark-color);
|
|
||||||
--#{$prefix}border-active-color: var(
|
|
||||||
--#{$prefix}dark-mode-border-active-color
|
|
||||||
);
|
|
||||||
|
|
||||||
--#{$prefix}btn-color: #{$darken-dark};
|
|
||||||
|
|
||||||
.navbar-brand-autodark {
|
|
||||||
.navbar-brand-image {
|
|
||||||
@include autodark-image;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
body[data-bs-theme=dark] [data-bs-theme=light] {
|
|
||||||
@extend [data-bs-theme=dark];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,8 +0,0 @@
|
|||||||
.body-marketing {
|
|
||||||
--#{$prefix}body-font-size: 1rem;
|
|
||||||
--#{$prefix}body-line-height: 1.75;
|
|
||||||
}
|
|
||||||
|
|
||||||
.body-gradient {
|
|
||||||
background: var(--#{$prefix}bg-surface) linear-gradient(to bottom, var(--#{$prefix}bg-surface-secondary) 12%, var(--#{$prefix}bg-surface) 99%) repeat-x top center/100% 100vh;
|
|
||||||
}
|
|
||||||
@@ -1,96 +0,0 @@
|
|||||||
@function theme-color-lighter($color, $background: #fff) {
|
|
||||||
@return mix($color, $background, 10%);
|
|
||||||
}
|
|
||||||
|
|
||||||
@function theme-color-darker($color) {
|
|
||||||
@return shade-color($color, 10%);
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// Replace all occurrences of a substring within a string.
|
|
||||||
//
|
|
||||||
@function str-replace($string, $search, $replace: "") {
|
|
||||||
$index: str-index($string, $search);
|
|
||||||
|
|
||||||
@if $index {
|
|
||||||
@return str-slice($string, 1, $index - 1) + $replace + str-replace(str-slice($string, $index + str-length($search)), $search, $replace);
|
|
||||||
}
|
|
||||||
|
|
||||||
@return $string;
|
|
||||||
}
|
|
||||||
|
|
||||||
@mixin media-breakpoint-down-than($name, $breakpoints: $grid-breakpoints) {
|
|
||||||
$prev: breakpoint-prev($name);
|
|
||||||
|
|
||||||
@if $prev == null {
|
|
||||||
@content;
|
|
||||||
} @else {
|
|
||||||
$max: breakpoint-max($prev, $breakpoints);
|
|
||||||
|
|
||||||
@if $max {
|
|
||||||
@media (max-width: $max) {
|
|
||||||
@content;
|
|
||||||
}
|
|
||||||
} @else {
|
|
||||||
@content;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@function breakpoint-prev($name, $breakpoints: $grid-breakpoints, $breakpoint-names: map-keys($breakpoints)) {
|
|
||||||
$n: index($breakpoint-names, $name);
|
|
||||||
@if not $n {
|
|
||||||
@error "breakpoint `#{$name}` not found in `#{$breakpoints}`";
|
|
||||||
}
|
|
||||||
@return if($n > 1, nth($breakpoint-names, $n - 1), null);
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// Escape SVG strings.
|
|
||||||
//
|
|
||||||
@function escape-svg($string) {
|
|
||||||
@if str-index($string, "data:image/svg+xml") {
|
|
||||||
@each $char, $encoded in $escaped-characters {
|
|
||||||
// Do not escape the url brackets
|
|
||||||
@if str-index($string, "url(") == 1 {
|
|
||||||
$string: url("#{str-replace(str-slice($string, 6, -3), $char, $encoded)}");
|
|
||||||
} @else {
|
|
||||||
$string: str-replace($string, $char, $encoded);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@return $string;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Converts a given value to a percentage string.
|
|
||||||
*
|
|
||||||
* @param {Number} $value - The value to be converted to a percentage.
|
|
||||||
* @return {String} - The percentage representation of the value.
|
|
||||||
*/
|
|
||||||
@function to-percentage($value) {
|
|
||||||
@return if(unitless($value), percentage($value), $value);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Generates a transparent version of the given color.
|
|
||||||
*
|
|
||||||
* @param {Color} $color - The base color to be made transparent.
|
|
||||||
* @param {Number} $alpha - The level of transparency, ranging from 0 (fully transparent) to 1 (fully opaque). Default is 1.
|
|
||||||
* @return {Color} - The resulting color with the specified transparency.
|
|
||||||
*/
|
|
||||||
@function color-transparent($color, $alpha: 1, $background: transparent) {
|
|
||||||
@if $alpha == 1 {
|
|
||||||
@return $color;
|
|
||||||
} @else {
|
|
||||||
@return color-mix(in srgb, #{$color} #{to-percentage($alpha)}, $background);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@function url-svg($svg) {
|
|
||||||
$svg: str-replace($svg, '#', '%23');
|
|
||||||
$svg: str-replace($svg, '<svg', '<svg xmlns="http://www.w3.org/2000/svg"');
|
|
||||||
|
|
||||||
@return url('data:image/svg+xml;charset=UTF-8,#{$svg}');
|
|
||||||
}
|
|
||||||
@@ -1 +0,0 @@
|
|||||||
@import "props"
|
|
||||||
@@ -1,121 +0,0 @@
|
|||||||
@import "config";
|
|
||||||
|
|
||||||
[data-bs-theme-base="slate"] {
|
|
||||||
--#{$prefix}gray-50: #f8fafc;
|
|
||||||
--#{$prefix}gray-100: #f1f5f9;
|
|
||||||
--#{$prefix}gray-200: #e2e8f0;
|
|
||||||
--#{$prefix}gray-300: #cbd5e1;
|
|
||||||
--#{$prefix}gray-400: #94a3b8;
|
|
||||||
--#{$prefix}gray-500: #64748b;
|
|
||||||
--#{$prefix}gray-600: #475569;
|
|
||||||
--#{$prefix}gray-700: #334155;
|
|
||||||
--#{$prefix}gray-800: #1e293b;
|
|
||||||
--#{$prefix}gray-900: #0f172a;
|
|
||||||
--#{$prefix}gray-950: #020617;
|
|
||||||
}
|
|
||||||
|
|
||||||
[data-bs-theme-base="gray"] {
|
|
||||||
--#{$prefix}gray-50: #f9fafb;
|
|
||||||
--#{$prefix}gray-100: #f3f4f6;
|
|
||||||
--#{$prefix}gray-200: #e5e7eb;
|
|
||||||
--#{$prefix}gray-300: #d1d5db;
|
|
||||||
--#{$prefix}gray-400: #9ca3af;
|
|
||||||
--#{$prefix}gray-500: #6b7280;
|
|
||||||
--#{$prefix}gray-600: #4b5563;
|
|
||||||
--#{$prefix}gray-700: #374151;
|
|
||||||
--#{$prefix}gray-800: #1f2937;
|
|
||||||
--#{$prefix}gray-900: #111827;
|
|
||||||
--#{$prefix}gray-950: #030712;
|
|
||||||
}
|
|
||||||
|
|
||||||
[data-bs-theme-base="zinc"] {
|
|
||||||
--#{$prefix}gray-50: #fafafa;
|
|
||||||
--#{$prefix}gray-100: #f4f4f5;
|
|
||||||
--#{$prefix}gray-200: #e4e4e7;
|
|
||||||
--#{$prefix}gray-300: #d4d4d8;
|
|
||||||
--#{$prefix}gray-400: #a1a1aa;
|
|
||||||
--#{$prefix}gray-500: #71717a;
|
|
||||||
--#{$prefix}gray-600: #52525b;
|
|
||||||
--#{$prefix}gray-700: #3f3f46;
|
|
||||||
--#{$prefix}gray-800: #27272a;
|
|
||||||
--#{$prefix}gray-900: #18181b;
|
|
||||||
--#{$prefix}gray-950: #09090b;
|
|
||||||
}
|
|
||||||
|
|
||||||
[data-bs-theme-base="neutral"] {
|
|
||||||
--#{$prefix}gray-50: #fafafa;
|
|
||||||
--#{$prefix}gray-100: #f5f5f5;
|
|
||||||
--#{$prefix}gray-200: #e5e5e5;
|
|
||||||
--#{$prefix}gray-300: #d4d4d4;
|
|
||||||
--#{$prefix}gray-400: #a3a3a3;
|
|
||||||
--#{$prefix}gray-500: #737373;
|
|
||||||
--#{$prefix}gray-600: #525252;
|
|
||||||
--#{$prefix}gray-700: #404040;
|
|
||||||
--#{$prefix}gray-800: #262626;
|
|
||||||
--#{$prefix}gray-900: #171717;
|
|
||||||
--#{$prefix}gray-950: #0a0a0a;
|
|
||||||
}
|
|
||||||
|
|
||||||
[data-bs-theme-base="stone"] {
|
|
||||||
--#{$prefix}gray-50: #fafaf9;
|
|
||||||
--#{$prefix}gray-100: #f5f5f4;
|
|
||||||
--#{$prefix}gray-200: #e7e5e4;
|
|
||||||
--#{$prefix}gray-300: #d6d3d1;
|
|
||||||
--#{$prefix}gray-400: #a8a29e;
|
|
||||||
--#{$prefix}gray-500: #78716c;
|
|
||||||
--#{$prefix}gray-600: #57534e;
|
|
||||||
--#{$prefix}gray-700: #44403c;
|
|
||||||
--#{$prefix}gray-800: #292524;
|
|
||||||
--#{$prefix}gray-900: #1c1917;
|
|
||||||
--#{$prefix}gray-950: #0c0a09;
|
|
||||||
}
|
|
||||||
|
|
||||||
[data-bs-theme-base="pink"] {
|
|
||||||
--#{$prefix}gray-50: #fdf2f8;
|
|
||||||
--#{$prefix}gray-100: #fce7f3;
|
|
||||||
--#{$prefix}gray-200: #fbcfe8;
|
|
||||||
--#{$prefix}gray-300: #f9a8d4;
|
|
||||||
--#{$prefix}gray-400: #f472b6;
|
|
||||||
--#{$prefix}gray-500: #ec4899;
|
|
||||||
--#{$prefix}gray-600: #db2777;
|
|
||||||
--#{$prefix}gray-700: #be185d;
|
|
||||||
--#{$prefix}gray-800: #9d174d;
|
|
||||||
--#{$prefix}gray-900: #831843;
|
|
||||||
--#{$prefix}gray-950: #500724;
|
|
||||||
}
|
|
||||||
|
|
||||||
@each $name, $value in $extra-colors {
|
|
||||||
[data-bs-theme-primary="#{$name}"] {
|
|
||||||
--#{$prefix}primary: #{$value};
|
|
||||||
--#{$prefix}primary-rgb: #{to-rgb($value)};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@each $value in (0, .5, 1, 1.5, 2) {
|
|
||||||
[data-bs-theme-radius="#{$value}"] {
|
|
||||||
--#{$prefix}border-radius-scale: #{$value};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
[data-bs-theme-primary="inverted"] {
|
|
||||||
--#{$prefix}primary: var(--#{$prefix}gray-800);
|
|
||||||
--#{$prefix}primary-fg: var(--#{$prefix}light);
|
|
||||||
--#{$prefix}primary-rgb: #{to-rgb($dark)};
|
|
||||||
|
|
||||||
&[data-bs-theme="dark"],
|
|
||||||
[data-bs-theme="dark"] {
|
|
||||||
--#{$prefix}primary: #{$light};
|
|
||||||
--#{$prefix}primary-fg: var(--#{$prefix}dark);
|
|
||||||
--#{$prefix}primary-rgb: #{to-rgb($light)};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@each $name, $value in (monospace: $font-family-monospace, sans-serif: $font-family-sans-serif, serif: $font-family-serif, comic: $font-family-comic) {
|
|
||||||
[data-bs-theme-font="#{$name}"] {
|
|
||||||
--#{$prefix}body-font-family: var(--#{$prefix}font-#{$name});
|
|
||||||
|
|
||||||
@if $name == "monospace" {
|
|
||||||
--#{$prefix}body-font-size: 80%;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,177 +0,0 @@
|
|||||||
.accordion {
|
|
||||||
--#{$prefix}accordion-color: var(--#{$prefix}body-color);
|
|
||||||
--#{$prefix}accordion-border-color: var(--#{$prefix}border-color);
|
|
||||||
--#{$prefix}accordion-border-radius: #{$accordion-border-radius};
|
|
||||||
--#{$prefix}accordion-inner-border-radius: #{$accordion-inner-border-radius};
|
|
||||||
--#{$prefix}accordion-padding-x: #{$accordion-body-padding-x};
|
|
||||||
--#{$prefix}accordion-gap: 0;
|
|
||||||
--#{$prefix}accordion-active-color: #{$accordion-button-active-color};
|
|
||||||
--#{$prefix}accordion-btn-color: var(--#{$prefix}accordion-color);
|
|
||||||
--#{$prefix}accordion-btn-bg: #{$accordion-button-bg};
|
|
||||||
--#{$prefix}accordion-btn-toggle-width: 1.25rem;
|
|
||||||
--#{$prefix}accordion-btn-padding-x: var(--#{$prefix}accordion-padding-x);
|
|
||||||
--#{$prefix}accordion-btn-padding-y: #{$accordion-button-padding-y};
|
|
||||||
--#{$prefix}accordion-btn-font-weight: var(--#{$prefix}font-weight-medium);
|
|
||||||
--#{$prefix}accordion-body-padding-x: var(--#{$prefix}accordion-padding-x);
|
|
||||||
--#{$prefix}accordion-body-padding-y: #{$accordion-body-padding-y};
|
|
||||||
|
|
||||||
display: flex;
|
|
||||||
flex-direction: column;
|
|
||||||
gap: var(--#{$prefix}accordion-gap);
|
|
||||||
}
|
|
||||||
|
|
||||||
.accordion-button {
|
|
||||||
position: relative;
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
width: 100%;
|
|
||||||
padding: var(--#{$prefix}accordion-btn-padding-y) var(--#{$prefix}accordion-padding-x);
|
|
||||||
color: inherit;
|
|
||||||
text-align: inherit;
|
|
||||||
background-color: transparent;
|
|
||||||
border: 0;
|
|
||||||
font-size: inherit;
|
|
||||||
font-weight: var(--#{$prefix}accordion-btn-font-weight);
|
|
||||||
gap: .75rem;
|
|
||||||
|
|
||||||
&:not(.collapsed) {
|
|
||||||
border-bottom-color: transparent;
|
|
||||||
box-shadow: none;
|
|
||||||
color: var(--#{$prefix}accordion-active-color);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.accordion-header {
|
|
||||||
margin: 0;
|
|
||||||
position: relative;
|
|
||||||
display: flex;
|
|
||||||
gap: 1rem;
|
|
||||||
align-items: center;
|
|
||||||
width: 100%;
|
|
||||||
color: var(--#{$prefix}accordion-btn-color);
|
|
||||||
text-align: left;
|
|
||||||
background-color: transparent;
|
|
||||||
border: 0;
|
|
||||||
overflow-anchor: none;
|
|
||||||
transition: transform $transition-time;
|
|
||||||
|
|
||||||
&:hover {
|
|
||||||
z-index: 2;
|
|
||||||
}
|
|
||||||
|
|
||||||
&:focus {
|
|
||||||
z-index: 3;
|
|
||||||
outline: 0;
|
|
||||||
box-shadow: var(--#{$prefix}accordion-btn-focus-box-shadow);
|
|
||||||
|
|
||||||
&:not(:focus-visible) {
|
|
||||||
outline: none;
|
|
||||||
box-shadow: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.accordion-button-icon {
|
|
||||||
color: var(--#{$prefix}secondary);
|
|
||||||
}
|
|
||||||
|
|
||||||
.accordion-button-toggle {
|
|
||||||
display: flex;
|
|
||||||
line-height: 1;
|
|
||||||
transition: $transition-time transform;
|
|
||||||
margin-left: auto;
|
|
||||||
margin-right: 0;
|
|
||||||
color: var(--#{$prefix}secondary);
|
|
||||||
width: var(--#{$prefix}accordion-btn-toggle-width);
|
|
||||||
height: var(--#{$prefix}accordion-btn-toggle-width);
|
|
||||||
|
|
||||||
.accordion-button:not(.collapsed) & {
|
|
||||||
transform: rotate(-180deg);
|
|
||||||
color: var(--#{$prefix}accordion-active-color);
|
|
||||||
}
|
|
||||||
|
|
||||||
path {
|
|
||||||
transition: $transition-time opacity;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.accordion-button-toggle-plus {
|
|
||||||
.accordion-button:not(.collapsed) & {
|
|
||||||
path:first-child {
|
|
||||||
opacity: 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.accordion-item {
|
|
||||||
color: var(--#{$prefix}accordion-color);
|
|
||||||
border: var(--#{$prefix}border-width) solid var(--#{$prefix}accordion-border-color);
|
|
||||||
|
|
||||||
&:first-of-type {
|
|
||||||
@include border-top-radius(var(--#{$prefix}accordion-border-radius));
|
|
||||||
|
|
||||||
> .accordion-header {
|
|
||||||
@include border-top-radius(var(--#{$prefix}accordion-inner-border-radius));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
&:not(:first-of-type) {
|
|
||||||
border-top: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
&:last-of-type {
|
|
||||||
@include border-bottom-radius(var(--#{$prefix}accordion-border-radius));
|
|
||||||
|
|
||||||
> .accordion-header {
|
|
||||||
&.collapsed {
|
|
||||||
@include border-bottom-radius(var(--#{$prefix}accordion-inner-border-radius));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
> .accordion-collapse {
|
|
||||||
@include border-bottom-radius(var(--#{$prefix}accordion-border-radius));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.accordion-body {
|
|
||||||
color: var(--#{$prefix}secondary);
|
|
||||||
padding: 0 var(--#{$prefix}accordion-body-padding-x) var(--#{$prefix}accordion-body-padding-y);
|
|
||||||
}
|
|
||||||
|
|
||||||
.accordion-flush {
|
|
||||||
> .accordion-item {
|
|
||||||
border-right: 0;
|
|
||||||
border-left: 0;
|
|
||||||
@include border-radius(0);
|
|
||||||
|
|
||||||
&:first-child {
|
|
||||||
border-top: 0;
|
|
||||||
}
|
|
||||||
&:last-child {
|
|
||||||
border-bottom: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
> .accordion-collapse,
|
|
||||||
> .accordion-header .accordion-button,
|
|
||||||
> .accordion-header .accordion-button.collapsed {
|
|
||||||
@include border-radius(0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.accordion-tabs {
|
|
||||||
--#{$prefix}accordion-gap: 0.75rem;
|
|
||||||
|
|
||||||
> .accordion-item {
|
|
||||||
border: var(--#{$prefix}border-width) solid var(--#{$prefix}accordion-border-color);
|
|
||||||
border-radius: var(--#{$prefix}accordion-border-radius);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.accordion-inverted {
|
|
||||||
.accordion-button-toggle {
|
|
||||||
order: -1;
|
|
||||||
margin-left: 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,101 +0,0 @@
|
|||||||
.alert {
|
|
||||||
// scss-docs-start alert-variables
|
|
||||||
--#{$prefix}alert-color: var(--#{$prefix}body-color);
|
|
||||||
--#{$prefix}alert-bg: #{color-transparent(var(--#{$prefix}alert-color), .1)};
|
|
||||||
--#{$prefix}alert-padding-x: #{$alert-padding-x};
|
|
||||||
--#{$prefix}alert-padding-y: #{$alert-padding-y};
|
|
||||||
--#{$prefix}alert-margin-bottom: #{$alert-margin-bottom};
|
|
||||||
--#{$prefix}alert-border-color: #{color-transparent(var(--#{$prefix}alert-color), .2)};
|
|
||||||
--#{$prefix}alert-border: var(--#{$prefix}border-width) solid var(--#{$prefix}alert-border-color);
|
|
||||||
--#{$prefix}alert-border-radius: var(--#{$prefix}border-radius);
|
|
||||||
--#{$prefix}alert-link-color: inherit;
|
|
||||||
--#{$prefix}alert-heading-font-weight: var(--#{$prefix}font-weight-medium);
|
|
||||||
// scss-docs-end
|
|
||||||
|
|
||||||
position: relative;
|
|
||||||
padding: var(--#{$prefix}alert-padding-y) var(--#{$prefix}alert-padding-x);
|
|
||||||
margin-bottom: var(--#{$prefix}alert-margin-bottom);
|
|
||||||
background-color: color-mix(in srgb, var(--#{$prefix}alert-bg), var(--#{$prefix}bg-surface));
|
|
||||||
border-radius: var(--#{$prefix}alert-border-radius);
|
|
||||||
border: var(--#{$prefix}border-width) var(--#{$prefix}border-style) var(--#{$prefix}alert-border-color);
|
|
||||||
display: flex;
|
|
||||||
flex-direction: row;
|
|
||||||
gap: 1rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.alert-heading {
|
|
||||||
color: inherit;
|
|
||||||
margin-bottom: .25rem; // todo: use variable
|
|
||||||
font-weight: var(--#{$prefix}alert-heading-font-weight);
|
|
||||||
}
|
|
||||||
|
|
||||||
.alert-description {
|
|
||||||
color: var(--#{$prefix}secondary);
|
|
||||||
}
|
|
||||||
|
|
||||||
.alert-icon {
|
|
||||||
color: var(--#{$prefix}alert-color);
|
|
||||||
width: 1.25rem !important; // todo: use variable
|
|
||||||
height: 1.25rem !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.alert-action {
|
|
||||||
color: var(--#{$prefix}alert-color);
|
|
||||||
text-decoration: underline;
|
|
||||||
|
|
||||||
&:hover {
|
|
||||||
text-decoration: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.alert-list {
|
|
||||||
margin: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.alert-link {
|
|
||||||
font-weight: $alert-link-font-weight;
|
|
||||||
color: var(--#{$prefix}alert-link-color);
|
|
||||||
|
|
||||||
&,
|
|
||||||
&:hover {
|
|
||||||
color: var(--#{$prefix}alert-color);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
.alert-dismissible {
|
|
||||||
padding-right: 3rem; //todo: use variable
|
|
||||||
|
|
||||||
.btn-close {
|
|
||||||
position: absolute;
|
|
||||||
top: calc(var(--#{$prefix}alert-padding-x) / 2 - 1px);
|
|
||||||
right: calc(var(--#{$prefix}alert-padding-y) / 2 - 1px);
|
|
||||||
z-index: 1;
|
|
||||||
padding: calc(var(--#{$prefix}alert-padding-y) * 1.25) var(--#{$prefix}alert-padding-x);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.alert-important {
|
|
||||||
border-color: var(--#{$prefix}alert-color);
|
|
||||||
background-color: var(--#{$prefix}alert-color);
|
|
||||||
color: var(--#{$prefix}white);
|
|
||||||
|
|
||||||
.alert-description {
|
|
||||||
color: inherit;
|
|
||||||
}
|
|
||||||
|
|
||||||
.alert-icon {
|
|
||||||
color: inherit;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.alert-minor {
|
|
||||||
background: transparent;
|
|
||||||
border-color: var(--tblr-border-color);
|
|
||||||
}
|
|
||||||
|
|
||||||
@each $name, $color in $theme-colors {
|
|
||||||
.alert-#{$name} {
|
|
||||||
--#{$prefix}alert-color: var(--#{$prefix}#{$name});
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,113 +0,0 @@
|
|||||||
.badge {
|
|
||||||
--#{$prefix}badge-padding-x: #{$badge-padding-x};
|
|
||||||
--#{$prefix}badge-padding-y: #{$badge-padding-y};
|
|
||||||
--#{$prefix}badge-font-size: #{$badge-font-size};
|
|
||||||
--#{$prefix}badge-font-weight: #{$badge-font-weight};
|
|
||||||
--#{$prefix}badge-color: #{$badge-color};
|
|
||||||
--#{$prefix}badge-border-radius: #{$badge-border-radius};
|
|
||||||
--#{$prefix}badge-icon-size: 1em;
|
|
||||||
--#{$prefix}badge-line-height: 1;
|
|
||||||
display: inline-flex;
|
|
||||||
padding: var(--#{$prefix}badge-padding-y) var(--#{$prefix}badge-padding-x);
|
|
||||||
font-weight: var(--#{$prefix}badge-font-weight);
|
|
||||||
font-size: var(--#{$prefix}badge-font-size);
|
|
||||||
color: var(--#{$prefix}badge-color);
|
|
||||||
text-align: center;
|
|
||||||
white-space: nowrap;
|
|
||||||
justify-content: center;
|
|
||||||
align-items: center;
|
|
||||||
gap: .25rem;
|
|
||||||
background: $badge-bg-color;
|
|
||||||
overflow: hidden;
|
|
||||||
user-select: none;
|
|
||||||
border: var(--#{$prefix}border-width) var(--#{$prefix}border-style) transparent;
|
|
||||||
border-radius: var(--#{$prefix}badge-border-radius);
|
|
||||||
min-width: calc(1em + var(--#{$prefix}badge-padding-y) * 2 + 2px);
|
|
||||||
letter-spacing: 0.04em;
|
|
||||||
vertical-align: bottom;
|
|
||||||
line-height: var(--#{$prefix}badge-line-height);
|
|
||||||
|
|
||||||
@at-root a#{&} {
|
|
||||||
background: var(--#{$prefix}bg-surface-secondary);
|
|
||||||
}
|
|
||||||
|
|
||||||
.icon {
|
|
||||||
width: 1em;
|
|
||||||
height: 1em;
|
|
||||||
font-size: var(--#{$prefix}badge-icon-size);
|
|
||||||
stroke-width: 2;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.badge:empty,
|
|
||||||
.badge-dot {
|
|
||||||
display: inline-block;
|
|
||||||
width: $badge-empty-size;
|
|
||||||
height: $badge-empty-size;
|
|
||||||
min-width: 0;
|
|
||||||
min-height: auto;
|
|
||||||
padding: 0;
|
|
||||||
border-radius: $border-radius-pill;
|
|
||||||
vertical-align: baseline;
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// Outline badge
|
|
||||||
//
|
|
||||||
.badge-outline {
|
|
||||||
background-color: transparent;
|
|
||||||
border: var(--#{$prefix}border-width) var(--#{$prefix}border-style) currentColor;
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// Pill badge
|
|
||||||
//
|
|
||||||
.badge-pill {
|
|
||||||
border-radius: $border-radius-pill;
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// Badges list
|
|
||||||
//
|
|
||||||
.badges-list {
|
|
||||||
@include elements-list;
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// Notification badge
|
|
||||||
//
|
|
||||||
.badge-notification {
|
|
||||||
position: absolute !important;
|
|
||||||
top: 0 !important;
|
|
||||||
right: 0 !important;
|
|
||||||
transform: translate(50%, -50%);
|
|
||||||
z-index: 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
.badge-blink {
|
|
||||||
animation: blink 2s infinite;
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// Badge sizes
|
|
||||||
//
|
|
||||||
.badge-sm {
|
|
||||||
--#{$prefix}badge-font-size: #{$badge-font-size-sm};
|
|
||||||
--#{$prefix}badge-icon-size: 1em;
|
|
||||||
--#{$prefix}badge-padding-y: 2px;
|
|
||||||
--#{$prefix}badge-padding-x: 0.25rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.badge-lg {
|
|
||||||
--#{$prefix}badge-font-size: #{$badge-font-size-lg};
|
|
||||||
--#{$prefix}badge-icon-size: 1em;
|
|
||||||
--#{$prefix}badge-padding-y: 0.25rem;
|
|
||||||
--#{$prefix}badge-padding-x: 0.5rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
//
|
|
||||||
// Badge with only icon
|
|
||||||
//
|
|
||||||
.badge-icononly {
|
|
||||||
--#{$prefix}badge-padding-x: 0;
|
|
||||||
}
|
|
||||||
@@ -1,60 +0,0 @@
|
|||||||
.btn-close {
|
|
||||||
--#{$prefix}btn-close-color: currentColor;
|
|
||||||
--#{$prefix}btn-close-bg: #{ escape-svg($btn-close-bg) };
|
|
||||||
--#{$prefix}btn-close-opacity: #{$btn-close-opacity};
|
|
||||||
--#{$prefix}btn-close-hover-opacity: #{$btn-close-hover-opacity};
|
|
||||||
--#{$prefix}btn-close-focus-shadow: #{$btn-close-focus-shadow};
|
|
||||||
--#{$prefix}btn-close-focus-opacity: #{$btn-close-focus-opacity};
|
|
||||||
--#{$prefix}btn-close-disabled-opacity: #{$btn-close-disabled-opacity};
|
|
||||||
--#{$prefix}btn-close-size: #{$btn-close-width};
|
|
||||||
|
|
||||||
width: var(--#{$prefix}btn-close-size);
|
|
||||||
height: var(--#{$prefix}btn-close-size);
|
|
||||||
padding: $btn-close-padding-y $btn-close-padding-x;
|
|
||||||
color: var(--#{$prefix}btn-close-color);
|
|
||||||
mask: var(--#{$prefix}btn-close-bg) no-repeat center/calc(var(--#{$prefix}btn-close-size) * .75);
|
|
||||||
background-color: var(--#{$prefix}btn-close-color);
|
|
||||||
border: 0;
|
|
||||||
border-radius: var(--tblr-border-radius);
|
|
||||||
opacity: var(--#{$prefix}btn-close-opacity);
|
|
||||||
cursor: pointer;
|
|
||||||
display: block;
|
|
||||||
|
|
||||||
&:hover {
|
|
||||||
color: var(--#{$prefix}btn-close-color);
|
|
||||||
text-decoration: none;
|
|
||||||
opacity: var(--#{$prefix}btn-close-hover-opacity);
|
|
||||||
}
|
|
||||||
|
|
||||||
&:focus {
|
|
||||||
outline: 0;
|
|
||||||
box-shadow: var(--#{$prefix}btn-close-focus-shadow);
|
|
||||||
opacity: var(--#{$prefix}btn-close-focus-opacity);
|
|
||||||
}
|
|
||||||
|
|
||||||
&:disabled,
|
|
||||||
&.disabled {
|
|
||||||
pointer-events: none;
|
|
||||||
user-select: none;
|
|
||||||
opacity: var(--#{$prefix}btn-close-disabled-opacity);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// @mixin btn-close-white() {
|
|
||||||
// --#{$prefix}btn-close-filter: #{$btn-close-filter-dark};
|
|
||||||
// }
|
|
||||||
|
|
||||||
// .btn-close-white {
|
|
||||||
// @include btn-close-white();
|
|
||||||
// }
|
|
||||||
|
|
||||||
// :root,
|
|
||||||
// [data-bs-theme="light"] {
|
|
||||||
// --#{$prefix}btn-close-filter: #{$btn-close-filter};
|
|
||||||
// }
|
|
||||||
|
|
||||||
// @if $enable-dark-mode {
|
|
||||||
// @include color-mode(dark, true) {
|
|
||||||
// @include btn-close-white();
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
@@ -1,101 +0,0 @@
|
|||||||
.nav-segmented {
|
|
||||||
--#{$prefix}nav-bg: var(--#{$prefix}bg-surface-tertiary);
|
|
||||||
--#{$prefix}nav-padding: 2px;
|
|
||||||
--#{$prefix}nav-height: 2.5rem;
|
|
||||||
--#{$prefix}nav-gap: .25rem;
|
|
||||||
--#{$prefix}nav-active-bg: var(--#{$prefix}bg-surface);
|
|
||||||
--#{$prefix}nav-font-size: inherit;
|
|
||||||
--#{$prefix}nav-radius: 6px;
|
|
||||||
|
|
||||||
|
|
||||||
--#{$prefix}nav-link-disabled-color: var(--#{$prefix}disabled-color);
|
|
||||||
--#{$prefix}nav-link-gap: .25rem;
|
|
||||||
--#{$prefix}nav-link-padding-x: .75rem;
|
|
||||||
--#{$prefix}nav-link-icon-size: 1.25rem;
|
|
||||||
display: inline-flex;
|
|
||||||
flex-wrap: wrap;
|
|
||||||
gap: var(--#{$prefix}nav-gap);
|
|
||||||
padding: var(--#{$prefix}nav-padding);
|
|
||||||
list-style: none;
|
|
||||||
background: var(--#{$prefix}nav-bg);
|
|
||||||
border-radius: calc(var(--#{$prefix}nav-radius) + var(--#{$prefix}nav-padding));
|
|
||||||
box-shadow: inset 0 0 0 1px rgba(0, 0, 0, .04);
|
|
||||||
|
|
||||||
.nav-link {
|
|
||||||
display: inline-flex;
|
|
||||||
gap: calc(.25rem + var(--#{$prefix}nav-link-gap));
|
|
||||||
align-items: center;
|
|
||||||
margin: 0;
|
|
||||||
font-size: var(--#{$prefix}nav-font-size);
|
|
||||||
min-width: calc(var(--#{$prefix}nav-height) - 2 * var(--#{$prefix}nav-padding));
|
|
||||||
height: calc(var(--#{$prefix}nav-height) - 2 * var(--#{$prefix}nav-padding));
|
|
||||||
padding: 0 calc(var(--#{$prefix}nav-link-padding-x) - 2px);
|
|
||||||
border: 1px solid transparent;
|
|
||||||
background: transparent;
|
|
||||||
color: var(--#{$prefix}secondary);
|
|
||||||
text-align: center;
|
|
||||||
text-decoration: none;
|
|
||||||
white-space: nowrap;
|
|
||||||
cursor: pointer;
|
|
||||||
transition: background-color $transition-time, color $transition-time;
|
|
||||||
border-radius: var(--#{$prefix}nav-radius);
|
|
||||||
flex-grow: 1;
|
|
||||||
justify-content: center;
|
|
||||||
|
|
||||||
&:hover,
|
|
||||||
&.hover {
|
|
||||||
background: rgba(0, 0, 0, .04);
|
|
||||||
color: var(--#{$prefix}body-color);
|
|
||||||
}
|
|
||||||
|
|
||||||
&.disabled,
|
|
||||||
&:disabled {
|
|
||||||
color: var(--#{$prefix}nav-link-disabled-color);
|
|
||||||
cursor: not-allowed;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.nav-link-input:checked + .nav-link,
|
|
||||||
.nav-link.active {
|
|
||||||
color: var(--#{$prefix}body-color);
|
|
||||||
background: var(--#{$prefix}nav-active-bg);
|
|
||||||
border-color: var(--#{$prefix}border-color);
|
|
||||||
}
|
|
||||||
|
|
||||||
.nav-link-input {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.nav-link-icon {
|
|
||||||
width: var(--#{$prefix}nav-link-icon-size);
|
|
||||||
height: var(--#{$prefix}nav-link-icon-size);
|
|
||||||
margin: 0 -.25rem;
|
|
||||||
color: inherit;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.nav-segmented-vertical {
|
|
||||||
flex-direction: column;
|
|
||||||
|
|
||||||
.nav-link {
|
|
||||||
justify-content: flex-start;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.nav-sm {
|
|
||||||
--#{$prefix}nav-height: 2rem;
|
|
||||||
--#{$prefix}nav-font-size: var(--tblr-font-size-h5);
|
|
||||||
--#{$prefix}nav-radius: 4px;
|
|
||||||
--#{$prefix}nav-link-padding-x: .5rem;
|
|
||||||
--#{$prefix}nav-link-gap: .25rem;
|
|
||||||
--#{$prefix}nav-link-icon-size: 1rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
.nav-lg {
|
|
||||||
--#{$prefix}nav-height: 3rem;
|
|
||||||
--#{$prefix}nav-font-size: var(--tblr-font-size-h3);
|
|
||||||
--#{$prefix}nav-radius: 8px;
|
|
||||||
--#{$prefix}nav-link-padding-x: 1rem;
|
|
||||||
--#{$prefix}nav-link-gap: .5rem;
|
|
||||||
--#{$prefix}nav-link-icon-size: 1.5rem;
|
|
||||||
}
|
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
.signature {
|
|
||||||
--#{$prefix}signature-padding: var(--#{$prefix}spacer-1);
|
|
||||||
--#{$prefix}signature-border-radius: var(--#{$prefix}border-radius);
|
|
||||||
border: var(--#{$prefix}border-width) solid var(--#{$prefix}border-color);
|
|
||||||
padding: var(--#{$prefix}signature-padding);
|
|
||||||
border-radius: var(--#{$prefix}border-radius);
|
|
||||||
}
|
|
||||||
|
|
||||||
.signature-canvas {
|
|
||||||
border: var(--#{$prefix}border-width) dashed var(--#{$prefix}border-color);
|
|
||||||
border-radius: calc(var(--#{$prefix}signature-border-radius) - var(--#{$prefix}signature-padding));
|
|
||||||
display: block;
|
|
||||||
cursor: crosshair;
|
|
||||||
width: 100%;
|
|
||||||
}
|
|
||||||
@@ -1,330 +0,0 @@
|
|||||||
@import "typo/hr";
|
|
||||||
|
|
||||||
.lead {
|
|
||||||
color: var(--#{$prefix}secondary);
|
|
||||||
font-size: inherit;
|
|
||||||
}
|
|
||||||
|
|
||||||
a {
|
|
||||||
text-decoration-skip-ink: auto;
|
|
||||||
color: color-mix(in srgb, transparent, var(--#{$prefix}link-color) var(--#{$prefix}link-opacity, 100%));
|
|
||||||
|
|
||||||
&:hover {
|
|
||||||
color: color-mix(in srgb, transparent, var(--#{$prefix}link-hover-color) var(--#{$prefix}link-opacity, 100%));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
h1,
|
|
||||||
h2,
|
|
||||||
h3,
|
|
||||||
h4,
|
|
||||||
h5,
|
|
||||||
h6,
|
|
||||||
.h1,
|
|
||||||
.h2,
|
|
||||||
.h3,
|
|
||||||
.h4,
|
|
||||||
.h5,
|
|
||||||
.h6 {
|
|
||||||
a {
|
|
||||||
color: inherit;
|
|
||||||
|
|
||||||
&:hover {
|
|
||||||
color: inherit;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
h1,
|
|
||||||
.h1 {
|
|
||||||
font-size: var(--#{$prefix}font-size-h1);
|
|
||||||
line-height: var(--#{$prefix}line-height-h1);
|
|
||||||
}
|
|
||||||
|
|
||||||
h2,
|
|
||||||
.h2 {
|
|
||||||
font-size: var(--#{$prefix}font-size-h2);
|
|
||||||
line-height: var(--#{$prefix}line-height-h2);
|
|
||||||
}
|
|
||||||
|
|
||||||
h3,
|
|
||||||
.h3 {
|
|
||||||
font-size: var(--#{$prefix}font-size-h3);
|
|
||||||
line-height: var(--#{$prefix}line-height-h3);
|
|
||||||
}
|
|
||||||
|
|
||||||
h4,
|
|
||||||
.h4 {
|
|
||||||
font-size: var(--#{$prefix}font-size-h4);
|
|
||||||
line-height: var(--#{$prefix}line-height-h4);
|
|
||||||
}
|
|
||||||
|
|
||||||
h5,
|
|
||||||
.h5 {
|
|
||||||
font-size: var(--#{$prefix}font-size-h5);
|
|
||||||
line-height: var(--#{$prefix}line-height-h5);
|
|
||||||
}
|
|
||||||
|
|
||||||
h6,
|
|
||||||
.h6 {
|
|
||||||
font-size: var(--#{$prefix}font-size-h6);
|
|
||||||
line-height: var(--#{$prefix}line-height-h6);
|
|
||||||
}
|
|
||||||
|
|
||||||
.fs-base {
|
|
||||||
font-size: var(--#{$prefix}body-font-size);
|
|
||||||
}
|
|
||||||
|
|
||||||
strong,
|
|
||||||
.strong,
|
|
||||||
b {
|
|
||||||
font-weight: $headings-font-weight;
|
|
||||||
}
|
|
||||||
|
|
||||||
blockquote {
|
|
||||||
padding: 1rem 1rem 1rem;
|
|
||||||
border-left: 2px var(--#{$prefix}border-style) var(--#{$prefix}border-color);
|
|
||||||
|
|
||||||
p {
|
|
||||||
margin-bottom: 1rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
cite {
|
|
||||||
display: block;
|
|
||||||
text-align: right;
|
|
||||||
|
|
||||||
&:before {
|
|
||||||
content: "— ";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
ul,
|
|
||||||
ol {
|
|
||||||
padding-left: 1.5rem;
|
|
||||||
}
|
|
||||||
|
|
||||||
hr {
|
|
||||||
margin: 2rem 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
dl {
|
|
||||||
dd {
|
|
||||||
&:last-child {
|
|
||||||
margin-bottom: 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
pre {
|
|
||||||
--#{$prefix}scrollbar-color: #{$pre-color};
|
|
||||||
padding: $pre-padding;
|
|
||||||
background: $pre-bg;
|
|
||||||
color: $pre-color;
|
|
||||||
border-radius: var(--#{$prefix}border-radius);
|
|
||||||
line-height: $line-height-base;
|
|
||||||
|
|
||||||
@include scrollbar;
|
|
||||||
|
|
||||||
code {
|
|
||||||
background: transparent;
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
code {
|
|
||||||
background: var(--#{$prefix}code-bg);
|
|
||||||
padding: 2px 4px;
|
|
||||||
border-radius: var(--#{$prefix}border-radius);
|
|
||||||
}
|
|
||||||
|
|
||||||
abbr {
|
|
||||||
text-decoration: underline dotted;
|
|
||||||
cursor: help;
|
|
||||||
text-decoration-skip-ink: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
kbd,
|
|
||||||
.kbd {
|
|
||||||
border: $kbd-border;
|
|
||||||
display: inline-block;
|
|
||||||
box-sizing: border-box;
|
|
||||||
max-width: 100%;
|
|
||||||
font-size: $kbd-font-size;
|
|
||||||
font-weight: $kbd-font-weight;
|
|
||||||
line-height: 1;
|
|
||||||
vertical-align: baseline;
|
|
||||||
border-radius: $kbd-border-radius;
|
|
||||||
}
|
|
||||||
|
|
||||||
img {
|
|
||||||
max-width: 100%;
|
|
||||||
height: auto;
|
|
||||||
}
|
|
||||||
|
|
||||||
.list-unstyled {
|
|
||||||
margin-left: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
Selection
|
|
||||||
*/
|
|
||||||
::selection,
|
|
||||||
.text-selected {
|
|
||||||
background-color: color-transparent(var(--#{$prefix}primary), 0.1);
|
|
||||||
}
|
|
||||||
|
|
||||||
.text-selected {
|
|
||||||
display: inline-block;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
Links
|
|
||||||
*/
|
|
||||||
[class^="link-"],
|
|
||||||
[class*=" link-"] {
|
|
||||||
&.disabled {
|
|
||||||
color: $nav-link-disabled-color !important;
|
|
||||||
pointer-events: none;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
a:hover:has(.icon) {
|
|
||||||
text-decoration: none;
|
|
||||||
}
|
|
||||||
|
|
||||||
.link-hoverable {
|
|
||||||
border-radius: var(--#{$prefix}border-radius);
|
|
||||||
transition: background-color 0.15s ease-in-out;
|
|
||||||
|
|
||||||
&:hover {
|
|
||||||
text-decoration: none;
|
|
||||||
color: var(--#{$prefix}primary);
|
|
||||||
background: color-transparent(var(--#{$prefix}secondary), 0.04);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
Subheader
|
|
||||||
*/
|
|
||||||
.subheader {
|
|
||||||
@include subheader;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
Mentions
|
|
||||||
*/
|
|
||||||
.mention {
|
|
||||||
display: inline-block;
|
|
||||||
box-shadow: var(--#{$prefix}shadow-border);
|
|
||||||
border-radius: var(--#{$prefix}border-radius-pill);
|
|
||||||
line-height: calc(16em / 12);
|
|
||||||
font-size: calc(12em / 14);
|
|
||||||
color: var(--#{$prefix}body-color);
|
|
||||||
background: var(--#{$prefix}bg-surface-tertiary);
|
|
||||||
padding: calc(2em / 12) calc(8em / 12);
|
|
||||||
font-weight: var(--#{$prefix}font-weight-medium);
|
|
||||||
|
|
||||||
@at-root a#{&} {
|
|
||||||
cursor: pointer;
|
|
||||||
|
|
||||||
&:hover,
|
|
||||||
&.hover {
|
|
||||||
background: var(--#{$prefix}bg-surface-secondary);
|
|
||||||
text-decoration: underline;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.mention-avatar,
|
|
||||||
.mention-app,
|
|
||||||
.mention-color {
|
|
||||||
width: calc(14em / 12);
|
|
||||||
height: calc(14em / 12);
|
|
||||||
border-radius: var(--#{$prefix}border-radius-pill);
|
|
||||||
margin: calc(-2em / 12) calc(4em / 12) 0 calc(-4em / 12);
|
|
||||||
display: inline-flex;
|
|
||||||
background: no-repeat center center/cover;
|
|
||||||
box-shadow: var(--#{$prefix}shadow-border);
|
|
||||||
vertical-align: middle;
|
|
||||||
text-align: center;
|
|
||||||
}
|
|
||||||
|
|
||||||
.mention-app {
|
|
||||||
box-shadow: none;
|
|
||||||
background: none;
|
|
||||||
border-radius: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
.mention-count {
|
|
||||||
color: var(--#{$prefix}secondary);
|
|
||||||
margin-left: calc(8em / 12);
|
|
||||||
}
|
|
||||||
|
|
||||||
$text-variants: (
|
|
||||||
incorrect: var(--#{$prefix}red),
|
|
||||||
correct: var(--#{$prefix}green),
|
|
||||||
);
|
|
||||||
|
|
||||||
@each $variant, $color in $text-variants {
|
|
||||||
.text-#{$variant} {
|
|
||||||
background: color-transparent($color, 0.04);
|
|
||||||
background: color-transparent($color, 4%);
|
|
||||||
text-decoration: underline;
|
|
||||||
text-decoration-thickness: 1px;
|
|
||||||
text-decoration-color: $color;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.steps {
|
|
||||||
--#{$prefix}steps-padding: 2rem;
|
|
||||||
--#{$prefix}steps-item-size: 1.5rem;
|
|
||||||
margin-left: 1rem;
|
|
||||||
padding-left: var(--#{$prefix}steps-padding);
|
|
||||||
counter-reset: step;
|
|
||||||
border-left: 1px solid var(--#{$prefix}border-color);
|
|
||||||
margin-bottom: 2rem;
|
|
||||||
|
|
||||||
h3 {
|
|
||||||
counter-increment: step;
|
|
||||||
|
|
||||||
&:not(:first-child) {
|
|
||||||
margin-top: 2.5rem !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
&:before {
|
|
||||||
content: counter(step);
|
|
||||||
display: inline-block;
|
|
||||||
position: absolute;
|
|
||||||
margin-top: 1px;
|
|
||||||
margin-left: calc(-1 * var(--#{$prefix}steps-padding) - var(--#{$prefix}steps-item-size) / 2);
|
|
||||||
width: var(--#{$prefix}steps-item-size);
|
|
||||||
height: var(--#{$prefix}steps-item-size);
|
|
||||||
text-align: center;
|
|
||||||
color: var(--#{$prefix}body-color);
|
|
||||||
border: 1px solid var(--#{$prefix}border-color);
|
|
||||||
background: var(--#{$prefix}bg-surface);
|
|
||||||
border-radius: var(--#{$prefix}border-radius);
|
|
||||||
line-height: calc(var(--#{$prefix}steps-item-size) - 2px);
|
|
||||||
font-size: var(--#{$prefix}font-size-h4);
|
|
||||||
font-weight: var(--#{$prefix}font-weight-bold);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
>:last-child {
|
|
||||||
margin-bottom: 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
.callout {
|
|
||||||
margin-bottom: 1.5rem;
|
|
||||||
border: 1px solid var(--#{$prefix}primary-200);
|
|
||||||
border-radius: var(--#{$prefix}border-radius);
|
|
||||||
padding: .5rem 1rem;
|
|
||||||
background: var(--#{$prefix}primary-lt);
|
|
||||||
|
|
||||||
&>:last-child {
|
|
||||||
margin-bottom: 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,100 +0,0 @@
|
|||||||
// All colors
|
|
||||||
@each $color, $value in map-merge($theme-colors, ( white: $white)) {
|
|
||||||
.bg-#{"" + $color} {
|
|
||||||
background-color: color-mix(in srgb, var(--#{$prefix}#{$color}) calc(var(--#{$prefix}bg-opacity, 1) * 100%), transparent) !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.bg-#{"" + $color}-lt {
|
|
||||||
color: color-mix(in srgb, var(--#{$prefix}#{$color}) calc(var(--#{$prefix}text-opacity, 1) * 100%), transparent) !important;
|
|
||||||
background-color: color-mix(in srgb, var(--#{$prefix}#{$color}-lt) calc(var(--#{$prefix}bg-opacity, 1) * 100%), transparent) !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.border-#{"" + $color} {
|
|
||||||
border-color: color-mix(in srgb, var(--#{$prefix}#{$color}) calc(var(--#{$prefix}border-opacity, 1) * 100%), transparent) !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.bg-gradient-from-#{"" + $color} {
|
|
||||||
--#{$prefix}gradient-from: var(--#{$prefix}#{$color});
|
|
||||||
}
|
|
||||||
|
|
||||||
.bg-gradient-to-#{"" + $color} {
|
|
||||||
--#{$prefix}gradient-to: var(--#{$prefix}#{$color});
|
|
||||||
}
|
|
||||||
|
|
||||||
.bg-gradient-via-#{"" + $color} {
|
|
||||||
--#{$prefix}gradient-via: var(--#{$prefix}#{$color});
|
|
||||||
--#{$prefix}gradient-stops: var(--#{$prefix}gradient-from, transparent), var(--#{$prefix}gradient-via, transparent), var(--#{$prefix}gradient-to, transparent);
|
|
||||||
}
|
|
||||||
|
|
||||||
.text-bg-#{"" + $color} {
|
|
||||||
color: color-contrast($value) if($enable-important-utilities, !important, null);
|
|
||||||
background-color: RGBA(var(--#{$prefix}#{$color}-rgb), var(--#{$prefix}bg-opacity, 1)) if($enable-important-utilities, !important, null);
|
|
||||||
}
|
|
||||||
|
|
||||||
.link-#{"" + $color} {
|
|
||||||
color: color-mix(in srgb, var(--#{$prefix}#{$color}) calc(var(--#{$prefix}link-opacity, 1) * 100%), transparent) !important;
|
|
||||||
text-decoration-color: color-mix(in srgb, var(--#{$prefix}#{$color}) calc(var(--#{$prefix}link-underline-opacity, 1) * 100%), transparent) !important;
|
|
||||||
|
|
||||||
@if $link-shade-percentage != 0 {
|
|
||||||
&:hover,
|
|
||||||
&:focus {
|
|
||||||
$hover-color: if(color-contrast($value) == $color-contrast-light, shade-color($value, $link-shade-percentage), tint-color($value, $link-shade-percentage));
|
|
||||||
color: RGBA(#{to-rgb($hover-color)}, var(--#{$prefix}link-opacity, 1)) if($enable-important-utilities, !important, null);
|
|
||||||
text-decoration-color: RGBA(to-rgb($hover-color), var(--#{$prefix}link-underline-opacity, 1)) if($enable-important-utilities, !important, null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@each $color, $value in $theme-colors {
|
|
||||||
.text-#{"" + $color} {
|
|
||||||
--#{$prefix}text-opacity: 1;
|
|
||||||
color: color-mix(in srgb, var(--#{$prefix}#{$color}) calc(var(--#{$prefix}text-opacity) * 100%), transparent) !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text-#{"" + $color}-fg {
|
|
||||||
color: var(--#{$prefix}#{$color}-fg) !important;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@each $color, $value in $gray-colors {
|
|
||||||
.bg-#{"" + $color} {
|
|
||||||
--#{$prefix}bg-opacity: 1;
|
|
||||||
background-color: color-mix(in srgb, var(--#{$prefix}#{$color}) calc(var(--#{$prefix}bg-opacity) * 100%), transparent) !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text-#{"" + $color}-fg {
|
|
||||||
color: var(--#{$prefix}#{$color}-fg) !important;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@each $color, $value in $social-colors {
|
|
||||||
.bg-#{"" + $color} {
|
|
||||||
--#{$prefix}bg-opacity: 1;
|
|
||||||
background-color: color-mix(in srgb, var(--#{$prefix}#{$color}) calc(var(--#{$prefix}bg-opacity) * 100%), transparent) !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.text-#{"" + $color}-fg {
|
|
||||||
color: var(--#{$prefix}#{$color}-fg) !important;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.bg-inverted {
|
|
||||||
--#{$prefix}bg-opacity: 1;
|
|
||||||
background-color: color-mix(in srgb, var(--#{$prefix}bg-surface-inverted) calc(var(--#{$prefix}bg-opacity) * 100%), transparent) !important;
|
|
||||||
}
|
|
||||||
.bg-surface {
|
|
||||||
background-color: var(--#{$prefix}bg-surface) !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.bg-surface-secondary {
|
|
||||||
background-color: var(--#{$prefix}bg-surface-secondary) !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.bg-surface-tertiary {
|
|
||||||
background-color: var(--#{$prefix}bg-surface-tertiary) !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.bg-surface-backdrop {
|
|
||||||
background-color: color-transparent($modal-backdrop-bg, $modal-backdrop-opacity) !important;
|
|
||||||
}
|
|
||||||
55
core/scss/vendor/_fullcalendar.scss
vendored
55
core/scss/vendor/_fullcalendar.scss
vendored
@@ -1,55 +0,0 @@
|
|||||||
:root {
|
|
||||||
--fc-border-color: var(--#{$prefix}border-color);
|
|
||||||
--fc-daygrid-event-dot-width: 5px;
|
|
||||||
|
|
||||||
--fc-event-bg-color: var(--#{$prefix}primary-lt);
|
|
||||||
--fc-event-border-color: var(--#{$prefix}primary-200);
|
|
||||||
--fc-event-text-color: var(--#{$prefix}body-color);
|
|
||||||
}
|
|
||||||
|
|
||||||
.fc-toolbar-title {
|
|
||||||
font-size: var(--#{$prefix}font-size-h3) !important;
|
|
||||||
font-weight: var(--#{$prefix}font-weight-medium);
|
|
||||||
}
|
|
||||||
|
|
||||||
.fc-daygrid-dot-event {
|
|
||||||
background-color: var(--fc-event-bg-color);
|
|
||||||
border: 1px solid var(--fc-event-border-color);
|
|
||||||
color: var(--fc-event-text-color);
|
|
||||||
padding-top: 1px;
|
|
||||||
padding-bottom: 1px;
|
|
||||||
|
|
||||||
.fc-event-title {
|
|
||||||
font-weight: inherit;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
.fc-col-header-cell {
|
|
||||||
background-color: var(--#{$prefix}bg-surface-secondary);
|
|
||||||
color: var(--#{$prefix}secondary);
|
|
||||||
text-transform: uppercase;
|
|
||||||
font-weight: var(--#{$prefix}font-weight-medium);
|
|
||||||
font-size: var(--#{$prefix}font-size-h5);
|
|
||||||
padding-top: .5rem !important;
|
|
||||||
padding-bottom: .5rem !important;
|
|
||||||
line-height: 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
.fc-event-time {
|
|
||||||
font-weight: var(--#{$prefix}font-weight-bold) !important;
|
|
||||||
}
|
|
||||||
|
|
||||||
.fc-col-header-cell-cushion {
|
|
||||||
color: inherit;
|
|
||||||
}
|
|
||||||
|
|
||||||
.fc-daygrid-day-number {
|
|
||||||
color: var(--#{$prefix}secondary);
|
|
||||||
}
|
|
||||||
|
|
||||||
.fc-button {
|
|
||||||
color: var(--#{$prefix}body-color) !important;
|
|
||||||
background-color: transparent !important;
|
|
||||||
border-color: var(--#{$prefix}border-color) !important;
|
|
||||||
font-weight: var(--#{$prefix}font-weight-medium) !important;
|
|
||||||
}
|
|
||||||
3
core/scss/vendor/_turbo.scss
vendored
3
core/scss/vendor/_turbo.scss
vendored
@@ -1,3 +0,0 @@
|
|||||||
.turbo-progress-bar {
|
|
||||||
background: var(--#{$prefix}primary);
|
|
||||||
}
|
|
||||||
@@ -1,40 +0,0 @@
|
|||||||
import path from 'node:path'
|
|
||||||
import { fileURLToPath } from 'node:url'
|
|
||||||
import { babel } from '@rollup/plugin-babel'
|
|
||||||
import { nodeResolve } from '@rollup/plugin-node-resolve'
|
|
||||||
import replace from '@rollup/plugin-replace'
|
|
||||||
import dotenv from "rollup-plugin-dotenv"
|
|
||||||
|
|
||||||
const __dirname = path.dirname(fileURLToPath(import.meta.url))
|
|
||||||
|
|
||||||
const external = []
|
|
||||||
const plugins = [
|
|
||||||
dotenv({
|
|
||||||
cwd: path.resolve(__dirname, '../..'),
|
|
||||||
}),
|
|
||||||
babel({
|
|
||||||
exclude: 'node_modules/**',
|
|
||||||
babelHelpers: 'bundled'
|
|
||||||
}),
|
|
||||||
replace({
|
|
||||||
'process.env.NODE_ENV': '"production"',
|
|
||||||
preventAssignment: true
|
|
||||||
}),
|
|
||||||
nodeResolve()
|
|
||||||
]
|
|
||||||
|
|
||||||
const rollupConfig = {
|
|
||||||
input: [
|
|
||||||
path.resolve(__dirname, `../js/docs.js`)
|
|
||||||
],
|
|
||||||
output: {
|
|
||||||
name: 'docs',
|
|
||||||
dir: path.resolve(__dirname, `../dist/js`),
|
|
||||||
format: 'esm',
|
|
||||||
generatedCode: 'es2015'
|
|
||||||
},
|
|
||||||
external,
|
|
||||||
plugins
|
|
||||||
}
|
|
||||||
|
|
||||||
export default rollupConfig
|
|
||||||
1
docs/.gitignore
vendored
1
docs/.gitignore
vendored
@@ -1 +0,0 @@
|
|||||||
.vercel
|
|
||||||
@@ -1,34 +0,0 @@
|
|||||||
# @tabler/docs
|
|
||||||
|
|
||||||
## 1.0.1
|
|
||||||
|
|
||||||
### Patch Changes
|
|
||||||
|
|
||||||
- Updated dependencies [c59bc9d]
|
|
||||||
- Updated dependencies [f9e4da2]
|
|
||||||
- Updated dependencies [aea3b0a]
|
|
||||||
- Updated dependencies [92a3afe]
|
|
||||||
- Updated dependencies [3fc7b84]
|
|
||||||
- Updated dependencies [199f39a]
|
|
||||||
- Updated dependencies [2f8a372]
|
|
||||||
- Updated dependencies [9fceadd]
|
|
||||||
- Updated dependencies [44250db]
|
|
||||||
- Updated dependencies [be1f3d1]
|
|
||||||
- Updated dependencies [c20d076]
|
|
||||||
- Updated dependencies [042e50f]
|
|
||||||
- Updated dependencies [473fa38]
|
|
||||||
- Updated dependencies [8646192]
|
|
||||||
- Updated dependencies [922bb03]
|
|
||||||
- Updated dependencies [44250db]
|
|
||||||
- Updated dependencies [9bbcb99]
|
|
||||||
- Updated dependencies [b17b488]
|
|
||||||
- Updated dependencies [ddcd3a7]
|
|
||||||
- Updated dependencies [e3d68d6]
|
|
||||||
- Updated dependencies [215eaa4]
|
|
||||||
- Updated dependencies [4846828]
|
|
||||||
- Updated dependencies [6b6617a]
|
|
||||||
- Updated dependencies [94bea00]
|
|
||||||
- Updated dependencies [e14e492]
|
|
||||||
- Updated dependencies [6d6d1bd]
|
|
||||||
- Updated dependencies [6c566cf]
|
|
||||||
- @tabler/core@1.2.0
|
|
||||||
@@ -1,6 +0,0 @@
|
|||||||
export default {
|
|
||||||
layout: 'docs/default',
|
|
||||||
permalink: function ({page}) {
|
|
||||||
return `${page.filePathStem.replace(/^\/content\//, '/').replace(/\/index$/, '') }/index.html`;
|
|
||||||
},
|
|
||||||
};
|
|
||||||
@@ -1,8 +0,0 @@
|
|||||||
---
|
|
||||||
title: Tabler Emails
|
|
||||||
seoTitle: Tabler Emails - premium email templates
|
|
||||||
order: 4
|
|
||||||
description: Customizable email templates for over 90 clients and devices.
|
|
||||||
summary: Tabler Emails is a set of 80 eye-catching, customizable HTML templates. They are compatible with over 90 email clients and devices.
|
|
||||||
seoDescription: Tabler Emails is a collection of 80 premium, customizable HTML templates. They are compatible with over 90 email clients and devices.
|
|
||||||
---
|
|
||||||
@@ -1,29 +0,0 @@
|
|||||||
---
|
|
||||||
title: Compiled templates
|
|
||||||
order: 2
|
|
||||||
seoTitle: Tabler Emails - How to use the compiled HTML email templates
|
|
||||||
description: Learn how to use the compiled HTML email templates from the Tabler Emails package.
|
|
||||||
summary: The compiled HTML files from the Tabler Emails package are ready to use in your email marketing campaigns. This guide explains how to use them effectively.
|
|
||||||
seoDescription: The compiled HTML files from the Tabler Emails package are ready to use in your email marketing campaigns. This guide explains how to use them effectively.
|
|
||||||
---
|
|
||||||
|
|
||||||
## Compiled version of the template
|
|
||||||
|
|
||||||
If you only want to change content (text or images) of the email template, you can just use the compiled HTML files - `compiled.html`. They are ready to use, and you need only a basic knowledge of HTML to modify them.
|
|
||||||
|
|
||||||
## How to modify the compiled HTML files
|
|
||||||
|
|
||||||
1. Open the `compiled.html` file in your favorite code editor.
|
|
||||||
2. Find the content you want to change inside the `<body>` element.
|
|
||||||
3. Modify the content as needed:
|
|
||||||
* Change the text, which is mostly placed inside the `<p>` or `<h1>` tags.
|
|
||||||
* Change the images by replacing the `src` attribute of the `<img>` tag.
|
|
||||||
* Change the links by replacing the `href` attribute of the `<a>` tag.
|
|
||||||
* Remove the HTML elements you don't need, but only if you're sure that they are not necessary for the email template to work correctly.
|
|
||||||
4. If you changed the images, make sure to replace them in the `assets/` folder.
|
|
||||||
5. Remove all the images you don't use from `assets/` to reduce the size of the email template.
|
|
||||||
|
|
||||||
## How to use the compiled HTML files
|
|
||||||
|
|
||||||
After changing the templates as needed, you can use them in your email campaigns.
|
|
||||||
The `compiled.html` file with the `assets/` folder should be sent to your email marketing tool, like Mailchimp, SendGrid, or any other.
|
|
||||||
@@ -1,65 +0,0 @@
|
|||||||
---
|
|
||||||
title: Contents
|
|
||||||
order: 1
|
|
||||||
seoTitle: Tabler Emails - Content of the package
|
|
||||||
description: Content of the Tabler Emails package.
|
|
||||||
summary: The Tabler Emails package contains files which can be used by everyone, even without great knowledge of HTML.
|
|
||||||
seoDescription: todo
|
|
||||||
---
|
|
||||||
|
|
||||||
## Folder structure
|
|
||||||
|
|
||||||
Once you unzip the downloaded file, you will see the following structure:
|
|
||||||
|
|
||||||
```
|
|
||||||
tabler-emails/
|
|
||||||
├── emails/
|
|
||||||
| ├── absence/
|
|
||||||
| | ├── assets/
|
|
||||||
| | ├── compiled.html
|
|
||||||
| | ├── compiled-dark.html
|
|
||||||
| | ├── source.html
|
|
||||||
| | ├── source-dark.html
|
|
||||||
| | ├── screenshot.jpg
|
|
||||||
| | ├── screenshot-dark.jpg
|
|
||||||
| | ├── screenshot-mobile.jpg
|
|
||||||
| | └── screenshot-mobile-dark.jpg
|
|
||||||
| ├── access-token/
|
|
||||||
| ├── account-deleted/
|
|
||||||
| ├── .../
|
|
||||||
| ├── welcome/
|
|
||||||
| └── whishlist/
|
|
||||||
├── images/
|
|
||||||
| ├── chart-donuts/
|
|
||||||
| ├── icons/
|
|
||||||
| ├── illustrations/
|
|
||||||
| └── overlays/
|
|
||||||
├── license.txt
|
|
||||||
└── readme.html
|
|
||||||
```
|
|
||||||
|
|
||||||
## Understanding the file structure in Tabler Emails
|
|
||||||
|
|
||||||
The **Tabler Emails** package is organized into a clear and efficient folder structure to streamline the use of its assets. Below is a breakdown of its key directories:
|
|
||||||
|
|
||||||
### 1. Email Templates: `emails/`
|
|
||||||
This folder contains {{ emailsCount }} email subfolders, each with a specific template. Each email folder contains the following files:
|
|
||||||
* Compiled HTML files for light and dark themes. Read more about their usage in the [Compiled HTML](/emails/introduction/compiled-html) section.
|
|
||||||
* Source HTML files for light and dark themes. Find more information in the [Source HTML](/emails/introduction/source-html) section.
|
|
||||||
* Screenshot images for desktop and mobile views.
|
|
||||||
* Assets folder with images used in the email template and the CSS file with styles.
|
|
||||||
|
|
||||||
### 2. Images: `images/`
|
|
||||||
It contains 4 subfolders with images used across the different email templates:
|
|
||||||
* `chart-donuts/`: Images of donut charts with different fills.
|
|
||||||
* `icons/`: [Tabler Icons](/icons) used in the email templates, in PNG version.
|
|
||||||
* `illustrations/`: PNG versions of [Tabler Illustrations](/illustrations) for light and dark themes.
|
|
||||||
* `overlays/`: Overlay images used in the email templates.
|
|
||||||
|
|
||||||
### 3. License: `license.txt`
|
|
||||||
This file contains the license information for the Tabler Emails package.
|
|
||||||
|
|
||||||
### 4. Readme: `readme.html`
|
|
||||||
This file contains the main information about the Tabler Emails package, including a brief description and instructions on how to use it.
|
|
||||||
|
|
||||||
Do you like our templates? **Find out more and purchase on [our website]({{ site.homepage }}/emails)**.
|
|
||||||
@@ -1,9 +0,0 @@
|
|||||||
---
|
|
||||||
title: Introduction
|
|
||||||
seoTitle: Introduction to Tabler Emails
|
|
||||||
description: Base information about Tabler Emails package.
|
|
||||||
summary: Tabler Emails is a set of 80 eye-catching, customizable HTML templates. They are compatible with over 90 email clients and devices.
|
|
||||||
seoDescription: Tabler Emails is a collection of 80 premium, customizable HTML templates. They are compatible with over 90 email clients and devices.
|
|
||||||
---
|
|
||||||
|
|
||||||
|
|
||||||
@@ -1,26 +0,0 @@
|
|||||||
---
|
|
||||||
title: Source templates
|
|
||||||
order: 3
|
|
||||||
seoTitle: Tabler Emails - How to use the source HTML email templates
|
|
||||||
description: Learn how to use the source HTML email templates from the Tabler Emails package.
|
|
||||||
summary: The source HTML files from the Tabler Emails package need a bit more work than the compiled ones. Learn how to use them.
|
|
||||||
seoDescription: The source HTML files from the Tabler Emails package need a bit more work than the compiled ones. Learn how to use them.
|
|
||||||
---
|
|
||||||
|
|
||||||
## Source version of the template
|
|
||||||
|
|
||||||
If you want to make more advanced changes to the email template, you can use the source HTML files - `source.html` combined with the `theme.css` file. They are ready to use, but you need a basic knowledge of HTML and CSS to modify them.
|
|
||||||
|
|
||||||
## How to modify the source HTML files
|
|
||||||
|
|
||||||
1. Open the `source.html` file in your favorite code editor.
|
|
||||||
2. Open the `theme.css` file from the `assets/`* directory in the same editor.
|
|
||||||
3. Change all the content and styles as needed.
|
|
||||||
4. Use a selected tool to inline the CSS styles into the HTML file. There are a lot of options, such as:
|
|
||||||
* Online tools like [Juice](https://automattic.github.io/juice/) or [Mailchimp CSS Inliner Tool](https://templates.mailchimp.com/resources/inline-css/).
|
|
||||||
* NPM tools like [juice](https://www.npmjs.com/package/juice) or [inline-css](https://www.npmjs.com/package/inline-css).
|
|
||||||
5. Save the output HTML file.
|
|
||||||
|
|
||||||
## How to use the source HTML files
|
|
||||||
|
|
||||||
To use the modified HTML template send the output file with the `assets/` folder to your email marketing tool.
|
|
||||||
File diff suppressed because it is too large
Load Diff
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user