2022-03-03 10:56:00 -07:00
|
|
|
---
|
|
|
|
title: Representing Files in a BrowserWindow
|
|
|
|
description: Set a represented file in the macOS title bar.
|
|
|
|
slug: represented-file
|
|
|
|
hide_title: true
|
|
|
|
---
|
|
|
|
|
|
|
|
# Representing Files in a BrowserWindow
|
2018-02-19 17:25:02 -07:00
|
|
|
|
2020-10-26 01:45:45 -06:00
|
|
|
## Overview
|
2018-02-19 17:25:02 -07:00
|
|
|
|
2020-10-26 01:45:45 -06:00
|
|
|
On macOS, you can set a represented file for any window in your application.
|
|
|
|
The represented file's icon will be shown in the title bar, and when users
|
|
|
|
`Command-Click` or `Control-Click`, a popup with a path to the file will be
|
|
|
|
shown.
|
2018-02-19 17:25:02 -07:00
|
|
|
|
|
|
|
![Represented File][represented-image]
|
|
|
|
|
2020-10-26 01:45:45 -06:00
|
|
|
> NOTE: The screenshot above is an example where this feature is used to indicate the currently opened file in the Atom text editor.
|
|
|
|
|
|
|
|
You can also set the edited state for a window so that the file icon can
|
|
|
|
indicate whether the document in this window has been modified.
|
|
|
|
|
2018-02-19 17:25:02 -07:00
|
|
|
To set the represented file of window, you can use the
|
|
|
|
[BrowserWindow.setRepresentedFilename][setrepresentedfilename] and
|
2020-10-26 01:45:45 -06:00
|
|
|
[BrowserWindow.setDocumentEdited][setdocumentedited] APIs.
|
|
|
|
|
|
|
|
## Example
|
|
|
|
|
2023-11-21 00:50:08 -07:00
|
|
|
```fiddle docs/fiddles/features/represented-file
|
|
|
|
const { app, BrowserWindow } = require('electron/main')
|
2023-08-30 09:55:23 -06:00
|
|
|
const os = require('node:os')
|
2021-06-14 19:29:51 -06:00
|
|
|
|
2023-11-21 00:50:08 -07:00
|
|
|
function createWindow () {
|
2021-06-14 19:29:51 -06:00
|
|
|
const win = new BrowserWindow({
|
|
|
|
width: 800,
|
|
|
|
height: 600
|
|
|
|
})
|
2023-11-21 00:50:08 -07:00
|
|
|
|
|
|
|
win.setRepresentedFilename(os.homedir())
|
|
|
|
win.setDocumentEdited(true)
|
|
|
|
|
|
|
|
win.loadFile('index.html')
|
2021-06-14 19:29:51 -06:00
|
|
|
}
|
2020-10-26 01:45:45 -06:00
|
|
|
|
|
|
|
app.whenReady().then(() => {
|
2023-11-21 00:50:08 -07:00
|
|
|
createWindow()
|
2018-02-19 17:25:02 -07:00
|
|
|
|
2023-11-21 00:50:08 -07:00
|
|
|
app.on('activate', () => {
|
|
|
|
if (BrowserWindow.getAllWindows().length === 0) {
|
|
|
|
createWindow()
|
|
|
|
}
|
|
|
|
})
|
2020-10-26 01:45:45 -06:00
|
|
|
})
|
2021-06-14 19:29:51 -06:00
|
|
|
|
|
|
|
app.on('window-all-closed', () => {
|
|
|
|
if (process.platform !== 'darwin') {
|
|
|
|
app.quit()
|
|
|
|
}
|
|
|
|
})
|
2018-02-19 17:25:02 -07:00
|
|
|
```
|
|
|
|
|
2020-10-26 01:45:45 -06:00
|
|
|
After launching the Electron application, click on the title with `Command` or
|
2021-06-14 19:29:51 -06:00
|
|
|
`Control` key pressed. You should see a popup with the represented file at the top.
|
|
|
|
In this guide, this is the current user's home directory:
|
2020-10-26 01:45:45 -06:00
|
|
|
|
|
|
|
![Represented file](../images/represented-file.png)
|
|
|
|
|
2018-02-19 17:25:02 -07:00
|
|
|
[represented-image]: https://cloud.githubusercontent.com/assets/639601/5082061/670a949a-6f14-11e4-987a-9aaa04b23c1d.png
|
|
|
|
[setrepresentedfilename]: ../api/browser-window.md#winsetrepresentedfilenamefilename-macos
|
|
|
|
[setdocumentedited]: ../api/browser-window.md#winsetdocumenteditededited-macos
|