mirror of
https://github.com/electron/electron.git
synced 2026-04-10 03:01:51 -04:00
* feat: add nativeTheme.themeSource to allow apps to override Chromiums theme choice (#19960) * feat: add nativeTheme.shouldUseDarkColorsOverride to allow apps to override Chromiums theme choice * spec: add tests for shouldUseDarkColorsOverride * chore: add missing forward declarations * refactor: rename overrideShouldUseDarkColors to themeSource * chore: only run appLevelAppearance specs on Mojave and up * chore: update patch with more info and no define * Update spec-main/api-native-theme-spec.ts Co-Authored-By: Jeremy Apthorp <jeremya@chromium.org> * Update api-native-theme-spec.ts * Update api-native-theme-spec.ts * Update api-native-theme-spec.ts * fix: don't expose nativeTheme in the renderer process (#20139) Exposing these in the renderer didn't make sense as they weren't backed by the same instance / value store. This API should be browser only especially now that we have nativeTheme.themeSource. Exposing in //common was a mistake from the beginning. * fix: emit updated on NativeTheme on the UI thread to avoid DCHECK (#20137) * fix: emit updated on NativeTheme on the UI thread to avoid DCHECK * Update atom_api_native_theme.cc * spec: wait a few ticks for async events to emit so that test events do not leak into each other * chore: add SetGTKDarkThemeEnabled(enabled) internal helper to allow dynamic theme selection on linux (#19964) This is just a after-creation setter for the `darkTheme` constructor option. This is delibrately a method and not a property as there is no getter. * spec: remove leftover .only
50 lines
2.6 KiB
JavaScript
50 lines
2.6 KiB
JavaScript
'use strict'
|
|
|
|
// TODO: Updating this file also required updating the module-keys file
|
|
|
|
const features = process.electronBinding('features')
|
|
|
|
// Browser side modules, please sort alphabetically.
|
|
module.exports = [
|
|
{ name: 'app', loader: () => require('./app') },
|
|
{ name: 'autoUpdater', loader: () => require('./auto-updater') },
|
|
{ name: 'BrowserView', loader: () => require('./browser-view') },
|
|
{ name: 'BrowserWindow', loader: () => require('./browser-window') },
|
|
{ name: 'contentTracing', loader: () => require('./content-tracing') },
|
|
{ name: 'crashReporter', loader: () => require('./crash-reporter') },
|
|
{ name: 'dialog', loader: () => require('./dialog') },
|
|
{ name: 'globalShortcut', loader: () => require('./global-shortcut') },
|
|
{ name: 'ipcMain', loader: () => require('./ipc-main') },
|
|
{ name: 'inAppPurchase', loader: () => require('./in-app-purchase') },
|
|
{ name: 'Menu', loader: () => require('./menu') },
|
|
{ name: 'MenuItem', loader: () => require('./menu-item') },
|
|
{ name: 'nativeTheme', loader: () => require('./native-theme') },
|
|
{ name: 'net', loader: () => require('./net') },
|
|
{ name: 'netLog', loader: () => require('./net-log') },
|
|
{ name: 'Notification', loader: () => require('./notification') },
|
|
{ name: 'powerMonitor', loader: () => require('./power-monitor') },
|
|
{ name: 'powerSaveBlocker', loader: () => require('./power-save-blocker') },
|
|
{ name: 'protocol', loader: () => require('./protocol') },
|
|
{ name: 'screen', loader: () => require('./screen') },
|
|
{ name: 'session', loader: () => require('./session') },
|
|
{ name: 'systemPreferences', loader: () => require('./system-preferences') },
|
|
{ name: 'TopLevelWindow', loader: () => require('./top-level-window') },
|
|
{ name: 'TouchBar', loader: () => require('./touch-bar') },
|
|
{ name: 'Tray', loader: () => require('./tray') },
|
|
{ name: 'View', loader: () => require('./view') },
|
|
{ name: 'webContents', loader: () => require('./web-contents') },
|
|
{ name: 'WebContentsView', loader: () => require('./web-contents-view') }
|
|
]
|
|
|
|
if (features.isViewApiEnabled()) {
|
|
module.exports.push(
|
|
{ name: 'BoxLayout', loader: () => require('./views/box-layout') },
|
|
{ name: 'Button', loader: () => require('./views/button') },
|
|
{ name: 'LabelButton', loader: () => require('./views/label-button') },
|
|
{ name: 'LayoutManager', loader: () => require('./views/layout-manager') },
|
|
{ name: 'MdTextButton', loader: () => require('./views/md-text-button') },
|
|
{ name: 'ResizeArea', loader: () => require('./views/resize-area') },
|
|
{ name: 'TextField', loader: () => require('./views/text-field') }
|
|
)
|
|
}
|