mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-28 02:49:30 +08:00
488dff0f90
Converted all references of global atom to NylasEnv Temporary rename atom.io find -E . -regex ".*\.(coffee|cjsx|js|md|cmd|es6)" -print0 | xargs -0 sed -i "" 's/atom.io/temporaryAtomIoReplacement/g' atom.config to NylasEnv.config find -E . -regex ".*\.(coffee|cjsx|js|md|cmd|es6)" -print0 | xargs -0 sed -i "" 's/atom.config/NylasEnv.config/g' atom.packages -> NylasEnv.packages atom.commands -> NylasEnv.commands atom.getLoadSettings find -E . -regex ".*\.(coffee|cjsx|js|md|cmd|es6)" -print0 | xargs -0 sed -i "" 's/atom.commands/NylasEnv.commands/g' find -E . -regex ".*\.(coffee|cjsx|js|md|cmd|es6)" -print0 | xargs -0 sed -i "" 's/atom.getLoadSettings/NylasEnv.getLoadSettings/g' More common atom methods find -E . -regex ".*\.(coffee|cjsx|js|md|cmd|es6)" -print0 | xargs -0 sed -i "" 's/atom.styles/NylasEnv.styles/g' find -E . -regex ".*\.(coffee|cjsx|js|md|cmd|es6)" -print0 | xargs -0 sed -i "" 's/atom.emitError/NylasEnv.emitError/g' find -E . -regex ".*\.(coffee|cjsx|js|md|cmd|es6)" -print0 | xargs -0 sed -i "" 's/atom.inSpecMode/NylasEnv.inSpecMode/g' find -E . -regex ".*\.(coffee|cjsx|js|md|cmd|es6)" -print0 | xargs -0 sed -i "" 's/atom.inDevMode/NylasEnv.inDevMode/g' find -E . -regex ".*\.(coffee|cjsx|js|md|cmd|es6)" -print0 | xargs -0 sed -i "" 's/atom.getWindowType/NylasEnv.getWindowType/g' find -E . -regex ".*\.(coffee|cjsx|js|md|cmd|es6)" -print0 | xargs -0 sed -i "" 's/atom.displayWindow/NylasEnv.displayWindow/g' find -E . -regex ".*\.(coffee|cjsx|js|md|cmd|es6)" -print0 | xargs -0 sed -i "" 's/atom.quit/NylasEnv.quit/g' find -E . -regex ".*\.(coffee|cjsx|js|md|cmd|es6)" -print0 | xargs -0 sed -i "" 's/atom.close/NylasEnv.close/g' More atom method changes find -E . -regex ".*\.(coffee|cjsx|js|md|cmd|es6)" -print0 | xargs -0 sed -i "" 's/atom.keymaps/NylasEnv.keymaps/g' find -E . -regex ".*\.(coffee|cjsx|js|md|cmd|es6)" -print0 | xargs -0 sed -i "" 's/atom.hide/NylasEnv.hide/g' find -E . -regex ".*\.(coffee|cjsx|js|md|cmd|es6)" -print0 | xargs -0 sed -i "" 's/atom.getCurrentWindow/NylasEnv.getCurrentWindow/g' find -E . -regex ".*\.(coffee|cjsx|js|md|cmd|es6)" -print0 | xargs -0 sed -i "" 's/atom.menu/NylasEnv.menu/g' find -E . -regex ".*\.(coffee|cjsx|js|md|cmd|es6)" -print0 | xargs -0 sed -i "" 's/atom.getConfigDirPath/NylasEnv.getConfigDirPath/g' find -E . -regex ".*\.(coffee|cjsx|js|md|cmd|es6)" -print0 | xargs -0 sed -i "" 's/atom.isMainWindow/NylasEnv.isMainWindow/g' find -E . -regex ".*\.(coffee|cjsx|js|md|cmd|es6)" -print0 | xargs -0 sed -i "" 's/atom.finishUnload/NylasEnv.finishUnload/g' find -E . -regex ".*\.(coffee|cjsx|js|md|cmd|es6)" -print0 | xargs -0 sed -i "" 's/atom.isWorkWindow/NylasEnv.isWorkWindow/g' find -E . -regex ".*\.(coffee|cjsx|js|md|cmd|es6)" -print0 | xargs -0 sed -i "" 's/atom.showSaveDialog/NylasEnv.showSaveDialog/g' find -E . -regex ".*\.(coffee|cjsx|js|md|cmd|es6)" -print0 | xargs -0 sed -i "" 's/atom.append/NylasEnv.append/g' find -E . -regex ".*\.(coffee|cjsx|js|md|cmd|es6)" -print0 | xargs -0 sed -i "" 's/atom.confirm/NylasEnv.confirm/g' find -E . -regex ".*\.(coffee|cjsx|js|md|cmd|es6)" -print0 | xargs -0 sed -i "" 's/atom.clipboard/NylasEnv.clipboard/g' find -E . -regex ".*\.(coffee|cjsx|js|md|cmd|es6)" -print0 | xargs -0 sed -i "" 's/atom.getVersion/NylasEnv.getVersion/g' More atom renaming Rename atom methods More atom methods Fix grunt config variable Change atom.cmd to N1.cmd Rename atom.coffee and atom.js to nylas-env.coffee nylas-env.js Fix atom global reference in specs manually Fix atom requires Change engine from atom to nylas got rid of global/nylas-env rename to nylas-win-bootup Fix onWindowPropsChanged to onWindowPropsReceived fix nylas-workspace atom-text-editor to nylas-theme-wrap atom-text-editor -> nylas-theme-wrap Replacing atom keyword AtomWindow -> NylasWindow Replace Atom -> N1 Rename atom items nylas.asar -> atom.asar Remove more atom references Remove 6to5 references Remove license exception for atom
114 lines
5.3 KiB
CoffeeScript
114 lines
5.3 KiB
CoffeeScript
StylesElement = require '../src/styles-element'
|
|
StyleManager = require '../src/style-manager'
|
|
|
|
describe "StylesElement", ->
|
|
[element, addedStyleElements, removedStyleElements, updatedStyleElements] = []
|
|
|
|
beforeEach ->
|
|
element = new StylesElement
|
|
document.querySelector('#jasmine-content').appendChild(element)
|
|
addedStyleElements = []
|
|
removedStyleElements = []
|
|
updatedStyleElements = []
|
|
element.onDidAddStyleElement (element) -> addedStyleElements.push(element)
|
|
element.onDidRemoveStyleElement (element) -> removedStyleElements.push(element)
|
|
element.onDidUpdateStyleElement (element) -> updatedStyleElements.push(element)
|
|
|
|
it "renders a style tag for all currently active stylesheets in the style manager", ->
|
|
initialChildCount = element.children.length
|
|
|
|
disposable1 = NylasEnv.styles.addStyleSheet("a {color: red;}")
|
|
expect(element.children.length).toBe initialChildCount + 1
|
|
expect(element.children[initialChildCount].textContent).toBe "a {color: red;}"
|
|
expect(addedStyleElements).toEqual [element.children[initialChildCount]]
|
|
|
|
disposable2 = NylasEnv.styles.addStyleSheet("a {color: blue;}")
|
|
expect(element.children.length).toBe initialChildCount + 2
|
|
expect(element.children[initialChildCount + 1].textContent).toBe "a {color: blue;}"
|
|
expect(addedStyleElements).toEqual [element.children[initialChildCount], element.children[initialChildCount + 1]]
|
|
|
|
disposable1.dispose()
|
|
expect(element.children.length).toBe initialChildCount + 1
|
|
expect(element.children[initialChildCount].textContent).toBe "a {color: blue;}"
|
|
expect(removedStyleElements).toEqual [addedStyleElements[0]]
|
|
|
|
it "orders style elements by priority", ->
|
|
initialChildCount = element.children.length
|
|
|
|
NylasEnv.styles.addStyleSheet("a {color: red}", priority: 1)
|
|
NylasEnv.styles.addStyleSheet("a {color: blue}", priority: 0)
|
|
NylasEnv.styles.addStyleSheet("a {color: green}", priority: 2)
|
|
NylasEnv.styles.addStyleSheet("a {color: yellow}", priority: 1)
|
|
|
|
expect(element.children[initialChildCount].textContent).toBe "a {color: blue}"
|
|
expect(element.children[initialChildCount + 1].textContent).toBe "a {color: red}"
|
|
expect(element.children[initialChildCount + 2].textContent).toBe "a {color: yellow}"
|
|
expect(element.children[initialChildCount + 3].textContent).toBe "a {color: green}"
|
|
|
|
it "updates existing style nodes when style elements are updated", ->
|
|
initialChildCount = element.children.length
|
|
|
|
NylasEnv.styles.addStyleSheet("a {color: red;}", sourcePath: '/foo/bar')
|
|
NylasEnv.styles.addStyleSheet("a {color: blue;}", sourcePath: '/foo/bar')
|
|
|
|
expect(element.children.length).toBe initialChildCount + 1
|
|
expect(element.children[initialChildCount].textContent).toBe "a {color: blue;}"
|
|
expect(updatedStyleElements).toEqual [element.children[initialChildCount]]
|
|
|
|
it "only includes style elements matching the 'context' attribute", ->
|
|
initialChildCount = element.children.length
|
|
|
|
NylasEnv.styles.addStyleSheet("a {color: red;}", context: 'test-context')
|
|
NylasEnv.styles.addStyleSheet("a {color: green;}")
|
|
|
|
expect(element.children.length).toBe initialChildCount + 2
|
|
expect(element.children[initialChildCount].textContent).toBe "a {color: red;}"
|
|
expect(element.children[initialChildCount + 1].textContent).toBe "a {color: green;}"
|
|
|
|
element.setAttribute('context', 'test-context')
|
|
|
|
expect(element.children.length).toBe 1
|
|
expect(element.children[0].textContent).toBe "a {color: red;}"
|
|
|
|
NylasEnv.styles.addStyleSheet("a {color: blue;}", context: 'test-context')
|
|
NylasEnv.styles.addStyleSheet("a {color: yellow;}")
|
|
|
|
expect(element.children.length).toBe 2
|
|
expect(element.children[0].textContent).toBe "a {color: red;}"
|
|
expect(element.children[1].textContent).toBe "a {color: blue;}"
|
|
|
|
describe "nylas-theme-wrap shadow DOM selector upgrades", ->
|
|
beforeEach ->
|
|
element.setAttribute('context', 'nylas-theme-wrap')
|
|
spyOn(console, 'warn')
|
|
|
|
it "upgrades selectors containing .editor-colors", ->
|
|
NylasEnv.styles.addStyleSheet(".editor-colors {background: black;}", context: 'nylas-theme-wrap')
|
|
expect(element.firstChild.sheet.cssRules[0].selectorText).toBe ':host'
|
|
|
|
it "upgrades selectors containing .editor", ->
|
|
NylasEnv.styles.addStyleSheet """
|
|
.editor {background: black;}
|
|
.editor.mini {background: black;}
|
|
.editor:focus {background: black;}
|
|
""", context: 'nylas-theme-wrap'
|
|
|
|
expect(element.firstChild.sheet.cssRules[0].selectorText).toBe ':host'
|
|
expect(element.firstChild.sheet.cssRules[1].selectorText).toBe ':host(.mini)'
|
|
expect(element.firstChild.sheet.cssRules[2].selectorText).toBe ':host(:focus)'
|
|
|
|
it "defers selector upgrade until the element is attached", ->
|
|
element = new StylesElement
|
|
element.setAttribute('context', 'nylas-theme-wrap')
|
|
element.initialize()
|
|
|
|
NylasEnv.styles.addStyleSheet ".editor {background: black;}", context: 'nylas-theme-wrap'
|
|
expect(element.firstChild.sheet).toBeNull()
|
|
|
|
document.querySelector('#jasmine-content').appendChild(element)
|
|
expect(element.firstChild.sheet.cssRules[0].selectorText).toBe ':host'
|
|
|
|
it "does not throw exceptions on rules with no selectors", ->
|
|
NylasEnv.styles.addStyleSheet """
|
|
@media screen {font-size: 10px;}
|
|
""", context: 'nylas-theme-wrap'
|