blob: 2a627f85c7aeabccf7c846b8af47ec7739960fea [file] [log] [blame]
// Copyright 2016 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
import 'chrome://resources/cr_elements/hidden_style_css.m.js';
import 'chrome://resources/cr_elements/icons.m.js';
import 'chrome://resources/cr_elements/shared_vars_css.m.js';
import 'chrome://resources/polymer/v3_0/iron-icon/iron-icon.js';
import {DragWrapper} from 'chrome://resources/js/cr/ui/drag_wrapper.m.js';
import {html, Polymer} from 'chrome://resources/polymer/v3_0/polymer/polymer_bundled.min.js';
import {DragAndDropHandler} from './drag_and_drop_handler.js';
Polymer({
is: 'extensions-drop-overlay',
_template: html`{__html_template__}`,
properties: {
/** @private {boolean} */
dragEnabled: {
type: Boolean,
observer: 'dragEnabledChanged_',
}
},
/** @override */
created: function() {
this.hidden = true;
const dragTarget = document.documentElement;
this.dragWrapperHandler_ = new DragAndDropHandler(true, dragTarget);
// TODO(devlin): All these dragTarget listeners leak (they aren't removed
// when the element is). This only matters in tests at the moment, but would
// be good to fix.
dragTarget.addEventListener('extension-drag-started', () => {
this.hidden = false;
});
dragTarget.addEventListener('extension-drag-ended', () => {
this.hidden = true;
});
dragTarget.addEventListener('drag-and-drop-load-error', (e) => {
this.fire('load-error', e.detail);
});
this.dragWrapper_ = new DragWrapper(dragTarget, this.dragWrapperHandler_);
},
/**
* @param {boolean} dragEnabled
* @private
*/
dragEnabledChanged_: function(dragEnabled) {
this.dragWrapperHandler_.dragEnabled = dragEnabled;
},
});