diff options
| author | Alex Yatskov <alex@foosoft.net> | 2019-12-03 18:30:22 -0800 | 
|---|---|---|
| committer | Alex Yatskov <alex@foosoft.net> | 2019-12-03 18:30:22 -0800 | 
| commit | f9ea6206550ceee625ea93215a6e08d45a750086 (patch) | |
| tree | 803fe11a788a631076b3fb11a98e50bb8b454396 /ext/bg/js/settings/popup-preview.js | |
| parent | 08ad2779678cd447bd747c2b155ef9b5135fdf5d (diff) | |
| parent | 3975aabf4dc283d49ec46d0ed7ead982b9fa7441 (diff) | |
Merge branch 'master' into testing
Diffstat (limited to 'ext/bg/js/settings/popup-preview.js')
| -rw-r--r-- | ext/bg/js/settings/popup-preview.js | 62 | 
1 files changed, 62 insertions, 0 deletions
diff --git a/ext/bg/js/settings/popup-preview.js b/ext/bg/js/settings/popup-preview.js new file mode 100644 index 00000000..d8579eb1 --- /dev/null +++ b/ext/bg/js/settings/popup-preview.js @@ -0,0 +1,62 @@ +/* + * Copyright (C) 2019  Alex Yatskov <alex@foosoft.net> + * Author: Alex Yatskov <alex@foosoft.net> + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program.  If not, see <http://www.gnu.org/licenses/>. + */ + + +function appearanceInitialize() { +    let previewVisible = false; +    $('#settings-popup-preview-button').on('click', () => { +        if (previewVisible) { return; } +        showAppearancePreview(); +        previewVisible = true; +    }); +} + +function showAppearancePreview() { +    const container = $('#settings-popup-preview-container'); +    const buttonContainer = $('#settings-popup-preview-button-container'); +    const settings = $('#settings-popup-preview-settings'); +    const text = $('#settings-popup-preview-text'); +    const customCss = $('#custom-popup-css'); +    const customOuterCss = $('#custom-popup-outer-css'); + +    const frame = document.createElement('iframe'); +    frame.src = '/bg/settings-popup-preview.html'; +    frame.id = 'settings-popup-preview-frame'; + +    window.wanakana.bind(text[0]); + +    text.on('input', () => { +        const action = 'setText'; +        const params = {text: text.val()}; +        frame.contentWindow.postMessage({action, params}, '*'); +    }); +    customCss.on('input', () => { +        const action = 'setCustomCss'; +        const params = {css: customCss.val()}; +        frame.contentWindow.postMessage({action, params}, '*'); +    }); +    customOuterCss.on('input', () => { +        const action = 'setCustomOuterCss'; +        const params = {css: customOuterCss.val()}; +        frame.contentWindow.postMessage({action, params}, '*'); +    }); + +    container.append(frame); +    buttonContainer.remove(); +    settings.css('display', ''); +}  |