2023-05-31 16:06:00 +02:00
|
|
|
import stripIndent from 'strip-indent';
|
|
|
|
|
2023-03-09 23:32:49 +01:00
|
|
|
import { liquidEngine } from '../engines';
|
2023-03-08 21:59:19 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Renders a status dashboard for each implementation's support for a feature.
|
|
|
|
*
|
|
|
|
* Each implementation's value can be:
|
|
|
|
*
|
|
|
|
* - `true`, indicating that that implementation fully supports the feature;
|
|
|
|
* - `false`, indicating that it does not yet support the feature at all;
|
|
|
|
* - `'partial'`, indicating that it has limited or incorrect support for the
|
|
|
|
* feature;
|
|
|
|
* - or a string, indicating the version it started supporting the feature.
|
|
|
|
*
|
|
|
|
* When possible, prefer using the start version rather than `true`.
|
|
|
|
*
|
|
|
|
* If `feature` is passed, it should be a terse (one- to three-word) description
|
|
|
|
* of the particular feature whose compatibility is described. This should be
|
|
|
|
* used whenever the status isn't referring to the entire feature being
|
|
|
|
* described by the surrounding prose.
|
|
|
|
*
|
|
|
|
* This takes an optional Markdown block (`details`) that should provide more
|
|
|
|
* information about the implementation differences or the old behavior.
|
|
|
|
*/
|
|
|
|
export const compatibility = async (
|
|
|
|
details: string,
|
|
|
|
dart: string | boolean | null = null,
|
|
|
|
libsass: string | boolean | null = null,
|
2023-05-19 23:27:02 +02:00
|
|
|
node: string | boolean | null = null,
|
2023-03-08 21:59:19 +01:00
|
|
|
ruby: string | boolean | null = null,
|
|
|
|
feature: string | null = null,
|
2023-05-30 22:27:01 +02:00
|
|
|
useMarkdown = true,
|
2023-03-08 21:59:19 +01:00
|
|
|
) =>
|
|
|
|
liquidEngine.renderFile('compatibility', {
|
2023-05-31 16:06:00 +02:00
|
|
|
details: stripIndent(details),
|
2023-03-08 21:59:19 +01:00
|
|
|
dart,
|
|
|
|
libsass,
|
2023-05-19 23:27:02 +02:00
|
|
|
node,
|
2023-03-08 21:59:19 +01:00
|
|
|
ruby,
|
|
|
|
feature,
|
2023-05-30 22:27:01 +02:00
|
|
|
useMarkdown,
|
2023-03-08 21:59:19 +01:00
|
|
|
});
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Renders a single row for `compatibility`.
|
|
|
|
*/
|
|
|
|
export const implStatus = (status: string | boolean | null) => {
|
|
|
|
switch (status) {
|
|
|
|
case true:
|
|
|
|
return '✓';
|
|
|
|
case false:
|
|
|
|
return '✗';
|
|
|
|
case 'partial':
|
|
|
|
case null:
|
|
|
|
return status;
|
|
|
|
default:
|
|
|
|
return `since ${status}`;
|
|
|
|
}
|
|
|
|
};
|