2022-05-06 23:27:29 -07:00
|
|
|
const yaml = require('yaml');
|
2022-06-28 18:55:21 -07:00
|
|
|
const StyleDictionary = require('style-dictionary');
|
|
|
|
|
|
|
|
StyleDictionary.registerFileHeader({
|
|
|
|
name: 'myCustomHeader',
|
|
|
|
fileHeader: defaultMessage => [
|
|
|
|
...defaultMessage,
|
|
|
|
``,
|
|
|
|
`How to edit these values:`,
|
|
|
|
`Edit the corresponding token file under the style-definitions directory`,
|
|
|
|
`in the Owncast web project.`,
|
|
|
|
],
|
|
|
|
});
|
2022-05-06 23:27:29 -07:00
|
|
|
|
|
|
|
module.exports = {
|
|
|
|
parsers: [
|
|
|
|
{
|
|
|
|
// A custom parser will only run against filenames that match the pattern
|
|
|
|
// This pattern will match any file with the .yaml extension.
|
|
|
|
// This allows you to mix different types of files in your token source
|
|
|
|
pattern: /\.yaml$/,
|
|
|
|
// the parse function takes a single argument, which is an object with
|
|
|
|
// 2 attributes: contents which is a string of the file contents, and
|
|
|
|
// filePath which is the path of the file.
|
|
|
|
// The function is expected to return a plain object.
|
|
|
|
parse: ({ contents, filePath }) => yaml.parse(contents),
|
|
|
|
},
|
|
|
|
],
|
|
|
|
source: [`tokens/**/*.yaml`],
|
|
|
|
platforms: {
|
|
|
|
css: {
|
|
|
|
transformGroup: 'css',
|
|
|
|
buildPath: 'build/',
|
|
|
|
files: [
|
|
|
|
{
|
|
|
|
destination: 'variables.css',
|
|
|
|
format: 'css/variables',
|
2022-06-28 18:55:21 -07:00
|
|
|
options: {
|
|
|
|
fileHeader: 'myCustomHeader',
|
|
|
|
},
|
2022-05-06 23:27:29 -07:00
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
less: {
|
|
|
|
transformGroup: 'less',
|
|
|
|
buildPath: 'build/',
|
|
|
|
files: [
|
|
|
|
{
|
|
|
|
destination: 'variables.less',
|
|
|
|
format: 'less/variables',
|
2022-06-28 18:55:21 -07:00
|
|
|
options: {
|
|
|
|
fileHeader: 'myCustomHeader',
|
|
|
|
},
|
2022-05-06 23:27:29 -07:00
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
2023-07-09 12:42:52 -07:00
|
|
|
'ios-swift': {
|
|
|
|
transforms: [
|
|
|
|
'attribute/cti',
|
|
|
|
'name/ti/camel',
|
|
|
|
'color/ColorSwiftUI',
|
|
|
|
'content/swift/literal',
|
|
|
|
'asset/swift/literal',
|
|
|
|
'size/swift/remToCGFloat',
|
|
|
|
'font/swift/literal',
|
|
|
|
],
|
|
|
|
buildPath: 'build/',
|
|
|
|
files: [
|
|
|
|
{
|
|
|
|
format: 'ios-swift/class.swift',
|
|
|
|
className: 'PlatformColor',
|
|
|
|
destination: 'Colors.swift',
|
|
|
|
filter: {
|
|
|
|
attributes: {
|
|
|
|
category: 'color',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
2022-05-06 23:27:29 -07:00
|
|
|
},
|
|
|
|
};
|