mirror of
https://github.com/balena-io/etcher.git
synced 2025-11-09 18:38:32 +00:00
We add a file-picker written with Rendition/React. It is activated with the `ETCHER_EXPERIMENTAL_FILE_PICKER` environment variable. Further customisation can be done with the `ETCHER_FILE_BROWSER_CONSTRAIN_FOLDER` variable that takes a path and allows one to constrain the file-picker to a folder. Related: https://github.com/resin-io/etcher/issues/2238 Related: https://github.com/resin-io/etcher/issues/2285 Change-Type: patch Changelog-Entry: Add electron-native file-picker component.
53 lines
1.2 KiB
JavaScript
53 lines
1.2 KiB
JavaScript
/*
|
|
* Copyright 2018 resin.io
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
'use strict'
|
|
|
|
module.exports = function (ModalService, $q) {
|
|
let modal = null
|
|
|
|
/**
|
|
* @summary Open the file selector widget
|
|
* @function
|
|
* @public
|
|
*
|
|
* @example
|
|
* DriveSelectorService.open()
|
|
*/
|
|
this.open = () => {
|
|
modal = ModalService.open({
|
|
name: 'file-selector',
|
|
template: require('../templates/file-selector-modal.tpl.html'),
|
|
controller: 'FileSelectorController as selector',
|
|
size: 'file-selector-modal'
|
|
})
|
|
}
|
|
|
|
/**
|
|
* @summary Close the file selector widget
|
|
* @function
|
|
* @public
|
|
*
|
|
* @example
|
|
* DriveSelectorService.close()
|
|
*/
|
|
this.close = () => {
|
|
if (modal) {
|
|
modal.close()
|
|
}
|
|
}
|
|
}
|