blob: d9030c66740b495eada60733e2cfbdf45c18d3be [file] [log] [blame]
/*
* Copyright (C) 2007, 2008 Apple Inc. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. Neither the name of Apple Computer, Inc. ("Apple") nor the names of
* its contributors may be used to endorse or promote products derived
* from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY APPLE AND ITS CONTRIBUTORS "AS IS" AND ANY
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL APPLE OR ITS CONTRIBUTORS BE LIABLE FOR ANY
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
/**
* @unrestricted
*/
SourceFrame.FontView = class extends UI.SimpleView {
/**
* @param {string} mimeType
* @param {!Common.ContentProvider} contentProvider
*/
constructor(mimeType, contentProvider) {
super(Common.UIString('Font'));
this.registerRequiredCSS('source_frame/fontView.css');
this.element.classList.add('font-view');
this._url = contentProvider.contentURL();
this._mimeType = mimeType;
this._contentProvider = contentProvider;
this._mimeTypeLabel = new UI.ToolbarText(mimeType);
}
/**
* @override
* @return {!Array<!UI.ToolbarItem>}
*/
syncToolbarItems() {
return [this._mimeTypeLabel];
}
/**
* @param {string} uniqueFontName
* @param {?string} content
*/
_onFontContentLoaded(uniqueFontName, content) {
const url = content ? Common.ContentProvider.contentAsDataURL(content, this._mimeType, true) : this._url;
this.fontStyleElement.textContent =
String.sprintf('@font-face { font-family: "%s"; src: url(%s); }', uniqueFontName, url);
}
_createContentIfNeeded() {
if (this.fontPreviewElement)
return;
const uniqueFontName = 'WebInspectorFontPreview' + (++SourceFrame.FontView._fontId);
this.fontStyleElement = createElement('style');
this._contentProvider.requestContent().then(this._onFontContentLoaded.bind(this, uniqueFontName));
this.element.appendChild(this.fontStyleElement);
const fontPreview = createElement('div');
for (let i = 0; i < SourceFrame.FontView._fontPreviewLines.length; ++i) {
if (i > 0)
fontPreview.createChild('br');
fontPreview.createTextChild(SourceFrame.FontView._fontPreviewLines[i]);
}
this.fontPreviewElement = fontPreview.cloneNode(true);
this.fontPreviewElement.style.overflow = 'hidden';
this.fontPreviewElement.style.setProperty('font-family', uniqueFontName);
this.fontPreviewElement.style.setProperty('visibility', 'hidden');
this._dummyElement = fontPreview;
this._dummyElement.style.visibility = 'hidden';
this._dummyElement.style.zIndex = '-1';
this._dummyElement.style.display = 'inline';
this._dummyElement.style.position = 'absolute';
this._dummyElement.style.setProperty('font-family', uniqueFontName);
this._dummyElement.style.setProperty('font-size', SourceFrame.FontView._measureFontSize + 'px');
this.element.appendChild(this.fontPreviewElement);
}
/**
* @override
*/
wasShown() {
this._createContentIfNeeded();
this.updateFontPreviewSize();
}
/**
* @override
*/
onResize() {
if (this._inResize)
return;
this._inResize = true;
try {
this.updateFontPreviewSize();
} finally {
delete this._inResize;
}
}
_measureElement() {
this.element.appendChild(this._dummyElement);
const result = {width: this._dummyElement.offsetWidth, height: this._dummyElement.offsetHeight};
this.element.removeChild(this._dummyElement);
return result;
}
updateFontPreviewSize() {
if (!this.fontPreviewElement || !this.isShowing())
return;
this.fontPreviewElement.style.removeProperty('visibility');
const dimension = this._measureElement();
const height = dimension.height;
const width = dimension.width;
// Subtract some padding. This should match the paddings in the CSS plus room for the scrollbar.
const containerWidth = this.element.offsetWidth - 50;
const containerHeight = this.element.offsetHeight - 30;
if (!height || !width || !containerWidth || !containerHeight) {
this.fontPreviewElement.style.removeProperty('font-size');
return;
}
const widthRatio = containerWidth / width;
const heightRatio = containerHeight / height;
const finalFontSize = Math.floor(SourceFrame.FontView._measureFontSize * Math.min(widthRatio, heightRatio)) - 2;
this.fontPreviewElement.style.setProperty('font-size', finalFontSize + 'px', null);
}
};
SourceFrame.FontView._fontPreviewLines =
['ABCDEFGHIJKLM', 'NOPQRSTUVWXYZ', 'abcdefghijklm', 'nopqrstuvwxyz', '1234567890'];
SourceFrame.FontView._fontId = 0;
SourceFrame.FontView._measureFontSize = 50;