2023-03-14 13:18:55 +00:00
|
|
|
/**
|
|
|
|
* Copyright (c) HashiCorp, Inc.
|
2023-08-11 13:12:13 +00:00
|
|
|
* SPDX-License-Identifier: BUSL-1.1
|
2023-03-14 13:18:55 +00:00
|
|
|
*/
|
|
|
|
|
2021-11-24 18:14:07 +00:00
|
|
|
import Modifier from 'ember-modifier';
|
|
|
|
import { assert } from '@ember/debug';
|
|
|
|
|
|
|
|
export default class StyleModifier extends Modifier {
|
|
|
|
setStyles(newStyles = []) {
|
|
|
|
const rulesToRemove = this._oldStyles || new Set();
|
2022-09-15 08:43:17 +00:00
|
|
|
if (!Array.isArray(newStyles)) {
|
|
|
|
newStyles = Object.entries(newStyles);
|
2021-11-24 18:14:07 +00:00
|
|
|
}
|
|
|
|
newStyles.forEach(([property, value]) => {
|
|
|
|
assert(
|
|
|
|
`Your given value for property '${property}' is ${value} (${typeof value}). Accepted types are string and undefined. Please change accordingly.`,
|
|
|
|
typeof value === 'undefined' || typeof value === 'string'
|
|
|
|
);
|
|
|
|
|
|
|
|
// priority must be specified as separate argument
|
|
|
|
// value must not contain "!important"
|
|
|
|
let priority = '';
|
|
|
|
if (value.length > 0 && value.includes('!important')) {
|
|
|
|
priority = 'important';
|
|
|
|
value = value.replace('!important', '');
|
|
|
|
}
|
|
|
|
|
|
|
|
// update CSSOM
|
|
|
|
this.element.style.setProperty(property, value, priority);
|
|
|
|
|
|
|
|
// should not remove rules that have been updated in this cycle
|
|
|
|
rulesToRemove.delete(property);
|
|
|
|
});
|
|
|
|
|
|
|
|
// remove rules that were present in last cycle but aren't present in this one
|
|
|
|
rulesToRemove.forEach((rule) => this.element.style.removeProperty(rule));
|
|
|
|
|
|
|
|
// cache styles that in this rendering cycle for the next one
|
|
|
|
this._oldStyles = new Set(newStyles.map((e) => e[0]));
|
|
|
|
}
|
|
|
|
|
2023-10-17 14:16:57 +00:00
|
|
|
modify(element, positional, named) {
|
|
|
|
this.element = element;
|
|
|
|
|
|
|
|
if (typeof named.delay !== 'undefined') {
|
2022-09-15 08:43:17 +00:00
|
|
|
setTimeout((_) => {
|
2023-10-17 14:16:57 +00:00
|
|
|
if (typeof this !== positional[0]) {
|
|
|
|
this.setStyles(positional[0]);
|
2022-09-15 08:43:17 +00:00
|
|
|
}
|
2023-10-17 14:16:57 +00:00
|
|
|
}, named?.delay);
|
2021-11-24 18:14:07 +00:00
|
|
|
} else {
|
2023-10-17 14:16:57 +00:00
|
|
|
this.setStyles(positional[0]);
|
2021-11-24 18:14:07 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|