diff --git a/.eslintrc b/.eslintrc index 39a0c7cef..d00afacfb 100644 --- a/.eslintrc +++ b/.eslintrc @@ -4,10 +4,8 @@ "node": true }, "parserOptions": { - "sourceType": "module", - "ecmaFeatures": { - "experimentalObjectRestSpread": true - } + "ecmaVersion": 2018, + "sourceType": "module" }, "rules": { "strict": 0, diff --git a/.github/FUNDING.yml b/.github/FUNDING.yml new file mode 100644 index 000000000..8fa789baa --- /dev/null +++ b/.github/FUNDING.yml @@ -0,0 +1,3 @@ +# Shows a funding button via Open Collective + +open_collective: grapesjs diff --git a/.github/ISSUE_TEMPLATE.md b/.github/ISSUE_TEMPLATE.md new file mode 100644 index 000000000..dcf0001cf --- /dev/null +++ b/.github/ISSUE_TEMPLATE.md @@ -0,0 +1,26 @@ +## WARNING +READ and FOLLOW next 5 steps, then REMOVE them before posting the issue + +1. Follow CONTRIBUTING Guidelines https://github.com/artf/grapesjs/blob/master/CONTRIBUTING.md +2. Use the GitHub Issues EXCLUSIVELY for BUGS, FEATURE REQUESTS or QUESTIONS. Prefix the title of the issue with its context, eg. `[Bug]: ....` +3. Do a quick SEARCH first, to see if someone else didn't open the same issue +4. DON'T ASK to create examples/code for you, read DOCS and APIs first, then you can post what you have tried (we'd like to see your code) and what you're unable to achieve +5. All relative statements/questions have to be filled/answered, otherwise, the issue might be CLOSED + +## You're submitting a BUG + 1. Are you using the latest release (older versions are NOT supported)? + 1. If you're not sure, type `grapesjs.version` in console and press ENTER + 1. Are you facing the bug with your local copy of GrapesJS or with the current demo? + 1. If a local copy + 1. Indicate all informations about your OS, browser and GrapesJS version. + 1. Are you able to reproduce the bug from the demo? + 1. What is the expected behavior? + 1. What happens instead? + 1. If you're able to reproduce the bug indicate all the necessary steps + 1. Attach screenshots (using KAP/LICEcap), screencasts or live demo + 1. JSFiddle Starter template https://jsfiddle.net/szLp8h4n + 1. CodeSandbox Starter template https://codesandbox.io/s/1r0w2pk1vl + +## You're submitting a FEATURE REQUEST + 1. Be sure to work on the latest version, as the feature might be already there + 1. Keep in mind that the feature should be considered valid to use for everyone, not only for your case diff --git a/.github/lock.yml b/.github/lock.yml new file mode 100644 index 000000000..3c621e2ca --- /dev/null +++ b/.github/lock.yml @@ -0,0 +1,38 @@ +# Configuration for Lock Threads - https://github.com/dessant/lock-threads + +# Number of days of inactivity before a closed issue or pull request is locked +daysUntilLock: 365 + +# Skip issues and pull requests created before a given timestamp. Timestamp must +# follow ISO 8601 (`YYYY-MM-DD`). Set to `false` to disable +skipCreatedBefore: false + +# Issues and pull requests with these labels will be ignored. Set to `[]` to disable +exemptLabels: [] + +# Label to add before locking, such as `outdated`. Set to `false` to disable +lockLabel: outdated + +# Comment to post before locking. Set to `false` to disable +lockComment: > + This thread has been automatically locked since there has not been + any recent activity after it was closed. Please open a new issue for + related bugs. + +# Assign `resolved` as the reason for locking. Set to `false` to disable +setLockReason: true + +# Limit to only `issues` or `pulls` +# only: issues + +# Optionally, specify configuration settings just for `issues` or `pulls` +# issues: +# exemptLabels: +# - help-wanted +# lockLabel: outdated + +# pulls: +# daysUntilLock: 30 + +# Repository to extend settings from +# _extends: repo \ No newline at end of file diff --git a/.github/no-response.yml b/.github/no-response.yml new file mode 100644 index 000000000..3f22a7763 --- /dev/null +++ b/.github/no-response.yml @@ -0,0 +1,13 @@ +# Configuration for probot-no-response - https://github.com/probot/no-response + +# Number of days of inactivity before an Issue is closed for lack of response +daysUntilClose: 10 +# Label requiring a response +responseRequiredLabel: more-information-needed +# Comment to post when closing an Issue for lack of response. Set to `false` to disable +closeComment: > + This issue has been automatically closed because there has been no response + to our request for more information from the original author. With only the + information that is currently in the issue, we don't have enough information + to take action. Please reach out if you have or find the answers we need so + that we can investigate further. diff --git a/.gitignore b/.gitignore index f21e704de..a68fe8236 100644 --- a/.gitignore +++ b/.gitignore @@ -4,15 +4,18 @@ .project .idea npm-debug.log* +yarn-error.log +yarn.lock style/.sass-cache/ +stats.json img/ images/ private/ -docs/ vendor/ coverage/ node_modules/ bower_components/ grapesjs-*.tgz _index.html +docs/.vuepress/dist diff --git a/.travis.yml b/.travis.yml index 0d2819ba5..437ee5d93 100644 --- a/.travis.yml +++ b/.travis.yml @@ -1,3 +1,4 @@ language: node_js node_js: - - "7.6" + - "8" + - "10" diff --git a/CODE_OF_CONDUCT.md b/CODE_OF_CONDUCT.md new file mode 100644 index 000000000..7561f0b9b --- /dev/null +++ b/CODE_OF_CONDUCT.md @@ -0,0 +1,46 @@ +# Contributor Covenant Code of Conduct + +## Our Pledge + +In the interest of fostering an open and welcoming environment, we as contributors and maintainers pledge to making participation in our project and our community a harassment-free experience for everyone, regardless of age, body size, disability, ethnicity, gender identity and expression, level of experience, nationality, personal appearance, race, religion, or sexual identity and orientation. + +## Our Standards + +Examples of behavior that contributes to creating a positive environment include: + +* Using welcoming and inclusive language +* Being respectful of differing viewpoints and experiences +* Gracefully accepting constructive criticism +* Focusing on what is best for the community +* Showing empathy towards other community members + +Examples of unacceptable behavior by participants include: + +* The use of sexualized language or imagery and unwelcome sexual attention or advances +* Trolling, insulting/derogatory comments, and personal or political attacks +* Public or private harassment +* Publishing others' private information, such as a physical or electronic address, without explicit permission +* Other conduct which could reasonably be considered inappropriate in a professional setting + +## Our Responsibilities + +Project maintainers are responsible for clarifying the standards of acceptable behavior and are expected to take appropriate and fair corrective action in response to any instances of unacceptable behavior. + +Project maintainers have the right and responsibility to remove, edit, or reject comments, commits, code, wiki edits, issues, and other contributions that are not aligned to this Code of Conduct, or to ban temporarily or permanently any contributor for other behaviors that they deem inappropriate, threatening, offensive, or harmful. + +## Scope + +This Code of Conduct applies both within project spaces and in public spaces when an individual is representing the project or its community. Examples of representing a project or community include using an official project e-mail address, posting via an official social media account, or acting as an appointed representative at an online or offline event. Representation of a project may be further defined and clarified by project maintainers. + +## Enforcement + +Instances of abusive, harassing, or otherwise unacceptable behavior may be reported by contacting the project team at artur.catch@hotmail.it. The project team will review and investigate all complaints, and will respond in a way that it deems appropriate to the circumstances. The project team is obligated to maintain confidentiality with regard to the reporter of an incident. Further details of specific enforcement policies may be posted separately. + +Project maintainers who do not follow or enforce the Code of Conduct in good faith may face temporary or permanent repercussions as determined by other members of the project's leadership. + +## Attribution + +This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 1.4, available at [http://contributor-covenant.org/version/1/4][version] + +[homepage]: http://contributor-covenant.org +[version]: http://contributor-covenant.org/version/1/4/ diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md new file mode 100644 index 000000000..5d8a3a673 --- /dev/null +++ b/CONTRIBUTING.md @@ -0,0 +1,52 @@ +# Contribute + +## Introduction + +First of all, thank you for considering contributing to GrapesJS! + +We welcome any type of contribution, not only code. Like for example: +- **QA**: file bug reports, the more details you can give the better (e.g. screenshots with the console open) +- **Marketing**: writing blog posts, howto's, tutorials, etc. +- **Community**: presenting the project at meetups, organizing a dedicated meetup for the local community, etc. +- **Money**: We welcome financial contributions in full transparency on our [Open Collective]. + + +## Your First Contribution + +Working on your first Pull Request? You can learn how from this **free** series, [How to Contribute to an Open Source Project on GitHub](https://egghead.io/series/how-to-contribute-to-an-open-source-project-on-github). + + +## Submitting code + +Any code change should be submitted as a pull request. Before start working on something make always a search in opened issues and pull requests, this might help you to avoid waisting time. + +A pull request could be a bug fix, new feature and much more, but in all cases, **open a new issue** and talk about what you want to do. Often happens to work on something already fixed (ready to release) or in progress. + +The title should be brief but comprehensive, the description contains a link to the opened issue and the proposed solution. The pull request should contain tests whenever possible. Keep in mind that the bigger is the pull request, the longer it will take to review and merge. Try to break down large pull requests in smaller chunks that are easier to review and merge. + + +## Styleguide + +The code is auto formatted with [prettier](https://github.com/prettier/prettier) on any commit, therefore you can write in any style you prefer + + +## Expenses + +Anyone can file an expense (code, marketing, etc.) via our [Open Collective]. If the expense makes sense for the development of the community, it will be "merged" in the ledger of our open collective by the core contributors and the person who filed the expense will be reimbursed. + +Before submitting an expense contact core contributors via the current active chat room ([Discord](https://discord.gg/QAbgGXq)) and explain your intents + + +## Questions + +If you have any questions, create an [issue](https://github.com/artf/grapesjs/issues) (protip: do a quick search first to see if someone else didn't ask the same question before!). + + + +## Credits + +Thank you to all the people who have already contributed to GrapesJS! + + + +[Open Collective]: diff --git a/LICENSE b/LICENSE index d880dc50e..5d5a2f861 100644 --- a/LICENSE +++ b/LICENSE @@ -1,4 +1,4 @@ -Copyright (c) 2017, Artur Arseniev +Copyright (c) 2017-current, Artur Arseniev All rights reserved. Redistribution and use in source and binary forms, with or without modification, diff --git a/README.md b/README.md index 4e73396bb..010b75d5c 100644 --- a/README.md +++ b/README.md @@ -4,6 +4,8 @@ [![Chat](https://img.shields.io/badge/chat-discord-7289da.svg)](https://discord.gg/QAbgGXq) [![CDNJS](https://img.shields.io/cdnjs/v/grapesjs.svg)](https://cdnjs.com/libraries/grapesjs) [![npm](https://img.shields.io/npm/v/grapesjs.svg)](https://www.npmjs.com/package/grapesjs) +[![BrowserStack Status](https://www.browserstack.com/automate/badge.svg?badge_key=QksxaStYaGI3eE5VMDlPTEh0Z3hYOXEwRWNMc1ZYT0lNbEJxMWdOZWFDZz0tLWlqcFVWb05PMmlQMmU3emFIZkFNWVE9PQ==--e89345be5e303d515276e3accd6f1316dfa857ab)](https://www.browserstack.com/automate/public-build/QksxaStYaGI3eE5VMDlPTEh0Z3hYOXEwRWNMc1ZYT0lNbEJxMWdOZWFDZz0tLWlqcFVWb05PMmlQMmU3emFIZkFNWVE9PQ==--e89345be5e303d515276e3accd6f1316dfa857ab) +

GrapesJS

@@ -35,6 +37,8 @@ Newsletter Demo - http://grapesjs.com/demo-newsletter-editor.html * [Testing](#testing) * [Plugins](#plugins) * [Support](#support) +* [Changelog](https://github.com/artf/grapesjs/releases) +* [Contributing](https://github.com/artf/grapesjs/blob/master/CONTRIBUTING.md) * [License](#license) @@ -42,21 +46,13 @@ Newsletter Demo - http://grapesjs.com/demo-newsletter-editor.html ## Features +| Blocks | Style Manager | Layer Manager | +|--|--|--| +|GrapesJS - Block Manager|GrapesJS - Style Manager|GrapesJS - Layer Manager| -* Blocks -

GrapesJS - Block Manager

- -* Style Manager, for component styling
-

GrapesJS - Style Manager

- -* Layer Manager, that comes handy with nested elements
-

GrapesJS - Layer Manager

- -* Code Viewer
-

GrapesJS - Code Viewer

- -* Asset Manager, for uploading and managing images
-

GrapesJS - Asset Manager

+| Code Viewer | Asset Manager | +|--|--| +|GrapesJS - Code Viewer|GrapesJS - Asset Manager| * Local and remote storage @@ -69,12 +65,12 @@ Newsletter Demo - http://grapesjs.com/demo-newsletter-editor.html ## Download * CDNs - * UNPKG + * UNPKG (resolves to the latest version) * `https://unpkg.com/grapesjs` * `https://unpkg.com/grapesjs/dist/css/grapes.min.css` - * CDNJS - * `https://cdnjs.cloudflare.com/ajax/libs/grapesjs/0.12.17/grapes.min.js` - * `https://cdnjs.cloudflare.com/ajax/libs/grapesjs/0.12.17/css/grapes.min.css` + * CDNJS (replace `X.X.X` with the current version) + * `https://cdnjs.cloudflare.com/ajax/libs/grapesjs/X.X.X/grapes.min.js` + * `https://cdnjs.cloudflare.com/ajax/libs/grapesjs/X.X.X/css/grapes.min.css` * NPM * `npm i grapesjs` * GIT @@ -122,9 +118,6 @@ You could also grab the content directly from the element with `fromElement` pro For more practical example I suggest to look up the code inside this demo: http://grapesjs.com/demo.html - - - ## Development GrapesJS uses [Webpack](https://github.com/webpack/webpack) as a module bundler and [Babel](https://github.com/babel/babel) as a compiler. @@ -151,7 +144,7 @@ Once the development server is started you should be able to reach the demo page ## Documentation -Check the getting started guide here: [wiki] +Check the getting started guide here: [Documentation] @@ -181,14 +174,23 @@ $ npm test * [grapesjs-plugin-export](https://github.com/artf/grapesjs-plugin-export) - Export GrapesJS templates in a zip archive * [grapesjs-plugin-filestack](https://github.com/artf/grapesjs-plugin-filestack) - Add Filestack uploader in Asset Manager * [grapesjs-plugin-ckeditor](https://github.com/artf/grapesjs-plugin-ckeditor) - Replaces the built-in RTE with CKEditor -* [grapesjs-aviary](https://github.com/artf/grapesjs-aviary) - Add the Aviary Image Editor +* [grapesjs-aviary](https://github.com/artf/grapesjs-aviary) - Add the Aviary Image Editor (dismissed, use the plugin below instead) +* [grapesjs-tui-image-editor](https://github.com/artf/grapesjs-tui-image-editor) - GrapesJS TOAST UI Image Editor * [grapesjs-blocks-basic](https://github.com/artf/grapesjs-blocks-basic) - Basic set of blocks * [grapesjs-plugin-forms](https://github.com/artf/grapesjs-plugin-forms) - Set of form components and blocks * [grapesjs-navbar](https://github.com/artf/grapesjs-navbar) - Simple navbar component * [grapesjs-component-countdown](https://github.com/artf/grapesjs-component-countdown) - Simple countdown component -* [grapesjs-style-gradient](https://github.com/artf/grapesjs-style-gradient) - Add a gradient type input +* [grapesjs-style-gradient](https://github.com/artf/grapesjs-style-gradient) - Add `gradient` type input to the Style Manager +* [grapesjs-style-filter](https://github.com/artf/grapesjs-style-filter) - Add `filter` type input to the Style Manager * [grapesjs-blocks-flexbox](https://github.com/artf/grapesjs-blocks-flexbox) - Add the flexbox block * [grapesjs-lory-slider](https://github.com/artf/grapesjs-lory-slider) - Slider component by using [lory](https://github.com/meandmax/lory) +* [grapesjs-tabs](https://github.com/artf/grapesjs-tabs) - Simple tabs component +* [grapesjs-tooltip](https://github.com/artf/grapesjs-tooltip) - Simple, CSS only, tooltip component for GrapesJS +* [grapesjs-custom-code](https://github.com/artf/grapesjs-custom-code) - Embed custom code +* [grapesjs-touch](https://github.com/artf/grapesjs-touch) - Enable touch support +* [grapesjs-indexeddb](https://github.com/artf/grapesjs-indexeddb) - Storage wrapper for IndexedDB +* [grapesjs-firestore](https://github.com/artf/grapesjs-firestore) - Storage wrapper for [Cloud Firestore](https://firebase.google.com/docs/firestore) +* [grapesjs-parser-postcss](https://github.com/artf/grapesjs-parser-postcss) - Custom CSS parser for GrapesJS by using [PostCSS](https://github.com/postcss/postcss) ### Presets * [grapesjs-preset-webpage](https://github.com/artf/grapesjs-preset-webpage) - Webpage Builder @@ -207,6 +209,7 @@ Find out more about plugins here: [Creating plugins](https://github.com/artf/gra If you like the project support it with a donation of your choice or become a backer/sponsor via [Open Collective](https://opencollective.com/grapesjs) [![PayPalMe](http://grapesjs.com/img/ppme.png)](https://paypal.me/grapesjs) +[![Bitcoin](https://user-images.githubusercontent.com/11614725/52977952-87235f80-33cf-11e9-9607-7a9a354e1155.png)](https://commerce.coinbase.com/checkout/fc90b940-558d-408b-a166-28a823c98173) @@ -229,7 +232,14 @@ If you like the project support it with a donation of your choice or become a ba + + + + +
+[![BrowserStack](https://user-images.githubusercontent.com/11614725/39406324-4ef89c40-4bb5-11e8-809a-113d9432e5a5.png)](https://www.browserstack.com)
+Thanks to [BrowserStack](https://www.browserstack.com) for providing us browser testing services ## License @@ -237,6 +247,6 @@ If you like the project support it with a donation of your choice or become a ba BSD 3-clause -[wiki]: -[API-Reference]: +[Documentation]: +[API-Reference]: [CMS]: diff --git a/dist/css/grapes.min.css b/dist/css/grapes.min.css index 533a24671..d004a0f1d 100644 --- a/dist/css/grapes.min.css +++ b/dist/css/grapes.min.css @@ -1,4 +1,4 @@ .sp-container{position:absolute;top:0;left:0;display:inline-block;*display:inline;*zoom:1;z-index:9999994;overflow:hidden}.sp-container.sp-flat{position:relative}.sp-container,.sp-container *{-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box}.sp-top{position:relative;width:100%;display:inline-block}.sp-top-inner{position:absolute;top:0;left:0;bottom:0;right:0}.sp-color{position:absolute;top:0;left:0;bottom:0;right:20%}.sp-hue{position:absolute;top:0;right:0;bottom:0;left:84%;height:100%}.sp-clear-enabled .sp-hue{top:33px;height:77.5%}.sp-fill{padding-top:80%}.sp-sat,.sp-val{position:absolute;top:0;left:0;right:0;bottom:0}.sp-alpha-enabled .sp-top{margin-bottom:18px}.sp-alpha-enabled .sp-alpha{display:block}.sp-alpha-handle{position:absolute;top:-4px;bottom:-4px;width:6px;left:50%;cursor:pointer;border:1px solid black;background:white;opacity:.8}.sp-alpha{display:none;position:absolute;bottom:-14px;right:0;left:0;height:8px}.sp-alpha-inner{border:solid 1px #333}.sp-clear{display:none}.sp-clear.sp-clear-display{background-position:center}.sp-clear-enabled .sp-clear{display:block;position:absolute;top:0px;right:0;bottom:0;left:84%;height:28px}.sp-container,.sp-replacer,.sp-preview,.sp-dragger,.sp-slider,.sp-alpha,.sp-clear,.sp-alpha-handle,.sp-container.sp-dragging .sp-input,.sp-container button{-webkit-user-select:none;-moz-user-select:-moz-none;-o-user-select:none;user-select:none}.sp-container.sp-input-disabled .sp-input-container{display:none}.sp-container.sp-buttons-disabled .sp-button-container{display:none}.sp-container.sp-palette-buttons-disabled .sp-palette-button-container{display:none}.sp-palette-only .sp-picker-container{display:none}.sp-palette-disabled .sp-palette-container{display:none}.sp-initial-disabled .sp-initial{display:none}.sp-sat{background-image:-webkit-gradient(linear, 0 0, 100% 0, from(#fff), to(rgba(204,154,129,0)));background-image:-webkit-linear-gradient(left, #fff, rgba(204,154,129,0));background-image:-moz-linear-gradient(left, #fff, rgba(204,154,129,0));background-image:-o-linear-gradient(left, #fff, rgba(204,154,129,0));background-image:-ms-linear-gradient(left, #fff, rgba(204,154,129,0));background-image:linear-gradient(to right, #fff, rgba(204,154,129,0));-ms-filter:"progid:DXImageTransform.Microsoft.gradient(GradientType = 1, startColorstr=#FFFFFFFF, endColorstr=#00CC9A81)";filter:progid:DXImageTransform.Microsoft.gradient(GradientType = 1, startColorstr='#FFFFFFFF', endColorstr='#00CC9A81')}.sp-val{background-image:-webkit-gradient(linear, 0 100%, 0 0, from(#000), to(rgba(204,154,129,0)));background-image:-webkit-linear-gradient(bottom, #000, rgba(204,154,129,0));background-image:-moz-linear-gradient(bottom, #000, rgba(204,154,129,0));background-image:-o-linear-gradient(bottom, #000, rgba(204,154,129,0));background-image:-ms-linear-gradient(bottom, #000, rgba(204,154,129,0));background-image:linear-gradient(to top, #000, rgba(204,154,129,0));-ms-filter:"progid:DXImageTransform.Microsoft.gradient(startColorstr=#00CC9A81, endColorstr=#FF000000)";filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#00CC9A81', endColorstr='#FF000000')}.sp-hue{background:-moz-linear-gradient(top, red 0%, #ff0 17%, lime 33%, cyan 50%, blue 67%, #f0f 83%, red 100%);background:-ms-linear-gradient(top, red 0%, #ff0 17%, lime 33%, cyan 50%, blue 67%, #f0f 83%, red 100%);background:-o-linear-gradient(top, red 0%, #ff0 17%, lime 33%, cyan 50%, blue 67%, #f0f 83%, red 100%);background:-webkit-gradient(linear, left top, left bottom, from(red), color-stop(0.17, #ff0), color-stop(0.33, lime), color-stop(0.5, cyan), color-stop(0.67, blue), color-stop(0.83, #f0f), to(red));background:-webkit-linear-gradient(top, red 0%, #ff0 17%, lime 33%, cyan 50%, blue 67%, #f0f 83%, red 100%);background:linear-gradient(to bottom, red 0%, #ff0 17%, lime 33%, cyan 50%, blue 67%, #f0f 83%, red 100%)}.sp-1{height:17%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff0000', endColorstr='#ffff00')}.sp-2{height:16%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffff00', endColorstr='#00ff00')}.sp-3{height:17%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#00ff00', endColorstr='#00ffff')}.sp-4{height:17%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#00ffff', endColorstr='#0000ff')}.sp-5{height:16%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#0000ff', endColorstr='#ff00ff')}.sp-6{height:17%;filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ff00ff', endColorstr='#ff0000')}.sp-hidden{display:none !important}.sp-cf:before,.sp-cf:after{content:"";display:table}.sp-cf:after{clear:both}.sp-cf{*zoom:1}@media (max-device-width: 480px){.sp-color{right:40%}.sp-hue{left:63%}.sp-fill{padding-top:60%}}.sp-dragger{border-radius:5px;height:5px;width:5px;border:1px solid #fff;background:#000;cursor:pointer;position:absolute;top:0;left:0}.sp-slider{position:absolute;top:0;cursor:pointer;height:3px;left:-1px;right:-1px;border:1px solid #000;background:white;opacity:.8}.sp-container{border-radius:0;background-color:#ECECEC;border:solid 1px #f0c49B;padding:0}.sp-container,.sp-container button,.sp-container input,.sp-color,.sp-hue,.sp-clear{font:normal 12px "Lucida Grande", "Lucida Sans Unicode", "Lucida Sans", Geneva, Verdana, sans-serif;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;-ms-box-sizing:border-box;box-sizing:border-box}.sp-top{margin-bottom:3px}.sp-color,.sp-hue,.sp-clear{border:solid 1px #666}.sp-input-container{float:right;width:100px;margin-bottom:4px}.sp-initial-disabled .sp-input-container{width:100%}.sp-input{font-size:12px !important;border:1px inset;padding:4px 5px;margin:0;width:100%;background:transparent;border-radius:3px;color:#222}.sp-input:focus{border:1px solid orange}.sp-input.sp-validation-error{border:1px solid red;background:#fdd}.sp-picker-container,.sp-palette-container{float:left;position:relative;padding:10px;padding-bottom:300px;margin-bottom:-290px}.sp-picker-container{width:172px;border-left:solid 1px #fff}.sp-palette-container{border-right:solid 1px #ccc}.sp-palette-only .sp-palette-container{border:0}.sp-palette .sp-thumb-el{display:block;position:relative;float:left;width:24px;height:15px;margin:3px;cursor:pointer;border:solid 2px transparent}.sp-palette .sp-thumb-el:hover,.sp-palette .sp-thumb-el.sp-thumb-active{border-color:orange}.sp-thumb-el{position:relative}.sp-initial{float:left;border:solid 1px #333}.sp-initial span{width:30px;height:25px;border:none;display:block;float:left;margin:0}.sp-initial .sp-clear-display{background-position:center}.sp-palette-button-container,.sp-button-container{float:right}.sp-replacer{margin:0;overflow:hidden;cursor:pointer;padding:4px;display:inline-block;*zoom:1;*display:inline;border:solid 1px #91765d;background:#eee;color:#333;vertical-align:middle}.sp-replacer:hover,.sp-replacer.sp-active{border-color:#F0C49B;color:#111}.sp-replacer.sp-disabled{cursor:default;border-color:silver;color:silver}.sp-dd{padding:2px 0;height:16px;line-height:16px;float:left;font-size:10px}.sp-preview{position:relative;width:25px;height:20px;border:solid 1px #222;margin-right:5px;float:left;z-index:0}.sp-palette{*width:220px;max-width:220px}.sp-palette .sp-thumb-el{width:16px;height:16px;margin:2px 1px;border:solid 1px #d0d0d0}.sp-container{padding-bottom:0}.sp-container button{background-color:#eeeeee;background-image:-webkit-linear-gradient(top, #eee, #ccc);background-image:-moz-linear-gradient(top, #eee, #ccc);background-image:-ms-linear-gradient(top, #eee, #ccc);background-image:-o-linear-gradient(top, #eee, #ccc);background-image:linear-gradient(to bottom, #eee, #ccc);border:1px solid #ccc;border-bottom:1px solid #bbb;border-radius:3px;color:#333;font-size:14px;line-height:1;padding:5px 4px;text-align:center;text-shadow:0 1px 0 #eee;vertical-align:middle}.sp-container button:hover{background-color:#dddddd;background-image:-webkit-linear-gradient(top, #ddd, #bbb);background-image:-moz-linear-gradient(top, #ddd, #bbb);background-image:-ms-linear-gradient(top, #ddd, #bbb);background-image:-o-linear-gradient(top, #ddd, #bbb);background-image:linear-gradient(to bottom, #ddd, #bbb);border:1px solid #bbb;border-bottom:1px solid #999;cursor:pointer;text-shadow:0 1px 0 #ddd}.sp-container button:active{border:1px solid #aaa;border-bottom:1px solid #888;-webkit-box-shadow:inset 0 0 5px 2px #aaaaaa, 0 1px 0 0 #eeeeee;-moz-box-shadow:inset 0 0 5px 2px #aaaaaa, 0 1px 0 0 #eeeeee;-ms-box-shadow:inset 0 0 5px 2px #aaaaaa, 0 1px 0 0 #eeeeee;-o-box-shadow:inset 0 0 5px 2px #aaaaaa, 0 1px 0 0 #eeeeee;box-shadow:inset 0 0 5px 2px #aaaaaa, 0 1px 0 0 #eeeeee}.sp-cancel{font-size:11px;color:#d93f3f !important;margin:0;padding:2px;margin-right:5px;vertical-align:middle;text-decoration:none}.sp-cancel:hover{color:#d93f3f !important;text-decoration:underline}.sp-palette span:hover,.sp-palette span.sp-thumb-active{border-color:#000}.sp-preview,.sp-alpha,.sp-thumb-el{position:relative;background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAwAAAAMCAIAAADZF8uwAAAAGUlEQVQYV2M4gwH+YwCGIasIUwhT25BVBADtzYNYrHvv4gAAAABJRU5ErkJggg==)}.sp-preview-inner,.sp-alpha-inner,.sp-thumb-inner{display:block;position:absolute;top:0;left:0;bottom:0;right:0}.sp-palette .sp-thumb-inner{background-position:50% 50%;background-repeat:no-repeat}.sp-palette .sp-thumb-light.sp-thumb-active .sp-thumb-inner{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABIAAAASCAYAAABWzo5XAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAIVJREFUeNpiYBhsgJFMffxAXABlN5JruT4Q3wfi/0DsT64h8UD8HmpIPCWG/KemIfOJCUB+Aoacx6EGBZyHBqI+WsDCwuQ9mhxeg2A210Ntfo8klk9sOMijaURm7yc1UP2RNCMbKE9ODK1HM6iegYLkfx8pligC9lCD7KmRof0ZhjQACDAAceovrtpVBRkAAAAASUVORK5CYII=)}.sp-palette .sp-thumb-dark.sp-thumb-active .sp-thumb-inner{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABIAAAASCAYAAABWzo5XAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAAadEVYdFNvZnR3YXJlAFBhaW50Lk5FVCB2My41LjEwMPRyoQAAAMdJREFUOE+tkgsNwzAMRMugEAahEAahEAZhEAqlEAZhEAohEAYh81X2dIm8fKpEspLGvudPOsUYpxE2BIJCroJmEW9qJ+MKaBFhEMNabSy9oIcIPwrB+afvAUFoK4H0tMaQ3XtlrggDhOVVMuT4E5MMG0FBbCEYzjYT7OxLEvIHQLY2zWwQ3D+9luyOQTfKDiFD3iUIfPk8VqrKjgAiSfGFPecrg6HN6m/iBcwiDAo7WiBeawa+Kwh7tZoSCGLMqwlSAzVDhoK+6vH4G0P5wdkAAAAASUVORK5CYII=)}.sp-clear-display{background-repeat:no-repeat;background-position:center;background-image:url(data:image/gif;base64,R0lGODlhFAAUAPcAAAAAAJmZmZ2dnZ6enqKioqOjo6SkpKWlpaampqenp6ioqKmpqaqqqqurq/Hx8fLy8vT09PX19ff39/j4+Pn5+fr6+vv7+wAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAACH5BAEAAP8ALAAAAAAUABQAAAihAP9FoPCvoMGDBy08+EdhQAIJCCMybCDAAYUEARBAlFiQQoMABQhKUJBxY0SPICEYHBnggEmDKAuoPMjS5cGYMxHW3IiT478JJA8M/CjTZ0GgLRekNGpwAsYABHIypcAgQMsITDtWJYBR6NSqMico9cqR6tKfY7GeBCuVwlipDNmefAtTrkSzB1RaIAoXodsABiZAEFB06gIBWC1mLVgBa0AAOw==)}/*! * Font Awesome 4.7.0 by @davegandy - http://fontawesome.io - @fontawesome * License - http://fontawesome.io/license (Font: SIL OFL 1.1, CSS: MIT License) - */@font-face{font-family:'FontAwesome';src:url("../fonts/fontawesome-webfont.eot?v=4.7.0");src:url("../fonts/fontawesome-webfont.eot?#iefix&v=4.7.0") format("embedded-opentype"),url("../fonts/fontawesome-webfont.woff2?v=4.7.0") format("woff2"),url("../fonts/fontawesome-webfont.woff?v=4.7.0") format("woff"),url("../fonts/fontawesome-webfont.ttf?v=4.7.0") format("truetype"),url("../fonts/fontawesome-webfont.svg?v=4.7.0#fontawesomeregular") format("svg");font-weight:normal;font-style:normal}.fa{display:inline-block;font:normal normal normal 14px/1 FontAwesome;font-size:inherit;text-rendering:auto;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.fa-lg{font-size:1.33333em;line-height:.75em;vertical-align:-15%}.fa-2x{font-size:2em}.fa-3x{font-size:3em}.fa-4x{font-size:4em}.fa-5x{font-size:5em}.fa-fw{width:1.28571em;text-align:center}.fa-ul{padding-left:0;margin-left:2.14286em;list-style-type:none}.fa-ul>li{position:relative}.fa-li{position:absolute;left:-2.14286em;width:2.14286em;top:.14286em;text-align:center}.fa-li.fa-lg{left:-1.85714em}.fa-border{padding:.2em .25em .15em;border:solid 0.08em #eee;border-radius:.1em}.fa-pull-left{float:left}.fa-pull-right{float:right}.fa.fa-pull-left{margin-right:.3em}.fa.fa-pull-right{margin-left:.3em}.pull-right{float:right}.pull-left{float:left}.fa.pull-left{margin-right:.3em}.fa.pull-right{margin-left:.3em}.fa-spin{-webkit-animation:fa-spin 2s infinite linear;animation:fa-spin 2s infinite linear}.fa-pulse{-webkit-animation:fa-spin 1s infinite steps(8);animation:fa-spin 1s infinite steps(8)}@-webkit-keyframes fa-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}100%{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}@keyframes fa-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}100%{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}.fa-rotate-90{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=1)";-webkit-transform:rotate(90deg);-ms-transform:rotate(90deg);transform:rotate(90deg)}.fa-rotate-180{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=2)";-webkit-transform:rotate(180deg);-ms-transform:rotate(180deg);transform:rotate(180deg)}.fa-rotate-270{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=3)";-webkit-transform:rotate(270deg);-ms-transform:rotate(270deg);transform:rotate(270deg)}.fa-flip-horizontal{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=0, mirror=1)";-webkit-transform:scale(-1, 1);-ms-transform:scale(-1, 1);transform:scale(-1, 1)}.fa-flip-vertical{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=2, mirror=1)";-webkit-transform:scale(1, -1);-ms-transform:scale(1, -1);transform:scale(1, -1)}:root .fa-rotate-90,:root .fa-rotate-180,:root .fa-rotate-270,:root .fa-flip-horizontal,:root .fa-flip-vertical{filter:none}.fa-stack{position:relative;display:inline-block;width:2em;height:2em;line-height:2em;vertical-align:middle}.fa-stack-1x,.fa-stack-2x{position:absolute;left:0;width:100%;text-align:center}.fa-stack-1x{line-height:inherit}.fa-stack-2x{font-size:2em}.fa-inverse{color:#fff}.fa-glass:before{content:""}.fa-music:before{content:""}.fa-search:before{content:""}.fa-envelope-o:before{content:""}.fa-heart:before{content:""}.fa-star:before{content:""}.fa-star-o:before{content:""}.fa-user:before{content:""}.fa-film:before{content:""}.fa-th-large:before{content:""}.fa-th:before{content:""}.fa-th-list:before{content:""}.fa-check:before{content:""}.fa-remove:before,.fa-close:before,.fa-times:before{content:""}.fa-search-plus:before{content:""}.fa-search-minus:before{content:""}.fa-power-off:before{content:""}.fa-signal:before{content:""}.fa-gear:before,.fa-cog:before{content:""}.fa-trash-o:before{content:""}.fa-home:before{content:""}.fa-file-o:before{content:""}.fa-clock-o:before{content:""}.fa-road:before{content:""}.fa-download:before{content:""}.fa-arrow-circle-o-down:before{content:""}.fa-arrow-circle-o-up:before{content:""}.fa-inbox:before{content:""}.fa-play-circle-o:before{content:""}.fa-rotate-right:before,.fa-repeat:before{content:""}.fa-refresh:before{content:""}.fa-list-alt:before{content:""}.fa-lock:before{content:""}.fa-flag:before{content:""}.fa-headphones:before{content:""}.fa-volume-off:before{content:""}.fa-volume-down:before{content:""}.fa-volume-up:before{content:""}.fa-qrcode:before{content:""}.fa-barcode:before{content:""}.fa-tag:before{content:""}.fa-tags:before{content:""}.fa-book:before{content:""}.fa-bookmark:before{content:""}.fa-print:before{content:""}.fa-camera:before{content:""}.fa-font:before{content:""}.fa-bold:before{content:""}.fa-italic:before{content:""}.fa-text-height:before{content:""}.fa-text-width:before{content:""}.fa-align-left:before{content:""}.fa-align-center:before{content:""}.fa-align-right:before{content:""}.fa-align-justify:before{content:""}.fa-list:before{content:""}.fa-dedent:before,.fa-outdent:before{content:""}.fa-indent:before{content:""}.fa-video-camera:before{content:""}.fa-photo:before,.fa-image:before,.fa-picture-o:before{content:""}.fa-pencil:before{content:""}.fa-map-marker:before{content:""}.fa-adjust:before{content:""}.fa-tint:before{content:""}.fa-edit:before,.fa-pencil-square-o:before{content:""}.fa-share-square-o:before{content:""}.fa-check-square-o:before{content:""}.fa-arrows:before{content:""}.fa-step-backward:before{content:""}.fa-fast-backward:before{content:""}.fa-backward:before{content:""}.fa-play:before{content:""}.fa-pause:before{content:""}.fa-stop:before{content:""}.fa-forward:before{content:""}.fa-fast-forward:before{content:""}.fa-step-forward:before{content:""}.fa-eject:before{content:""}.fa-chevron-left:before{content:""}.fa-chevron-right:before{content:""}.fa-plus-circle:before{content:""}.fa-minus-circle:before{content:""}.fa-times-circle:before{content:""}.fa-check-circle:before{content:""}.fa-question-circle:before{content:""}.fa-info-circle:before{content:""}.fa-crosshairs:before{content:""}.fa-times-circle-o:before{content:""}.fa-check-circle-o:before{content:""}.fa-ban:before{content:""}.fa-arrow-left:before{content:""}.fa-arrow-right:before{content:""}.fa-arrow-up:before{content:""}.fa-arrow-down:before{content:""}.fa-mail-forward:before,.fa-share:before{content:""}.fa-expand:before{content:""}.fa-compress:before{content:""}.fa-plus:before{content:""}.fa-minus:before{content:""}.fa-asterisk:before{content:""}.fa-exclamation-circle:before{content:""}.fa-gift:before{content:""}.fa-leaf:before{content:""}.fa-fire:before{content:""}.fa-eye:before{content:""}.fa-eye-slash:before{content:""}.fa-warning:before,.fa-exclamation-triangle:before{content:""}.fa-plane:before{content:""}.fa-calendar:before{content:""}.fa-random:before{content:""}.fa-comment:before{content:""}.fa-magnet:before{content:""}.fa-chevron-up:before{content:""}.fa-chevron-down:before{content:""}.fa-retweet:before{content:""}.fa-shopping-cart:before{content:""}.fa-folder:before{content:""}.fa-folder-open:before{content:""}.fa-arrows-v:before{content:""}.fa-arrows-h:before{content:""}.fa-bar-chart-o:before,.fa-bar-chart:before{content:""}.fa-twitter-square:before{content:""}.fa-facebook-square:before{content:""}.fa-camera-retro:before{content:""}.fa-key:before{content:""}.fa-gears:before,.fa-cogs:before{content:""}.fa-comments:before{content:""}.fa-thumbs-o-up:before{content:""}.fa-thumbs-o-down:before{content:""}.fa-star-half:before{content:""}.fa-heart-o:before{content:""}.fa-sign-out:before{content:""}.fa-linkedin-square:before{content:""}.fa-thumb-tack:before{content:""}.fa-external-link:before{content:""}.fa-sign-in:before{content:""}.fa-trophy:before{content:""}.fa-github-square:before{content:""}.fa-upload:before{content:""}.fa-lemon-o:before{content:""}.fa-phone:before{content:""}.fa-square-o:before{content:""}.fa-bookmark-o:before{content:""}.fa-phone-square:before{content:""}.fa-twitter:before{content:""}.fa-facebook-f:before,.fa-facebook:before{content:""}.fa-github:before{content:""}.fa-unlock:before{content:""}.fa-credit-card:before{content:""}.fa-feed:before,.fa-rss:before{content:""}.fa-hdd-o:before{content:""}.fa-bullhorn:before{content:""}.fa-bell:before{content:""}.fa-certificate:before{content:""}.fa-hand-o-right:before{content:""}.fa-hand-o-left:before{content:""}.fa-hand-o-up:before{content:""}.fa-hand-o-down:before{content:""}.fa-arrow-circle-left:before{content:""}.fa-arrow-circle-right:before{content:""}.fa-arrow-circle-up:before{content:""}.fa-arrow-circle-down:before{content:""}.fa-globe:before{content:""}.fa-wrench:before{content:""}.fa-tasks:before{content:""}.fa-filter:before{content:""}.fa-briefcase:before{content:""}.fa-arrows-alt:before{content:""}.fa-group:before,.fa-users:before{content:""}.fa-chain:before,.fa-link:before{content:""}.fa-cloud:before{content:""}.fa-flask:before{content:""}.fa-cut:before,.fa-scissors:before{content:""}.fa-copy:before,.fa-files-o:before{content:""}.fa-paperclip:before{content:""}.fa-save:before,.fa-floppy-o:before{content:""}.fa-square:before{content:""}.fa-navicon:before,.fa-reorder:before,.fa-bars:before{content:""}.fa-list-ul:before{content:""}.fa-list-ol:before{content:""}.fa-strikethrough:before{content:""}.fa-underline:before{content:""}.fa-table:before{content:""}.fa-magic:before{content:""}.fa-truck:before{content:""}.fa-pinterest:before{content:""}.fa-pinterest-square:before{content:""}.fa-google-plus-square:before{content:""}.fa-google-plus:before{content:""}.fa-money:before{content:""}.fa-caret-down:before{content:""}.fa-caret-up:before{content:""}.fa-caret-left:before{content:""}.fa-caret-right:before{content:""}.fa-columns:before{content:""}.fa-unsorted:before,.fa-sort:before{content:""}.fa-sort-down:before,.fa-sort-desc:before{content:""}.fa-sort-up:before,.fa-sort-asc:before{content:""}.fa-envelope:before{content:""}.fa-linkedin:before{content:""}.fa-rotate-left:before,.fa-undo:before{content:""}.fa-legal:before,.fa-gavel:before{content:""}.fa-dashboard:before,.fa-tachometer:before{content:""}.fa-comment-o:before{content:""}.fa-comments-o:before{content:""}.fa-flash:before,.fa-bolt:before{content:""}.fa-sitemap:before{content:""}.fa-umbrella:before{content:""}.fa-paste:before,.fa-clipboard:before{content:""}.fa-lightbulb-o:before{content:""}.fa-exchange:before{content:""}.fa-cloud-download:before{content:""}.fa-cloud-upload:before{content:""}.fa-user-md:before{content:""}.fa-stethoscope:before{content:""}.fa-suitcase:before{content:""}.fa-bell-o:before{content:""}.fa-coffee:before{content:""}.fa-cutlery:before{content:""}.fa-file-text-o:before{content:""}.fa-building-o:before{content:""}.fa-hospital-o:before{content:""}.fa-ambulance:before{content:""}.fa-medkit:before{content:""}.fa-fighter-jet:before{content:""}.fa-beer:before{content:""}.fa-h-square:before{content:""}.fa-plus-square:before{content:""}.fa-angle-double-left:before{content:""}.fa-angle-double-right:before{content:""}.fa-angle-double-up:before{content:""}.fa-angle-double-down:before{content:""}.fa-angle-left:before{content:""}.fa-angle-right:before{content:""}.fa-angle-up:before{content:""}.fa-angle-down:before{content:""}.fa-desktop:before{content:""}.fa-laptop:before{content:""}.fa-tablet:before{content:""}.fa-mobile-phone:before,.fa-mobile:before{content:""}.fa-circle-o:before{content:""}.fa-quote-left:before{content:""}.fa-quote-right:before{content:""}.fa-spinner:before{content:""}.fa-circle:before{content:""}.fa-mail-reply:before,.fa-reply:before{content:""}.fa-github-alt:before{content:""}.fa-folder-o:before{content:""}.fa-folder-open-o:before{content:""}.fa-smile-o:before{content:""}.fa-frown-o:before{content:""}.fa-meh-o:before{content:""}.fa-gamepad:before{content:""}.fa-keyboard-o:before{content:""}.fa-flag-o:before{content:""}.fa-flag-checkered:before{content:""}.fa-terminal:before{content:""}.fa-code:before{content:""}.fa-mail-reply-all:before,.fa-reply-all:before{content:""}.fa-star-half-empty:before,.fa-star-half-full:before,.fa-star-half-o:before{content:""}.fa-location-arrow:before{content:""}.fa-crop:before{content:""}.fa-code-fork:before{content:""}.fa-unlink:before,.fa-chain-broken:before{content:""}.fa-question:before{content:""}.fa-info:before{content:""}.fa-exclamation:before{content:""}.fa-superscript:before{content:""}.fa-subscript:before{content:""}.fa-eraser:before{content:""}.fa-puzzle-piece:before{content:""}.fa-microphone:before{content:""}.fa-microphone-slash:before{content:""}.fa-shield:before{content:""}.fa-calendar-o:before{content:""}.fa-fire-extinguisher:before{content:""}.fa-rocket:before{content:""}.fa-maxcdn:before{content:""}.fa-chevron-circle-left:before{content:""}.fa-chevron-circle-right:before{content:""}.fa-chevron-circle-up:before{content:""}.fa-chevron-circle-down:before{content:""}.fa-html5:before{content:""}.fa-css3:before{content:""}.fa-anchor:before{content:""}.fa-unlock-alt:before{content:""}.fa-bullseye:before{content:""}.fa-ellipsis-h:before{content:""}.fa-ellipsis-v:before{content:""}.fa-rss-square:before{content:""}.fa-play-circle:before{content:""}.fa-ticket:before{content:""}.fa-minus-square:before{content:""}.fa-minus-square-o:before{content:""}.fa-level-up:before{content:""}.fa-level-down:before{content:""}.fa-check-square:before{content:""}.fa-pencil-square:before{content:""}.fa-external-link-square:before{content:""}.fa-share-square:before{content:""}.fa-compass:before{content:""}.fa-toggle-down:before,.fa-caret-square-o-down:before{content:""}.fa-toggle-up:before,.fa-caret-square-o-up:before{content:""}.fa-toggle-right:before,.fa-caret-square-o-right:before{content:""}.fa-euro:before,.fa-eur:before{content:""}.fa-gbp:before{content:""}.fa-dollar:before,.fa-usd:before{content:""}.fa-rupee:before,.fa-inr:before{content:""}.fa-cny:before,.fa-rmb:before,.fa-yen:before,.fa-jpy:before{content:""}.fa-ruble:before,.fa-rouble:before,.fa-rub:before{content:""}.fa-won:before,.fa-krw:before{content:""}.fa-bitcoin:before,.fa-btc:before{content:""}.fa-file:before{content:""}.fa-file-text:before{content:""}.fa-sort-alpha-asc:before{content:""}.fa-sort-alpha-desc:before{content:""}.fa-sort-amount-asc:before{content:""}.fa-sort-amount-desc:before{content:""}.fa-sort-numeric-asc:before{content:""}.fa-sort-numeric-desc:before{content:""}.fa-thumbs-up:before{content:""}.fa-thumbs-down:before{content:""}.fa-youtube-square:before{content:""}.fa-youtube:before{content:""}.fa-xing:before{content:""}.fa-xing-square:before{content:""}.fa-youtube-play:before{content:""}.fa-dropbox:before{content:""}.fa-stack-overflow:before{content:""}.fa-instagram:before{content:""}.fa-flickr:before{content:""}.fa-adn:before{content:""}.fa-bitbucket:before{content:""}.fa-bitbucket-square:before{content:""}.fa-tumblr:before{content:""}.fa-tumblr-square:before{content:""}.fa-long-arrow-down:before{content:""}.fa-long-arrow-up:before{content:""}.fa-long-arrow-left:before{content:""}.fa-long-arrow-right:before{content:""}.fa-apple:before{content:""}.fa-windows:before{content:""}.fa-android:before{content:""}.fa-linux:before{content:""}.fa-dribbble:before{content:""}.fa-skype:before{content:""}.fa-foursquare:before{content:""}.fa-trello:before{content:""}.fa-female:before{content:""}.fa-male:before{content:""}.fa-gittip:before,.fa-gratipay:before{content:""}.fa-sun-o:before{content:""}.fa-moon-o:before{content:""}.fa-archive:before{content:""}.fa-bug:before{content:""}.fa-vk:before{content:""}.fa-weibo:before{content:""}.fa-renren:before{content:""}.fa-pagelines:before{content:""}.fa-stack-exchange:before{content:""}.fa-arrow-circle-o-right:before{content:""}.fa-arrow-circle-o-left:before{content:""}.fa-toggle-left:before,.fa-caret-square-o-left:before{content:""}.fa-dot-circle-o:before{content:""}.fa-wheelchair:before{content:""}.fa-vimeo-square:before{content:""}.fa-turkish-lira:before,.fa-try:before{content:""}.fa-plus-square-o:before{content:""}.fa-space-shuttle:before{content:""}.fa-slack:before{content:""}.fa-envelope-square:before{content:""}.fa-wordpress:before{content:""}.fa-openid:before{content:""}.fa-institution:before,.fa-bank:before,.fa-university:before{content:""}.fa-mortar-board:before,.fa-graduation-cap:before{content:""}.fa-yahoo:before{content:""}.fa-google:before{content:""}.fa-reddit:before{content:""}.fa-reddit-square:before{content:""}.fa-stumbleupon-circle:before{content:""}.fa-stumbleupon:before{content:""}.fa-delicious:before{content:""}.fa-digg:before{content:""}.fa-pied-piper-pp:before{content:""}.fa-pied-piper-alt:before{content:""}.fa-drupal:before{content:""}.fa-joomla:before{content:""}.fa-language:before{content:""}.fa-fax:before{content:""}.fa-building:before{content:""}.fa-child:before{content:""}.fa-paw:before{content:""}.fa-spoon:before{content:""}.fa-cube:before{content:""}.fa-cubes:before{content:""}.fa-behance:before{content:""}.fa-behance-square:before{content:""}.fa-steam:before{content:""}.fa-steam-square:before{content:""}.fa-recycle:before{content:""}.fa-automobile:before,.fa-car:before{content:""}.fa-cab:before,.fa-taxi:before{content:""}.fa-tree:before{content:""}.fa-spotify:before{content:""}.fa-deviantart:before{content:""}.fa-soundcloud:before{content:""}.fa-database:before{content:""}.fa-file-pdf-o:before{content:""}.fa-file-word-o:before{content:""}.fa-file-excel-o:before{content:""}.fa-file-powerpoint-o:before{content:""}.fa-file-photo-o:before,.fa-file-picture-o:before,.fa-file-image-o:before{content:""}.fa-file-zip-o:before,.fa-file-archive-o:before{content:""}.fa-file-sound-o:before,.fa-file-audio-o:before{content:""}.fa-file-movie-o:before,.fa-file-video-o:before{content:""}.fa-file-code-o:before{content:""}.fa-vine:before{content:""}.fa-codepen:before{content:""}.fa-jsfiddle:before{content:""}.fa-life-bouy:before,.fa-life-buoy:before,.fa-life-saver:before,.fa-support:before,.fa-life-ring:before{content:""}.fa-circle-o-notch:before{content:""}.fa-ra:before,.fa-resistance:before,.fa-rebel:before{content:""}.fa-ge:before,.fa-empire:before{content:""}.fa-git-square:before{content:""}.fa-git:before{content:""}.fa-y-combinator-square:before,.fa-yc-square:before,.fa-hacker-news:before{content:""}.fa-tencent-weibo:before{content:""}.fa-qq:before{content:""}.fa-wechat:before,.fa-weixin:before{content:""}.fa-send:before,.fa-paper-plane:before{content:""}.fa-send-o:before,.fa-paper-plane-o:before{content:""}.fa-history:before{content:""}.fa-circle-thin:before{content:""}.fa-header:before{content:""}.fa-paragraph:before{content:""}.fa-sliders:before{content:""}.fa-share-alt:before{content:""}.fa-share-alt-square:before{content:""}.fa-bomb:before{content:""}.fa-soccer-ball-o:before,.fa-futbol-o:before{content:""}.fa-tty:before{content:""}.fa-binoculars:before{content:""}.fa-plug:before{content:""}.fa-slideshare:before{content:""}.fa-twitch:before{content:""}.fa-yelp:before{content:""}.fa-newspaper-o:before{content:""}.fa-wifi:before{content:""}.fa-calculator:before{content:""}.fa-paypal:before{content:""}.fa-google-wallet:before{content:""}.fa-cc-visa:before{content:""}.fa-cc-mastercard:before{content:""}.fa-cc-discover:before{content:""}.fa-cc-amex:before{content:""}.fa-cc-paypal:before{content:""}.fa-cc-stripe:before{content:""}.fa-bell-slash:before{content:""}.fa-bell-slash-o:before{content:""}.fa-trash:before{content:""}.fa-copyright:before{content:""}.fa-at:before{content:""}.fa-eyedropper:before{content:""}.fa-paint-brush:before{content:""}.fa-birthday-cake:before{content:""}.fa-area-chart:before{content:""}.fa-pie-chart:before{content:""}.fa-line-chart:before{content:""}.fa-lastfm:before{content:""}.fa-lastfm-square:before{content:""}.fa-toggle-off:before{content:""}.fa-toggle-on:before{content:""}.fa-bicycle:before{content:""}.fa-bus:before{content:""}.fa-ioxhost:before{content:""}.fa-angellist:before{content:""}.fa-cc:before{content:""}.fa-shekel:before,.fa-sheqel:before,.fa-ils:before{content:""}.fa-meanpath:before{content:""}.fa-buysellads:before{content:""}.fa-connectdevelop:before{content:""}.fa-dashcube:before{content:""}.fa-forumbee:before{content:""}.fa-leanpub:before{content:""}.fa-sellsy:before{content:""}.fa-shirtsinbulk:before{content:""}.fa-simplybuilt:before{content:""}.fa-skyatlas:before{content:""}.fa-cart-plus:before{content:""}.fa-cart-arrow-down:before{content:""}.fa-diamond:before{content:""}.fa-ship:before{content:""}.fa-user-secret:before{content:""}.fa-motorcycle:before{content:""}.fa-street-view:before{content:""}.fa-heartbeat:before{content:""}.fa-venus:before{content:""}.fa-mars:before{content:""}.fa-mercury:before{content:""}.fa-intersex:before,.fa-transgender:before{content:""}.fa-transgender-alt:before{content:""}.fa-venus-double:before{content:""}.fa-mars-double:before{content:""}.fa-venus-mars:before{content:""}.fa-mars-stroke:before{content:""}.fa-mars-stroke-v:before{content:""}.fa-mars-stroke-h:before{content:""}.fa-neuter:before{content:""}.fa-genderless:before{content:""}.fa-facebook-official:before{content:""}.fa-pinterest-p:before{content:""}.fa-whatsapp:before{content:""}.fa-server:before{content:""}.fa-user-plus:before{content:""}.fa-user-times:before{content:""}.fa-hotel:before,.fa-bed:before{content:""}.fa-viacoin:before{content:""}.fa-train:before{content:""}.fa-subway:before{content:""}.fa-medium:before{content:""}.fa-yc:before,.fa-y-combinator:before{content:""}.fa-optin-monster:before{content:""}.fa-opencart:before{content:""}.fa-expeditedssl:before{content:""}.fa-battery-4:before,.fa-battery:before,.fa-battery-full:before{content:""}.fa-battery-3:before,.fa-battery-three-quarters:before{content:""}.fa-battery-2:before,.fa-battery-half:before{content:""}.fa-battery-1:before,.fa-battery-quarter:before{content:""}.fa-battery-0:before,.fa-battery-empty:before{content:""}.fa-mouse-pointer:before{content:""}.fa-i-cursor:before{content:""}.fa-object-group:before{content:""}.fa-object-ungroup:before{content:""}.fa-sticky-note:before{content:""}.fa-sticky-note-o:before{content:""}.fa-cc-jcb:before{content:""}.fa-cc-diners-club:before{content:""}.fa-clone:before{content:""}.fa-balance-scale:before{content:""}.fa-hourglass-o:before{content:""}.fa-hourglass-1:before,.fa-hourglass-start:before{content:""}.fa-hourglass-2:before,.fa-hourglass-half:before{content:""}.fa-hourglass-3:before,.fa-hourglass-end:before{content:""}.fa-hourglass:before{content:""}.fa-hand-grab-o:before,.fa-hand-rock-o:before{content:""}.fa-hand-stop-o:before,.fa-hand-paper-o:before{content:""}.fa-hand-scissors-o:before{content:""}.fa-hand-lizard-o:before{content:""}.fa-hand-spock-o:before{content:""}.fa-hand-pointer-o:before{content:""}.fa-hand-peace-o:before{content:""}.fa-trademark:before{content:""}.fa-registered:before{content:""}.fa-creative-commons:before{content:""}.fa-gg:before{content:""}.fa-gg-circle:before{content:""}.fa-tripadvisor:before{content:""}.fa-odnoklassniki:before{content:""}.fa-odnoklassniki-square:before{content:""}.fa-get-pocket:before{content:""}.fa-wikipedia-w:before{content:""}.fa-safari:before{content:""}.fa-chrome:before{content:""}.fa-firefox:before{content:""}.fa-opera:before{content:""}.fa-internet-explorer:before{content:""}.fa-tv:before,.fa-television:before{content:""}.fa-contao:before{content:""}.fa-500px:before{content:""}.fa-amazon:before{content:""}.fa-calendar-plus-o:before{content:""}.fa-calendar-minus-o:before{content:""}.fa-calendar-times-o:before{content:""}.fa-calendar-check-o:before{content:""}.fa-industry:before{content:""}.fa-map-pin:before{content:""}.fa-map-signs:before{content:""}.fa-map-o:before{content:""}.fa-map:before{content:""}.fa-commenting:before{content:""}.fa-commenting-o:before{content:""}.fa-houzz:before{content:""}.fa-vimeo:before{content:""}.fa-black-tie:before{content:""}.fa-fonticons:before{content:""}.fa-reddit-alien:before{content:""}.fa-edge:before{content:""}.fa-credit-card-alt:before{content:""}.fa-codiepie:before{content:""}.fa-modx:before{content:""}.fa-fort-awesome:before{content:""}.fa-usb:before{content:""}.fa-product-hunt:before{content:""}.fa-mixcloud:before{content:""}.fa-scribd:before{content:""}.fa-pause-circle:before{content:""}.fa-pause-circle-o:before{content:""}.fa-stop-circle:before{content:""}.fa-stop-circle-o:before{content:""}.fa-shopping-bag:before{content:""}.fa-shopping-basket:before{content:""}.fa-hashtag:before{content:""}.fa-bluetooth:before{content:""}.fa-bluetooth-b:before{content:""}.fa-percent:before{content:""}.fa-gitlab:before{content:""}.fa-wpbeginner:before{content:""}.fa-wpforms:before{content:""}.fa-envira:before{content:""}.fa-universal-access:before{content:""}.fa-wheelchair-alt:before{content:""}.fa-question-circle-o:before{content:""}.fa-blind:before{content:""}.fa-audio-description:before{content:""}.fa-volume-control-phone:before{content:""}.fa-braille:before{content:""}.fa-assistive-listening-systems:before{content:""}.fa-asl-interpreting:before,.fa-american-sign-language-interpreting:before{content:""}.fa-deafness:before,.fa-hard-of-hearing:before,.fa-deaf:before{content:""}.fa-glide:before{content:""}.fa-glide-g:before{content:""}.fa-signing:before,.fa-sign-language:before{content:""}.fa-low-vision:before{content:""}.fa-viadeo:before{content:""}.fa-viadeo-square:before{content:""}.fa-snapchat:before{content:""}.fa-snapchat-ghost:before{content:""}.fa-snapchat-square:before{content:""}.fa-pied-piper:before{content:""}.fa-first-order:before{content:""}.fa-yoast:before{content:""}.fa-themeisle:before{content:""}.fa-google-plus-circle:before,.fa-google-plus-official:before{content:""}.fa-fa:before,.fa-font-awesome:before{content:""}.fa-handshake-o:before{content:""}.fa-envelope-open:before{content:""}.fa-envelope-open-o:before{content:""}.fa-linode:before{content:""}.fa-address-book:before{content:""}.fa-address-book-o:before{content:""}.fa-vcard:before,.fa-address-card:before{content:""}.fa-vcard-o:before,.fa-address-card-o:before{content:""}.fa-user-circle:before{content:""}.fa-user-circle-o:before{content:""}.fa-user-o:before{content:""}.fa-id-badge:before{content:""}.fa-drivers-license:before,.fa-id-card:before{content:""}.fa-drivers-license-o:before,.fa-id-card-o:before{content:""}.fa-quora:before{content:""}.fa-free-code-camp:before{content:""}.fa-telegram:before{content:""}.fa-thermometer-4:before,.fa-thermometer:before,.fa-thermometer-full:before{content:""}.fa-thermometer-3:before,.fa-thermometer-three-quarters:before{content:""}.fa-thermometer-2:before,.fa-thermometer-half:before{content:""}.fa-thermometer-1:before,.fa-thermometer-quarter:before{content:""}.fa-thermometer-0:before,.fa-thermometer-empty:before{content:""}.fa-shower:before{content:""}.fa-bathtub:before,.fa-s15:before,.fa-bath:before{content:""}.fa-podcast:before{content:""}.fa-window-maximize:before{content:""}.fa-window-minimize:before{content:""}.fa-window-restore:before{content:""}.fa-times-rectangle:before,.fa-window-close:before{content:""}.fa-times-rectangle-o:before,.fa-window-close-o:before{content:""}.fa-bandcamp:before{content:""}.fa-grav:before{content:""}.fa-etsy:before{content:""}.fa-imdb:before{content:""}.fa-ravelry:before{content:""}.fa-eercast:before{content:""}.fa-microchip:before{content:""}.fa-snowflake-o:before{content:""}.fa-superpowers:before{content:""}.fa-wpexplorer:before{content:""}.fa-meetup:before{content:""}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0, 0, 0, 0);border:0}.sr-only-focusable:active,.sr-only-focusable:focus{position:static;width:auto;height:auto;margin:0;overflow:visible;clip:auto}.CodeMirror{font-family:monospace;height:300px;color:black;direction:ltr}.CodeMirror-lines{padding:4px 0}.CodeMirror pre{padding:0 4px}.CodeMirror-scrollbar-filler,.CodeMirror-gutter-filler{background-color:white}.CodeMirror-gutters{border-right:1px solid #ddd;background-color:#f7f7f7;white-space:nowrap}.CodeMirror-linenumber{padding:0 3px 0 5px;min-width:20px;text-align:right;color:#999;white-space:nowrap}.CodeMirror-guttermarker{color:black}.CodeMirror-guttermarker-subtle{color:#999}.CodeMirror-cursor{border-left:1px solid black;border-right:none;width:0}.CodeMirror div.CodeMirror-secondarycursor{border-left:1px solid silver}.cm-fat-cursor .CodeMirror-cursor{width:auto;border:0 !important;background:#7e7}.cm-fat-cursor div.CodeMirror-cursors{z-index:1}.cm-fat-cursor-mark{background-color:rgba(20,255,20,0.5);-webkit-animation:blink 1.06s steps(1) infinite;-moz-animation:blink 1.06s steps(1) infinite;animation:blink 1.06s steps(1) infinite}.cm-animate-fat-cursor{width:auto;border:0;-webkit-animation:blink 1.06s steps(1) infinite;-moz-animation:blink 1.06s steps(1) infinite;animation:blink 1.06s steps(1) infinite;background-color:#7e7}@-moz-keyframes blink{0%{}50%{background-color:transparent}100%{}}@-webkit-keyframes blink{0%{}50%{background-color:transparent}100%{}}@keyframes blink{0%{}50%{background-color:transparent}100%{}}.cm-tab{display:inline-block;text-decoration:inherit}.CodeMirror-rulers{position:absolute;left:0;right:0;top:-50px;bottom:-20px;overflow:hidden}.CodeMirror-ruler{border-left:1px solid #ccc;top:0;bottom:0;position:absolute}.cm-s-default .cm-header{color:blue}.cm-s-default .cm-quote{color:#090}.cm-negative{color:#d44}.cm-positive{color:#292}.cm-header,.cm-strong{font-weight:bold}.cm-em{font-style:italic}.cm-link{text-decoration:underline}.cm-strikethrough{text-decoration:line-through}.cm-s-default .cm-keyword{color:#708}.cm-s-default .cm-atom{color:#219}.cm-s-default .cm-number{color:#164}.cm-s-default .cm-def{color:#00f}.cm-s-default .cm-variable-2{color:#05a}.cm-s-default .cm-variable-3,.cm-s-default .cm-type{color:#085}.cm-s-default .cm-comment{color:#a50}.cm-s-default .cm-string{color:#a11}.cm-s-default .cm-string-2{color:#f50}.cm-s-default .cm-meta{color:#555}.cm-s-default .cm-qualifier{color:#555}.cm-s-default .cm-builtin{color:#30a}.cm-s-default .cm-bracket{color:#997}.cm-s-default .cm-tag{color:#170}.cm-s-default .cm-attribute{color:#00c}.cm-s-default .cm-hr{color:#999}.cm-s-default .cm-link{color:#00c}.cm-s-default .cm-error{color:#f00}.cm-invalidchar{color:#f00}.CodeMirror-composing{border-bottom:2px solid}div.CodeMirror span.CodeMirror-matchingbracket{color:#0f0}div.CodeMirror span.CodeMirror-nonmatchingbracket{color:#f22}.CodeMirror-matchingtag{background:rgba(255,150,0,0.3)}.CodeMirror-activeline-background{background:#e8f2ff}.CodeMirror{position:relative;overflow:hidden;background:white}.CodeMirror-scroll{overflow:scroll !important;margin-bottom:-30px;margin-right:-30px;padding-bottom:30px;height:100%;outline:none;position:relative}.CodeMirror-sizer{position:relative;border-right:30px solid transparent}.CodeMirror-vscrollbar,.CodeMirror-hscrollbar,.CodeMirror-scrollbar-filler,.CodeMirror-gutter-filler{position:absolute;z-index:6;display:none}.CodeMirror-vscrollbar{right:0;top:0;overflow-x:hidden;overflow-y:scroll}.CodeMirror-hscrollbar{bottom:0;left:0;overflow-y:hidden;overflow-x:scroll}.CodeMirror-scrollbar-filler{right:0;bottom:0}.CodeMirror-gutter-filler{left:0;bottom:0}.CodeMirror-gutters{position:absolute;left:0;top:0;min-height:100%;z-index:3}.CodeMirror-gutter{white-space:normal;height:100%;display:inline-block;vertical-align:top;margin-bottom:-30px}.CodeMirror-gutter-wrapper{position:absolute;z-index:4;background:none !important;border:none !important}.CodeMirror-gutter-background{position:absolute;top:0;bottom:0;z-index:4}.CodeMirror-gutter-elt{position:absolute;cursor:default;z-index:4}.CodeMirror-gutter-wrapper ::selection{background-color:transparent}.CodeMirror-gutter-wrapper ::-moz-selection{background-color:transparent}.CodeMirror-lines{cursor:text;min-height:1px}.CodeMirror pre{-moz-border-radius:0;-webkit-border-radius:0;border-radius:0;border-width:0;background:transparent;font-family:inherit;font-size:inherit;margin:0;white-space:pre;word-wrap:normal;line-height:inherit;color:inherit;z-index:2;position:relative;overflow:visible;-webkit-tap-highlight-color:transparent;-webkit-font-variant-ligatures:contextual;font-variant-ligatures:contextual}.CodeMirror-wrap pre{word-wrap:break-word;white-space:pre-wrap;word-break:normal}.CodeMirror-linebackground{position:absolute;left:0;right:0;top:0;bottom:0;z-index:0}.CodeMirror-linewidget{position:relative;z-index:2;overflow:auto}.CodeMirror-rtl pre{direction:rtl}.CodeMirror-code{outline:none}.CodeMirror-scroll,.CodeMirror-sizer,.CodeMirror-gutter,.CodeMirror-gutters,.CodeMirror-linenumber{-moz-box-sizing:content-box;box-sizing:content-box}.CodeMirror-measure{position:absolute;width:100%;height:0;overflow:hidden;visibility:hidden}.CodeMirror-cursor{position:absolute;pointer-events:none}.CodeMirror-measure pre{position:static}div.CodeMirror-cursors{visibility:hidden;position:relative;z-index:3}div.CodeMirror-dragcursors{visibility:visible}.CodeMirror-focused div.CodeMirror-cursors{visibility:visible}.CodeMirror-selected{background:#d9d9d9}.CodeMirror-focused .CodeMirror-selected{background:#d7d4f0}.CodeMirror-crosshair{cursor:crosshair}.CodeMirror-line::selection,.CodeMirror-line>span::selection,.CodeMirror-line>span>span::selection{background:#d7d4f0}.CodeMirror-line::-moz-selection,.CodeMirror-line>span::-moz-selection,.CodeMirror-line>span>span::-moz-selection{background:#d7d4f0}.cm-searching{background-color:#ffa;background-color:rgba(255,255,0,0.4)}.cm-force-border{padding-right:.1px}@media print{.CodeMirror div.CodeMirror-cursors{visibility:hidden}}.cm-tab-wrap-hack:after{content:''}span.CodeMirror-selectedtext{background:none}.cm-s-hopscotch.CodeMirror{background:#322931;color:#d5d3d5}.cm-s-hopscotch div.CodeMirror-selected{background:#433b42 !important}.cm-s-hopscotch .CodeMirror-gutters{background:#322931;border-right:0px}.cm-s-hopscotch .CodeMirror-linenumber{color:#797379}.cm-s-hopscotch .CodeMirror-cursor{border-left:1px solid #989498 !important}.cm-s-hopscotch span.cm-comment{color:#b33508}.cm-s-hopscotch span.cm-atom{color:#c85e7c}.cm-s-hopscotch span.cm-number{color:#c85e7c}.cm-s-hopscotch span.cm-property,.cm-s-hopscotch span.cm-attribute{color:#8fc13e}.cm-s-hopscotch span.cm-keyword{color:#dd464c}.cm-s-hopscotch span.cm-string{color:#fdcc59}.cm-s-hopscotch span.cm-variable{color:#8fc13e}.cm-s-hopscotch span.cm-variable-2{color:#1290bf}.cm-s-hopscotch span.cm-def{color:#fd8b19}.cm-s-hopscotch span.cm-error{background:#dd464c;color:#989498}.cm-s-hopscotch span.cm-bracket{color:#d5d3d5}.cm-s-hopscotch span.cm-tag{color:#dd464c}.cm-s-hopscotch span.cm-link{color:#c85e7c}.cm-s-hopscotch .CodeMirror-matchingbracket{text-decoration:underline;color:white !important}.cm-s-hopscotch .CodeMirror-activeline-background{background:#302020}@font-face{font-family:'font3336';src:url("../fonts/main-fonts.eot?v=20");src:url("../fonts/main-fonts.woff?v=20") format("woff"),url("../fonts/main-fonts.ttf?v=20") format("truetype"),url("../fonts/main-fonts.svg?v=20") format("svg"),url("../fonts/main-fonts.eot?v=20") format("embedded-opentype");font-weight:normal;font-style:normal}.gjs-one-bg{background-color:#444}.gjs-one-color{color:#444}.gjs-one-color-h:hover{color:#444}.gjs-two-bg{background-color:#ddd}.gjs-two-color{color:#ddd}.gjs-two-color-h:hover{color:#ddd}.gjs-three-bg{background-color:#804f7b}.gjs-three-color{color:#804f7b}.gjs-three-color-h:hover{color:#804f7b}.gjs-four-bg{background-color:#d278c9}.gjs-four-color{color:#d278c9}.gjs-four-color-h:hover{color:#d278c9}.gjs-bg-main,.gjs-off-prv,.gjs-sm-sector .gjs-sm-colorp-c,.gjs-clm-tags .gjs-sm-colorp-c{background-color:#444}.gjs-color-main,.gjs-off-prv,.gjs-sm-sector .gjs-sm-stack #gjs-sm-add,.gjs-clm-tags .gjs-sm-stack #gjs-sm-add{color:#ddd;fill:#ddd}.gjs-color-active{color:#f8f8f8;fill:#f8f8f8}.gjs-color-warn{color:#ffca6f;fill:#ffca6f}.gjs-color-hl{color:#71b7f1;fill:#71b7f1}.gjs-fonts::before{display:block;font:normal normal normal 14px font3336;text-rendering:auto;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:5em}.gjs-f-b1::before{content:'Q'}.gjs-f-b2::before{content:'W'}.gjs-f-b3::before{content:'E'}.gjs-f-b37::before{content:'R'}.gjs-f-hero::before{content:'T'}.gjs-f-h1p::before{content:'y'}.gjs-f-3ba::before{content:'u'}.gjs-f-image::before{content:'I'}.gjs-f-text::before{content:'o'}.gjs-f-quo::before{content:'p'}.gjs-f-button::before{content:'B'}.gjs-f-divider::before{content:'D'}.gjs-invis-invis,.gjs-clm-tags #gjs-clm-new,.gjs-no-app{background-color:transparent;border:none;color:inherit}.gjs-no-app{height:10px}.gjs-test::btn{color:'#fff'}.opac50,.gjs-clm-tags #gjs-clm-close{opacity:.5;filter:alpha(opacity=50)}.gjs-checker-bg,.gjs-field-colorp-c,.checker-bg,.gjs-sm-sector .gjs-sm-property .gjs-sm-layer>#gjs-sm-preview-box,.gjs-clm-tags .gjs-sm-property .gjs-sm-layer>#gjs-sm-preview-box{background-image:url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAwAAAAMCAIAAADZF8uwAAAAGUlEQVQYV2M4gwH+YwCGIasIUwhT25BVBADtzYNYrHvv4gAAAABJRU5ErkJggg==")}.gjs-no-user-select,.gjs-grabbing,.gjs-grabbing *,.gjs-nav-comp-name,.gjs-rte-toolbar{-moz-user-select:none;-khtml-user-select:none;-webkit-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none}.gjs-no-pointer-events,.gjs-resizer-c,.gjs-margin-v-el,.gjs-padding-v-el,.gjs-fixedmargin-v-el,.gjs-fixedpadding-v-el{pointer-events:none}.gjs-bdrag{pointer-events:none !important;position:absolute !important;z-index:10 !important;width:auto}.gjs-drag-helper{background-color:#3b97e3 !important;pointer-events:none !important;position:absolute !important;z-index:10 !important;transform:scale(0.3) !important;transform-origin:top left !important;-webkit-transform-origin:top left !important;margin:15px !important;transition:none !important;outline:none !important}.gjs-grabbing,.gjs-grabbing *{cursor:grabbing !important;cursor:-webkit-grabbing !important}.gjs-grabbing{overflow:hidden}.gjs-off-prv{position:relative;z-index:10;padding:5px;cursor:pointer}.gjs-editor-cont ::-webkit-scrollbar-track{background:rgba(0,0,0,0.1)}.gjs-editor-cont ::-webkit-scrollbar-thumb{background-color:rgba(255,255,255,0.2)}.gjs-editor-cont ::-webkit-scrollbar{width:8px}.clear{clear:both}.no-select,.gjs-com-no-select,.gjs-com-no-select img,.gjs-category-title,.gjs-sm-sector .gjs-sm-title,.gjs-clm-tags .gjs-sm-title,.gjs-block-category .gjs-title,.gjs-nv-title,.gjs-clm-tags #gjs-clm-close{-moz-user-select:none;-khtml-user-select:none;-webkit-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none}.gjs-editor{font-family:Helvetica,sans-serif;font-size:.7rem;position:relative;box-sizing:border-box;height:100%}.gjs-freezed,.gjs-nv-freezed{opacity:.5;filter:alpha(opacity=50);pointer-events:none}.gjs-traits-label{border-bottom:1px solid rgba(0,0,0,0.2);font-size:13px;font-weight:lighter;margin-bottom:5px;padding:10px;text-align:left}.gjs-trt-trait{display:flex;justify-content:start;padding:5px 10px;font-weight:lighter}.gjs-trt-trait .gjs-label{width:30%;text-align:left}.gjs-trt-trait .gjs-field{width:70%}.gjs-cv-canvas{background-color:rgba(0,0,0,0.15);box-sizing:border-box;width:85%;height:calc(100% - $canvasTop);bottom:0;overflow:hidden;z-index:1;position:absolute;left:0;top:40px}.gjs-cv-canvas .gjs-ghost{display:none;pointer-events:none;background-color:#5b5b5b;border:2px dashed #ccc;position:absolute;z-index:10;opacity:.55;filter:alpha(opacity=55)}.gjs-cv-canvas .gjs-highlighter,.gjs-cv-canvas .gjs-highlighter-sel{position:absolute;outline:1px solid #3b97e3;outline-offset:-1px;pointer-events:none}.gjs-cv-canvas .gjs-highlighter-warning{outline:3px solid #ffca6f}.gjs-cv-canvas .gjs-highlighter-sel{outline:3px solid #3b97e3}.gjs-cv-canvas #gjs-tools{width:100%;position:absolute;top:0;left:0;outline:none}.gjs-cv-canvas>div:first-child{background-color:#fff;position:relative;height:100%;overflow:auto;width:100%}.gjs-cv-canvas *{box-sizing:border-box}.gjs-frame{outline:medium none;height:100%;width:100%;border:none;margin:auto;display:block;transition:width 0.35s ease,height 0.35s ease;position:absolute;top:0;bottom:0;left:0;right:0}.gjs-toolbar{position:absolute;background-color:#3b97e3;color:white;z-index:10}.gjs-toolbar-item{padding:5px 7px;font-size:0.8rem;cursor:pointer}.gjs-resizer-c{position:absolute;z-index:9}.gjs-margin-v-el,.gjs-padding-v-el,.gjs-fixedmargin-v-el,.gjs-fixedpadding-v-el{opacity:.1;filter:alpha(opacity=10);position:absolute;background-color:yellow}.gjs-fixedmargin-v-el,.gjs-fixedpadding-v-el{opacity:.2;filter:alpha(opacity=20)}.gjs-padding-v-el,.gjs-fixedpadding-v-el{background-color:navy}.gjs-resizer-h{pointer-events:all;position:absolute;border:3px solid #3b97e3;width:10px;height:10px;background-color:#fff;margin:-5px}.gjs-resizer-h-tl{top:0;left:0;cursor:nwse-resize}.gjs-resizer-h-tr{top:0;right:0;cursor:nesw-resize}.gjs-resizer-h-tc{top:0;margin:-5px auto;left:0;right:0;cursor:ns-resize}.gjs-resizer-h-cl{left:0;margin:auto -5px;top:0;bottom:0;cursor:ew-resize}.gjs-resizer-h-cr{margin:auto -5px;top:0;bottom:0;right:0;cursor:ew-resize}.gjs-resizer-h-bl{bottom:0;left:0;cursor:nesw-resize}.gjs-resizer-h-bc{bottom:0;margin:-5px auto;left:0;right:0;cursor:ns-resize}.gjs-resizer-h-br{bottom:0;right:0;cursor:nwse-resize}.gjs-pn-panel .gjs-resizer-h{background-color:rgba(0,0,0,0.2);border:none;opacity:0;transition:opacity 0.25s}.gjs-pn-panel .gjs-resizer-h:hover{opacity:1}.gjs-pn-panel .gjs-resizer-h-tc,.gjs-pn-panel .gjs-resizer-h-bc{margin:0 auto;width:100%}.gjs-pn-panel .gjs-resizer-h-cr,.gjs-pn-panel .gjs-resizer-h-cl{margin:auto 0;height:100%}.gjs-resizing .gjs-highlighter,.gjs-resizing .gjs-badge{display:none !important}.gjs-resizing-tl *{cursor:nwse-resize !important}.gjs-resizing-tr *{cursor:nesw-resize !important}.gjs-resizing-tc *{cursor:ns-resize !important}.gjs-resizing-cl *{cursor:ew-resize !important}.gjs-resizing-cr *{cursor:ew-resize !important}.gjs-resizing-bl *{cursor:nesw-resize !important}.gjs-resizing-bc *{cursor:ns-resize !important}.gjs-resizing-br *{cursor:nwse-resize !important}.btn-cl,.gjs-mdl-btn-close,.gjs-am-close{opacity:.3;filter:alpha(opacity=30);font-size:25px;cursor:pointer}.btn-cl:hover,.gjs-mdl-btn-close:hover,.gjs-am-close:hover{opacity:.7;filter:alpha(opacity=70)}.no-dots,.ui-resizable-handle{border:none !important;margin:0 !important;outline:none !important}.gjs-com-dashed *{outline:1px dashed #888;outline-offset:-2px;box-sizing:border-box}.gjs-cv-canvas .gjs-comp-selected{outline:3px solid #3b97e3 !important}*.gjs-com-hover,div.gjs-com-hover{outline:1px solid #3b97e3}*.gjs-com-hover-delete,div.gjs-com-hover-delete{outline:2px solid #dd3636;opacity:.5;filter:alpha(opacity=50)}*.gjs-com-hover-move,div.gjs-com-hover-move{outline:3px solid #ffca6f}.gjs-com-badge,.gjs-com-badge-red,.gjs-badge{pointer-events:none;background-color:#3b97e3;color:#fff;padding:2px 5px;position:absolute;z-index:1;font-size:12px;outline:none;display:none}.gjs-com-badge-red{background-color:#dd3636}.gjs-badge-warning{background-color:#ffca6f}.gjs-placeholder,.gjs-com-placeholder,.gjs-nv-placeholder{position:absolute;z-index:10;pointer-events:none;display:none}.gjs-placeholder,.gjs-nv-placeholder{border-style:solid !important;border-color:#62c462;outline:none;box-sizing:border-box;transition:top .2s,left .2s,width .2s,height .2s}.gjs-placeholder-int,.gjs-com-placeholder-int,.gjs-nv-placeholder-int{background-color:#62c462;box-shadow:0 0 3px rgba(0,0,0,0.2);height:100%;width:100%;pointer-events:none;padding:1.5px;outline:none}.gjs-pn-panel{display:inline-block;padding:5px;position:absolute;box-sizing:border-box;text-align:center;z-index:3}.gjs-pn-panel#gjs-pn-commands,.gjs-pn-panel#gjs-pn-options2{width:85%;left:0;top:0;box-shadow:0 0 5px rgba(0,0,0,0.2)}.gjs-pn-panel#gjs-pn-options{right:15%;top:0}.gjs-pn-panel#gjs-pn-options2{bottom:150px;height:auto}.gjs-pn-panel .icon-undo,.gjs-pn-panel .icon-redo{font-size:20px;height:30px;width:25px}.gjs-pn-panel#gjs-pn-views{border-bottom:2px solid rgba(0,0,0,0.2);right:0;width:15%;z-index:4}.gjs-pn-panel#gjs-pn-views-container{height:100%;padding:42px 0 0;right:0;width:15%;overflow:auto;box-shadow:0 0 5px rgba(0,0,0,0.2)}.gjs-pn-buttons{align-items:center;display:flex;justify-content:space-between}.gjs-pn-btn,.gjs-btnt{box-sizing:border-box;height:30px;width:30px;line-height:21px;background-color:transparent;border:none;font-size:18px;margin-right:5px;border-radius:2px;cursor:pointer;padding:5px;position:relative}.gjs-pn-btn.gjs-pn-active,.gjs-btnt.gjs-pn-active{background-color:rgba(0,0,0,0.15);box-shadow:0 0 3px rgba(0,0,0,0.25) inset}.gjs-pn-btn>.gjs-pn-arrow-rd,.gjs-btnt>.gjs-pn-arrow-rd{border-bottom:5px solid rgba(255,255,255,0.7);border-left:5px solid transparent;bottom:2px;right:2px;position:absolute}.gjs-pn-btn>.gjs-pn-buttons,.gjs-btnt>.gjs-pn-buttons{background-color:#444;border-radius:2px;position:absolute;display:none;left:50px;top:0;padding:5px}.gjs-pn-btn>.gjs-pn-buttons.gjs-pn-visible,.gjs-btnt>.gjs-pn-buttons.gjs-pn-visible{display:block}.gjs-pn-btn>.gjs-pn-buttons>.gjs-pn-arrow-l,.gjs-btnt>.gjs-pn-buttons>.gjs-pn-arrow-l{border-bottom:5px solid transparent;border-right:5px solid #444;border-top:5px solid transparent;left:-5px;top:15px;position:absolute}.btn.expand,.gjs-layers .gjs-nv-item .expand#gjs-nv-btn-eye{background-image:none}.gjs-comp-image-placeholder{display:block;background-color:#f5f5f5;color:#777;height:50px;width:50px;line-height:50px;outline:3px solid #ffca6f;outline-offset:-3px;text-align:center;font-size:16.66667px;cursor:pointer}.gjs-comp-image-placeholder.fa-picture-o::after{content:"\f03e"}.gjs-label{line-height:18px}.gjs-fields{display:flex}.gjs-select{padding:0;width:100%}.gjs-select select{padding-right:10px}.gjs-select:-moz-focusring,.gjs-select select:-moz-focusring{color:transparent;text-shadow:0 0 0 rgba(255,255,255,0.7)}.gjs-input:focus,.gjs-button:focus,.gjs-btn-prim:focus,.gjs-select:focus,.gjs-select select:focus{outline:none}.gjs-field input,.gjs-field select,.gjs-field textarea{-webkit-appearance:none;-moz-appearance:none;appearance:none;color:inherit;border:none;background-color:transparent;box-sizing:border-box;width:100%;position:relative;padding:5px;z-index:1}.gjs-field input:focus,.gjs-field select:focus,.gjs-field textarea:focus{outline:none}.gjs-field-range{flex:9 1 auto}.gjs-field-integer input{padding-right:30px}.gjs-select option,.gjs-clm-select option,.gjs-sm-select option,.gjs-fields option,.gjs-sm-unit option{background-color:#444;color:#ddd}.gjs-field{background-color:rgba(0,0,0,0.2);border:none;box-shadow:none;border-radius:2px;box-sizing:border-box;padding:0;position:relative}.gjs-field textarea{resize:vertical}.gjs-field .gjs-sel-arrow{height:100%;width:9px;position:absolute;right:0;top:0;z-index:0}.gjs-field .gjs-d-s-arrow{bottom:0;top:0;margin:auto;right:5px;border-top:4px solid rgba(255,255,255,0.7);position:absolute;height:0;width:0;border-left:3px solid transparent;border-right:4px solid transparent;cursor:pointer}.gjs-field-arrows{position:absolute;cursor:ns-resize;margin:auto;height:20px;width:9px;z-index:10;bottom:0;right:3px;top:0}.gjs-field-color,.gjs-field-radio{width:100%}.gjs-field-color input{padding-right:22px;box-sizing:border-box}.gjs-field-colorp{border-left:1px solid rgba(0,0,0,0.2);box-sizing:border-box;height:100%;padding:2px;position:absolute;right:0;top:0;width:22px;z-index:10}.gjs-field-colorp .gjs-checker-bg,.gjs-field-colorp .gjs-field-colorp-c{height:100%;width:100%;border-radius:1px}.gjs-field-colorp-c{height:100%;position:relative;width:100%}.gjs-field-color-picker{background-color:#ddd;cursor:pointer;height:100%;width:100%;box-shadow:0 0 1px rgba(0,0,0,0.2);border-radius:1px;position:absolute;top:0}.gjs-field-checkbox{padding:0;width:auto !important}.gjs-field-checkbox input{display:none}.gjs-field-checkbox input:checked+.gjs-chk-icon{border-color:rgba(255,255,255,0.5);border-width:0 2px 2px 0;border-style:solid}.gjs-radio-item{flex:1 1 auto;text-align:center;border-left:1px solid rgba(0,0,0,0.2)}.gjs-radio-item:first-child{border:none}.gjs-radio-item:hover{background:rgba(0,0,0,0.2)}.gjs-radio-item input{display:none}.gjs-radio-item input:checked+.gjs-radio-item-label{background-color:rgba(255,255,255,0.2)}.gjs-radio-items{display:flex}.gjs-radio-item-label{cursor:pointer;display:block;padding:5px}.gjs-field-units{position:absolute;margin:auto;right:10px;bottom:0;top:0}.gjs-field-unit{position:absolute;right:10px;top:3px;font-size:10px;color:rgba(255,255,255,0.7);cursor:pointer}.gjs-field-arrow-u,.gjs-field-arrow-d{position:absolute;height:0;width:0;border-left:3px solid transparent;border-right:4px solid transparent;border-top:4px solid rgba(255,255,255,0.7);bottom:4px;cursor:pointer}.gjs-field-arrow-u{border-bottom:4px solid rgba(255,255,255,0.7);border-top:none;top:4px}.gjs-field-select{padding:0}.gjs-field-range{background-color:transparent;border:none;box-shadow:none;padding:0}.gjs-field-range input{margin:0;height:100%}.gjs-field-range input:focus{outline:none}.gjs-field-range input::-webkit-slider-thumb{-webkit-appearance:none;margin-top:-4px;height:10px;width:10px;border:1px solid rgba(0,0,0,0.2);border-radius:100%;background-color:#ddd;cursor:pointer}.gjs-field-range input::-moz-range-thumb{height:10px;width:10px;border:1px solid rgba(0,0,0,0.2);border-radius:100%;background-color:#ddd;cursor:pointer}.gjs-field-range input::-ms-thumb{height:10px;width:10px;border:1px solid rgba(0,0,0,0.2);border-radius:100%;background-color:#ddd;cursor:pointer}.gjs-field-range input::-moz-range-track{background-color:rgba(0,0,0,0.2);border-radius:1px;margin-top:3px;height:3px}.gjs-field-range input::-webkit-slider-runnable-track{background-color:rgba(0,0,0,0.2);border-radius:1px;margin-top:3px;height:3px}.gjs-field-range input::-ms-track{background-color:rgba(0,0,0,0.2);border-radius:1px;margin-top:3px;height:3px}.gjs-btn-prim{color:inherit;background-color:rgba(255,255,255,0.1);border-radius:2px;padding:3px 6px;padding:5px;cursor:pointer;border:none}.gjs-btn-prim:active{background-color:rgba(255,255,255,0.1)}.gjs-chk-icon{-ms-transform:rotate(45deg);-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);transform:rotate(45deg);box-sizing:border-box;display:block;height:14px;margin:0 5px;width:6px;cursor:pointer}.gjs-add-trasp{background:none;border:none;color:#ddd;cursor:pointer;font-size:1em;border-radius:2px;opacity:.75;filter:alpha(opacity=75)}.gjs-add-trasp:hover{opacity:1;filter:alpha(opacity=100)}.gjs-add-trasp:active{background-color:rgba(0,0,0,0.2)}.gjs-devices-c{display:flex;align-items:center;padding:3px}.gjs-devices-c .gjs-device-label{flex-grow:2;text-align:left;margin-right:10px}.gjs-devices-c .gjs-select{flex-grow:20}.gjs-devices-c .gjs-add-trasp{flex-grow:1;margin-left:5px}.gjs-category-open,.gjs-sm-sector.gjs-sm-open,.gjs-sm-open.gjs-clm-tags,.gjs-block-category.gjs-open{border-bottom:1px solid rgba(0,0,0,0.25)}.gjs-category-title,.gjs-sm-sector .gjs-sm-title,.gjs-clm-tags .gjs-sm-title,.gjs-block-category .gjs-title,.gjs-nv-title{font-weight:lighter;background-color:rgba(0,0,0,0.1);font-size:13px;letter-spacing:1px;padding:9px 10px 9px 20px;border-bottom:1px solid rgba(0,0,0,0.25);text-align:left;position:relative;cursor:pointer}.gjs-sm-clear{font-size:1rem;line-height:0;cursor:pointer}.gjs-sm-header{font-size:11px;font-weight:lighter;padding:10px}.gjs-sm-properties{font-size:11px;padding:10px 5px;display:flex;flex-wrap:wrap;align-items:flex-end;box-sizing:border-box;width:100%}.gjs-sm-label{margin:5px 5px 3px 0}.gjs-sm-close-btn,.gjs-sm-sector .gjs-sm-property.gjs-sm-file #gjs-sm-preview-box #gjs-sm-close,.gjs-clm-tags .gjs-sm-property.gjs-sm-file #gjs-sm-preview-box #gjs-sm-close{display:block;font-size:23px;position:absolute;cursor:pointer;right:5px;top:0;opacity:.2;filter:alpha(opacity=20)}.gjs-sm-close-btn:hover,.gjs-sm-sector .gjs-sm-property.gjs-sm-file #gjs-sm-preview-box #gjs-sm-close:hover,.gjs-clm-tags .gjs-sm-property.gjs-sm-file #gjs-sm-preview-box #gjs-sm-close:hover{opacity:.7;filter:alpha(opacity=70)}.gjs-sm-sector,.gjs-clm-tags{clear:both;font-weight:lighter;text-align:left}.gjs-sm-sector #gjs-sm-caret,.gjs-clm-tags #gjs-sm-caret{padding-right:5px;font-size:11px}.gjs-sm-sector .gjs-sm-field,.gjs-clm-tags .gjs-sm-field,.gjs-sm-sector .gjs-clm-field,.gjs-clm-tags .gjs-clm-field{width:100%;position:relative}.gjs-sm-sector .gjs-sm-field input,.gjs-clm-tags .gjs-sm-field input,.gjs-sm-sector .gjs-clm-field input,.gjs-clm-tags .gjs-clm-field input,.gjs-sm-sector .gjs-sm-field select,.gjs-clm-tags .gjs-sm-field select,.gjs-sm-sector .gjs-clm-field select,.gjs-clm-tags .gjs-clm-field select{background-color:transparent;color:rgba(255,255,255,0.7);border:none;width:100%}.gjs-sm-sector .gjs-sm-field input,.gjs-clm-tags .gjs-sm-field input,.gjs-sm-sector .gjs-clm-field input,.gjs-clm-tags .gjs-clm-field input{box-sizing:border-box}.gjs-sm-sector .gjs-sm-field select,.gjs-clm-tags .gjs-sm-field select,.gjs-sm-sector .gjs-clm-field select,.gjs-clm-tags .gjs-clm-field select{position:relative;z-index:1;-webkit-appearance:none;-moz-appearance:none;appearance:none}.gjs-sm-sector .gjs-sm-field select::-ms-expand,.gjs-clm-tags .gjs-sm-field select::-ms-expand,.gjs-sm-sector .gjs-clm-field select::-ms-expand,.gjs-clm-tags .gjs-clm-field select::-ms-expand{display:none}.gjs-sm-sector .gjs-sm-field select:-moz-focusring,.gjs-clm-tags .gjs-sm-field select:-moz-focusring,.gjs-sm-sector .gjs-clm-field select:-moz-focusring,.gjs-clm-tags .gjs-clm-field select:-moz-focusring{color:transparent;text-shadow:0 0 0 rgba(255,255,255,0.7)}.gjs-sm-sector .gjs-sm-field input:focus,.gjs-clm-tags .gjs-sm-field input:focus,.gjs-sm-sector .gjs-clm-field input:focus,.gjs-clm-tags .gjs-clm-field input:focus,.gjs-sm-sector .gjs-sm-field select:focus,.gjs-clm-tags .gjs-sm-field select:focus,.gjs-sm-sector .gjs-clm-field select:focus,.gjs-clm-tags .gjs-clm-field select:focus{outline:none}.gjs-sm-sector .gjs-sm-field .gjs-sm-unit,.gjs-clm-tags .gjs-sm-field .gjs-sm-unit,.gjs-sm-sector .gjs-clm-field .gjs-sm-unit,.gjs-clm-tags .gjs-clm-field .gjs-sm-unit{position:absolute;right:10px;top:3px;font-size:10px;color:rgba(255,255,255,0.7);cursor:pointer}.gjs-sm-sector .gjs-sm-field .gjs-clm-sel-arrow,.gjs-clm-tags .gjs-sm-field .gjs-clm-sel-arrow,.gjs-sm-sector .gjs-clm-field .gjs-clm-sel-arrow,.gjs-clm-tags .gjs-clm-field .gjs-clm-sel-arrow,.gjs-sm-sector .gjs-sm-field .gjs-sm-int-arrows,.gjs-clm-tags .gjs-sm-field .gjs-sm-int-arrows,.gjs-sm-sector .gjs-clm-field .gjs-sm-int-arrows,.gjs-clm-tags .gjs-clm-field .gjs-sm-int-arrows,.gjs-sm-sector .gjs-sm-field .gjs-sm-sel-arrow,.gjs-clm-tags .gjs-sm-field .gjs-sm-sel-arrow,.gjs-sm-sector .gjs-clm-field .gjs-sm-sel-arrow,.gjs-clm-tags .gjs-clm-field .gjs-sm-sel-arrow{height:100%;width:9px;position:absolute;right:0;top:0;cursor:ns-resize}.gjs-sm-sector .gjs-sm-field .gjs-sm-sel-arrow,.gjs-clm-tags .gjs-sm-field .gjs-sm-sel-arrow,.gjs-sm-sector .gjs-clm-field .gjs-sm-sel-arrow,.gjs-clm-tags .gjs-clm-field .gjs-sm-sel-arrow{cursor:pointer}.gjs-sm-sector .gjs-sm-field .gjs-clm-d-s-arrow,.gjs-clm-tags .gjs-sm-field .gjs-clm-d-s-arrow,.gjs-sm-sector .gjs-clm-field .gjs-clm-d-s-arrow,.gjs-clm-tags .gjs-clm-field .gjs-clm-d-s-arrow,.gjs-sm-sector .gjs-sm-field .gjs-sm-d-arrow,.gjs-clm-tags .gjs-sm-field .gjs-sm-d-arrow,.gjs-sm-sector .gjs-clm-field .gjs-sm-d-arrow,.gjs-clm-tags .gjs-clm-field .gjs-sm-d-arrow,.gjs-sm-sector .gjs-sm-field .gjs-sm-d-s-arrow,.gjs-clm-tags .gjs-sm-field .gjs-sm-d-s-arrow,.gjs-sm-sector .gjs-clm-field .gjs-sm-d-s-arrow,.gjs-clm-tags .gjs-clm-field .gjs-sm-d-s-arrow,.gjs-sm-sector .gjs-sm-field .gjs-sm-u-arrow,.gjs-clm-tags .gjs-sm-field .gjs-sm-u-arrow,.gjs-sm-sector .gjs-clm-field .gjs-sm-u-arrow,.gjs-clm-tags .gjs-clm-field .gjs-sm-u-arrow{position:absolute;height:0;width:0;border-left:3px solid transparent;border-right:4px solid transparent;cursor:pointer}.gjs-sm-sector .gjs-sm-field .gjs-sm-u-arrow,.gjs-clm-tags .gjs-sm-field .gjs-sm-u-arrow,.gjs-sm-sector .gjs-clm-field .gjs-sm-u-arrow,.gjs-clm-tags .gjs-clm-field .gjs-sm-u-arrow{border-bottom:4px solid rgba(255,255,255,0.7);top:4px}.gjs-sm-sector .gjs-sm-field .gjs-clm-d-s-arrow,.gjs-clm-tags .gjs-sm-field .gjs-clm-d-s-arrow,.gjs-sm-sector .gjs-clm-field .gjs-clm-d-s-arrow,.gjs-clm-tags .gjs-clm-field .gjs-clm-d-s-arrow,.gjs-sm-sector .gjs-sm-field .gjs-sm-d-arrow,.gjs-clm-tags .gjs-sm-field .gjs-sm-d-arrow,.gjs-sm-sector .gjs-clm-field .gjs-sm-d-arrow,.gjs-clm-tags .gjs-clm-field .gjs-sm-d-arrow,.gjs-sm-sector .gjs-sm-field .gjs-sm-d-s-arrow,.gjs-clm-tags .gjs-sm-field .gjs-sm-d-s-arrow,.gjs-sm-sector .gjs-clm-field .gjs-sm-d-s-arrow,.gjs-clm-tags .gjs-clm-field .gjs-sm-d-s-arrow{border-top:4px solid rgba(255,255,255,0.7);bottom:4px}.gjs-sm-sector .gjs-sm-field .gjs-clm-d-s-arrow,.gjs-clm-tags .gjs-sm-field .gjs-clm-d-s-arrow,.gjs-sm-sector .gjs-clm-field .gjs-clm-d-s-arrow,.gjs-clm-tags .gjs-clm-field .gjs-clm-d-s-arrow,.gjs-sm-sector .gjs-sm-field .gjs-sm-d-s-arrow,.gjs-clm-tags .gjs-sm-field .gjs-sm-d-s-arrow,.gjs-sm-sector .gjs-clm-field .gjs-sm-d-s-arrow,.gjs-clm-tags .gjs-clm-field .gjs-sm-d-s-arrow{bottom:7px}.gjs-sm-sector .gjs-sm-field.gjs-sm-color,.gjs-clm-tags .gjs-sm-field.gjs-sm-color,.gjs-sm-sector .gjs-sm-color.gjs-clm-field,.gjs-clm-tags .gjs-sm-color.gjs-clm-field,.gjs-sm-sector .gjs-sm-field.gjs-sm-input,.gjs-clm-tags .gjs-sm-field.gjs-sm-input,.gjs-sm-sector .gjs-sm-input.gjs-clm-field,.gjs-clm-tags .gjs-sm-input.gjs-clm-field,.gjs-sm-sector .gjs-sm-field.gjs-sm-integer,.gjs-clm-tags .gjs-sm-field.gjs-sm-integer,.gjs-sm-sector .gjs-sm-integer.gjs-clm-field,.gjs-clm-tags .gjs-sm-integer.gjs-clm-field,.gjs-sm-sector .gjs-sm-field.gjs-sm-list,.gjs-clm-tags .gjs-sm-field.gjs-sm-list,.gjs-sm-sector .gjs-sm-list.gjs-clm-field,.gjs-clm-tags .gjs-sm-list.gjs-clm-field,.gjs-sm-sector .gjs-sm-field.gjs-sm-select,.gjs-clm-tags .gjs-sm-field.gjs-sm-select,.gjs-sm-sector .gjs-sm-select.gjs-clm-field,.gjs-clm-tags .gjs-sm-select.gjs-clm-field,.gjs-sm-sector .gjs-clm-select,.gjs-clm-tags .gjs-clm-select{background-color:rgba(0,0,0,0.2);border:1px solid rgba(0,0,0,0.1);box-shadow:1px 1px 0 rgba(255,255,255,0.1);color:rgba(255,255,255,0.7);border-radius:2px;box-sizing:border-box;padding:0 5px}.gjs-sm-sector .gjs-sm-field.gjs-sm-composite,.gjs-clm-tags .gjs-sm-field.gjs-sm-composite,.gjs-sm-sector .gjs-sm-composite.gjs-clm-field,.gjs-clm-tags .gjs-sm-composite.gjs-clm-field{border-radius:2px}.gjs-sm-sector .gjs-sm-field.gjs-sm-select,.gjs-clm-tags .gjs-sm-field.gjs-sm-select,.gjs-sm-sector .gjs-sm-select.gjs-clm-field,.gjs-clm-tags .gjs-sm-select.gjs-clm-field,.gjs-sm-sector .gjs-clm-select,.gjs-clm-tags .gjs-clm-select{padding:0}.gjs-sm-sector .gjs-sm-field.gjs-sm-select select,.gjs-clm-tags .gjs-sm-field.gjs-sm-select select,.gjs-sm-sector .gjs-sm-select.gjs-clm-field select,.gjs-clm-tags .gjs-sm-select.gjs-clm-field select,.gjs-sm-sector .gjs-clm-select select,.gjs-clm-tags .gjs-clm-select select{height:20px}.gjs-sm-sector .gjs-sm-field.gjs-sm-select option,.gjs-clm-tags .gjs-sm-field.gjs-sm-select option,.gjs-sm-sector .gjs-sm-select.gjs-clm-field option,.gjs-clm-tags .gjs-sm-select.gjs-clm-field option,.gjs-sm-sector .gjs-clm-select option,.gjs-clm-tags .gjs-clm-select option{padding:3px 0}.gjs-sm-sector .gjs-sm-field.gjs-sm-composite,.gjs-clm-tags .gjs-sm-field.gjs-sm-composite,.gjs-sm-sector .gjs-sm-composite.gjs-clm-field,.gjs-clm-tags .gjs-sm-composite.gjs-clm-field{background-color:rgba(0,0,0,0.1);border:1px solid rgba(0,0,0,0.25)}.gjs-sm-sector .gjs-sm-field.gjs-sm-list,.gjs-clm-tags .gjs-sm-field.gjs-sm-list,.gjs-sm-sector .gjs-sm-list.gjs-clm-field,.gjs-clm-tags .gjs-sm-list.gjs-clm-field{width:auto;padding:0;overflow:hidden;float:left}.gjs-sm-sector .gjs-sm-field.gjs-sm-list input,.gjs-clm-tags .gjs-sm-field.gjs-sm-list input,.gjs-sm-sector .gjs-sm-list.gjs-clm-field input,.gjs-clm-tags .gjs-sm-list.gjs-clm-field input{display:none}.gjs-sm-sector .gjs-sm-field.gjs-sm-list label,.gjs-clm-tags .gjs-sm-field.gjs-sm-list label,.gjs-sm-sector .gjs-sm-list.gjs-clm-field label,.gjs-clm-tags .gjs-sm-list.gjs-clm-field label{cursor:pointer;padding:5px;display:block}.gjs-sm-sector .gjs-sm-field.gjs-sm-list .gjs-sm-radio:checked+label,.gjs-clm-tags .gjs-sm-field.gjs-sm-list .gjs-sm-radio:checked+label,.gjs-sm-sector .gjs-sm-list.gjs-clm-field .gjs-sm-radio:checked+label,.gjs-clm-tags .gjs-sm-list.gjs-clm-field .gjs-sm-radio:checked+label{background-color:rgba(255,255,255,0.2)}.gjs-sm-sector .gjs-sm-field.gjs-sm-list .gjs-sm-icon,.gjs-clm-tags .gjs-sm-field.gjs-sm-list .gjs-sm-icon,.gjs-sm-sector .gjs-sm-list.gjs-clm-field .gjs-sm-icon,.gjs-clm-tags .gjs-sm-list.gjs-clm-field .gjs-sm-icon{background-repeat:no-repeat;background-position:center;text-shadow:none;line-height:normal}.gjs-sm-sector .gjs-sm-field.gjs-sm-integer select,.gjs-clm-tags .gjs-sm-field.gjs-sm-integer select,.gjs-sm-sector .gjs-sm-integer.gjs-clm-field select,.gjs-clm-tags .gjs-sm-integer.gjs-clm-field select{width:auto;padding:0}.gjs-sm-sector .gjs-sm-list .gjs-sm-el,.gjs-clm-tags .gjs-sm-list .gjs-sm-el{float:left;border-left:1px solid rgba(0,0,0,0.2)}.gjs-sm-sector .gjs-sm-list .gjs-sm-el:first-child,.gjs-clm-tags .gjs-sm-list .gjs-sm-el:first-child{border:none}.gjs-sm-sector .gjs-sm-list .gjs-sm-el:hover,.gjs-clm-tags .gjs-sm-list .gjs-sm-el:hover{background:rgba(0,0,0,0.2)}.gjs-sm-sector .gjs-sm-slider .gjs-field-integer,.gjs-clm-tags .gjs-sm-slider .gjs-field-integer{flex:1 1 65px}.gjs-sm-sector .gjs-sm-property,.gjs-clm-tags .gjs-sm-property{box-sizing:border-box;float:left;width:50%;margin-bottom:5px;padding:0 5px}.gjs-sm-sector .gjs-sm-property.gjs-sm-composite,.gjs-clm-tags .gjs-sm-property.gjs-sm-composite,.gjs-sm-sector .gjs-sm-property.gjs-sm-file,.gjs-clm-tags .gjs-sm-property.gjs-sm-file,.gjs-sm-sector .gjs-sm-property.gjs-sm-list,.gjs-clm-tags .gjs-sm-property.gjs-sm-list,.gjs-sm-sector .gjs-sm-property.gjs-sm-radio,.gjs-clm-tags .gjs-sm-property.gjs-sm-radio,.gjs-sm-sector .gjs-sm-property.gjs-sm-stack,.gjs-clm-tags .gjs-sm-property.gjs-sm-stack,.gjs-sm-sector .gjs-sm-property.gjs-sm-slider,.gjs-clm-tags .gjs-sm-property.gjs-sm-slider,.gjs-sm-sector .gjs-sm-property.gjs-sm-color,.gjs-clm-tags .gjs-sm-property.gjs-sm-color{width:100%}.gjs-sm-sector .gjs-sm-property .gjs-sm-btn,.gjs-clm-tags .gjs-sm-property .gjs-sm-btn{background-color:rgba(33,33,33,0.2);border-radius:2px;box-shadow:1px 1px 0 rgba(5,5,5,0.2),1px 1px 0 rgba(43,43,43,0.2) inset;padding:5px;position:relative;text-align:center;height:auto;width:100%;cursor:pointer;color:#ddd;box-sizing:border-box;text-shadow:-1px -1px 0 rgba(0,0,0,0.2);border:none;opacity:.85;filter:alpha(opacity=85)}.gjs-sm-sector .gjs-sm-property .gjs-sm-btn-c,.gjs-clm-tags .gjs-sm-property .gjs-sm-btn-c{box-sizing:border-box;float:left;width:100%}.gjs-sm-sector .gjs-sm-property.gjs-sm-file #gjs-sm-preview-box,.gjs-clm-tags .gjs-sm-property.gjs-sm-file #gjs-sm-preview-box{background-color:rgba(255,255,255,0.05);border-radius:2px;margin-top:5px;position:relative;overflow:hidden}.gjs-sm-sector .gjs-sm-property.gjs-sm-file #gjs-sm-preview-box.gjs-sm-show,.gjs-clm-tags .gjs-sm-property.gjs-sm-file #gjs-sm-preview-box.gjs-sm-show{border:1px solid rgba(252,252,252,0.05);padding:3px 20px}.gjs-sm-sector .gjs-sm-property.gjs-sm-file #gjs-sm-preview-box #gjs-sm-close,.gjs-clm-tags .gjs-sm-property.gjs-sm-file #gjs-sm-preview-box #gjs-sm-close{top:-5px;display:block}.gjs-sm-sector .gjs-sm-property.gjs-sm-file .gjs-sm-show #gjs-sm-preview-file,.gjs-clm-tags .gjs-sm-property.gjs-sm-file .gjs-sm-show #gjs-sm-preview-file{height:50px}.gjs-sm-sector .gjs-sm-property.gjs-sm-file #gjs-sm-preview-file,.gjs-clm-tags .gjs-sm-property.gjs-sm-file #gjs-sm-preview-file{background-size:auto 100%;background-repeat:no-repeat;background-position:center center}.gjs-sm-sector .gjs-sm-property .gjs-sm-layers,.gjs-clm-tags .gjs-sm-property .gjs-sm-layers{margin-top:5px;padding:1px 3px;min-height:30px}.gjs-sm-sector .gjs-sm-property .gjs-sm-layer,.gjs-clm-tags .gjs-sm-property .gjs-sm-layer{background-color:rgba(255,255,255,0.055);border-radius:2px;margin:2px 0;padding:7px;position:relative;cursor:pointer}.gjs-sm-sector .gjs-sm-property .gjs-sm-layer>#gjs-sm-preview-box,.gjs-clm-tags .gjs-sm-property .gjs-sm-layer>#gjs-sm-preview-box{height:15px;position:absolute;right:27px;top:6px;width:15px}.gjs-sm-sector .gjs-sm-property .gjs-sm-layer #gjs-sm-preview,.gjs-clm-tags .gjs-sm-property .gjs-sm-layer #gjs-sm-preview,.gjs-sm-sector .gjs-sm-property .gjs-sm-layer #gjs-sm-preview-box,.gjs-clm-tags .gjs-sm-property .gjs-sm-layer #gjs-sm-preview-box{border-radius:2px}.gjs-sm-sector .gjs-sm-property .gjs-sm-layer #gjs-sm-close-layer,.gjs-clm-tags .gjs-sm-property .gjs-sm-layer #gjs-sm-close-layer{display:block;font-size:23px;position:absolute;cursor:pointer;right:5px;top:0;opacity:.5;filter:alpha(opacity=50)}.gjs-sm-sector .gjs-sm-property .gjs-sm-layer #gjs-sm-close-layer:hover,.gjs-clm-tags .gjs-sm-property .gjs-sm-layer #gjs-sm-close-layer:hover{opacity:.8;filter:alpha(opacity=80)}.gjs-sm-sector .gjs-sm-property .gjs-sm-layer>#gjs-sm-preview-box #gjs-sm-preview,.gjs-clm-tags .gjs-sm-property .gjs-sm-layer>#gjs-sm-preview-box #gjs-sm-preview{background-color:white;height:100%;width:100%;background-size:cover !important}.gjs-sm-sector .gjs-sm-property .gjs-sm-layer.gjs-sm-active,.gjs-clm-tags .gjs-sm-property .gjs-sm-layer.gjs-sm-active{background-color:rgba(255,255,255,0.12)}.gjs-sm-sector .gjs-sm-property .gjs-sm-layer.gjs-sm-no-preview #gjs-sm-preview-box,.gjs-clm-tags .gjs-sm-property .gjs-sm-layer.gjs-sm-no-preview #gjs-sm-preview-box{display:none}.gjs-sm-sector #gjs-sm-text-shadow #gjs-sm-preview::after,.gjs-clm-tags #gjs-sm-text-shadow #gjs-sm-preview::after{color:#000;content:"T";font-weight:900;line-height:17px;padding:0 4px}.gjs-sm-sector .gjs-sm-stack .gjs-sm-properties,.gjs-clm-tags .gjs-sm-stack .gjs-sm-properties{padding:5px 0 0}.gjs-sm-sector .gjs-sm-stack #gjs-sm-add,.gjs-clm-tags .gjs-sm-stack #gjs-sm-add{background:none;border:none;cursor:pointer;outline:none;font-size:22px;line-height:10px;position:absolute;right:0;top:-17px;opacity:0.75}.gjs-sm-sector .gjs-sm-stack #gjs-sm-add:hover,.gjs-clm-tags .gjs-sm-stack #gjs-sm-add:hover{opacity:1;filter:alpha(opacity=100)}.gjs-sm-sector .gjs-sm-colorp-c,.gjs-clm-tags .gjs-sm-colorp-c{height:100%;width:20px;position:absolute;right:0;top:0;box-sizing:border-box;border-radius:2px;padding:2px}.gjs-sm-sector .gjs-sm-colorp-c .gjs-checker-bg,.gjs-clm-tags .gjs-sm-colorp-c .gjs-checker-bg,.gjs-sm-sector .gjs-sm-colorp-c .gjs-field-colorp-c,.gjs-clm-tags .gjs-sm-colorp-c .gjs-field-colorp-c{height:100%;width:100%;border-radius:1px}.gjs-sm-sector .gjs-sm-color-picker,.gjs-clm-tags .gjs-sm-color-picker{background-color:#ddd;cursor:pointer;height:16px;width:100%;margin-top:-16px;box-shadow:0 0 1px rgba(0,0,0,0.2);border-radius:1px}.gjs-sm-sector .gjs-sm-btn-upload #gjs-sm-upload,.gjs-clm-tags .gjs-sm-btn-upload #gjs-sm-upload{left:0;top:0;position:absolute;width:100%;opacity:0;cursor:pointer}.gjs-sm-sector .gjs-sm-btn-upload #gjs-sm-label,.gjs-clm-tags .gjs-sm-btn-upload #gjs-sm-label{padding:2px 0}.gjs-sm-layer>#gjs-sm-move{opacity:.7;filter:alpha(opacity=70);cursor:move;font-size:12px;float:left;margin:0 5px 0 0}.gjs-sm-layer>#gjs-sm-move:hover{opacity:.9;filter:alpha(opacity=90)}.gjs-blocks-c{display:flex;flex-wrap:wrap;justify-content:flex-start}.gjs-block-category{width:100%}.gjs-block-category .gjs-caret-icon{margin-right:5px}.gjs-block{-moz-user-select:none;-khtml-user-select:none;-webkit-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none;width:45%;padding:1em;box-sizing:border-box;height:90px;cursor:all-scroll;font-size:11px;font-weight:lighter;display:flex;flex-direction:column;justify-content:flex-end;border:1px solid rgba(0,0,0,0.2);border-radius:3px;margin:10px 2.5% 5px;box-shadow:0 1px 0 0 rgba(0,0,0,0.15);transition:all 0.2s ease 0s;transition-property:box-shadow, color}.gjs-block:hover{box-shadow:0 3px 4px 0 rgba(0,0,0,0.15)}.gjs-block-svg{width:61%;fill:currentColor}.gjs-block-svg-path{fill:currentColor}.gjs-block.fa{font-size:2em;line-height:2em;padding:11px}.gjs-block-label{line-height:normal;font-size:0.65rem;font-weight:normal;font-family:Helvetica, sans-serif}.gjs-block.gjs-bdrag{width:auto;padding:0}.gjs-nv-selected-parent{border:1px solid #ffca6f}.gjs-nv-opac50{opacity:.5;filter:alpha(opacity=50)}.gjs-layers{position:relative;height:100%}.gjs-layers #gjs-nv-placeholder{width:100%;position:absolute}.gjs-layers #gjs-nv-placeholder #gjs-nv-plh-int{height:100%;padding:1px}.gjs-layers #gjs-nv-placeholder #gjs-nv-plh-int.gjs-nv-insert{background-color:#62c462}.gjs-layers .gjs-nv-item{font-weight:lighter;text-align:left;position:relative;background-color:rgba(0,0,0,0.1)}.gjs-layers .gjs-nv-item.gjs-nv-hide{opacity:.55;filter:alpha(opacity=55)}.gjs-layers .gjs-nv-item #gjs-nv-counter{font-size:10px;position:absolute;right:27px;top:9px}.gjs-layers .gjs-nv-item #gjs-nv-btn-eye{height:auto !important;width:auto !important;font-size:13px;left:0;top:0;padding:7px 5px 7px 10px;position:absolute;cursor:pointer;z-index:1}.gjs-nv-item #gjs-nv-caret{font-size:7px;width:8px;padding:2px;cursor:pointer;position:absolute;left:-9px;top:6px;opacity:.7;filter:alpha(opacity=70)}.gjs-nv-item #gjs-nv-caret:hover{opacity:1;filter:alpha(opacity=100)}.gjs-nv-title{padding:3px 10px 5px 30px;display:flex;align-items:center}.gjs-nv-title-inn{position:relative}.gjs-nv-item .gjs-nv-children .gjs-nv-title{border-left:1px solid rgba(5,5,5,0.2)}.gjs-nv-item>.gjs-nv-children{display:none}.gjs-nv-item.open>.gjs-nv-children{display:block}.gjs-nv-item>.gjs-nv-no-chld>#gjs-nv-caret::before{content:''}.gjs-nv-no-chld>.gjs-nv-title-inn>#gjs-nv-caret{display:none}.gjs-nv-item>#gjs-nv-move{position:absolute;cursor:move;font-size:12px;right:0;top:0;padding:7px 10px 7px 5px}.gjs-nv-selected .gjs-nv-title{background-color:rgba(255,255,255,0.1)}.gjs-nv-nav-item-edit{visibility:hidden;padding:5px;font-size:9px;position:absolute;left:-27px;top:1px;opacity:.7;filter:alpha(opacity=70)}.gjs-nv-nav-item-edit:hover{opacity:1;filter:alpha(opacity=100)}.gjs-nv-title-c:hover .gjs-nv-nav-item-edit{visibility:visible;cursor:pointer}.gjs-nav-comp-name{padding:5px;box-sizing:content-box}.gjs-clm-tags{font-size:11px;padding:10px 5px}.gjs-clm-tags #gjs-clm-label,.gjs-clm-tags #gjs-clm-sel{padding:7px 0;float:left}.gjs-clm-tags #gjs-clm-sel{font-style:italic;margin-left:5px}.gjs-clm-tags #gjs-clm-status-c{float:right}.gjs-clm-tags #gjs-clm-tags-field{clear:both;padding:5px;margin-bottom:5px}.gjs-clm-tags #gjs-clm-tags-c{display:inline-block;vertical-align:top}.gjs-clm-tags #gjs-clm-add-tag{background-color:rgba(255,255,255,0.15);border-radius:2px;padding:5px 6px;box-shadow:1px 1px 0 rgba(255,255,255,0.2) inset;border:1px solid rgba(0,0,0,0.15);cursor:pointer}.gjs-clm-tags #gjs-clm-new{color:#ddd;padding:5px 6px;display:none}.gjs-clm-tags .gjs-clm-tag{display:inline-block;border-radius:3px;margin:0 3px 3px 0;padding:5px;cursor:default}.gjs-clm-tags #gjs-clm-close{font-size:20px;line-height:0;cursor:pointer;color:rgba(255,255,255,0.9)}.gjs-clm-tags #gjs-clm-close:hover{opacity:.7;filter:alpha(opacity=70)}.gjs-clm-tags #gjs-clm-checkbox{color:rgba(255,255,255,0.9);vertical-align:middle;cursor:pointer;font-size:9px}.gjs-clm-tags #gjs-clm-tag-label{padding:0 3px;cursor:text}.gjs-mdl-backlayer{opacity:.5;filter:alpha(opacity=50);background-color:#000;position:absolute;top:0;left:0;z-index:1;width:100%;height:100%}.gjs-mdl-container{font-family:Helvetica,sans-serif;position:absolute;top:0;left:0;z-index:10;width:100%;height:100%}.gjs-mdl-dialog{text-shadow:-1px -1px 0 rgba(0,0,0,0.05);animation:gjs-slide-down 0.215s;margin:30px auto 0;max-width:850px;width:90%;border-radius:3px;font-weight:lighter;position:relative;z-index:2}.gjs-mdl-title{font-size:1rem}.gjs-mdl-btn-close{position:absolute;right:15px;top:5px}.gjs-mdl-active .gjs-mdl-dialog{animation:gjs-mdl-slide-down 0.216s}.gjs-mdl-header,.gjs-mdl-content{padding:10px 15px;clear:both}.gjs-mdl-header{position:relative;border-bottom:1px solid rgba(0,0,0,0.2);padding:15px 15px 7px}.gjs-export-dl::after{content:"";clear:both;display:block;margin-bottom:10px}.gjs-dropzone{display:none;opacity:0;position:absolute;top:0;left:0;z-index:11;width:100%;height:100%;transition:opacity 0.25s;pointer-events:none}.gjs-dropzone-active .gjs-dropzone{display:block;opacity:1}.gjs-am-assets{height:290px;overflow:auto;clear:both;display:flex;flex-wrap:wrap;align-items:flex-start;align-content:flex-start}.gjs-am-assets-header{padding:5px}.gjs-am-add-asset .gjs-am-add-field{width:70%;float:left}.gjs-am-add-asset button{width:25%;float:right}.gjs-am-preview-cont{position:relative;height:70px;width:30%;background-color:#444;border-radius:2px;float:left;overflow:hidden}.gjs-am-preview{position:absolute;background-position:center center;background-size:cover;background-repeat:no-repeat;height:100%;width:100%;z-index:1}.gjs-am-preview-bg{opacity:.5;filter:alpha(opacity=50);position:absolute;height:100%;width:100%;z-index:0}.gjs-am-dimensions{opacity:.5;filter:alpha(opacity=50);font-size:10px}.gjs-am-meta{width:70%;float:left;font-size:12px;padding:5px 0 0 5px;box-sizing:border-box}.gjs-am-meta>div{margin-bottom:5px}.gjs-am-close{cursor:pointer;position:absolute;right:5px;top:0;display:none}.gjs-am-asset{border-bottom:1px solid rgba(0,0,0,0.2);padding:5px;cursor:pointer;position:relative;box-sizing:border-box;width:100%}.gjs-am-asset:hover .gjs-am-close{display:block}.gjs-am-highlight{background-color:rgba(255,255,255,0.1)}.gjs-am-assets-cont{background-color:rgba(0,0,0,0.1);border-radius:3px;box-sizing:border-box;padding:10px;width:45%;float:right;height:325px;overflow:hidden}.gjs-am-file-uploader{width:55%;float:left}.gjs-am-file-uploader>form{background-color:rgba(0,0,0,0.1);border:2px dashed;border-radius:3px;position:relative;text-align:center;margin-bottom:15px}.gjs-am-file-uploader>form.gjs-am-hover{border:2px solid #62c462;color:#75cb75}.gjs-am-file-uploader>form.gjs-am-disabled{border-color:red}.gjs-am-file-uploader>form #gjs-am-uploadFile{opacity:0;filter:alpha(opacity=0);padding:150px 10px;width:100%;box-sizing:border-box}.gjs-am-file-uploader #gjs-am-title{position:absolute;padding:150px 10px;width:100%}.gjs-cm-editor-c{float:left;box-sizing:border-box;width:50%}.gjs-cm-editor-c .CodeMirror{height:450px}.gjs-cm-editor{font-size:12px}.gjs-cm-editor#gjs-cm-htmlmixed{padding-right:10px;border-right:1px solid rgba(0,0,0,0.2)}.gjs-cm-editor#gjs-cm-htmlmixed #gjs-cm-title{color:#a97d44}.gjs-cm-editor#gjs-cm-css{padding-left:10px}.gjs-cm-editor#gjs-cm-css #gjs-cm-title{color:#ddca7e}.gjs-cm-editor #gjs-cm-title{background-color:rgba(0,0,0,0.2);font-size:12px;padding:5px 10px 3px;text-align:right}.gjs-rte-toolbar{border:1px solid rgba(0,0,0,0.2);position:absolute;border-radius:3px;z-index:10}.gjs-rte-actionbar{display:flex}.gjs-rte-action{display:flex;align-items:center;justify-content:center;padding:5px;min-width:25px;border-right:1px solid rgba(0,0,0,0.2);text-align:center;cursor:pointer;outline:none}.gjs-rte-action:last-child{border-right:none}.gjs-rte-action:hover{background-color:rgba(255,255,255,0.1)}.gjs-rte-active{background-color:rgba(0,0,0,0.2)}.gjs-editor-cont .sp-hue,.gjs-editor-cont .sp-slider{cursor:row-resize}.gjs-editor-cont .sp-color,.gjs-editor-cont .sp-dragger{cursor:crosshair}.gjs-editor-cont .sp-alpha-inner,.gjs-editor-cont .sp-alpha-handle{cursor:col-resize}.gjs-editor-cont .sp-hue{left:90%}.gjs-editor-cont .sp-color{right:15%}.gjs-editor-cont .sp-container{border:1px solid rgba(0,0,0,0.2);box-shadow:0 0 7px rgba(0,0,0,0.2);border-radius:3px}.gjs-editor-cont .sp-picker-container{border:none}.gjs-editor-cont .colpick_dark .colpick_color{outline:1px solid rgba(0,0,0,0.2)}.gjs-editor-cont .sp-cancel,.gjs-editor-cont .sp-cancel:hover{bottom:-8px;color:#777 !important;font-size:25px;left:0;position:absolute;text-decoration:none}.gjs-editor-cont .sp-alpha-handle{background-color:#ccc;border:1px solid #555;width:4px}.gjs-editor-cont .sp-color,.gjs-editor-cont .sp-hue{border:1px solid #333333}.gjs-editor-cont .sp-slider{background-color:#ccc;border:1px solid #555;height:3px;left:-4px;width:22px}.gjs-editor-cont .sp-dragger{background:transparent;box-shadow:0 0 0 1px #111}.gjs-editor-cont .sp-button-container{float:none;width:100%;position:relative;text-align:right}.gjs-editor-cont .sp-container button,.gjs-editor-cont .sp-container button:hover,.gjs-editor-cont .sp-container button:active{background:rgba(0,0,0,0.2);border-color:rgba(0,0,0,0.2);color:#ddd;text-shadow:none;box-shadow:none;padding:3px 5px}.gjs-editor-cont .sp-palette-container{border:none;float:none;margin:0;padding:5px 10px 0}.gjs-editor-cont .sp-palette .sp-thumb-el,.gjs-editor-cont .sp-palette .sp-thumb-el:hover{border:1px solid rgba(0,0,0,0.9)}.gjs-editor-cont .sp-palette .sp-thumb-el:hover,.gjs-editor-cont .sp-palette .sp-thumb-el.sp-thumb-active{border-color:rgba(0,0,0,0.9)}.gjs-hidden{display:none}@keyframes gjs-slide-down{0%{transform:translate(0, -3rem);opacity:0}100%{transform:translate(0, 0);opacity:1}}@keyframes gjs-slide-up{0%{transform:translate(0, 0);opacity:1}100%{transform:translate(0, -3rem);opacity:0}} + */@font-face{font-family:'FontAwesome';src:url("../fonts/fontawesome-webfont.eot?v=4.7.0");src:url("../fonts/fontawesome-webfont.eot?#iefix&v=4.7.0") format("embedded-opentype"),url("../fonts/fontawesome-webfont.woff2?v=4.7.0") format("woff2"),url("../fonts/fontawesome-webfont.woff?v=4.7.0") format("woff"),url("../fonts/fontawesome-webfont.ttf?v=4.7.0") format("truetype"),url("../fonts/fontawesome-webfont.svg?v=4.7.0#fontawesomeregular") format("svg");font-weight:normal;font-style:normal}.fa{display:inline-block;font:normal normal normal 14px/1 FontAwesome;font-size:inherit;text-rendering:auto;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.fa-lg{font-size:1.33333em;line-height:.75em;vertical-align:-15%}.fa-2x{font-size:2em}.fa-3x{font-size:3em}.fa-4x{font-size:4em}.fa-5x{font-size:5em}.fa-fw{width:1.28571em;text-align:center}.fa-ul{padding-left:0;margin-left:2.14286em;list-style-type:none}.fa-ul>li{position:relative}.fa-li{position:absolute;left:-2.14286em;width:2.14286em;top:.14286em;text-align:center}.fa-li.fa-lg{left:-1.85714em}.fa-border{padding:.2em .25em .15em;border:solid 0.08em #eee;border-radius:.1em}.fa-pull-left{float:left}.fa-pull-right{float:right}.fa.fa-pull-left{margin-right:.3em}.fa.fa-pull-right{margin-left:.3em}.pull-right{float:right}.pull-left{float:left}.fa.pull-left{margin-right:.3em}.fa.pull-right{margin-left:.3em}.fa-spin{-webkit-animation:fa-spin 2s infinite linear;animation:fa-spin 2s infinite linear}.fa-pulse{-webkit-animation:fa-spin 1s infinite steps(8);animation:fa-spin 1s infinite steps(8)}@-webkit-keyframes fa-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}100%{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}@keyframes fa-spin{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}100%{-webkit-transform:rotate(359deg);transform:rotate(359deg)}}.fa-rotate-90{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=1)";-webkit-transform:rotate(90deg);-ms-transform:rotate(90deg);transform:rotate(90deg)}.fa-rotate-180{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=2)";-webkit-transform:rotate(180deg);-ms-transform:rotate(180deg);transform:rotate(180deg)}.fa-rotate-270{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=3)";-webkit-transform:rotate(270deg);-ms-transform:rotate(270deg);transform:rotate(270deg)}.fa-flip-horizontal{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=0, mirror=1)";-webkit-transform:scale(-1, 1);-ms-transform:scale(-1, 1);transform:scale(-1, 1)}.fa-flip-vertical{-ms-filter:"progid:DXImageTransform.Microsoft.BasicImage(rotation=2, mirror=1)";-webkit-transform:scale(1, -1);-ms-transform:scale(1, -1);transform:scale(1, -1)}:root .fa-rotate-90,:root .fa-rotate-180,:root .fa-rotate-270,:root .fa-flip-horizontal,:root .fa-flip-vertical{filter:none}.fa-stack{position:relative;display:inline-block;width:2em;height:2em;line-height:2em;vertical-align:middle}.fa-stack-1x,.fa-stack-2x{position:absolute;left:0;width:100%;text-align:center}.fa-stack-1x{line-height:inherit}.fa-stack-2x{font-size:2em}.fa-inverse{color:#fff}.fa-glass:before{content:""}.fa-music:before{content:""}.fa-search:before{content:""}.fa-envelope-o:before{content:""}.fa-heart:before{content:""}.fa-star:before{content:""}.fa-star-o:before{content:""}.fa-user:before{content:""}.fa-film:before{content:""}.fa-th-large:before{content:""}.fa-th:before{content:""}.fa-th-list:before{content:""}.fa-check:before{content:""}.fa-remove:before,.fa-close:before,.fa-times:before{content:""}.fa-search-plus:before{content:""}.fa-search-minus:before{content:""}.fa-power-off:before{content:""}.fa-signal:before{content:""}.fa-gear:before,.fa-cog:before{content:""}.fa-trash-o:before{content:""}.fa-home:before{content:""}.fa-file-o:before{content:""}.fa-clock-o:before{content:""}.fa-road:before{content:""}.fa-download:before{content:""}.fa-arrow-circle-o-down:before{content:""}.fa-arrow-circle-o-up:before{content:""}.fa-inbox:before{content:""}.fa-play-circle-o:before{content:""}.fa-rotate-right:before,.fa-repeat:before{content:""}.fa-refresh:before{content:""}.fa-list-alt:before{content:""}.fa-lock:before{content:""}.fa-flag:before{content:""}.fa-headphones:before{content:""}.fa-volume-off:before{content:""}.fa-volume-down:before{content:""}.fa-volume-up:before{content:""}.fa-qrcode:before{content:""}.fa-barcode:before{content:""}.fa-tag:before{content:""}.fa-tags:before{content:""}.fa-book:before{content:""}.fa-bookmark:before{content:""}.fa-print:before{content:""}.fa-camera:before{content:""}.fa-font:before{content:""}.fa-bold:before{content:""}.fa-italic:before{content:""}.fa-text-height:before{content:""}.fa-text-width:before{content:""}.fa-align-left:before{content:""}.fa-align-center:before{content:""}.fa-align-right:before{content:""}.fa-align-justify:before{content:""}.fa-list:before{content:""}.fa-dedent:before,.fa-outdent:before{content:""}.fa-indent:before{content:""}.fa-video-camera:before{content:""}.fa-photo:before,.fa-image:before,.fa-picture-o:before{content:""}.fa-pencil:before{content:""}.fa-map-marker:before{content:""}.fa-adjust:before{content:""}.fa-tint:before{content:""}.fa-edit:before,.fa-pencil-square-o:before{content:""}.fa-share-square-o:before{content:""}.fa-check-square-o:before{content:""}.fa-arrows:before{content:""}.fa-step-backward:before{content:""}.fa-fast-backward:before{content:""}.fa-backward:before{content:""}.fa-play:before{content:""}.fa-pause:before{content:""}.fa-stop:before{content:""}.fa-forward:before{content:""}.fa-fast-forward:before{content:""}.fa-step-forward:before{content:""}.fa-eject:before{content:""}.fa-chevron-left:before{content:""}.fa-chevron-right:before{content:""}.fa-plus-circle:before{content:""}.fa-minus-circle:before{content:""}.fa-times-circle:before{content:""}.fa-check-circle:before{content:""}.fa-question-circle:before{content:""}.fa-info-circle:before{content:""}.fa-crosshairs:before{content:""}.fa-times-circle-o:before{content:""}.fa-check-circle-o:before{content:""}.fa-ban:before{content:""}.fa-arrow-left:before{content:""}.fa-arrow-right:before{content:""}.fa-arrow-up:before{content:""}.fa-arrow-down:before{content:""}.fa-mail-forward:before,.fa-share:before{content:""}.fa-expand:before{content:""}.fa-compress:before{content:""}.fa-plus:before{content:""}.fa-minus:before{content:""}.fa-asterisk:before{content:""}.fa-exclamation-circle:before{content:""}.fa-gift:before{content:""}.fa-leaf:before{content:""}.fa-fire:before{content:""}.fa-eye:before{content:""}.fa-eye-slash:before{content:""}.fa-warning:before,.fa-exclamation-triangle:before{content:""}.fa-plane:before{content:""}.fa-calendar:before{content:""}.fa-random:before{content:""}.fa-comment:before{content:""}.fa-magnet:before{content:""}.fa-chevron-up:before{content:""}.fa-chevron-down:before{content:""}.fa-retweet:before{content:""}.fa-shopping-cart:before{content:""}.fa-folder:before{content:""}.fa-folder-open:before{content:""}.fa-arrows-v:before{content:""}.fa-arrows-h:before{content:""}.fa-bar-chart-o:before,.fa-bar-chart:before{content:""}.fa-twitter-square:before{content:""}.fa-facebook-square:before{content:""}.fa-camera-retro:before{content:""}.fa-key:before{content:""}.fa-gears:before,.fa-cogs:before{content:""}.fa-comments:before{content:""}.fa-thumbs-o-up:before{content:""}.fa-thumbs-o-down:before{content:""}.fa-star-half:before{content:""}.fa-heart-o:before{content:""}.fa-sign-out:before{content:""}.fa-linkedin-square:before{content:""}.fa-thumb-tack:before{content:""}.fa-external-link:before{content:""}.fa-sign-in:before{content:""}.fa-trophy:before{content:""}.fa-github-square:before{content:""}.fa-upload:before{content:""}.fa-lemon-o:before{content:""}.fa-phone:before{content:""}.fa-square-o:before{content:""}.fa-bookmark-o:before{content:""}.fa-phone-square:before{content:""}.fa-twitter:before{content:""}.fa-facebook-f:before,.fa-facebook:before{content:""}.fa-github:before{content:""}.fa-unlock:before{content:""}.fa-credit-card:before{content:""}.fa-feed:before,.fa-rss:before{content:""}.fa-hdd-o:before{content:""}.fa-bullhorn:before{content:""}.fa-bell:before{content:""}.fa-certificate:before{content:""}.fa-hand-o-right:before{content:""}.fa-hand-o-left:before{content:""}.fa-hand-o-up:before{content:""}.fa-hand-o-down:before{content:""}.fa-arrow-circle-left:before{content:""}.fa-arrow-circle-right:before{content:""}.fa-arrow-circle-up:before{content:""}.fa-arrow-circle-down:before{content:""}.fa-globe:before{content:""}.fa-wrench:before{content:""}.fa-tasks:before{content:""}.fa-filter:before{content:""}.fa-briefcase:before{content:""}.fa-arrows-alt:before{content:""}.fa-group:before,.fa-users:before{content:""}.fa-chain:before,.fa-link:before{content:""}.fa-cloud:before{content:""}.fa-flask:before{content:""}.fa-cut:before,.fa-scissors:before{content:""}.fa-copy:before,.fa-files-o:before{content:""}.fa-paperclip:before{content:""}.fa-save:before,.fa-floppy-o:before{content:""}.fa-square:before{content:""}.fa-navicon:before,.fa-reorder:before,.fa-bars:before{content:""}.fa-list-ul:before{content:""}.fa-list-ol:before{content:""}.fa-strikethrough:before{content:""}.fa-underline:before{content:""}.fa-table:before{content:""}.fa-magic:before{content:""}.fa-truck:before{content:""}.fa-pinterest:before{content:""}.fa-pinterest-square:before{content:""}.fa-google-plus-square:before{content:""}.fa-google-plus:before{content:""}.fa-money:before{content:""}.fa-caret-down:before{content:""}.fa-caret-up:before{content:""}.fa-caret-left:before{content:""}.fa-caret-right:before{content:""}.fa-columns:before{content:""}.fa-unsorted:before,.fa-sort:before{content:""}.fa-sort-down:before,.fa-sort-desc:before{content:""}.fa-sort-up:before,.fa-sort-asc:before{content:""}.fa-envelope:before{content:""}.fa-linkedin:before{content:""}.fa-rotate-left:before,.fa-undo:before{content:""}.fa-legal:before,.fa-gavel:before{content:""}.fa-dashboard:before,.fa-tachometer:before{content:""}.fa-comment-o:before{content:""}.fa-comments-o:before{content:""}.fa-flash:before,.fa-bolt:before{content:""}.fa-sitemap:before{content:""}.fa-umbrella:before{content:""}.fa-paste:before,.fa-clipboard:before{content:""}.fa-lightbulb-o:before{content:""}.fa-exchange:before{content:""}.fa-cloud-download:before{content:""}.fa-cloud-upload:before{content:""}.fa-user-md:before{content:""}.fa-stethoscope:before{content:""}.fa-suitcase:before{content:""}.fa-bell-o:before{content:""}.fa-coffee:before{content:""}.fa-cutlery:before{content:""}.fa-file-text-o:before{content:""}.fa-building-o:before{content:""}.fa-hospital-o:before{content:""}.fa-ambulance:before{content:""}.fa-medkit:before{content:""}.fa-fighter-jet:before{content:""}.fa-beer:before{content:""}.fa-h-square:before{content:""}.fa-plus-square:before{content:""}.fa-angle-double-left:before{content:""}.fa-angle-double-right:before{content:""}.fa-angle-double-up:before{content:""}.fa-angle-double-down:before{content:""}.fa-angle-left:before{content:""}.fa-angle-right:before{content:""}.fa-angle-up:before{content:""}.fa-angle-down:before{content:""}.fa-desktop:before{content:""}.fa-laptop:before{content:""}.fa-tablet:before{content:""}.fa-mobile-phone:before,.fa-mobile:before{content:""}.fa-circle-o:before{content:""}.fa-quote-left:before{content:""}.fa-quote-right:before{content:""}.fa-spinner:before{content:""}.fa-circle:before{content:""}.fa-mail-reply:before,.fa-reply:before{content:""}.fa-github-alt:before{content:""}.fa-folder-o:before{content:""}.fa-folder-open-o:before{content:""}.fa-smile-o:before{content:""}.fa-frown-o:before{content:""}.fa-meh-o:before{content:""}.fa-gamepad:before{content:""}.fa-keyboard-o:before{content:""}.fa-flag-o:before{content:""}.fa-flag-checkered:before{content:""}.fa-terminal:before{content:""}.fa-code:before{content:""}.fa-mail-reply-all:before,.fa-reply-all:before{content:""}.fa-star-half-empty:before,.fa-star-half-full:before,.fa-star-half-o:before{content:""}.fa-location-arrow:before{content:""}.fa-crop:before{content:""}.fa-code-fork:before{content:""}.fa-unlink:before,.fa-chain-broken:before{content:""}.fa-question:before{content:""}.fa-info:before{content:""}.fa-exclamation:before{content:""}.fa-superscript:before{content:""}.fa-subscript:before{content:""}.fa-eraser:before{content:""}.fa-puzzle-piece:before{content:""}.fa-microphone:before{content:""}.fa-microphone-slash:before{content:""}.fa-shield:before{content:""}.fa-calendar-o:before{content:""}.fa-fire-extinguisher:before{content:""}.fa-rocket:before{content:""}.fa-maxcdn:before{content:""}.fa-chevron-circle-left:before{content:""}.fa-chevron-circle-right:before{content:""}.fa-chevron-circle-up:before{content:""}.fa-chevron-circle-down:before{content:""}.fa-html5:before{content:""}.fa-css3:before{content:""}.fa-anchor:before{content:""}.fa-unlock-alt:before{content:""}.fa-bullseye:before{content:""}.fa-ellipsis-h:before{content:""}.fa-ellipsis-v:before{content:""}.fa-rss-square:before{content:""}.fa-play-circle:before{content:""}.fa-ticket:before{content:""}.fa-minus-square:before{content:""}.fa-minus-square-o:before{content:""}.fa-level-up:before{content:""}.fa-level-down:before{content:""}.fa-check-square:before{content:""}.fa-pencil-square:before{content:""}.fa-external-link-square:before{content:""}.fa-share-square:before{content:""}.fa-compass:before{content:""}.fa-toggle-down:before,.fa-caret-square-o-down:before{content:""}.fa-toggle-up:before,.fa-caret-square-o-up:before{content:""}.fa-toggle-right:before,.fa-caret-square-o-right:before{content:""}.fa-euro:before,.fa-eur:before{content:""}.fa-gbp:before{content:""}.fa-dollar:before,.fa-usd:before{content:""}.fa-rupee:before,.fa-inr:before{content:""}.fa-cny:before,.fa-rmb:before,.fa-yen:before,.fa-jpy:before{content:""}.fa-ruble:before,.fa-rouble:before,.fa-rub:before{content:""}.fa-won:before,.fa-krw:before{content:""}.fa-bitcoin:before,.fa-btc:before{content:""}.fa-file:before{content:""}.fa-file-text:before{content:""}.fa-sort-alpha-asc:before{content:""}.fa-sort-alpha-desc:before{content:""}.fa-sort-amount-asc:before{content:""}.fa-sort-amount-desc:before{content:""}.fa-sort-numeric-asc:before{content:""}.fa-sort-numeric-desc:before{content:""}.fa-thumbs-up:before{content:""}.fa-thumbs-down:before{content:""}.fa-youtube-square:before{content:""}.fa-youtube:before{content:""}.fa-xing:before{content:""}.fa-xing-square:before{content:""}.fa-youtube-play:before{content:""}.fa-dropbox:before{content:""}.fa-stack-overflow:before{content:""}.fa-instagram:before{content:""}.fa-flickr:before{content:""}.fa-adn:before{content:""}.fa-bitbucket:before{content:""}.fa-bitbucket-square:before{content:""}.fa-tumblr:before{content:""}.fa-tumblr-square:before{content:""}.fa-long-arrow-down:before{content:""}.fa-long-arrow-up:before{content:""}.fa-long-arrow-left:before{content:""}.fa-long-arrow-right:before{content:""}.fa-apple:before{content:""}.fa-windows:before{content:""}.fa-android:before{content:""}.fa-linux:before{content:""}.fa-dribbble:before{content:""}.fa-skype:before{content:""}.fa-foursquare:before{content:""}.fa-trello:before{content:""}.fa-female:before{content:""}.fa-male:before{content:""}.fa-gittip:before,.fa-gratipay:before{content:""}.fa-sun-o:before{content:""}.fa-moon-o:before{content:""}.fa-archive:before{content:""}.fa-bug:before{content:""}.fa-vk:before{content:""}.fa-weibo:before{content:""}.fa-renren:before{content:""}.fa-pagelines:before{content:""}.fa-stack-exchange:before{content:""}.fa-arrow-circle-o-right:before{content:""}.fa-arrow-circle-o-left:before{content:""}.fa-toggle-left:before,.fa-caret-square-o-left:before{content:""}.fa-dot-circle-o:before{content:""}.fa-wheelchair:before{content:""}.fa-vimeo-square:before{content:""}.fa-turkish-lira:before,.fa-try:before{content:""}.fa-plus-square-o:before{content:""}.fa-space-shuttle:before{content:""}.fa-slack:before{content:""}.fa-envelope-square:before{content:""}.fa-wordpress:before{content:""}.fa-openid:before{content:""}.fa-institution:before,.fa-bank:before,.fa-university:before{content:""}.fa-mortar-board:before,.fa-graduation-cap:before{content:""}.fa-yahoo:before{content:""}.fa-google:before{content:""}.fa-reddit:before{content:""}.fa-reddit-square:before{content:""}.fa-stumbleupon-circle:before{content:""}.fa-stumbleupon:before{content:""}.fa-delicious:before{content:""}.fa-digg:before{content:""}.fa-pied-piper-pp:before{content:""}.fa-pied-piper-alt:before{content:""}.fa-drupal:before{content:""}.fa-joomla:before{content:""}.fa-language:before{content:""}.fa-fax:before{content:""}.fa-building:before{content:""}.fa-child:before{content:""}.fa-paw:before{content:""}.fa-spoon:before{content:""}.fa-cube:before{content:""}.fa-cubes:before{content:""}.fa-behance:before{content:""}.fa-behance-square:before{content:""}.fa-steam:before{content:""}.fa-steam-square:before{content:""}.fa-recycle:before{content:""}.fa-automobile:before,.fa-car:before{content:""}.fa-cab:before,.fa-taxi:before{content:""}.fa-tree:before{content:""}.fa-spotify:before{content:""}.fa-deviantart:before{content:""}.fa-soundcloud:before{content:""}.fa-database:before{content:""}.fa-file-pdf-o:before{content:""}.fa-file-word-o:before{content:""}.fa-file-excel-o:before{content:""}.fa-file-powerpoint-o:before{content:""}.fa-file-photo-o:before,.fa-file-picture-o:before,.fa-file-image-o:before{content:""}.fa-file-zip-o:before,.fa-file-archive-o:before{content:""}.fa-file-sound-o:before,.fa-file-audio-o:before{content:""}.fa-file-movie-o:before,.fa-file-video-o:before{content:""}.fa-file-code-o:before{content:""}.fa-vine:before{content:""}.fa-codepen:before{content:""}.fa-jsfiddle:before{content:""}.fa-life-bouy:before,.fa-life-buoy:before,.fa-life-saver:before,.fa-support:before,.fa-life-ring:before{content:""}.fa-circle-o-notch:before{content:""}.fa-ra:before,.fa-resistance:before,.fa-rebel:before{content:""}.fa-ge:before,.fa-empire:before{content:""}.fa-git-square:before{content:""}.fa-git:before{content:""}.fa-y-combinator-square:before,.fa-yc-square:before,.fa-hacker-news:before{content:""}.fa-tencent-weibo:before{content:""}.fa-qq:before{content:""}.fa-wechat:before,.fa-weixin:before{content:""}.fa-send:before,.fa-paper-plane:before{content:""}.fa-send-o:before,.fa-paper-plane-o:before{content:""}.fa-history:before{content:""}.fa-circle-thin:before{content:""}.fa-header:before{content:""}.fa-paragraph:before{content:""}.fa-sliders:before{content:""}.fa-share-alt:before{content:""}.fa-share-alt-square:before{content:""}.fa-bomb:before{content:""}.fa-soccer-ball-o:before,.fa-futbol-o:before{content:""}.fa-tty:before{content:""}.fa-binoculars:before{content:""}.fa-plug:before{content:""}.fa-slideshare:before{content:""}.fa-twitch:before{content:""}.fa-yelp:before{content:""}.fa-newspaper-o:before{content:""}.fa-wifi:before{content:""}.fa-calculator:before{content:""}.fa-paypal:before{content:""}.fa-google-wallet:before{content:""}.fa-cc-visa:before{content:""}.fa-cc-mastercard:before{content:""}.fa-cc-discover:before{content:""}.fa-cc-amex:before{content:""}.fa-cc-paypal:before{content:""}.fa-cc-stripe:before{content:""}.fa-bell-slash:before{content:""}.fa-bell-slash-o:before{content:""}.fa-trash:before{content:""}.fa-copyright:before{content:""}.fa-at:before{content:""}.fa-eyedropper:before{content:""}.fa-paint-brush:before{content:""}.fa-birthday-cake:before{content:""}.fa-area-chart:before{content:""}.fa-pie-chart:before{content:""}.fa-line-chart:before{content:""}.fa-lastfm:before{content:""}.fa-lastfm-square:before{content:""}.fa-toggle-off:before{content:""}.fa-toggle-on:before{content:""}.fa-bicycle:before{content:""}.fa-bus:before{content:""}.fa-ioxhost:before{content:""}.fa-angellist:before{content:""}.fa-cc:before{content:""}.fa-shekel:before,.fa-sheqel:before,.fa-ils:before{content:""}.fa-meanpath:before{content:""}.fa-buysellads:before{content:""}.fa-connectdevelop:before{content:""}.fa-dashcube:before{content:""}.fa-forumbee:before{content:""}.fa-leanpub:before{content:""}.fa-sellsy:before{content:""}.fa-shirtsinbulk:before{content:""}.fa-simplybuilt:before{content:""}.fa-skyatlas:before{content:""}.fa-cart-plus:before{content:""}.fa-cart-arrow-down:before{content:""}.fa-diamond:before{content:""}.fa-ship:before{content:""}.fa-user-secret:before{content:""}.fa-motorcycle:before{content:""}.fa-street-view:before{content:""}.fa-heartbeat:before{content:""}.fa-venus:before{content:""}.fa-mars:before{content:""}.fa-mercury:before{content:""}.fa-intersex:before,.fa-transgender:before{content:""}.fa-transgender-alt:before{content:""}.fa-venus-double:before{content:""}.fa-mars-double:before{content:""}.fa-venus-mars:before{content:""}.fa-mars-stroke:before{content:""}.fa-mars-stroke-v:before{content:""}.fa-mars-stroke-h:before{content:""}.fa-neuter:before{content:""}.fa-genderless:before{content:""}.fa-facebook-official:before{content:""}.fa-pinterest-p:before{content:""}.fa-whatsapp:before{content:""}.fa-server:before{content:""}.fa-user-plus:before{content:""}.fa-user-times:before{content:""}.fa-hotel:before,.fa-bed:before{content:""}.fa-viacoin:before{content:""}.fa-train:before{content:""}.fa-subway:before{content:""}.fa-medium:before{content:""}.fa-yc:before,.fa-y-combinator:before{content:""}.fa-optin-monster:before{content:""}.fa-opencart:before{content:""}.fa-expeditedssl:before{content:""}.fa-battery-4:before,.fa-battery:before,.fa-battery-full:before{content:""}.fa-battery-3:before,.fa-battery-three-quarters:before{content:""}.fa-battery-2:before,.fa-battery-half:before{content:""}.fa-battery-1:before,.fa-battery-quarter:before{content:""}.fa-battery-0:before,.fa-battery-empty:before{content:""}.fa-mouse-pointer:before{content:""}.fa-i-cursor:before{content:""}.fa-object-group:before{content:""}.fa-object-ungroup:before{content:""}.fa-sticky-note:before{content:""}.fa-sticky-note-o:before{content:""}.fa-cc-jcb:before{content:""}.fa-cc-diners-club:before{content:""}.fa-clone:before{content:""}.fa-balance-scale:before{content:""}.fa-hourglass-o:before{content:""}.fa-hourglass-1:before,.fa-hourglass-start:before{content:""}.fa-hourglass-2:before,.fa-hourglass-half:before{content:""}.fa-hourglass-3:before,.fa-hourglass-end:before{content:""}.fa-hourglass:before{content:""}.fa-hand-grab-o:before,.fa-hand-rock-o:before{content:""}.fa-hand-stop-o:before,.fa-hand-paper-o:before{content:""}.fa-hand-scissors-o:before{content:""}.fa-hand-lizard-o:before{content:""}.fa-hand-spock-o:before{content:""}.fa-hand-pointer-o:before{content:""}.fa-hand-peace-o:before{content:""}.fa-trademark:before{content:""}.fa-registered:before{content:""}.fa-creative-commons:before{content:""}.fa-gg:before{content:""}.fa-gg-circle:before{content:""}.fa-tripadvisor:before{content:""}.fa-odnoklassniki:before{content:""}.fa-odnoklassniki-square:before{content:""}.fa-get-pocket:before{content:""}.fa-wikipedia-w:before{content:""}.fa-safari:before{content:""}.fa-chrome:before{content:""}.fa-firefox:before{content:""}.fa-opera:before{content:""}.fa-internet-explorer:before{content:""}.fa-tv:before,.fa-television:before{content:""}.fa-contao:before{content:""}.fa-500px:before{content:""}.fa-amazon:before{content:""}.fa-calendar-plus-o:before{content:""}.fa-calendar-minus-o:before{content:""}.fa-calendar-times-o:before{content:""}.fa-calendar-check-o:before{content:""}.fa-industry:before{content:""}.fa-map-pin:before{content:""}.fa-map-signs:before{content:""}.fa-map-o:before{content:""}.fa-map:before{content:""}.fa-commenting:before{content:""}.fa-commenting-o:before{content:""}.fa-houzz:before{content:""}.fa-vimeo:before{content:""}.fa-black-tie:before{content:""}.fa-fonticons:before{content:""}.fa-reddit-alien:before{content:""}.fa-edge:before{content:""}.fa-credit-card-alt:before{content:""}.fa-codiepie:before{content:""}.fa-modx:before{content:""}.fa-fort-awesome:before{content:""}.fa-usb:before{content:""}.fa-product-hunt:before{content:""}.fa-mixcloud:before{content:""}.fa-scribd:before{content:""}.fa-pause-circle:before{content:""}.fa-pause-circle-o:before{content:""}.fa-stop-circle:before{content:""}.fa-stop-circle-o:before{content:""}.fa-shopping-bag:before{content:""}.fa-shopping-basket:before{content:""}.fa-hashtag:before{content:""}.fa-bluetooth:before{content:""}.fa-bluetooth-b:before{content:""}.fa-percent:before{content:""}.fa-gitlab:before{content:""}.fa-wpbeginner:before{content:""}.fa-wpforms:before{content:""}.fa-envira:before{content:""}.fa-universal-access:before{content:""}.fa-wheelchair-alt:before{content:""}.fa-question-circle-o:before{content:""}.fa-blind:before{content:""}.fa-audio-description:before{content:""}.fa-volume-control-phone:before{content:""}.fa-braille:before{content:""}.fa-assistive-listening-systems:before{content:""}.fa-asl-interpreting:before,.fa-american-sign-language-interpreting:before{content:""}.fa-deafness:before,.fa-hard-of-hearing:before,.fa-deaf:before{content:""}.fa-glide:before{content:""}.fa-glide-g:before{content:""}.fa-signing:before,.fa-sign-language:before{content:""}.fa-low-vision:before{content:""}.fa-viadeo:before{content:""}.fa-viadeo-square:before{content:""}.fa-snapchat:before{content:""}.fa-snapchat-ghost:before{content:""}.fa-snapchat-square:before{content:""}.fa-pied-piper:before{content:""}.fa-first-order:before{content:""}.fa-yoast:before{content:""}.fa-themeisle:before{content:""}.fa-google-plus-circle:before,.fa-google-plus-official:before{content:""}.fa-fa:before,.fa-font-awesome:before{content:""}.fa-handshake-o:before{content:""}.fa-envelope-open:before{content:""}.fa-envelope-open-o:before{content:""}.fa-linode:before{content:""}.fa-address-book:before{content:""}.fa-address-book-o:before{content:""}.fa-vcard:before,.fa-address-card:before{content:""}.fa-vcard-o:before,.fa-address-card-o:before{content:""}.fa-user-circle:before{content:""}.fa-user-circle-o:before{content:""}.fa-user-o:before{content:""}.fa-id-badge:before{content:""}.fa-drivers-license:before,.fa-id-card:before{content:""}.fa-drivers-license-o:before,.fa-id-card-o:before{content:""}.fa-quora:before{content:""}.fa-free-code-camp:before{content:""}.fa-telegram:before{content:""}.fa-thermometer-4:before,.fa-thermometer:before,.fa-thermometer-full:before{content:""}.fa-thermometer-3:before,.fa-thermometer-three-quarters:before{content:""}.fa-thermometer-2:before,.fa-thermometer-half:before{content:""}.fa-thermometer-1:before,.fa-thermometer-quarter:before{content:""}.fa-thermometer-0:before,.fa-thermometer-empty:before{content:""}.fa-shower:before{content:""}.fa-bathtub:before,.fa-s15:before,.fa-bath:before{content:""}.fa-podcast:before{content:""}.fa-window-maximize:before{content:""}.fa-window-minimize:before{content:""}.fa-window-restore:before{content:""}.fa-times-rectangle:before,.fa-window-close:before{content:""}.fa-times-rectangle-o:before,.fa-window-close-o:before{content:""}.fa-bandcamp:before{content:""}.fa-grav:before{content:""}.fa-etsy:before{content:""}.fa-imdb:before{content:""}.fa-ravelry:before{content:""}.fa-eercast:before{content:""}.fa-microchip:before{content:""}.fa-snowflake-o:before{content:""}.fa-superpowers:before{content:""}.fa-wpexplorer:before{content:""}.fa-meetup:before{content:""}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0, 0, 0, 0);border:0}.sr-only-focusable:active,.sr-only-focusable:focus{position:static;width:auto;height:auto;margin:0;overflow:visible;clip:auto}.CodeMirror{font-family:monospace;height:300px;color:black;direction:ltr}.CodeMirror-lines{padding:4px 0}.CodeMirror pre.CodeMirror-line,.CodeMirror pre.CodeMirror-line-like{padding:0 4px}.CodeMirror-scrollbar-filler,.CodeMirror-gutter-filler{background-color:white}.CodeMirror-gutters{border-right:1px solid #ddd;background-color:#f7f7f7;white-space:nowrap}.CodeMirror-linenumber{padding:0 3px 0 5px;min-width:20px;text-align:right;color:#999;white-space:nowrap}.CodeMirror-guttermarker{color:black}.CodeMirror-guttermarker-subtle{color:#999}.CodeMirror-cursor{border-left:1px solid black;border-right:none;width:0}.CodeMirror div.CodeMirror-secondarycursor{border-left:1px solid silver}.cm-fat-cursor .CodeMirror-cursor{width:auto;border:0 !important;background:#7e7}.cm-fat-cursor div.CodeMirror-cursors{z-index:1}.cm-fat-cursor-mark{background-color:rgba(20,255,20,0.5);-webkit-animation:blink 1.06s steps(1) infinite;-moz-animation:blink 1.06s steps(1) infinite;animation:blink 1.06s steps(1) infinite}.cm-animate-fat-cursor{width:auto;border:0;-webkit-animation:blink 1.06s steps(1) infinite;-moz-animation:blink 1.06s steps(1) infinite;animation:blink 1.06s steps(1) infinite;background-color:#7e7}@-moz-keyframes blink{0%{}50%{background-color:transparent}100%{}}@-webkit-keyframes blink{0%{}50%{background-color:transparent}100%{}}@keyframes blink{0%{}50%{background-color:transparent}100%{}}.cm-tab{display:inline-block;text-decoration:inherit}.CodeMirror-rulers{position:absolute;left:0;right:0;top:-50px;bottom:0;overflow:hidden}.CodeMirror-ruler{border-left:1px solid #ccc;top:0;bottom:0;position:absolute}.cm-s-default .cm-header{color:blue}.cm-s-default .cm-quote{color:#090}.cm-negative{color:#d44}.cm-positive{color:#292}.cm-header,.cm-strong{font-weight:bold}.cm-em{font-style:italic}.cm-link{text-decoration:underline}.cm-strikethrough{text-decoration:line-through}.cm-s-default .cm-keyword{color:#708}.cm-s-default .cm-atom{color:#219}.cm-s-default .cm-number{color:#164}.cm-s-default .cm-def{color:#00f}.cm-s-default .cm-variable-2{color:#05a}.cm-s-default .cm-variable-3,.cm-s-default .cm-type{color:#085}.cm-s-default .cm-comment{color:#a50}.cm-s-default .cm-string{color:#a11}.cm-s-default .cm-string-2{color:#f50}.cm-s-default .cm-meta{color:#555}.cm-s-default .cm-qualifier{color:#555}.cm-s-default .cm-builtin{color:#30a}.cm-s-default .cm-bracket{color:#997}.cm-s-default .cm-tag{color:#170}.cm-s-default .cm-attribute{color:#00c}.cm-s-default .cm-hr{color:#999}.cm-s-default .cm-link{color:#00c}.cm-s-default .cm-error{color:#f00}.cm-invalidchar{color:#f00}.CodeMirror-composing{border-bottom:2px solid}div.CodeMirror span.CodeMirror-matchingbracket{color:#0b0}div.CodeMirror span.CodeMirror-nonmatchingbracket{color:#a22}.CodeMirror-matchingtag{background:rgba(255,150,0,0.3)}.CodeMirror-activeline-background{background:#e8f2ff}.CodeMirror{position:relative;overflow:hidden;background:white}.CodeMirror-scroll{overflow:scroll !important;margin-bottom:-30px;margin-right:-30px;padding-bottom:30px;height:100%;outline:none;position:relative}.CodeMirror-sizer{position:relative;border-right:30px solid transparent}.CodeMirror-vscrollbar,.CodeMirror-hscrollbar,.CodeMirror-scrollbar-filler,.CodeMirror-gutter-filler{position:absolute;z-index:6;display:none}.CodeMirror-vscrollbar{right:0;top:0;overflow-x:hidden;overflow-y:scroll}.CodeMirror-hscrollbar{bottom:0;left:0;overflow-y:hidden;overflow-x:scroll}.CodeMirror-scrollbar-filler{right:0;bottom:0}.CodeMirror-gutter-filler{left:0;bottom:0}.CodeMirror-gutters{position:absolute;left:0;top:0;min-height:100%;z-index:3}.CodeMirror-gutter{white-space:normal;height:100%;display:inline-block;vertical-align:top;margin-bottom:-30px}.CodeMirror-gutter-wrapper{position:absolute;z-index:4;background:none !important;border:none !important}.CodeMirror-gutter-background{position:absolute;top:0;bottom:0;z-index:4}.CodeMirror-gutter-elt{position:absolute;cursor:default;z-index:4}.CodeMirror-gutter-wrapper ::selection{background-color:transparent}.CodeMirror-gutter-wrapper ::-moz-selection{background-color:transparent}.CodeMirror-lines{cursor:text;min-height:1px}.CodeMirror pre.CodeMirror-line,.CodeMirror pre.CodeMirror-line-like{-moz-border-radius:0;-webkit-border-radius:0;border-radius:0;border-width:0;background:transparent;font-family:inherit;font-size:inherit;margin:0;white-space:pre;word-wrap:normal;line-height:inherit;color:inherit;z-index:2;position:relative;overflow:visible;-webkit-tap-highlight-color:transparent;-webkit-font-variant-ligatures:contextual;font-variant-ligatures:contextual}.CodeMirror-wrap pre.CodeMirror-line,.CodeMirror-wrap pre.CodeMirror-line-like{word-wrap:break-word;white-space:pre-wrap;word-break:normal}.CodeMirror-linebackground{position:absolute;left:0;right:0;top:0;bottom:0;z-index:0}.CodeMirror-linewidget{position:relative;z-index:2;padding:0.1px}.CodeMirror-rtl pre{direction:rtl}.CodeMirror-code{outline:none}.CodeMirror-scroll,.CodeMirror-sizer,.CodeMirror-gutter,.CodeMirror-gutters,.CodeMirror-linenumber{-moz-box-sizing:content-box;box-sizing:content-box}.CodeMirror-measure{position:absolute;width:100%;height:0;overflow:hidden;visibility:hidden}.CodeMirror-cursor{position:absolute;pointer-events:none}.CodeMirror-measure pre{position:static}div.CodeMirror-cursors{visibility:hidden;position:relative;z-index:3}div.CodeMirror-dragcursors{visibility:visible}.CodeMirror-focused div.CodeMirror-cursors{visibility:visible}.CodeMirror-selected{background:#d9d9d9}.CodeMirror-focused .CodeMirror-selected{background:#d7d4f0}.CodeMirror-crosshair{cursor:crosshair}.CodeMirror-line::selection,.CodeMirror-line>span::selection,.CodeMirror-line>span>span::selection{background:#d7d4f0}.CodeMirror-line::-moz-selection,.CodeMirror-line>span::-moz-selection,.CodeMirror-line>span>span::-moz-selection{background:#d7d4f0}.cm-searching{background-color:#ffa;background-color:rgba(255,255,0,0.4)}.cm-force-border{padding-right:.1px}@media print{.CodeMirror div.CodeMirror-cursors{visibility:hidden}}.cm-tab-wrap-hack:after{content:''}span.CodeMirror-selectedtext{background:none}.cm-s-hopscotch.CodeMirror{background:#322931;color:#d5d3d5}.cm-s-hopscotch div.CodeMirror-selected{background:#433b42 !important}.cm-s-hopscotch .CodeMirror-gutters{background:#322931;border-right:0px}.cm-s-hopscotch .CodeMirror-linenumber{color:#797379}.cm-s-hopscotch .CodeMirror-cursor{border-left:1px solid #989498 !important}.cm-s-hopscotch span.cm-comment{color:#b33508}.cm-s-hopscotch span.cm-atom{color:#c85e7c}.cm-s-hopscotch span.cm-number{color:#c85e7c}.cm-s-hopscotch span.cm-property,.cm-s-hopscotch span.cm-attribute{color:#8fc13e}.cm-s-hopscotch span.cm-keyword{color:#dd464c}.cm-s-hopscotch span.cm-string{color:#fdcc59}.cm-s-hopscotch span.cm-variable{color:#8fc13e}.cm-s-hopscotch span.cm-variable-2{color:#1290bf}.cm-s-hopscotch span.cm-def{color:#fd8b19}.cm-s-hopscotch span.cm-error{background:#dd464c;color:#989498}.cm-s-hopscotch span.cm-bracket{color:#d5d3d5}.cm-s-hopscotch span.cm-tag{color:#dd464c}.cm-s-hopscotch span.cm-link{color:#c85e7c}.cm-s-hopscotch .CodeMirror-matchingbracket{text-decoration:underline;color:white !important}.cm-s-hopscotch .CodeMirror-activeline-background{background:#302020}@font-face{font-family:'font3336';src:url("../fonts/main-fonts.eot?v=20");src:url("../fonts/main-fonts.woff?v=20") format("woff"),url("../fonts/main-fonts.ttf?v=20") format("truetype"),url("../fonts/main-fonts.svg?v=20") format("svg"),url("../fonts/main-fonts.eot?v=20") format("embedded-opentype");font-weight:normal;font-style:normal}.gjs-is__grab,.gjs-is__grab *{cursor:grab !important}.gjs-is__grabbing,.gjs-is__grabbing *{-moz-user-select:none;-khtml-user-select:none;-webkit-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none;cursor:grabbing !important}.gjs-one-bg{background-color:#444}.gjs-one-color{color:#444}.gjs-one-color-h:hover{color:#444}.gjs-two-bg{background-color:#ddd}.gjs-two-color{color:#ddd}.gjs-two-color-h:hover{color:#ddd}.gjs-three-bg{background-color:#804f7b}.gjs-three-color{color:#804f7b}.gjs-three-color-h:hover{color:#804f7b}.gjs-four-bg{background-color:#d278c9}.gjs-four-color{color:#d278c9}.gjs-four-color-h:hover{color:#d278c9}.gjs-danger-bg{background-color:#dd3636}.gjs-danger-color{color:#dd3636}.gjs-danger-color-h:hover{color:#dd3636}.gjs-bg-main,.gjs-off-prv,.gjs-sm-sector .gjs-sm-colorp-c,.gjs-clm-tags .gjs-sm-colorp-c{background-color:#444}.gjs-color-main,.gjs-off-prv,.gjs-sm-sector .gjs-sm-stack #gjs-sm-add,.gjs-clm-tags .gjs-sm-stack #gjs-sm-add{color:#ddd;fill:#ddd}.gjs-color-active{color:#f8f8f8;fill:#f8f8f8}.gjs-color-warn{color:#ffca6f;fill:#ffca6f}.gjs-color-hl{color:#71b7f1;fill:#71b7f1}.gjs-fonts::before{display:block;font:normal normal normal 14px font3336;text-rendering:auto;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:5em}.gjs-f-b1::before{content:'Q'}.gjs-f-b2::before{content:'W'}.gjs-f-b3::before{content:'E'}.gjs-f-b37::before{content:'R'}.gjs-f-hero::before{content:'T'}.gjs-f-h1p::before{content:'y'}.gjs-f-3ba::before{content:'u'}.gjs-f-image::before{content:'I'}.gjs-f-text::before{content:'o'}.gjs-f-quo::before{content:'p'}.gjs-f-button::before{content:'B'}.gjs-f-divider::before{content:'D'}.gjs-invis-invis,.gjs-clm-tags #gjs-clm-new,.gjs-no-app{background-color:transparent;border:none;color:inherit}.gjs-no-app{height:10px}.gjs-test::btn{color:'#fff'}.opac50,.gjs-clm-tags #gjs-clm-close{opacity:.5;filter:alpha(opacity=50)}.gjs-checker-bg,.gjs-field-colorp-c,.checker-bg,.gjs-sm-sector .gjs-sm-property .gjs-sm-layer>#gjs-sm-preview-box,.gjs-clm-tags .gjs-sm-property .gjs-sm-layer>#gjs-sm-preview-box{background-image:url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAwAAAAMCAIAAADZF8uwAAAAGUlEQVQYV2M4gwH+YwCGIasIUwhT25BVBADtzYNYrHvv4gAAAABJRU5ErkJggg==")}.gjs-no-user-select,.gjs-grabbing,.gjs-grabbing *,.gjs-layer-name,.gjs-rte-toolbar{-moz-user-select:none;-khtml-user-select:none;-webkit-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none}.gjs-no-pointer-events,.gjs-resizer-c,.gjs-margin-v-el,.gjs-padding-v-el,.gjs-fixedmargin-v-el,.gjs-fixedpadding-v-el{pointer-events:none}.gjs-bdrag{pointer-events:none !important;position:absolute !important;z-index:10 !important;width:auto}.gjs-drag-helper{background-color:#3b97e3 !important;pointer-events:none !important;position:absolute !important;z-index:10 !important;transform:scale(0.3) !important;transform-origin:top left !important;-webkit-transform-origin:top left !important;margin:15px !important;transition:none !important;outline:none !important}.gjs-grabbing,.gjs-grabbing *{cursor:grabbing !important;cursor:-webkit-grabbing !important}.gjs-grabbing{overflow:hidden}.gjs-off-prv{position:relative;z-index:10;padding:5px;cursor:pointer}.gjs-editor-cont ::-webkit-scrollbar-track{background:rgba(0,0,0,0.1)}.gjs-editor-cont ::-webkit-scrollbar-thumb{background-color:rgba(255,255,255,0.2)}.gjs-editor-cont ::-webkit-scrollbar{width:8px}.clear{clear:both}.no-select,.gjs-com-no-select,.gjs-com-no-select img,.gjs-category-title,.gjs-sm-sector .gjs-sm-title,.gjs-clm-tags .gjs-sm-title,.gjs-block-category .gjs-title,.gjs-layer-title,.gjs-clm-tags #gjs-clm-close{-moz-user-select:none;-khtml-user-select:none;-webkit-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none}.gjs-no-touch-actions{touch-action:none}.gjs-disabled{-moz-user-select:none;-khtml-user-select:none;-webkit-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none;opacity:.5;filter:alpha(opacity=50)}.gjs-editor{font-family:Helvetica,sans-serif;font-size:.75rem;position:relative;box-sizing:border-box;height:100%}.gjs-freezed,.gjs-freezed{opacity:.5;filter:alpha(opacity=50);pointer-events:none}.gjs-traits-label{border-bottom:1px solid rgba(0,0,0,0.2);font-weight:lighter;margin-bottom:5px;padding:10px;text-align:left}.gjs-label-wrp{width:30%;min-width:30%}.gjs-field-wrp{flex-grow:1}.gjs-trt-header{font-weight:lighter;padding:10px}.gjs-trt-trait{display:flex;justify-content:flex-start;padding:5px 10px;font-weight:lighter;align-items:center;text-align:left}.gjs-trt-traits{font-size:.75rem}.gjs-trt-trait .gjs-label{text-align:left;text-overflow:ellipsis;overflow:hidden}.gjs-guide-info{position:absolute}.gjs-guide-info__content{position:absolute;height:100%;display:flex;width:100%;padding:5px}.gjs-guide-info__line{position:relative;margin:auto}.gjs-guide-info__line::before,.gjs-guide-info__line::after{content:"";display:block;position:absolute;background-color:inherit}.gjs-guide-info__y{padding:0 5px}.gjs-guide-info__y .gjs-guide-info__content{justify-content:center}.gjs-guide-info__y .gjs-guide-info__line{width:100%;height:1px}.gjs-guide-info__y .gjs-guide-info__line::before,.gjs-guide-info__y .gjs-guide-info__line::after{width:1px;height:10px;top:0;bottom:0;left:0;margin:auto}.gjs-guide-info__y .gjs-guide-info__line::after{left:auto;right:0}.gjs-guide-info__x{padding:5px 0}.gjs-guide-info__x .gjs-guide-info__content{align-items:center}.gjs-guide-info__x .gjs-guide-info__line{height:100%;width:1px}.gjs-guide-info__x .gjs-guide-info__line::before,.gjs-guide-info__x .gjs-guide-info__line::after{width:10px;height:1px;left:0;right:0;top:0;margin:auto;transform:translateX(-50%)}.gjs-guide-info__x .gjs-guide-info__line::after{top:auto;bottom:0}.gjs-badge__icon{vertical-align:middle;display:inline-block;width:15px;height:15px}.gjs-badge__icon svg{fill:currentColor}.gjs-badge__name{display:inline-block;vertical-align:middle}.gjs-cv-canvas{background-color:rgba(0,0,0,0.15);box-sizing:border-box;width:85%;height:calc(100% - 40px);bottom:0;overflow:hidden;z-index:1;position:absolute;left:0;top:40px}.gjs-cv-canvas.gjs-is__grab .gjs-cv-canvas__frames,.gjs-cv-canvas.gjs-is__grabbing .gjs-cv-canvas__frames{pointer-events:none}.gjs-cv-canvas__frames{position:absolute;top:0;left:0;width:100%;height:100%}.gjs-cv-canvas .gjs-ghost{display:none;pointer-events:none;background-color:#5b5b5b;border:2px dashed #ccc;position:absolute;z-index:10;opacity:.55;filter:alpha(opacity=55)}.gjs-cv-canvas .gjs-highlighter,.gjs-cv-canvas .gjs-highlighter-sel{position:absolute;outline:1px solid #3b97e3;outline-offset:-1px;pointer-events:none}.gjs-cv-canvas .gjs-highlighter-warning{outline:3px solid #ffca6f}.gjs-cv-canvas .gjs-highlighter-sel{outline:3px solid #3b97e3}.gjs-cv-canvas #gjs-tools{width:100%;height:100%;position:absolute;top:0;left:0;outline:none;z-index:1}.gjs-cv-canvas *{box-sizing:border-box}.gjs-frame{outline:medium none;height:100%;width:100%;border:none;margin:auto;display:block;transition:width 0.35s ease,height 0.35s ease;position:absolute;top:0;bottom:0;left:0;right:0}.gjs-toolbar{position:absolute;background-color:#3b97e3;color:white;z-index:10;top:0;left:0}.gjs-toolbar-item{padding:5px 7px;font-size:0.8rem;cursor:pointer;width:26px;vertical-align:middle;display:inline-block}.gjs-toolbar-item svg{fill:currentColor;vertical-align:middle}.gjs-resizer-c{position:absolute;left:0;top:0;width:100%;height:100%;z-index:9}.gjs-margin-v-el,.gjs-padding-v-el,.gjs-fixedmargin-v-el,.gjs-fixedpadding-v-el{opacity:.1;filter:alpha(opacity=10);position:absolute;background-color:yellow}.gjs-fixedmargin-v-el,.gjs-fixedpadding-v-el{opacity:.2;filter:alpha(opacity=20)}.gjs-padding-v-el,.gjs-fixedpadding-v-el{background-color:navy}.gjs-resizer-h{pointer-events:all;position:absolute;border:3px solid #3b97e3;width:10px;height:10px;background-color:#fff;margin:-5px}.gjs-resizer-h-tl{top:0;left:0;cursor:nwse-resize}.gjs-resizer-h-tr{top:0;right:0;cursor:nesw-resize}.gjs-resizer-h-tc{top:0;margin:-5px auto;left:0;right:0;cursor:ns-resize}.gjs-resizer-h-cl{left:0;margin:auto -5px;top:0;bottom:0;cursor:ew-resize}.gjs-resizer-h-cr{margin:auto -5px;top:0;bottom:0;right:0;cursor:ew-resize}.gjs-resizer-h-bl{bottom:0;left:0;cursor:nesw-resize}.gjs-resizer-h-bc{bottom:0;margin:-5px auto;left:0;right:0;cursor:ns-resize}.gjs-resizer-h-br{bottom:0;right:0;cursor:nwse-resize}.gjs-pn-panel .gjs-resizer-h{background-color:rgba(0,0,0,0.2);border:none;opacity:0;transition:opacity 0.25s}.gjs-pn-panel .gjs-resizer-h:hover{opacity:1}.gjs-pn-panel .gjs-resizer-h-tc,.gjs-pn-panel .gjs-resizer-h-bc{margin:0 auto;width:100%}.gjs-pn-panel .gjs-resizer-h-cr,.gjs-pn-panel .gjs-resizer-h-cl{margin:auto 0;height:100%}.gjs-resizing .gjs-highlighter,.gjs-resizing .gjs-badge{display:none !important}.gjs-resizing-tl *{cursor:nwse-resize !important}.gjs-resizing-tr *{cursor:nesw-resize !important}.gjs-resizing-tc *{cursor:ns-resize !important}.gjs-resizing-cl *{cursor:ew-resize !important}.gjs-resizing-cr *{cursor:ew-resize !important}.gjs-resizing-bl *{cursor:nesw-resize !important}.gjs-resizing-bc *{cursor:ns-resize !important}.gjs-resizing-br *{cursor:nwse-resize !important}.btn-cl,.gjs-mdl-btn-close,.gjs-am-close{opacity:.3;filter:alpha(opacity=30);font-size:25px;cursor:pointer}.btn-cl:hover,.gjs-mdl-btn-close:hover,.gjs-am-close:hover{opacity:.7;filter:alpha(opacity=70)}.no-dots,.ui-resizable-handle{border:none !important;margin:0 !important;outline:none !important}.gjs-com-dashed *{outline:1px dashed #888;outline-offset:-2px;box-sizing:border-box}.gjs-cv-canvas .gjs-comp-selected{outline:3px solid #3b97e3 !important}*.gjs-com-hover,div.gjs-com-hover{outline:1px solid #3b97e3}*.gjs-com-hover-delete,div.gjs-com-hover-delete{outline:2px solid #dd3636;opacity:.5;filter:alpha(opacity=50)}*.gjs-com-hover-move,div.gjs-com-hover-move{outline:3px solid #ffca6f}.gjs-com-badge,.gjs-com-badge-red,.gjs-badge{pointer-events:none;background-color:#3b97e3;color:#fff;padding:2px 5px;position:absolute;z-index:1;font-size:12px;outline:none;display:none}.gjs-com-badge-red{background-color:#dd3636}.gjs-badge-warning{background-color:#ffca6f}.gjs-placeholder,.gjs-com-placeholder,.gjs-placeholder{position:absolute;z-index:10;pointer-events:none;display:none}.gjs-placeholder,.gjs-placeholder{border-style:solid !important;border-color:#62c462;outline:none;box-sizing:border-box;transition:top .2s,left .2s,width .2s,height .2s}.gjs-placeholder-int,.gjs-com-placeholder-int,.gjs-placeholder-int{background-color:#62c462;box-shadow:0 0 3px rgba(0,0,0,0.2);height:100%;width:100%;pointer-events:none;padding:1.5px;outline:none}.gjs-pn-panel{display:inline-block;position:absolute;box-sizing:border-box;text-align:center;padding:5px;z-index:3}.gjs-pn-panel .icon-undo,.gjs-pn-panel .icon-redo{font-size:20px;height:30px;width:25px}.gjs-pn-commands{width:85%;left:0;top:0;box-shadow:0 0 5px rgba(0,0,0,0.2)}.gjs-pn-options{right:15%;top:0}.gjs-pn-views{border-bottom:2px solid rgba(0,0,0,0.2);right:0;width:15%;z-index:4}.gjs-pn-views-container{height:100%;padding:42px 0 0;right:0;width:15%;overflow:auto;box-shadow:0 0 5px rgba(0,0,0,0.2)}.gjs-pn-buttons{align-items:center;display:flex;justify-content:space-between}.gjs-pn-btn{box-sizing:border-box;min-height:30px;min-width:30px;line-height:21px;background-color:transparent;border:none;font-size:18px;margin-right:5px;border-radius:2px;padding:4px;position:relative;cursor:pointer}.gjs-pn-btn.gjs-pn-active{background-color:rgba(0,0,0,0.15);box-shadow:0 0 3px rgba(0,0,0,0.25) inset}.gjs-pn-btn svg{fill:currentColor}.gjs-comp-image-placeholder{display:block;background-color:#f5f5f5;color:#777;height:50px;width:50px;line-height:50px;outline:3px solid #ffca6f;outline-offset:-3px;text-align:center;font-size:16.66667px;cursor:pointer}.gjs-comp-image-placeholder.fa-picture-o::after{content:"\f03e"}.gjs-label{line-height:18px}.gjs-fields{display:flex}.gjs-select{padding:0;width:100%}.gjs-select select{padding-right:10px}.gjs-select:-moz-focusring,.gjs-select select:-moz-focusring{color:transparent;text-shadow:0 0 0 rgba(255,255,255,0.7)}.gjs-input:focus,.gjs-button:focus,.gjs-btn-prim:focus,.gjs-select:focus,.gjs-select select:focus{outline:none}.gjs-field input,.gjs-field select,.gjs-field textarea{-webkit-appearance:none;-moz-appearance:none;appearance:none;color:inherit;border:none;background-color:transparent;box-sizing:border-box;width:100%;position:relative;padding:5px;z-index:1}.gjs-field input:focus,.gjs-field select:focus,.gjs-field textarea:focus{outline:none}.gjs-field-range{flex:9 1 auto}.gjs-field-integer input{padding-right:30px}.gjs-select option,.gjs-field-select option,.gjs-clm-select option,.gjs-sm-select option,.gjs-clm-select option,.gjs-fields option,.gjs-sm-unit option{background-color:#444;color:#ddd}.gjs-field{background-color:rgba(0,0,0,0.2);border:none;box-shadow:none;border-radius:2px;box-sizing:border-box;padding:0;position:relative}.gjs-field textarea{resize:vertical}.gjs-field .gjs-sel-arrow{height:100%;width:9px;position:absolute;right:0;top:0;z-index:0}.gjs-field .gjs-d-s-arrow{bottom:0;top:0;margin:auto;right:5px;border-top:4px solid rgba(255,255,255,0.7);position:absolute;height:0;width:0;border-left:3px solid transparent;border-right:4px solid transparent;cursor:pointer}.gjs-field-arrows{position:absolute;cursor:ns-resize;margin:auto;height:20px;width:9px;z-index:10;bottom:0;right:3px;top:0}.gjs-field-color,.gjs-field-radio{width:100%}.gjs-field-color input{padding-right:22px;box-sizing:border-box}.gjs-field-colorp{border-left:1px solid rgba(0,0,0,0.2);box-sizing:border-box;height:100%;padding:2px;position:absolute;right:0;top:0;width:22px;z-index:10}.gjs-field-colorp .gjs-checker-bg,.gjs-field-colorp .gjs-field-colorp-c{height:100%;width:100%;border-radius:1px}.gjs-field-colorp-c{height:100%;position:relative;width:100%}.gjs-field-color-picker{background-color:#ddd;cursor:pointer;height:100%;width:100%;box-shadow:0 0 1px rgba(0,0,0,0.2);border-radius:1px;position:absolute;top:0}.gjs-field-checkbox{padding:0;width:17px;height:17px;display:block;cursor:pointer}.gjs-field-checkbox input{display:none}.gjs-field-checkbox input:checked+.gjs-chk-icon{border-color:rgba(255,255,255,0.5);border-width:0 2px 2px 0;border-style:solid}.gjs-radio-item{flex:1 1 auto;text-align:center;border-left:1px solid rgba(0,0,0,0.2)}.gjs-radio-item:first-child{border:none}.gjs-radio-item:hover{background:rgba(0,0,0,0.2)}.gjs-radio-item input{display:none}.gjs-radio-item input:checked+.gjs-radio-item-label{background-color:rgba(255,255,255,0.2)}.gjs-radio-items{display:flex}.gjs-radio-item-label{cursor:pointer;display:block;padding:5px}.gjs-field-units{position:absolute;margin:auto;right:10px;bottom:0;top:0}.gjs-field-unit{position:absolute;right:10px;top:3px;font-size:10px;color:rgba(255,255,255,0.7);cursor:pointer}.gjs-field-arrow-u,.gjs-field-arrow-d{position:absolute;height:0;width:0;border-left:3px solid transparent;border-right:4px solid transparent;border-top:4px solid rgba(255,255,255,0.7);bottom:4px;cursor:pointer}.gjs-field-arrow-u{border-bottom:4px solid rgba(255,255,255,0.7);border-top:none;top:4px}.gjs-field-select{padding:0}.gjs-field-range{background-color:transparent;border:none;box-shadow:none;padding:0}.gjs-field-range input{margin:0;height:100%}.gjs-field-range input:focus{outline:none}.gjs-field-range input::-webkit-slider-thumb{-webkit-appearance:none;margin-top:-4px;height:10px;width:10px;border:1px solid rgba(0,0,0,0.2);border-radius:100%;background-color:#ddd;cursor:pointer}.gjs-field-range input::-moz-range-thumb{height:10px;width:10px;border:1px solid rgba(0,0,0,0.2);border-radius:100%;background-color:#ddd;cursor:pointer}.gjs-field-range input::-ms-thumb{height:10px;width:10px;border:1px solid rgba(0,0,0,0.2);border-radius:100%;background-color:#ddd;cursor:pointer}.gjs-field-range input::-moz-range-track{background-color:rgba(0,0,0,0.2);border-radius:1px;margin-top:3px;height:3px}.gjs-field-range input::-webkit-slider-runnable-track{background-color:rgba(0,0,0,0.2);border-radius:1px;margin-top:3px;height:3px}.gjs-field-range input::-ms-track{background-color:rgba(0,0,0,0.2);border-radius:1px;margin-top:3px;height:3px}.gjs-btn-prim{color:inherit;background-color:rgba(255,255,255,0.1);border-radius:2px;padding:3px 6px;padding:5px;cursor:pointer;border:none}.gjs-btn-prim:active{background-color:rgba(255,255,255,0.1)}.gjs-btn--full{width:100%}.gjs-chk-icon{-ms-transform:rotate(45deg);-webkit-transform:rotate(45deg);-moz-transform:rotate(45deg);transform:rotate(45deg);box-sizing:border-box;display:block;height:14px;margin:0 5px;width:6px}.gjs-add-trasp{background:none;border:none;color:#ddd;cursor:pointer;font-size:1em;border-radius:2px;opacity:.75;filter:alpha(opacity=75)}.gjs-add-trasp:hover{opacity:1;filter:alpha(opacity=100)}.gjs-add-trasp:active{background-color:rgba(0,0,0,0.2)}.gjs-devices-c{display:flex;align-items:center;padding:3px}.gjs-devices-c .gjs-device-label{flex-grow:2;text-align:left;margin-right:10px}.gjs-devices-c .gjs-select{flex-grow:20}.gjs-devices-c .gjs-add-trasp{flex-grow:1;margin-left:5px}.gjs-category-open,.gjs-sm-sector.gjs-sm-open,.gjs-sm-open.gjs-clm-tags,.gjs-block-category.gjs-open{border-bottom:1px solid rgba(0,0,0,0.25)}.gjs-category-title,.gjs-sm-sector .gjs-sm-title,.gjs-clm-tags .gjs-sm-title,.gjs-block-category .gjs-title,.gjs-layer-title{font-weight:lighter;background-color:rgba(0,0,0,0.1);letter-spacing:1px;padding:9px 10px 9px 20px;border-bottom:1px solid rgba(0,0,0,0.25);text-align:left;position:relative;cursor:pointer}.gjs-sm-clear{line-height:0;cursor:pointer}.gjs-sm-header{font-weight:lighter;padding:10px}.gjs-sm-properties{font-size:.75rem;padding:10px 5px;display:flex;flex-wrap:wrap;align-items:flex-end;box-sizing:border-box;width:100%}.gjs-sm-label{margin:5px 5px 3px 0}.gjs-sm-close-btn,.gjs-sm-sector .gjs-sm-property.gjs-sm-file #gjs-sm-preview-box #gjs-sm-close,.gjs-clm-tags .gjs-sm-property.gjs-sm-file #gjs-sm-preview-box #gjs-sm-close{display:block;font-size:23px;position:absolute;cursor:pointer;right:5px;top:0;opacity:.2;filter:alpha(opacity=20)}.gjs-sm-close-btn:hover,.gjs-sm-sector .gjs-sm-property.gjs-sm-file #gjs-sm-preview-box #gjs-sm-close:hover,.gjs-clm-tags .gjs-sm-property.gjs-sm-file #gjs-sm-preview-box #gjs-sm-close:hover{opacity:.7;filter:alpha(opacity=70)}.gjs-sm-sector,.gjs-clm-tags{clear:both;font-weight:lighter;text-align:left}.gjs-sm-sector #gjs-sm-caret,.gjs-clm-tags #gjs-sm-caret{padding-right:5px;font-size:11px}.gjs-sm-sector .gjs-sm-field,.gjs-clm-tags .gjs-sm-field,.gjs-sm-sector .gjs-clm-field,.gjs-clm-tags .gjs-clm-field,.gjs-sm-sector .gjs-clm-select,.gjs-clm-tags .gjs-clm-select{width:100%;position:relative}.gjs-sm-sector .gjs-sm-field input,.gjs-clm-tags .gjs-sm-field input,.gjs-sm-sector .gjs-clm-field input,.gjs-clm-tags .gjs-clm-field input,.gjs-sm-sector .gjs-clm-select input,.gjs-clm-tags .gjs-clm-select input,.gjs-sm-sector .gjs-sm-field select,.gjs-clm-tags .gjs-sm-field select,.gjs-sm-sector .gjs-clm-field select,.gjs-clm-tags .gjs-clm-field select,.gjs-sm-sector .gjs-clm-select select,.gjs-clm-tags .gjs-clm-select select{background-color:transparent;color:rgba(255,255,255,0.7);border:none;width:100%}.gjs-sm-sector .gjs-sm-field input,.gjs-clm-tags .gjs-sm-field input,.gjs-sm-sector .gjs-clm-field input,.gjs-clm-tags .gjs-clm-field input,.gjs-sm-sector .gjs-clm-select input,.gjs-clm-tags .gjs-clm-select input{box-sizing:border-box}.gjs-sm-sector .gjs-sm-field select,.gjs-clm-tags .gjs-sm-field select,.gjs-sm-sector .gjs-clm-field select,.gjs-clm-tags .gjs-clm-field select,.gjs-sm-sector .gjs-clm-select select,.gjs-clm-tags .gjs-clm-select select{position:relative;z-index:1;-webkit-appearance:none;-moz-appearance:none;appearance:none}.gjs-sm-sector .gjs-sm-field select::-ms-expand,.gjs-clm-tags .gjs-sm-field select::-ms-expand,.gjs-sm-sector .gjs-clm-field select::-ms-expand,.gjs-clm-tags .gjs-clm-field select::-ms-expand,.gjs-sm-sector .gjs-clm-select select::-ms-expand,.gjs-clm-tags .gjs-clm-select select::-ms-expand{display:none}.gjs-sm-sector .gjs-sm-field select:-moz-focusring,.gjs-clm-tags .gjs-sm-field select:-moz-focusring,.gjs-sm-sector .gjs-clm-field select:-moz-focusring,.gjs-clm-tags .gjs-clm-field select:-moz-focusring,.gjs-sm-sector .gjs-clm-select select:-moz-focusring,.gjs-clm-tags .gjs-clm-select select:-moz-focusring{color:transparent;text-shadow:0 0 0 rgba(255,255,255,0.7)}.gjs-sm-sector .gjs-sm-field input:focus,.gjs-clm-tags .gjs-sm-field input:focus,.gjs-sm-sector .gjs-clm-field input:focus,.gjs-clm-tags .gjs-clm-field input:focus,.gjs-sm-sector .gjs-clm-select input:focus,.gjs-clm-tags .gjs-clm-select input:focus,.gjs-sm-sector .gjs-sm-field select:focus,.gjs-clm-tags .gjs-sm-field select:focus,.gjs-sm-sector .gjs-clm-field select:focus,.gjs-clm-tags .gjs-clm-field select:focus,.gjs-sm-sector .gjs-clm-select select:focus,.gjs-clm-tags .gjs-clm-select select:focus{outline:none}.gjs-sm-sector .gjs-sm-field .gjs-sm-unit,.gjs-clm-tags .gjs-sm-field .gjs-sm-unit,.gjs-sm-sector .gjs-clm-field .gjs-sm-unit,.gjs-clm-tags .gjs-clm-field .gjs-sm-unit,.gjs-sm-sector .gjs-clm-select .gjs-sm-unit,.gjs-clm-tags .gjs-clm-select .gjs-sm-unit{position:absolute;right:10px;top:3px;font-size:10px;color:rgba(255,255,255,0.7);cursor:pointer}.gjs-sm-sector .gjs-sm-field .gjs-clm-sel-arrow,.gjs-clm-tags .gjs-sm-field .gjs-clm-sel-arrow,.gjs-sm-sector .gjs-clm-field .gjs-clm-sel-arrow,.gjs-clm-tags .gjs-clm-field .gjs-clm-sel-arrow,.gjs-sm-sector .gjs-clm-select .gjs-clm-sel-arrow,.gjs-clm-tags .gjs-clm-select .gjs-clm-sel-arrow,.gjs-sm-sector .gjs-sm-field .gjs-sm-int-arrows,.gjs-clm-tags .gjs-sm-field .gjs-sm-int-arrows,.gjs-sm-sector .gjs-clm-field .gjs-sm-int-arrows,.gjs-clm-tags .gjs-clm-field .gjs-sm-int-arrows,.gjs-sm-sector .gjs-clm-select .gjs-sm-int-arrows,.gjs-clm-tags .gjs-clm-select .gjs-sm-int-arrows,.gjs-sm-sector .gjs-sm-field .gjs-sm-sel-arrow,.gjs-clm-tags .gjs-sm-field .gjs-sm-sel-arrow,.gjs-sm-sector .gjs-clm-field .gjs-sm-sel-arrow,.gjs-clm-tags .gjs-clm-field .gjs-sm-sel-arrow,.gjs-sm-sector .gjs-clm-select .gjs-sm-sel-arrow,.gjs-clm-tags .gjs-clm-select .gjs-sm-sel-arrow{height:100%;width:9px;position:absolute;right:0;top:0;cursor:ns-resize}.gjs-sm-sector .gjs-sm-field .gjs-sm-sel-arrow,.gjs-clm-tags .gjs-sm-field .gjs-sm-sel-arrow,.gjs-sm-sector .gjs-clm-field .gjs-sm-sel-arrow,.gjs-clm-tags .gjs-clm-field .gjs-sm-sel-arrow,.gjs-sm-sector .gjs-clm-select .gjs-sm-sel-arrow,.gjs-clm-tags .gjs-clm-select .gjs-sm-sel-arrow{cursor:pointer}.gjs-sm-sector .gjs-sm-field .gjs-clm-d-s-arrow,.gjs-clm-tags .gjs-sm-field .gjs-clm-d-s-arrow,.gjs-sm-sector .gjs-clm-field .gjs-clm-d-s-arrow,.gjs-clm-tags .gjs-clm-field .gjs-clm-d-s-arrow,.gjs-sm-sector .gjs-clm-select .gjs-clm-d-s-arrow,.gjs-clm-tags .gjs-clm-select .gjs-clm-d-s-arrow,.gjs-sm-sector .gjs-sm-field .gjs-sm-d-arrow,.gjs-clm-tags .gjs-sm-field .gjs-sm-d-arrow,.gjs-sm-sector .gjs-clm-field .gjs-sm-d-arrow,.gjs-clm-tags .gjs-clm-field .gjs-sm-d-arrow,.gjs-sm-sector .gjs-clm-select .gjs-sm-d-arrow,.gjs-clm-tags .gjs-clm-select .gjs-sm-d-arrow,.gjs-sm-sector .gjs-sm-field .gjs-sm-d-s-arrow,.gjs-clm-tags .gjs-sm-field .gjs-sm-d-s-arrow,.gjs-sm-sector .gjs-clm-field .gjs-sm-d-s-arrow,.gjs-clm-tags .gjs-clm-field .gjs-sm-d-s-arrow,.gjs-sm-sector .gjs-clm-select .gjs-sm-d-s-arrow,.gjs-clm-tags .gjs-clm-select .gjs-sm-d-s-arrow,.gjs-sm-sector .gjs-sm-field .gjs-sm-u-arrow,.gjs-clm-tags .gjs-sm-field .gjs-sm-u-arrow,.gjs-sm-sector .gjs-clm-field .gjs-sm-u-arrow,.gjs-clm-tags .gjs-clm-field .gjs-sm-u-arrow,.gjs-sm-sector .gjs-clm-select .gjs-sm-u-arrow,.gjs-clm-tags .gjs-clm-select .gjs-sm-u-arrow{position:absolute;height:0;width:0;border-left:3px solid transparent;border-right:4px solid transparent;cursor:pointer}.gjs-sm-sector .gjs-sm-field .gjs-sm-u-arrow,.gjs-clm-tags .gjs-sm-field .gjs-sm-u-arrow,.gjs-sm-sector .gjs-clm-field .gjs-sm-u-arrow,.gjs-clm-tags .gjs-clm-field .gjs-sm-u-arrow,.gjs-sm-sector .gjs-clm-select .gjs-sm-u-arrow,.gjs-clm-tags .gjs-clm-select .gjs-sm-u-arrow{border-bottom:4px solid rgba(255,255,255,0.7);top:4px}.gjs-sm-sector .gjs-sm-field .gjs-clm-d-s-arrow,.gjs-clm-tags .gjs-sm-field .gjs-clm-d-s-arrow,.gjs-sm-sector .gjs-clm-field .gjs-clm-d-s-arrow,.gjs-clm-tags .gjs-clm-field .gjs-clm-d-s-arrow,.gjs-sm-sector .gjs-clm-select .gjs-clm-d-s-arrow,.gjs-clm-tags .gjs-clm-select .gjs-clm-d-s-arrow,.gjs-sm-sector .gjs-sm-field .gjs-sm-d-arrow,.gjs-clm-tags .gjs-sm-field .gjs-sm-d-arrow,.gjs-sm-sector .gjs-clm-field .gjs-sm-d-arrow,.gjs-clm-tags .gjs-clm-field .gjs-sm-d-arrow,.gjs-sm-sector .gjs-clm-select .gjs-sm-d-arrow,.gjs-clm-tags .gjs-clm-select .gjs-sm-d-arrow,.gjs-sm-sector .gjs-sm-field .gjs-sm-d-s-arrow,.gjs-clm-tags .gjs-sm-field .gjs-sm-d-s-arrow,.gjs-sm-sector .gjs-clm-field .gjs-sm-d-s-arrow,.gjs-clm-tags .gjs-clm-field .gjs-sm-d-s-arrow,.gjs-sm-sector .gjs-clm-select .gjs-sm-d-s-arrow,.gjs-clm-tags .gjs-clm-select .gjs-sm-d-s-arrow{border-top:4px solid rgba(255,255,255,0.7);bottom:4px}.gjs-sm-sector .gjs-sm-field .gjs-clm-d-s-arrow,.gjs-clm-tags .gjs-sm-field .gjs-clm-d-s-arrow,.gjs-sm-sector .gjs-clm-field .gjs-clm-d-s-arrow,.gjs-clm-tags .gjs-clm-field .gjs-clm-d-s-arrow,.gjs-sm-sector .gjs-clm-select .gjs-clm-d-s-arrow,.gjs-clm-tags .gjs-clm-select .gjs-clm-d-s-arrow,.gjs-sm-sector .gjs-sm-field .gjs-sm-d-s-arrow,.gjs-clm-tags .gjs-sm-field .gjs-sm-d-s-arrow,.gjs-sm-sector .gjs-clm-field .gjs-sm-d-s-arrow,.gjs-clm-tags .gjs-clm-field .gjs-sm-d-s-arrow,.gjs-sm-sector .gjs-clm-select .gjs-sm-d-s-arrow,.gjs-clm-tags .gjs-clm-select .gjs-sm-d-s-arrow{bottom:7px}.gjs-sm-sector .gjs-sm-field.gjs-sm-color,.gjs-clm-tags .gjs-sm-field.gjs-sm-color,.gjs-sm-sector .gjs-sm-color.gjs-clm-field,.gjs-clm-tags .gjs-sm-color.gjs-clm-field,.gjs-sm-sector .gjs-sm-color.gjs-clm-select,.gjs-clm-tags .gjs-sm-color.gjs-clm-select,.gjs-sm-sector .gjs-sm-field.gjs-sm-input,.gjs-clm-tags .gjs-sm-field.gjs-sm-input,.gjs-sm-sector .gjs-sm-input.gjs-clm-field,.gjs-clm-tags .gjs-sm-input.gjs-clm-field,.gjs-sm-sector .gjs-sm-input.gjs-clm-select,.gjs-clm-tags .gjs-sm-input.gjs-clm-select,.gjs-sm-sector .gjs-sm-field.gjs-sm-integer,.gjs-clm-tags .gjs-sm-field.gjs-sm-integer,.gjs-sm-sector .gjs-sm-integer.gjs-clm-field,.gjs-clm-tags .gjs-sm-integer.gjs-clm-field,.gjs-sm-sector .gjs-sm-integer.gjs-clm-select,.gjs-clm-tags .gjs-sm-integer.gjs-clm-select,.gjs-sm-sector .gjs-sm-field.gjs-sm-list,.gjs-clm-tags .gjs-sm-field.gjs-sm-list,.gjs-sm-sector .gjs-sm-list.gjs-clm-field,.gjs-clm-tags .gjs-sm-list.gjs-clm-field,.gjs-sm-sector .gjs-sm-list.gjs-clm-select,.gjs-clm-tags .gjs-sm-list.gjs-clm-select,.gjs-sm-sector .gjs-sm-field.gjs-sm-select,.gjs-clm-tags .gjs-sm-field.gjs-sm-select,.gjs-sm-sector .gjs-sm-select.gjs-clm-field,.gjs-clm-tags .gjs-sm-select.gjs-clm-field,.gjs-sm-sector .gjs-clm-field.gjs-clm-select,.gjs-sm-sector .gjs-clm-select,.gjs-clm-tags .gjs-clm-select{background-color:rgba(0,0,0,0.2);border:1px solid rgba(0,0,0,0.1);box-shadow:1px 1px 0 rgba(255,255,255,0.1);color:rgba(255,255,255,0.7);border-radius:2px;box-sizing:border-box;padding:0 5px}.gjs-sm-sector .gjs-sm-field.gjs-sm-composite,.gjs-clm-tags .gjs-sm-field.gjs-sm-composite,.gjs-sm-sector .gjs-sm-composite.gjs-clm-field,.gjs-clm-tags .gjs-sm-composite.gjs-clm-field,.gjs-sm-sector .gjs-sm-composite.gjs-clm-select,.gjs-clm-tags .gjs-sm-composite.gjs-clm-select{border-radius:2px}.gjs-sm-sector .gjs-sm-field.gjs-sm-select,.gjs-clm-tags .gjs-sm-field.gjs-sm-select,.gjs-sm-sector .gjs-sm-select.gjs-clm-field,.gjs-clm-tags .gjs-sm-select.gjs-clm-field,.gjs-sm-sector .gjs-clm-field.gjs-clm-select,.gjs-sm-sector .gjs-clm-select,.gjs-clm-tags .gjs-clm-select{padding:0}.gjs-sm-sector .gjs-sm-field.gjs-sm-select select,.gjs-clm-tags .gjs-sm-field.gjs-sm-select select,.gjs-sm-sector .gjs-sm-select.gjs-clm-field select,.gjs-clm-tags .gjs-sm-select.gjs-clm-field select,.gjs-sm-sector .gjs-clm-field.gjs-clm-select select,.gjs-clm-tags .gjs-clm-field.gjs-clm-select select,.gjs-sm-sector .gjs-clm-select select,.gjs-clm-tags .gjs-clm-select select{height:20px}.gjs-sm-sector .gjs-sm-field.gjs-sm-select option,.gjs-clm-tags .gjs-sm-field.gjs-sm-select option,.gjs-sm-sector .gjs-sm-select.gjs-clm-field option,.gjs-clm-tags .gjs-sm-select.gjs-clm-field option,.gjs-sm-sector .gjs-clm-field.gjs-clm-select option,.gjs-clm-tags .gjs-clm-field.gjs-clm-select option,.gjs-sm-sector .gjs-clm-select option,.gjs-clm-tags .gjs-clm-select option{padding:3px 0}.gjs-sm-sector .gjs-sm-field.gjs-sm-composite,.gjs-clm-tags .gjs-sm-field.gjs-sm-composite,.gjs-sm-sector .gjs-sm-composite.gjs-clm-field,.gjs-clm-tags .gjs-sm-composite.gjs-clm-field,.gjs-sm-sector .gjs-sm-composite.gjs-clm-select,.gjs-clm-tags .gjs-sm-composite.gjs-clm-select{background-color:rgba(0,0,0,0.1);border:1px solid rgba(0,0,0,0.25)}.gjs-sm-sector .gjs-sm-field.gjs-sm-list,.gjs-clm-tags .gjs-sm-field.gjs-sm-list,.gjs-sm-sector .gjs-sm-list.gjs-clm-field,.gjs-clm-tags .gjs-sm-list.gjs-clm-field,.gjs-sm-sector .gjs-sm-list.gjs-clm-select,.gjs-clm-tags .gjs-sm-list.gjs-clm-select{width:auto;padding:0;overflow:hidden;float:left}.gjs-sm-sector .gjs-sm-field.gjs-sm-list input,.gjs-clm-tags .gjs-sm-field.gjs-sm-list input,.gjs-sm-sector .gjs-sm-list.gjs-clm-field input,.gjs-clm-tags .gjs-sm-list.gjs-clm-field input,.gjs-sm-sector .gjs-sm-list.gjs-clm-select input,.gjs-clm-tags .gjs-sm-list.gjs-clm-select input{display:none}.gjs-sm-sector .gjs-sm-field.gjs-sm-list label,.gjs-clm-tags .gjs-sm-field.gjs-sm-list label,.gjs-sm-sector .gjs-sm-list.gjs-clm-field label,.gjs-clm-tags .gjs-sm-list.gjs-clm-field label,.gjs-sm-sector .gjs-sm-list.gjs-clm-select label,.gjs-clm-tags .gjs-sm-list.gjs-clm-select label{cursor:pointer;padding:5px;display:block}.gjs-sm-sector .gjs-sm-field.gjs-sm-list .gjs-sm-radio:checked+label,.gjs-clm-tags .gjs-sm-field.gjs-sm-list .gjs-sm-radio:checked+label,.gjs-sm-sector .gjs-sm-list.gjs-clm-field .gjs-sm-radio:checked+label,.gjs-clm-tags .gjs-sm-list.gjs-clm-field .gjs-sm-radio:checked+label,.gjs-sm-sector .gjs-sm-list.gjs-clm-select .gjs-sm-radio:checked+label,.gjs-clm-tags .gjs-sm-list.gjs-clm-select .gjs-sm-radio:checked+label{background-color:rgba(255,255,255,0.2)}.gjs-sm-sector .gjs-sm-field.gjs-sm-list .gjs-sm-icon,.gjs-clm-tags .gjs-sm-field.gjs-sm-list .gjs-sm-icon,.gjs-sm-sector .gjs-sm-list.gjs-clm-field .gjs-sm-icon,.gjs-clm-tags .gjs-sm-list.gjs-clm-field .gjs-sm-icon,.gjs-sm-sector .gjs-sm-list.gjs-clm-select .gjs-sm-icon,.gjs-clm-tags .gjs-sm-list.gjs-clm-select .gjs-sm-icon{background-repeat:no-repeat;background-position:center;text-shadow:none;line-height:normal}.gjs-sm-sector .gjs-sm-field.gjs-sm-integer select,.gjs-clm-tags .gjs-sm-field.gjs-sm-integer select,.gjs-sm-sector .gjs-sm-integer.gjs-clm-field select,.gjs-clm-tags .gjs-sm-integer.gjs-clm-field select,.gjs-sm-sector .gjs-sm-integer.gjs-clm-select select,.gjs-clm-tags .gjs-sm-integer.gjs-clm-select select{width:auto;padding:0}.gjs-sm-sector .gjs-sm-list .gjs-sm-el,.gjs-clm-tags .gjs-sm-list .gjs-sm-el{float:left;border-left:1px solid rgba(0,0,0,0.2)}.gjs-sm-sector .gjs-sm-list .gjs-sm-el:first-child,.gjs-clm-tags .gjs-sm-list .gjs-sm-el:first-child{border:none}.gjs-sm-sector .gjs-sm-list .gjs-sm-el:hover,.gjs-clm-tags .gjs-sm-list .gjs-sm-el:hover{background:rgba(0,0,0,0.2)}.gjs-sm-sector .gjs-sm-slider .gjs-field-integer,.gjs-clm-tags .gjs-sm-slider .gjs-field-integer{flex:1 1 65px}.gjs-sm-sector .gjs-sm-property,.gjs-clm-tags .gjs-sm-property{box-sizing:border-box;float:left;width:50%;margin-bottom:5px;padding:0 5px}.gjs-sm-sector .gjs-sm-property--full,.gjs-clm-tags .gjs-sm-property--full,.gjs-sm-sector .gjs-sm-property.gjs-sm-composite,.gjs-clm-tags .gjs-sm-property.gjs-sm-composite,.gjs-sm-sector .gjs-sm-property.gjs-sm-file,.gjs-clm-tags .gjs-sm-property.gjs-sm-file,.gjs-sm-sector .gjs-sm-property.gjs-sm-list,.gjs-clm-tags .gjs-sm-property.gjs-sm-list,.gjs-sm-sector .gjs-sm-property.gjs-sm-stack,.gjs-clm-tags .gjs-sm-property.gjs-sm-stack,.gjs-sm-sector .gjs-sm-property.gjs-sm-slider,.gjs-clm-tags .gjs-sm-property.gjs-sm-slider,.gjs-sm-sector .gjs-sm-property.gjs-sm-color,.gjs-clm-tags .gjs-sm-property.gjs-sm-color{width:100%}.gjs-sm-sector .gjs-sm-property .gjs-sm-btn,.gjs-clm-tags .gjs-sm-property .gjs-sm-btn{background-color:rgba(33,33,33,0.2);border-radius:2px;box-shadow:1px 1px 0 rgba(5,5,5,0.2),1px 1px 0 rgba(43,43,43,0.2) inset;padding:5px;position:relative;text-align:center;height:auto;width:100%;cursor:pointer;color:#ddd;box-sizing:border-box;text-shadow:-1px -1px 0 rgba(0,0,0,0.2);border:none;opacity:.85;filter:alpha(opacity=85)}.gjs-sm-sector .gjs-sm-property .gjs-sm-btn-c,.gjs-clm-tags .gjs-sm-property .gjs-sm-btn-c{box-sizing:border-box;float:left;width:100%}.gjs-sm-sector .gjs-sm-property.gjs-sm-file #gjs-sm-preview-box,.gjs-clm-tags .gjs-sm-property.gjs-sm-file #gjs-sm-preview-box{background-color:rgba(255,255,255,0.05);border-radius:2px;margin-top:5px;position:relative;overflow:hidden}.gjs-sm-sector .gjs-sm-property.gjs-sm-file #gjs-sm-preview-box.gjs-sm-show,.gjs-clm-tags .gjs-sm-property.gjs-sm-file #gjs-sm-preview-box.gjs-sm-show{border:1px solid rgba(252,252,252,0.05);padding:3px 20px}.gjs-sm-sector .gjs-sm-property.gjs-sm-file #gjs-sm-preview-box #gjs-sm-close,.gjs-clm-tags .gjs-sm-property.gjs-sm-file #gjs-sm-preview-box #gjs-sm-close{top:-5px;display:block}.gjs-sm-sector .gjs-sm-property.gjs-sm-file .gjs-sm-show #gjs-sm-preview-file,.gjs-clm-tags .gjs-sm-property.gjs-sm-file .gjs-sm-show #gjs-sm-preview-file{height:50px}.gjs-sm-sector .gjs-sm-property.gjs-sm-file #gjs-sm-preview-file,.gjs-clm-tags .gjs-sm-property.gjs-sm-file #gjs-sm-preview-file{background-size:auto 100%;background-repeat:no-repeat;background-position:center center}.gjs-sm-sector .gjs-sm-property .gjs-sm-layers,.gjs-clm-tags .gjs-sm-property .gjs-sm-layers{margin-top:5px;padding:1px 3px;min-height:30px}.gjs-sm-sector .gjs-sm-property .gjs-sm-layer,.gjs-clm-tags .gjs-sm-property .gjs-sm-layer{background-color:rgba(255,255,255,0.055);border-radius:2px;margin:2px 0;padding:7px;position:relative;cursor:pointer}.gjs-sm-sector .gjs-sm-property .gjs-sm-layer>#gjs-sm-preview-box,.gjs-clm-tags .gjs-sm-property .gjs-sm-layer>#gjs-sm-preview-box{height:15px;position:absolute;right:27px;top:6px;width:15px}.gjs-sm-sector .gjs-sm-property .gjs-sm-layer #gjs-sm-preview,.gjs-clm-tags .gjs-sm-property .gjs-sm-layer #gjs-sm-preview,.gjs-sm-sector .gjs-sm-property .gjs-sm-layer #gjs-sm-preview-box,.gjs-clm-tags .gjs-sm-property .gjs-sm-layer #gjs-sm-preview-box{border-radius:2px}.gjs-sm-sector .gjs-sm-property .gjs-sm-layer #gjs-sm-close-layer,.gjs-clm-tags .gjs-sm-property .gjs-sm-layer #gjs-sm-close-layer{display:block;font-size:23px;position:absolute;cursor:pointer;right:5px;top:0;opacity:.5;filter:alpha(opacity=50)}.gjs-sm-sector .gjs-sm-property .gjs-sm-layer #gjs-sm-close-layer:hover,.gjs-clm-tags .gjs-sm-property .gjs-sm-layer #gjs-sm-close-layer:hover{opacity:.8;filter:alpha(opacity=80)}.gjs-sm-sector .gjs-sm-property .gjs-sm-layer>#gjs-sm-preview-box #gjs-sm-preview,.gjs-clm-tags .gjs-sm-property .gjs-sm-layer>#gjs-sm-preview-box #gjs-sm-preview{background-color:white;height:100%;width:100%;background-size:cover !important}.gjs-sm-sector .gjs-sm-property .gjs-sm-layer.gjs-sm-active,.gjs-clm-tags .gjs-sm-property .gjs-sm-layer.gjs-sm-active{background-color:rgba(255,255,255,0.12)}.gjs-sm-sector .gjs-sm-property .gjs-sm-layer.gjs-sm-no-preview #gjs-sm-preview-box,.gjs-clm-tags .gjs-sm-property .gjs-sm-layer.gjs-sm-no-preview #gjs-sm-preview-box{display:none}.gjs-sm-sector #gjs-sm-text-shadow #gjs-sm-preview::after,.gjs-clm-tags #gjs-sm-text-shadow #gjs-sm-preview::after{color:#000;content:"T";font-weight:900;line-height:17px;padding:0 4px}.gjs-sm-sector .gjs-sm-stack .gjs-sm-properties,.gjs-clm-tags .gjs-sm-stack .gjs-sm-properties{padding:5px 0 0}.gjs-sm-sector .gjs-sm-stack #gjs-sm-add,.gjs-clm-tags .gjs-sm-stack #gjs-sm-add{background:none;border:none;cursor:pointer;outline:none;font-size:22px;line-height:10px;position:absolute;right:0;top:-17px;opacity:0.75}.gjs-sm-sector .gjs-sm-stack #gjs-sm-add:hover,.gjs-clm-tags .gjs-sm-stack #gjs-sm-add:hover{opacity:1;filter:alpha(opacity=100)}.gjs-sm-sector .gjs-sm-colorp-c,.gjs-clm-tags .gjs-sm-colorp-c{height:100%;width:20px;position:absolute;right:0;top:0;box-sizing:border-box;border-radius:2px;padding:2px}.gjs-sm-sector .gjs-sm-colorp-c .gjs-checker-bg,.gjs-clm-tags .gjs-sm-colorp-c .gjs-checker-bg,.gjs-sm-sector .gjs-sm-colorp-c .gjs-field-colorp-c,.gjs-clm-tags .gjs-sm-colorp-c .gjs-field-colorp-c{height:100%;width:100%;border-radius:1px}.gjs-sm-sector .gjs-sm-color-picker,.gjs-clm-tags .gjs-sm-color-picker{background-color:#ddd;cursor:pointer;height:16px;width:100%;margin-top:-16px;box-shadow:0 0 1px rgba(0,0,0,0.2);border-radius:1px}.gjs-sm-sector .gjs-sm-btn-upload #gjs-sm-upload,.gjs-clm-tags .gjs-sm-btn-upload #gjs-sm-upload{left:0;top:0;position:absolute;width:100%;opacity:0;cursor:pointer}.gjs-sm-sector .gjs-sm-btn-upload #gjs-sm-label,.gjs-clm-tags .gjs-sm-btn-upload #gjs-sm-label{padding:2px 0}.gjs-sm-layer>#gjs-sm-move{opacity:.7;filter:alpha(opacity=70);cursor:move;font-size:12px;float:left;margin:0 5px 0 0}.gjs-sm-layer>#gjs-sm-move:hover{opacity:.9;filter:alpha(opacity=90)}.gjs-blocks-c{display:flex;flex-wrap:wrap;justify-content:flex-start}.gjs-block-categories{display:flex;flex-direction:column}.gjs-block-category{width:100%}.gjs-block-category .gjs-caret-icon{margin-right:5px}.gjs-block{-moz-user-select:none;-khtml-user-select:none;-webkit-user-select:none;-ms-user-select:none;-o-user-select:none;user-select:none;width:45%;min-width:45px;padding:1em;box-sizing:border-box;min-height:90px;cursor:all-scroll;font-size:11px;font-weight:lighter;text-align:center;display:flex;flex-direction:column;justify-content:space-between;border:1px solid rgba(0,0,0,0.2);border-radius:3px;margin:10px 2.5% 5px;box-shadow:0 1px 0 0 rgba(0,0,0,0.15);transition:all 0.2s ease 0s;transition-property:box-shadow, color}.gjs-block:hover{box-shadow:0 3px 4px 0 rgba(0,0,0,0.15)}.gjs-block svg{fill:currentColor}.gjs-block__media{margin-bottom:10px}.gjs-block-svg{width:54px;fill:currentColor}.gjs-block-svg-path{fill:currentColor}.gjs-block.fa{font-size:2em;line-height:2em;padding:11px}.gjs-block-label{line-height:normal;font-size:0.65rem;font-weight:normal;font-family:Helvetica, sans-serif;overflow:hidden;text-overflow:ellipsis}.gjs-block.gjs-bdrag{width:auto;padding:0}.gjs-selected-parent{border:1px solid #ffca6f}.gjs-opac50{opacity:.5;filter:alpha(opacity=50)}.gjs-layer{font-weight:lighter;text-align:left;position:relative;background-color:rgba(0,0,0,0.1);font-size:.75rem}.gjs-layer-hidden{opacity:.55;filter:alpha(opacity=55)}.gjs-layer-count{position:absolute;right:27px;top:9px}.gjs-layer-vis{height:auto !important;width:auto !important;left:0;top:0;padding:7px 5px 7px 10px;position:absolute;cursor:pointer;z-index:1}.gjs-layer-caret{font-size:0.5rem;width:8px;padding:2px;cursor:pointer;position:absolute;left:-9px;top:6px;opacity:.7;filter:alpha(opacity=70)}.gjs-layer-caret:hover{opacity:1;filter:alpha(opacity=100)}.gjs-layer-title{padding:3px 10px 5px 30px;display:flex;align-items:center}.gjs-layer-title-inn{align-items:center;position:relative;display:flex;width:100%}.gjs-layer__icon{display:block;width:100%;max-width:15px;max-height:15px;padding-left:5px}.gjs-layer__icon svg{fill:currentColor}.gjs-layer-name{padding:5px 0;display:inline-block;box-sizing:content-box;overflow:hidden;white-space:nowrap;margin:0 30px 0 5px}.gjs-layer-name--no-edit{text-overflow:ellipsis}.gjs-layer>.gjs-layer-children{display:none}.gjs-layer.open>.gjs-layer-children{display:block}.gjs-layer-no-chld>.gjs-layer-title-inn>.gjs-layer-caret{display:none}.gjs-layer-move{padding:7px 10px 7px 5px;position:absolute;font-size:12px;cursor:move;right:0;top:0}.gjs-layer.gjs-hovered .gjs-layer-title{background-color:rgba(255,255,255,0.015)}.gjs-layer.gjs-selected .gjs-layer-title{background-color:rgba(255,255,255,0.1)}.gjs-layers{position:relative;height:100%}.gjs-layers #gjs-placeholder{width:100%;position:absolute}.gjs-layers #gjs-placeholder #gjs-plh-int{height:100%;padding:1px}.gjs-layers #gjs-placeholder #gjs-plh-int.gjs-insert{background-color:#62c462}.gjs-clm-tags{font-size:.75rem;padding:10px 5px}.gjs-clm-tags #gjs-clm-label,.gjs-clm-tags #gjs-clm-sel{padding:7px 0;float:left}.gjs-clm-tags #gjs-clm-sel{font-style:italic;margin-left:5px}.gjs-clm-tags #gjs-clm-status-c{float:right}.gjs-clm-tags #gjs-clm-tags-field{clear:both;padding:5px;margin-bottom:5px}.gjs-clm-tags #gjs-clm-tags-c{display:inline-block;vertical-align:top}.gjs-clm-tags #gjs-clm-add-tag{background-color:rgba(255,255,255,0.15);border-radius:2px;padding:5px 6px;box-shadow:1px 1px 0 rgba(255,255,255,0.2) inset;border:1px solid rgba(0,0,0,0.15);cursor:pointer}.gjs-clm-tags #gjs-clm-new{color:#ddd;padding:5px 6px;display:none}.gjs-clm-tags .gjs-clm-tag{display:inline-block;border-radius:3px;margin:0 3px 3px 0;padding:5px;cursor:default}.gjs-clm-tags #gjs-clm-close{font-size:20px;line-height:0;cursor:pointer;color:rgba(255,255,255,0.9)}.gjs-clm-tags #gjs-clm-close:hover{opacity:.7;filter:alpha(opacity=70)}.gjs-clm-tags #gjs-clm-checkbox{color:rgba(255,255,255,0.9);vertical-align:middle;cursor:pointer;font-size:9px}.gjs-clm-tags #gjs-clm-tag-label{padding:0 3px;cursor:text}.gjs-mdl-container{font-family:Helvetica,sans-serif;overflow-y:auto;position:fixed;background-color:rgba(0,0,0,0.5);display:flex;top:0;left:0;right:0;bottom:0;z-index:100}.gjs-mdl-dialog{text-shadow:-1px -1px 0 rgba(0,0,0,0.05);animation:gjs-slide-down 0.215s;margin:auto;max-width:850px;width:90%;border-radius:3px;font-weight:lighter;position:relative;z-index:2}.gjs-mdl-title{font-size:1rem}.gjs-mdl-btn-close{position:absolute;right:15px;top:5px}.gjs-mdl-active .gjs-mdl-dialog{animation:gjs-mdl-slide-down 0.216s}.gjs-mdl-header,.gjs-mdl-content{padding:10px 15px;clear:both}.gjs-mdl-header{position:relative;border-bottom:1px solid rgba(0,0,0,0.2);padding:15px 15px 7px}.gjs-export-dl::after{content:"";clear:both;display:block;margin-bottom:10px}.gjs-dropzone{display:none;opacity:0;position:absolute;top:0;left:0;z-index:11;width:100%;height:100%;transition:opacity 0.25s;pointer-events:none}.gjs-dropzone-active .gjs-dropzone{display:block;opacity:1}.gjs-am-assets{height:290px;overflow:auto;clear:both;display:flex;flex-wrap:wrap;align-items:flex-start;align-content:flex-start}.gjs-am-assets-header{padding:5px}.gjs-am-add-asset .gjs-am-add-field{width:70%;float:left}.gjs-am-add-asset button{width:25%;float:right}.gjs-am-preview-cont{position:relative;height:70px;width:30%;background-color:#444;border-radius:2px;float:left;overflow:hidden}.gjs-am-preview{position:absolute;background-position:center center;background-size:cover;background-repeat:no-repeat;height:100%;width:100%;z-index:1}.gjs-am-preview-bg{opacity:.5;filter:alpha(opacity=50);position:absolute;height:100%;width:100%;z-index:0}.gjs-am-dimensions{opacity:.5;filter:alpha(opacity=50);font-size:10px}.gjs-am-meta{width:70%;float:left;font-size:12px;padding:5px 0 0 5px;box-sizing:border-box}.gjs-am-meta>div{margin-bottom:5px}.gjs-am-close{cursor:pointer;position:absolute;right:5px;top:0;display:none}.gjs-am-asset{border-bottom:1px solid rgba(0,0,0,0.2);padding:5px;cursor:pointer;position:relative;box-sizing:border-box;width:100%}.gjs-am-asset:hover .gjs-am-close{display:block}.gjs-am-highlight{background-color:rgba(255,255,255,0.1)}.gjs-am-assets-cont{background-color:rgba(0,0,0,0.1);border-radius:3px;box-sizing:border-box;padding:10px;width:45%;float:right;height:325px;overflow:hidden}.gjs-am-file-uploader{width:55%;float:left}.gjs-am-file-uploader>form{background-color:rgba(0,0,0,0.1);border:2px dashed;border-radius:3px;position:relative;text-align:center;margin-bottom:15px}.gjs-am-file-uploader>form.gjs-am-hover{border:2px solid #62c462;color:#75cb75}.gjs-am-file-uploader>form.gjs-am-disabled{border-color:red}.gjs-am-file-uploader>form #gjs-am-uploadFile{opacity:0;filter:alpha(opacity=0);padding:150px 10px;width:100%;box-sizing:border-box}.gjs-am-file-uploader #gjs-am-title{position:absolute;padding:150px 10px;width:100%}.gjs-cm-editor-c{float:left;box-sizing:border-box;width:50%}.gjs-cm-editor-c .CodeMirror{height:450px}.gjs-cm-editor{font-size:12px}.gjs-cm-editor#gjs-cm-htmlmixed{padding-right:10px;border-right:1px solid rgba(0,0,0,0.2)}.gjs-cm-editor#gjs-cm-htmlmixed #gjs-cm-title{color:#a97d44}.gjs-cm-editor#gjs-cm-css{padding-left:10px}.gjs-cm-editor#gjs-cm-css #gjs-cm-title{color:#ddca7e}.gjs-cm-editor #gjs-cm-title{background-color:rgba(0,0,0,0.2);font-size:12px;padding:5px 10px 3px;text-align:right}.gjs-rte-toolbar{border:1px solid rgba(0,0,0,0.2);position:absolute;border-radius:3px;z-index:10}.gjs-rte-actionbar{display:flex}.gjs-rte-action{display:flex;align-items:center;justify-content:center;padding:5px;min-width:25px;border-right:1px solid rgba(0,0,0,0.2);text-align:center;cursor:pointer;outline:none}.gjs-rte-action:last-child{border-right:none}.gjs-rte-action:hover{background-color:rgba(255,255,255,0.1)}.gjs-rte-active{background-color:rgba(0,0,0,0.2)}.gjs-editor-cont .sp-hue,.gjs-editor-cont .sp-slider{cursor:row-resize}.gjs-editor-cont .sp-color,.gjs-editor-cont .sp-dragger{cursor:crosshair}.gjs-editor-cont .sp-alpha-inner,.gjs-editor-cont .sp-alpha-handle{cursor:col-resize}.gjs-editor-cont .sp-hue{left:90%}.gjs-editor-cont .sp-color{right:15%}.gjs-editor-cont .sp-container{border:1px solid rgba(0,0,0,0.2);box-shadow:0 0 7px rgba(0,0,0,0.2);border-radius:3px}.gjs-editor-cont .sp-picker-container{border:none}.gjs-editor-cont .colpick_dark .colpick_color{outline:1px solid rgba(0,0,0,0.2)}.gjs-editor-cont .sp-cancel,.gjs-editor-cont .sp-cancel:hover{bottom:-8px;color:#777 !important;font-size:25px;left:0;position:absolute;text-decoration:none}.gjs-editor-cont .sp-alpha-handle{background-color:#ccc;border:1px solid #555;width:4px}.gjs-editor-cont .sp-color,.gjs-editor-cont .sp-hue{border:1px solid #333333}.gjs-editor-cont .sp-slider{background-color:#ccc;border:1px solid #555;height:3px;left:-4px;width:22px}.gjs-editor-cont .sp-dragger{background:transparent;box-shadow:0 0 0 1px #111}.gjs-editor-cont .sp-button-container{float:none;width:100%;position:relative;text-align:right}.gjs-editor-cont .sp-container button,.gjs-editor-cont .sp-container button:hover,.gjs-editor-cont .sp-container button:active{background:rgba(0,0,0,0.2);border-color:rgba(0,0,0,0.2);color:#ddd;text-shadow:none;box-shadow:none;padding:3px 5px}.gjs-editor-cont .sp-palette-container{border:none;float:none;margin:0;padding:5px 10px 0}.gjs-editor-cont .sp-palette .sp-thumb-el,.gjs-editor-cont .sp-palette .sp-thumb-el:hover{border:1px solid rgba(0,0,0,0.9)}.gjs-editor-cont .sp-palette .sp-thumb-el:hover,.gjs-editor-cont .sp-palette .sp-thumb-el.sp-thumb-active{border-color:rgba(0,0,0,0.9)}.gjs-hidden{display:none}@keyframes gjs-slide-down{0%{transform:translate(0, -3rem);opacity:0}100%{transform:translate(0, 0);opacity:1}}@keyframes gjs-slide-up{0%{transform:translate(0, 0);opacity:1}100%{transform:translate(0, -3rem);opacity:0}}.cm-s-hopscotch span.cm-error{color:#ffffff} diff --git a/dist/fonts/FontAwesome.otf b/dist/fonts/FontAwesome.otf index 3ed7f8b48..401ec0f36 100644 Binary files a/dist/fonts/FontAwesome.otf and b/dist/fonts/FontAwesome.otf differ diff --git a/dist/fonts/fontawesome-webfont.eot b/dist/fonts/fontawesome-webfont.eot index 9b6afaedc..e9f60ca95 100644 Binary files a/dist/fonts/fontawesome-webfont.eot and b/dist/fonts/fontawesome-webfont.eot differ diff --git a/dist/fonts/fontawesome-webfont.svg b/dist/fonts/fontawesome-webfont.svg index d05688e9e..855c845e5 100644 --- a/dist/fonts/fontawesome-webfont.svg +++ b/dist/fonts/fontawesome-webfont.svg @@ -1,655 +1,2671 @@ - - + + +Created by FontForge 20120731 at Mon Oct 24 17:37:40 2016 + By ,,, +Copyright Dave Gandy 2016. All rights reserved. + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/dist/fonts/fontawesome-webfont.ttf b/dist/fonts/fontawesome-webfont.ttf index 26dea7951..35acda2fa 100644 Binary files a/dist/fonts/fontawesome-webfont.ttf and b/dist/fonts/fontawesome-webfont.ttf differ diff --git a/dist/fonts/fontawesome-webfont.woff b/dist/fonts/fontawesome-webfont.woff index dc35ce3c2..400014a4b 100644 Binary files a/dist/fonts/fontawesome-webfont.woff and b/dist/fonts/fontawesome-webfont.woff differ diff --git a/dist/fonts/fontawesome-webfont.woff2 b/dist/fonts/fontawesome-webfont.woff2 index 500e51725..4d13fc604 100644 Binary files a/dist/fonts/fontawesome-webfont.woff2 and b/dist/fonts/fontawesome-webfont.woff2 differ diff --git a/dist/grapes.js b/dist/grapes.js index 0b303ebb5..f156bbfc1 100644 --- a/dist/grapes.js +++ b/dist/grapes.js @@ -7,7 +7,7 @@ exports["grapesjs"] = factory(); else root["grapesjs"] = factory(); -})(this, function() { +})(window, function() { return /******/ (function(modules) { // webpackBootstrap /******/ // The module cache /******/ var installedModules = {}; @@ -46,14 +46,34 @@ return /******/ (function(modules) { // webpackBootstrap /******/ // define getter function for harmony exports /******/ __webpack_require__.d = function(exports, name, getter) { /******/ if(!__webpack_require__.o(exports, name)) { -/******/ Object.defineProperty(exports, name, { -/******/ configurable: false, -/******/ enumerable: true, -/******/ get: getter -/******/ }); +/******/ Object.defineProperty(exports, name, { enumerable: true, get: getter }); /******/ } /******/ }; /******/ +/******/ // define __esModule on exports +/******/ __webpack_require__.r = function(exports) { +/******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) { +/******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' }); +/******/ } +/******/ Object.defineProperty(exports, '__esModule', { value: true }); +/******/ }; +/******/ +/******/ // create a fake namespace object +/******/ // mode & 1: value is a module id, require it +/******/ // mode & 2: merge all properties of value into the ns +/******/ // mode & 4: return value when already ns object +/******/ // mode & 8|1: behave like require +/******/ __webpack_require__.t = function(value, mode) { +/******/ if(mode & 1) value = __webpack_require__(value); +/******/ if(mode & 8) return value; +/******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value; +/******/ var ns = Object.create(null); +/******/ __webpack_require__.r(ns); +/******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value }); +/******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key)); +/******/ return ns; +/******/ }; +/******/ /******/ // getDefaultExport function for compatibility with non-harmony modules /******/ __webpack_require__.n = function(module) { /******/ var getter = module && module.__esModule ? @@ -69,35505 +89,37489 @@ return /******/ (function(modules) { // webpackBootstrap /******/ // __webpack_public_path__ /******/ __webpack_require__.p = ""; /******/ +/******/ /******/ // Load entry module and return exports -/******/ return __webpack_require__(__webpack_require__.s = 58); +/******/ return __webpack_require__(__webpack_require__.s = "./src/index.js"); /******/ }) /************************************************************************/ -/******/ ([ -/* 0 */ -/***/ (function(module, exports, __webpack_require__) { +/******/ ({ -/* WEBPACK VAR INJECTION */(function(global) {var __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;// Backbone.js 1.3.3 +/***/ "./node_modules/@babel/runtime/helpers/arrayWithHoles.js": +/*!***************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/arrayWithHoles.js ***! + \***************************************************************/ +/*! no static exports found */ +/***/ (function(module, exports) { -// (c) 2010-2016 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors -// Backbone may be freely distributed under the MIT license. -// For all details and documentation: -// http://backbonejs.org +function _arrayWithHoles(arr) { + if (Array.isArray(arr)) return arr; +} -(function(factory) { +module.exports = _arrayWithHoles; - // Establish the root object, `window` (`self`) in the browser, or `global` on the server. - // We use `self` instead of `window` for `WebWorker` support. - var root = (typeof self == 'object' && self.self === self && self) || - (typeof global == 'object' && global.global === global && global); +/***/ }), - // Set up Backbone appropriately for the environment. Start with AMD. - if (true) { - !(__WEBPACK_AMD_DEFINE_ARRAY__ = [__webpack_require__(1), __webpack_require__(9), exports], __WEBPACK_AMD_DEFINE_RESULT__ = function(_, $, exports) { - // Export global even in AMD case in case this script is loaded with - // others that may still expect a global Backbone. - root.Backbone = factory(root, exports, _, $); - }.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__), - __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)); +/***/ "./node_modules/@babel/runtime/helpers/arrayWithoutHoles.js": +/*!******************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/arrayWithoutHoles.js ***! + \******************************************************************/ +/*! no static exports found */ +/***/ (function(module, exports) { - // Next for Node.js or CommonJS. jQuery may not be needed as a module. - } else if (typeof exports !== 'undefined') { - var _ = require('underscore'), $; - try { $ = require('jquery'); } catch (e) {} - factory(root, exports, _, $); +function _arrayWithoutHoles(arr) { + if (Array.isArray(arr)) { + for (var i = 0, arr2 = new Array(arr.length); i < arr.length; i++) { + arr2[i] = arr[i]; + } - // Finally, as a browser global. - } else { - root.Backbone = factory(root, {}, root._, (root.jQuery || root.Zepto || root.ender || root.$)); + return arr2; } +} -})(function(root, Backbone, _, $) { +module.exports = _arrayWithoutHoles; - // Initial Setup - // ------------- +/***/ }), - // Save the previous value of the `Backbone` variable, so that it can be - // restored later on, if `noConflict` is used. - var previousBackbone = root.Backbone; +/***/ "./node_modules/@babel/runtime/helpers/classCallCheck.js": +/*!***************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/classCallCheck.js ***! + \***************************************************************/ +/*! no static exports found */ +/***/ (function(module, exports) { - // Create a local reference to a common array method we'll want to use later. - var slice = Array.prototype.slice; +function _classCallCheck(instance, Constructor) { + if (!(instance instanceof Constructor)) { + throw new TypeError("Cannot call a class as a function"); + } +} - // Current version of the library. Keep in sync with `package.json`. - Backbone.VERSION = '1.3.3'; +module.exports = _classCallCheck; - // For Backbone's purposes, jQuery, Zepto, Ender, or My Library (kidding) owns - // the `$` variable. - Backbone.$ = $; +/***/ }), - // Runs Backbone.js in *noConflict* mode, returning the `Backbone` variable - // to its previous owner. Returns a reference to this Backbone object. - Backbone.noConflict = function() { - root.Backbone = previousBackbone; - return this; - }; +/***/ "./node_modules/@babel/runtime/helpers/createClass.js": +/*!************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/createClass.js ***! + \************************************************************/ +/*! no static exports found */ +/***/ (function(module, exports) { - // Turn on `emulateHTTP` to support legacy HTTP servers. Setting this option - // will fake `"PATCH"`, `"PUT"` and `"DELETE"` requests via the `_method` parameter and - // set a `X-Http-Method-Override` header. - Backbone.emulateHTTP = false; +function _defineProperties(target, props) { + for (var i = 0; i < props.length; i++) { + var descriptor = props[i]; + descriptor.enumerable = descriptor.enumerable || false; + descriptor.configurable = true; + if ("value" in descriptor) descriptor.writable = true; + Object.defineProperty(target, descriptor.key, descriptor); + } +} - // Turn on `emulateJSON` to support legacy servers that can't deal with direct - // `application/json` requests ... this will encode the body as - // `application/x-www-form-urlencoded` instead and will send the model in a - // form param named `model`. - Backbone.emulateJSON = false; +function _createClass(Constructor, protoProps, staticProps) { + if (protoProps) _defineProperties(Constructor.prototype, protoProps); + if (staticProps) _defineProperties(Constructor, staticProps); + return Constructor; +} - // Proxy Backbone class methods to Underscore functions, wrapping the model's - // `attributes` object or collection's `models` array behind the scenes. - // - // collection.filter(function(model) { return model.get('age') > 10 }); - // collection.each(this.addView); - // - // `Function#apply` can be slow so we use the method's arg count, if we know it. - var addMethod = function(length, method, attribute) { - switch (length) { - case 1: return function() { - return _[method](this[attribute]); - }; - case 2: return function(value) { - return _[method](this[attribute], value); - }; - case 3: return function(iteratee, context) { - return _[method](this[attribute], cb(iteratee, this), context); - }; - case 4: return function(iteratee, defaultVal, context) { - return _[method](this[attribute], cb(iteratee, this), defaultVal, context); - }; - default: return function() { - var args = slice.call(arguments); - args.unshift(this[attribute]); - return _[method].apply(_, args); - }; - } - }; - var addUnderscoreMethods = function(Class, methods, attribute) { - _.each(methods, function(length, method) { - if (_[method]) Class.prototype[method] = addMethod(length, method, attribute); - }); - }; +module.exports = _createClass; - // Support `collection.sortBy('attr')` and `collection.findWhere({id: 1})`. - var cb = function(iteratee, instance) { - if (_.isFunction(iteratee)) return iteratee; - if (_.isObject(iteratee) && !instance._isModel(iteratee)) return modelMatcher(iteratee); - if (_.isString(iteratee)) return function(model) { return model.get(iteratee); }; - return iteratee; - }; - var modelMatcher = function(attrs) { - var matcher = _.matches(attrs); - return function(model) { - return matcher(model.attributes); - }; - }; +/***/ }), - // Backbone.Events - // --------------- +/***/ "./node_modules/@babel/runtime/helpers/defineProperty.js": +/*!***************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/defineProperty.js ***! + \***************************************************************/ +/*! no static exports found */ +/***/ (function(module, exports) { - // A module that can be mixed in to *any object* in order to provide it with - // a custom event channel. You may bind a callback to an event with `on` or - // remove with `off`; `trigger`-ing an event fires all callbacks in - // succession. - // - // var object = {}; - // _.extend(object, Backbone.Events); - // object.on('expand', function(){ alert('expanded'); }); - // object.trigger('expand'); - // - var Events = Backbone.Events = {}; +function _defineProperty(obj, key, value) { + if (key in obj) { + Object.defineProperty(obj, key, { + value: value, + enumerable: true, + configurable: true, + writable: true + }); + } else { + obj[key] = value; + } - // Regular expression used to split event strings. - var eventSplitter = /\s+/; + return obj; +} - // Iterates over the standard `event, callback` (as well as the fancy multiple - // space-separated events `"change blur", callback` and jQuery-style event - // maps `{event: callback}`). - var eventsApi = function(iteratee, events, name, callback, opts) { - var i = 0, names; - if (name && typeof name === 'object') { - // Handle event maps. - if (callback !== void 0 && 'context' in opts && opts.context === void 0) opts.context = callback; - for (names = _.keys(name); i < names.length ; i++) { - events = eventsApi(iteratee, events, names[i], name[names[i]], opts); - } - } else if (name && eventSplitter.test(name)) { - // Handle space-separated event names by delegating them individually. - for (names = name.split(eventSplitter); i < names.length; i++) { - events = iteratee(events, names[i], callback, opts); - } - } else { - // Finally, standard events. - events = iteratee(events, name, callback, opts); - } - return events; - }; +module.exports = _defineProperty; - // Bind an event to a `callback` function. Passing `"all"` will bind - // the callback to all events fired. - Events.on = function(name, callback, context) { - return internalOn(this, name, callback, context); - }; +/***/ }), - // Guard the `listening` argument from the public API. - var internalOn = function(obj, name, callback, context, listening) { - obj._events = eventsApi(onApi, obj._events || {}, name, callback, { - context: context, - ctx: obj, - listening: listening - }); +/***/ "./node_modules/@babel/runtime/helpers/iterableToArray.js": +/*!****************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/iterableToArray.js ***! + \****************************************************************/ +/*! no static exports found */ +/***/ (function(module, exports) { - if (listening) { - var listeners = obj._listeners || (obj._listeners = {}); - listeners[listening.id] = listening; - } +function _iterableToArray(iter) { + if (Symbol.iterator in Object(iter) || Object.prototype.toString.call(iter) === "[object Arguments]") return Array.from(iter); +} - return obj; - }; +module.exports = _iterableToArray; - // Inversion-of-control versions of `on`. Tell *this* object to listen to - // an event in another object... keeping track of what it's listening to - // for easier unbinding later. - Events.listenTo = function(obj, name, callback) { - if (!obj) return this; - var id = obj._listenId || (obj._listenId = _.uniqueId('l')); - var listeningTo = this._listeningTo || (this._listeningTo = {}); - var listening = listeningTo[id]; +/***/ }), - // This object is not listening to any other events on `obj` yet. - // Setup the necessary references to track the listening callbacks. - if (!listening) { - var thisId = this._listenId || (this._listenId = _.uniqueId('l')); - listening = listeningTo[id] = {obj: obj, objId: id, id: thisId, listeningTo: listeningTo, count: 0}; - } +/***/ "./node_modules/@babel/runtime/helpers/iterableToArrayLimit.js": +/*!*********************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/iterableToArrayLimit.js ***! + \*********************************************************************/ +/*! no static exports found */ +/***/ (function(module, exports) { - // Bind callbacks on obj, and keep track of them on listening. - internalOn(obj, name, callback, this, listening); - return this; - }; +function _iterableToArrayLimit(arr, i) { + if (!(Symbol.iterator in Object(arr) || Object.prototype.toString.call(arr) === "[object Arguments]")) { + return; + } - // The reducing API that adds a callback to the `events` object. - var onApi = function(events, name, callback, options) { - if (callback) { - var handlers = events[name] || (events[name] = []); - var context = options.context, ctx = options.ctx, listening = options.listening; - if (listening) listening.count++; + var _arr = []; + var _n = true; + var _d = false; + var _e = undefined; - handlers.push({callback: callback, context: context, ctx: context || ctx, listening: listening}); + try { + for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { + _arr.push(_s.value); + + if (i && _arr.length === i) break; } - return events; - }; + } catch (err) { + _d = true; + _e = err; + } finally { + try { + if (!_n && _i["return"] != null) _i["return"](); + } finally { + if (_d) throw _e; + } + } - // Remove one or many callbacks. If `context` is null, removes all - // callbacks with that function. If `callback` is null, removes all - // callbacks for the event. If `name` is null, removes all bound - // callbacks for all events. - Events.off = function(name, callback, context) { - if (!this._events) return this; - this._events = eventsApi(offApi, this._events, name, callback, { - context: context, - listeners: this._listeners - }); - return this; - }; + return _arr; +} - // Tell this object to stop listening to either specific events ... or - // to every object it's currently listening to. - Events.stopListening = function(obj, name, callback) { - var listeningTo = this._listeningTo; - if (!listeningTo) return this; +module.exports = _iterableToArrayLimit; - var ids = obj ? [obj._listenId] : _.keys(listeningTo); +/***/ }), - for (var i = 0; i < ids.length; i++) { - var listening = listeningTo[ids[i]]; +/***/ "./node_modules/@babel/runtime/helpers/nonIterableRest.js": +/*!****************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/nonIterableRest.js ***! + \****************************************************************/ +/*! no static exports found */ +/***/ (function(module, exports) { - // If listening doesn't exist, this object is not currently - // listening to obj. Break out early. - if (!listening) break; +function _nonIterableRest() { + throw new TypeError("Invalid attempt to destructure non-iterable instance"); +} - listening.obj.off(name, callback, this); - } +module.exports = _nonIterableRest; - return this; - }; +/***/ }), - // The reducing API that removes a callback from the `events` object. - var offApi = function(events, name, callback, options) { - if (!events) return; +/***/ "./node_modules/@babel/runtime/helpers/nonIterableSpread.js": +/*!******************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/nonIterableSpread.js ***! + \******************************************************************/ +/*! no static exports found */ +/***/ (function(module, exports) { - var i = 0, listening; - var context = options.context, listeners = options.listeners; +function _nonIterableSpread() { + throw new TypeError("Invalid attempt to spread non-iterable instance"); +} - // Delete all events listeners and "drop" events. - if (!name && !callback && !context) { - var ids = _.keys(listeners); - for (; i < ids.length; i++) { - listening = listeners[ids[i]]; - delete listeners[listening.id]; - delete listening.listeningTo[listening.objId]; - } - return; - } - - var names = name ? [name] : _.keys(events); - for (; i < names.length; i++) { - name = names[i]; - var handlers = events[name]; +module.exports = _nonIterableSpread; - // Bail out if there are no events stored. - if (!handlers) break; +/***/ }), - // Replace events if there are any remaining. Otherwise, clean up. - var remaining = []; - for (var j = 0; j < handlers.length; j++) { - var handler = handlers[j]; - if ( - callback && callback !== handler.callback && - callback !== handler.callback._callback || - context && context !== handler.context - ) { - remaining.push(handler); - } else { - listening = handler.listening; - if (listening && --listening.count === 0) { - delete listeners[listening.id]; - delete listening.listeningTo[listening.objId]; - } - } - } +/***/ "./node_modules/@babel/runtime/helpers/slicedToArray.js": +/*!**************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/slicedToArray.js ***! + \**************************************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { - // Update tail event if the list has any events. Otherwise, clean up. - if (remaining.length) { - events[name] = remaining; - } else { - delete events[name]; - } - } - return events; - }; +var arrayWithHoles = __webpack_require__(/*! ./arrayWithHoles */ "./node_modules/@babel/runtime/helpers/arrayWithHoles.js"); - // Bind an event to only be triggered a single time. After the first time - // the callback is invoked, its listener will be removed. If multiple events - // are passed in using the space-separated syntax, the handler will fire - // once for each event, not once for a combination of all events. - Events.once = function(name, callback, context) { - // Map the event into a `{event: once}` object. - var events = eventsApi(onceMap, {}, name, callback, _.bind(this.off, this)); - if (typeof name === 'string' && context == null) callback = void 0; - return this.on(events, callback, context); - }; +var iterableToArrayLimit = __webpack_require__(/*! ./iterableToArrayLimit */ "./node_modules/@babel/runtime/helpers/iterableToArrayLimit.js"); - // Inversion-of-control versions of `once`. - Events.listenToOnce = function(obj, name, callback) { - // Map the event into a `{event: once}` object. - var events = eventsApi(onceMap, {}, name, callback, _.bind(this.stopListening, this, obj)); - return this.listenTo(obj, events); - }; +var nonIterableRest = __webpack_require__(/*! ./nonIterableRest */ "./node_modules/@babel/runtime/helpers/nonIterableRest.js"); - // Reduces the event callbacks into a map of `{event: onceWrapper}`. - // `offer` unbinds the `onceWrapper` after it has been called. - var onceMap = function(map, name, callback, offer) { - if (callback) { - var once = map[name] = _.once(function() { - offer(name, once); - callback.apply(this, arguments); - }); - once._callback = callback; - } - return map; - }; +function _slicedToArray(arr, i) { + return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || nonIterableRest(); +} - // Trigger one or many events, firing all bound callbacks. Callbacks are - // passed the same arguments as `trigger` is, apart from the event name - // (unless you're listening on `"all"`, which will cause your callback to - // receive the true name of the event as the first argument). - Events.trigger = function(name) { - if (!this._events) return this; +module.exports = _slicedToArray; - var length = Math.max(0, arguments.length - 1); - var args = Array(length); - for (var i = 0; i < length; i++) args[i] = arguments[i + 1]; +/***/ }), - eventsApi(triggerApi, this._events, name, void 0, args); - return this; - }; +/***/ "./node_modules/@babel/runtime/helpers/toConsumableArray.js": +/*!******************************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/toConsumableArray.js ***! + \******************************************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { - // Handles triggering the appropriate event callbacks. - var triggerApi = function(objEvents, name, callback, args) { - if (objEvents) { - var events = objEvents[name]; - var allEvents = objEvents.all; - if (events && allEvents) allEvents = allEvents.slice(); - if (events) triggerEvents(events, args); - if (allEvents) triggerEvents(allEvents, [name].concat(args)); - } - return objEvents; - }; +var arrayWithoutHoles = __webpack_require__(/*! ./arrayWithoutHoles */ "./node_modules/@babel/runtime/helpers/arrayWithoutHoles.js"); - // A difficult-to-believe, but optimized internal dispatch function for - // triggering events. Tries to keep the usual cases speedy (most internal - // Backbone events have 3 arguments). - var triggerEvents = function(events, args) { - var ev, i = -1, l = events.length, a1 = args[0], a2 = args[1], a3 = args[2]; - switch (args.length) { - case 0: while (++i < l) (ev = events[i]).callback.call(ev.ctx); return; - case 1: while (++i < l) (ev = events[i]).callback.call(ev.ctx, a1); return; - case 2: while (++i < l) (ev = events[i]).callback.call(ev.ctx, a1, a2); return; - case 3: while (++i < l) (ev = events[i]).callback.call(ev.ctx, a1, a2, a3); return; - default: while (++i < l) (ev = events[i]).callback.apply(ev.ctx, args); return; - } - }; +var iterableToArray = __webpack_require__(/*! ./iterableToArray */ "./node_modules/@babel/runtime/helpers/iterableToArray.js"); - // Aliases for backwards compatibility. - Events.bind = Events.on; - Events.unbind = Events.off; +var nonIterableSpread = __webpack_require__(/*! ./nonIterableSpread */ "./node_modules/@babel/runtime/helpers/nonIterableSpread.js"); - // Allow the `Backbone` object to serve as a global event bus, for folks who - // want global "pubsub" in a convenient place. - _.extend(Backbone, Events); +function _toConsumableArray(arr) { + return arrayWithoutHoles(arr) || iterableToArray(arr) || nonIterableSpread(); +} - // Backbone.Model - // -------------- +module.exports = _toConsumableArray; - // Backbone **Models** are the basic data object in the framework -- - // frequently representing a row in a table in a database on your server. - // A discrete chunk of data and a bunch of useful, related methods for - // performing computations and transformations on that data. +/***/ }), - // Create a new model with the specified attributes. A client id (`cid`) - // is automatically generated and assigned for you. - var Model = Backbone.Model = function(attributes, options) { - var attrs = attributes || {}; - options || (options = {}); - this.cid = _.uniqueId(this.cidPrefix); - this.attributes = {}; - if (options.collection) this.collection = options.collection; - if (options.parse) attrs = this.parse(attrs, options) || {}; - var defaults = _.result(this, 'defaults'); - attrs = _.defaults(_.extend({}, defaults, attrs), defaults); - this.set(attrs, options); - this.changed = {}; - this.initialize.apply(this, arguments); - }; +/***/ "./node_modules/@babel/runtime/helpers/typeof.js": +/*!*******************************************************!*\ + !*** ./node_modules/@babel/runtime/helpers/typeof.js ***! + \*******************************************************/ +/*! no static exports found */ +/***/ (function(module, exports) { - // Attach all inheritable methods to the Model prototype. - _.extend(Model.prototype, Events, { +function _typeof2(obj) { if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof2 = function _typeof2(obj) { return typeof obj; }; } else { _typeof2 = function _typeof2(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof2(obj); } - // A hash of attributes whose current and previous value differ. - changed: null, +function _typeof(obj) { + if (typeof Symbol === "function" && _typeof2(Symbol.iterator) === "symbol") { + module.exports = _typeof = function _typeof(obj) { + return _typeof2(obj); + }; + } else { + module.exports = _typeof = function _typeof(obj) { + return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : _typeof2(obj); + }; + } - // The value returned during the last failed validation. - validationError: null, + return _typeof(obj); +} - // The default name for the JSON `id` attribute is `"id"`. MongoDB and - // CouchDB users may want to set this to `"_id"`. - idAttribute: 'id', +module.exports = _typeof; - // The prefix is used to create the client id which is used to identify models locally. - // You may want to override this if you're experiencing name clashes with model ids. - cidPrefix: 'c', +/***/ }), - // Initialize is an empty function by default. Override it with your own - // initialization logic. - initialize: function(){}, +/***/ "./node_modules/backbone-undo/Backbone.Undo.js": +/*!*****************************************************!*\ + !*** ./node_modules/backbone-undo/Backbone.Undo.js ***! + \*****************************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { - // Return a copy of the model's `attributes` object. - toJSON: function(options) { - return _.clone(this.attributes); - }, +var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;/*! + * Backbone.Undo.js v0.2 + * + * Copyright (c)2013 Oliver Sartun + * Released under the MIT License + * + * Documentation and full license available at + * https://github.com/osartun/Backbone.Undo.js + */ - // Proxy `Backbone.sync` by default -- but override this if you need - // custom syncing semantics for *this* particular model. - sync: function() { - return Backbone.sync.apply(this, arguments); - }, - // Get the value of an attribute. - get: function(attr) { - return this.attributes[attr]; - }, +(function (factory) { + if (true) { + // AMD support + !(__WEBPACK_AMD_DEFINE_ARRAY__ = [__webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"), __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js")], __WEBPACK_AMD_DEFINE_FACTORY__ = (factory), + __WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ? + (__WEBPACK_AMD_DEFINE_FACTORY__.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__)) : __WEBPACK_AMD_DEFINE_FACTORY__), + __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)); + } else {} +})(function (_, Backbone) { - // Get the HTML-escaped value of an attribute. - escape: function(attr) { - return _.escape(this.get(attr)); - }, + var core_slice = Array.prototype.slice; - // Returns `true` if the attribute contains a value that is not null - // or undefined. - has: function(attr) { - return this.get(attr) != null; - }, + /** + * As call is faster than apply, this is a faster version of apply as it uses call. + * + * @param {Function} fn The function to execute + * @param {Object} ctx The context the function should be called in + * @param {Array} args The array of arguments that should be applied to the function + * @return Forwards whatever the called function returns + */ + function apply (fn, ctx, args) { + return args.length <= 4 ? + fn.call(ctx, args[0], args[1], args[2], args[3]) : + fn.apply(ctx, args); + } - // Special-cased proxy to underscore's `_.matches` method. - matches: function(attrs) { - return !!_.iteratee(attrs, this)(this.attributes); - }, + /** + * Uses slice on an array or an array-like object. + * + * @param {Array|Object} arr The array or array-like object. + * @param {Number} [index] The index from where the array should be sliced. Default is 0. + * @return {Array} The sliced array + */ + function slice (arr, index) { + return core_slice.call(arr, index); + } - // Set a hash of model attributes on the object, firing `"change"`. This is - // the core primitive operation of a model, updating the data and notifying - // anyone who needs to know about the change in state. The heart of the beast. - set: function(key, val, options) { - if (key == null) return this; + /** + * Checks if an object has one or more specific keys. The keys + * don't have to be an owned property. + * You can call this function either this way: + * hasKeys(obj, ["a", "b", "c"]) + * or this way: + * hasKeys(obj, "a", "b", "c") + * + * @param {Object} obj The object to check on + * @param {Array} keys The keys to check for + * @return {Boolean} True, if the object has all those keys + */ + function hasKeys (obj, keys) { + if (obj == null) return false; + if (!_.isArray(keys)) { + keys = slice(arguments, 1); + } + return _.all(keys, function (key) { + return key in obj; + }); + } - // Handle both `"key", value` and `{key: value}` -style arguments. - var attrs; - if (typeof key === 'object') { - attrs = key; - options = val; - } else { - (attrs = {})[key] = val; - } - - options || (options = {}); - - // Run validation. - if (!this._validate(attrs, options)) return false; + /** + * Returns a number that is unique per call stack. The number gets + * changed after the call stack has been completely processed. + * + * @return {number} MagicFusionIndex + */ + var getMagicFusionIndex = (function () { + // If you add several models to a collection or set several + // attributes on a model all in sequence and yet all for + // example in one function, then several Undo-Actions are + // generated. + // If you want to undo your last action only the last model + // would be removed from the collection or the last set + // attribute would be changed back to its previous value. + // To prevent that we have to figure out a way to combine + // all those actions that happened "at the same time". + // Timestamps aren't exact enough. A complex routine could + // run several milliseconds and in that time produce a lot + // of actions with different timestamps. + // Instead we take advantage of the single-threadedness of + // JavaScript: - // Extract attributes and options. - var unset = options.unset; - var silent = options.silent; - var changes = []; - var changing = this._changing; - this._changing = true; + var callstackWasIndexed = false, magicFusionIndex = -1; + function indexCycle() { + magicFusionIndex++; + callstackWasIndexed = true; + _.defer(function () { + // Here comes the magic. With a Timeout of 0 + // milliseconds this function gets called whenever + // the current callstack is completed + callstackWasIndexed = false; + }) + } + return function () { + if (!callstackWasIndexed) { + indexCycle(); + } + return magicFusionIndex; + } + })(); - if (!changing) { - this._previousAttributes = _.clone(this.attributes); - this.changed = {}; - } + /** + * To prevent binding a listener several times to one + * object, we register the objects in an ObjectRegistry + * + * @constructor + */ + function ObjectRegistry () { + // This uses two different ways of storing + // objects: In case the object has a cid + // (which Backbone objects typically have) + // it uses this cid as an index. That way + // the Array's length attribute doesn't + // change and the object isn't an item + // in the array, but an object-property. + // Otherwise it's added to the Array as an + // item. + // That way we can use the fast property- + // lookup and only have to fall back to + // iterating over the array in case + // non-Backbone-objects are registered. + this.registeredObjects = []; + // To return a list of all registered + // objects in the 'get' method we have to + // store the objects that have a cid in + // an additional array. + this.cidIndexes = []; + } + ObjectRegistry.prototype = { + /** + * Returns whether the object is already registered in this ObjectRegistry or not. + * + * @this {ObjectRegistry} + * @param {Object} obj The object to check + * @return {Boolean} True if the object is already registered + */ + isRegistered: function (obj) { + // This is where we get a performance boost + // by using the two different ways of storing + // objects. + return obj && obj.cid ? this.registeredObjects[obj.cid] : _.contains(this.registeredObjects, obj); + }, + /** + * Registers an object in this ObjectRegistry. + * + * @this {ObjectRegistry} + * @param {Object} obj The object to register + * @return {undefined} + */ + register: function (obj) { + if (!this.isRegistered(obj)) { + if (obj && obj.cid) { + this.registeredObjects[obj.cid] = obj; + this.cidIndexes.push(obj.cid); + } else { + this.registeredObjects.push(obj); + } + return true; + } + return false; + }, + /** + * Unregisters an object from this ObjectRegistry. + * + * @this {ObjectRegistry} + * @param {Object} obj The object to unregister + * @return {undefined} + */ + unregister: function (obj) { + if (this.isRegistered(obj)) { + if (obj && obj.cid) { + delete this.registeredObjects[obj.cid]; + this.cidIndexes.splice(_.indexOf(this.cidIndexes, obj.cid), 1); + } else { + var i = _.indexOf(this.registeredObjects, obj); + this.registeredObjects.splice(i, 1); + } + return true; + } + return false; + }, + /** + * Returns an array of all objects that are currently in this ObjectRegistry. + * + * @return {Array} An array of all the objects which are currently in the ObjectRegistry + */ + get: function () { + return (_.map(this.cidIndexes, function (cid) {return this.registeredObjects[cid];}, this)).concat(this.registeredObjects); + } + } - var current = this.attributes; - var changed = this.changed; - var prev = this._previousAttributes; + /** + * Binds or unbinds the "all"-listener for one or more objects. + * + * @param {String} which Either "on" or "off" + * @param {Object[]} objects Array of the objects on which the "all"-listener should be bound / unbound to + * @param {Function} [fn] The function that should be bound / unbound. Optional in case of "off" + * @param {Object} [ctx] The context the function should be called in + * @return {undefined} + */ + function onoff(which, objects, fn, ctx) { + for (var i = 0, l = objects.length, obj; i < l; i++) { + obj = objects[i]; + if (!obj) continue; + if (which === "on") { + if (!ctx.objectRegistry.register(obj)) { + // register returned false, so obj was already registered + continue; + } + } else { + if (!ctx.objectRegistry.unregister(obj)) { + // unregister returned false, so obj wasn't registered + continue; + } + } + if (_.isFunction(obj[which])) { + obj[which]("all", fn, ctx); + } + } + } - // For each `set` attribute, update or delete the current value. - for (var attr in attrs) { - val = attrs[attr]; - if (!_.isEqual(current[attr], val)) changes.push(attr); - if (!_.isEqual(prev[attr], val)) { - changed[attr] = val; - } else { - delete changed[attr]; - } - unset ? delete current[attr] : current[attr] = val; - } + /** + * Calls the undo/redo-function for a specific action. + * + * @param {String} which Either "undo" or "redo" + * @param {Object} action The Action's attributes + * @return {undefined} + */ + function actionUndoRedo (which, action) { + var type = action.type, undoTypes = action.undoTypes, fn = !undoTypes[type] || undoTypes[type][which]; + if (_.isFunction(fn)) { + fn(action.object, action.before, action.after, action.options); + } + } - // Update the `id`. - if (this.idAttribute in attrs) this.id = this.get(this.idAttribute); + /** + * The main undo/redo function. + * + * @param {String} which Either "undo" or "redo" + * @param {UndoManager} manager The UndoManager-instance on which an "undo"/"redo"-Event is triggered afterwards + * @param {UndoStack} stack The UndoStack on which we perform + * @param {Boolean} magic If true, undoes / redoes all actions with the same magicFusionIndex + * @param {Boolean} everything If true, undoes / redoes every action that had been tracked + * @return {undefined} + */ + function managerUndoRedo (which, manager, stack, magic, everything) { + if (stack.isCurrentlyUndoRedoing || + (which === "undo" && stack.pointer === -1) || + (which === "redo" && stack.pointer === stack.length - 1)) { + // We're either currently in an undo- / redo-process or + // we reached the end of the stack + return; + } + stack.isCurrentlyUndoRedoing = true; + var action, actions, isUndo = which === "undo"; + if (everything) { + // Undo / Redo all steps until you reach the stack's beginning / end + actions = isUndo && stack.pointer === stack.length - 1 || // If at the stack's end calling undo + !isUndo && stack.pointer === -1 ? // or at the stack's beginning calling redo + _.clone(stack.models) : // => Take all the models. Otherwise: + core_slice.apply(stack.models, isUndo ? [0, stack.pointer] : [stack.pointer, stack.length - 1]); + } else { + // Undo / Redo only one step + action = stack.at(isUndo ? stack.pointer : stack.pointer + 1); + actions = magic ? stack.where({"magicFusionIndex": action.get("magicFusionIndex")}) : [action]; + } + + stack.pointer += (isUndo ? -1 : 1) * actions.length; + while (action = isUndo ? actions.pop() : actions.shift()) { + // Here we're calling the Action's undo / redo method + action[which](); + } + stack.isCurrentlyUndoRedoing = false; - // Trigger all relevant attribute changes. - if (!silent) { - if (changes.length) this._pending = options; - for (var i = 0; i < changes.length; i++) { - this.trigger('change:' + changes[i], this, current[changes[i]], options); - } - } + manager.trigger(which, manager); + } - // You might be wondering why there's a `while` loop here. Changes can - // be recursively nested within `"change"` events. - if (changing) return this; - if (!silent) { - while (this._pending) { - options = this._pending; - this._pending = false; - this.trigger('change', this, options); - } - } - this._pending = false; - this._changing = false; - return this; - }, - - // Remove an attribute from the model, firing `"change"`. `unset` is a noop - // if the attribute doesn't exist. - unset: function(attr, options) { - return this.set(attr, void 0, _.extend({}, options, {unset: true})); - }, + /** + * Checks whether an UndoAction should be created or not. Therefore it checks + * whether a "condition" property is set in the undoTypes-object of the specific + * event type. If not, it returns true. If it's set and a boolean, it returns it. + * If it's a function, it returns its result, converting it into a boolean. + * Otherwise it returns true. + * + * @param {Object} undoTypesType The object within the UndoTypes that holds the function for this event type (i.e. "change") + * @param {Arguments} args The arguments the "condition" function is called with + * @return {Boolean} True, if an UndoAction should be created + */ + function validateUndoActionCreation (undoTypesType, args) { + var condition = undoTypesType.condition, type = typeof condition; + return type === "function" ? !!apply(condition, undoTypesType, args) : + type === "boolean" ? condition : true; + } - // Clear all attributes on the model, firing `"change"`. - clear: function(options) { - var attrs = {}; - for (var key in this.attributes) attrs[key] = void 0; - return this.set(attrs, _.extend({}, options, {unset: true})); - }, + /** + * Adds an Undo-Action to the stack. + * + * @param {UndoStack} stack The undostack the action should be added to. + * @param {String} type The event type (i.e. "change") + * @param {Arguments} args The arguments passed to the undoTypes' "on"-handler + * @param {OwnedUndoTypes} undoTypes The undoTypes-object which has the "on"-handler + * @return {undefined} + */ + function addToStack(stack, type, args, undoTypes) { + if (stack.track && !stack.isCurrentlyUndoRedoing && type in undoTypes && + validateUndoActionCreation(undoTypes[type], args)) { + // An UndoAction should be created + var res = apply(undoTypes[type]["on"], undoTypes[type], args), diff; + if (hasKeys(res, "object", "before", "after")) { + res.type = type; + res.magicFusionIndex = getMagicFusionIndex(); + res.undoTypes = undoTypes; + if (stack.pointer < stack.length - 1) { + // New Actions must always be added to the end of the stack. + // If the pointer is not pointed to the last action in the + // stack, presumably because actions were undone before, then + // all following actions must be discarded + var diff = stack.length - stack.pointer - 1; + while (diff--) { + stack.pop(); + } + } + stack.pointer = stack.length; + stack.add(res); + if (stack.length > stack.maximumStackLength) { + stack.shift(); + stack.pointer--; + } + } + } + } - // Determine if the model has changed since the last `"change"` event. - // If you specify an attribute name, determine if that attribute has changed. - hasChanged: function(attr) { - if (attr == null) return !_.isEmpty(this.changed); - return _.has(this.changed, attr); - }, - // Return an object containing all the attributes that have changed, or - // false if there are no changed attributes. Useful for determining what - // parts of a view need to be updated and/or what attributes need to be - // persisted to the server. Unset attributes will be set to undefined. - // You can also pass an attributes object to diff against the model, - // determining if there *would be* a change. - changedAttributes: function(diff) { - if (!diff) return this.hasChanged() ? _.clone(this.changed) : false; - var old = this._changing ? this._previousAttributes : this.attributes; - var changed = {}; - for (var attr in diff) { - var val = diff[attr]; - if (_.isEqual(old[attr], val)) continue; - changed[attr] = val; - } - return _.size(changed) ? changed : false; - }, + /** + * Predefined UndoTypes object with default handlers for the most common events. + * @type {Object} + */ + var UndoTypes = { + "add": { + "undo": function (collection, ignore, model, options) { + // Undo add = remove + collection.remove(model, options); + }, + "redo": function (collection, ignore, model, options) { + // Redo add = add + if (options.index) { + options.at = options.index; + } + collection.add(model, options); + }, + "on": function (model, collection, options) { + return { + object: collection, + before: undefined, + after: model, + options: _.clone(options) + }; + } + }, + "remove": { + "undo": function (collection, model, ignore, options) { + if ("index" in options) { + options.at = options.index; + } + collection.add(model, options); + }, + "redo": function (collection, model, ignore, options) { + collection.remove(model, options); + }, + "on": function (model, collection, options) { + return { + object: collection, + before: model, + after: undefined, + options: _.clone(options) + }; + } + }, + "change": { + "undo": function (model, before, after, options) { + if (_.isEmpty(before)) { + _.each(_.keys(after), model.unset, model); + } else { + model.set(before); + if (options && options.unsetData && options.unsetData.before && options.unsetData.before.length) { + _.each(options.unsetData.before, model.unset, model); + } + } + }, + "redo": function (model, before, after, options) { + if (_.isEmpty(after)) { + _.each(_.keys(before), model.unset, model); + } else { + model.set(after); + if (options && options.unsetData && options.unsetData.after && options.unsetData.after.length) { + _.each(options.unsetData.after, model.unset, model); + } + } + }, + "on": function (model, options) { + var + afterAttributes = model.changedAttributes(), + keysAfter = _.keys(afterAttributes), + previousAttributes = _.pick(model.previousAttributes(), keysAfter), + keysPrevious = _.keys(previousAttributes), + unsetData = (options || (options = {})).unsetData = { + after: [], + before: [] + }; - // Get the previous value of an attribute, recorded at the time the last - // `"change"` event was fired. - previous: function(attr) { - if (attr == null || !this._previousAttributes) return null; - return this._previousAttributes[attr]; - }, + if (keysAfter.length != keysPrevious.length) { + // There are new attributes or old attributes have been unset + if (keysAfter.length > keysPrevious.length) { + // New attributes have been added + _.each(keysAfter, function (val) { + if (!(val in previousAttributes)) { + unsetData.before.push(val); + } + }, this); + } else { + // Old attributes have been unset + _.each(keysPrevious, function (val) { + if (!(val in afterAttributes)) { + unsetData.after.push(val); + } + }) + } + } + return { + object: model, + before: previousAttributes, + after: afterAttributes, + options: _.clone(options) + }; + } + }, + "reset": { + "undo": function (collection, before, after) { + collection.reset(before); + }, + "redo": function (collection, before, after) { + collection.reset(after); + }, + "on": function (collection, options) { + return { + object: collection, + before: options.previousModels, + after: _.clone(collection.models) + }; + } + } + }; - // Get all of the attributes of the model at the time of the previous - // `"change"` event. - previousAttributes: function() { - return _.clone(this._previousAttributes); - }, + /** + * Every UndoManager instance has an own undoTypes object + * which is an instance of OwnedUndoTypes. OwnedUndoTypes' + * prototype is the global UndoTypes object. Changes to the + * global UndoTypes object take effect on every instance of + * UndoManager as the object is its prototype. And yet every + * local UndoTypes object can be changed individually. + * + * @constructor + */ + function OwnedUndoTypes () {} + OwnedUndoTypes.prototype = UndoTypes; - // Fetch the model from the server, merging the response with the model's - // local attributes. Any changed attributes will trigger a "change" event. - fetch: function(options) { - options = _.extend({parse: true}, options); - var model = this; - var success = options.success; - options.success = function(resp) { - var serverAttrs = options.parse ? model.parse(resp, options) : resp; - if (!model.set(serverAttrs, options)) return false; - if (success) success.call(options.context, model, resp, options); - model.trigger('sync', model, resp, options); - }; - wrapError(this, options); - return this.sync('read', this, options); - }, + /** + * Adds, changes or removes an undo-type from an UndoTypes-object. + * You can call it this way: + * manipulateUndoType (1, "reset", {"on": function () {}}, undoTypes) + * or this way to perform bulk actions: + * manipulateUndoType (1, {"reset": {"on": function () {}}}, undoTypes) + * In case of removing undo-types you can pass an Array for performing + * bulk actions: + * manipulateUndoType(2, ["reset", "change"], undoTypes) + * + * @param {Number} manipType Indicates the kind of action to execute: 0 for add, 1 for change, 2 for remove + * @param {String|Object|Array} undoType The type of undoType that should be added/changed/removed. Can be an object / array to perform bulk actions + * @param {Object} [fns] Object with the functions to add / change. Is optional in case you passed an object as undoType that contains these functions + * @param {OwnedUndoTypes|UndoTypes} undoTypesInstance The undoTypes object to act on + * @return {undefined} + */ + function manipulateUndoType (manipType, undoType, fns, undoTypesInstance) { + // manipType, passed by the calling function + // 0: add + // 1: change + // 2: remove + if (typeof undoType === "object") { + // bulk action. Iterate over this data. + return _.each(undoType, function (val, key) { + if (manipType === 2) { // remove + // undoType is an array + manipulateUndoType (manipType, val, fns, undoTypesInstance); + } else { + // undoType is an object + manipulateUndoType (manipType, key, val, fns); + } + }) + } - // Set a hash of model attributes, and sync the model to the server. - // If the server returns an attributes hash that differs, the model's - // state will be `set` again. - save: function(key, val, options) { - // Handle both `"key", value` and `{key: value}` -style arguments. - var attrs; - if (key == null || typeof key === 'object') { - attrs = key; - options = val; - } else { - (attrs = {})[key] = val; - } + switch (manipType) { + case 0: // add + if (hasKeys(fns, "undo", "redo", "on") && _.all(_.pick(fns, "undo", "redo", "on"), _.isFunction)) { + undoTypesInstance[undoType] = fns; + } + break; + case 1: // change + if (undoTypesInstance[undoType] && _.isObject(fns)) { + // undoTypeInstance[undoType] may be a prototype's property + // So, if we did this _.extend(undoTypeInstance[undoType], fns) + // we would extend the object on the prototype which means + // that this change would have a global effect + // Instead we just want to manipulate this instance. That's why + // we're doing this: + undoTypesInstance[undoType] = _.extend({}, undoTypesInstance[undoType], fns); + } + break; + case 2: // remove + delete undoTypesInstance[undoType]; + break; + } + return this; + } - options = _.extend({validate: true, parse: true}, options); - var wait = options.wait; + /** + * Instantiating "Action" creates the UndoActions that + * are collected in an UndoStack. It holds all relevant + * data to undo / redo an action and has an undo / redo + * method. + */ + var Action = Backbone.Model.extend({ + defaults: { + type: null, // "add", "change", "reset", etc. + object: null, // The object on which the action occurred + before: null, // The previous values which were changed with this action + after: null, // The values after this action + magicFusionIndex: null // The magicFusionIndex helps to combine + // all actions that occurred "at the same time" to undo/redo them altogether + }, + /** + * Undoes this action. + * @param {OwnedUndoTypes|UndoTypes} undoTypes The undoTypes object which contains the "undo"-handler that should be used + * @return {undefined} + */ + undo: function (undoTypes) { + actionUndoRedo("undo", this.attributes); + }, + /** + * Redoes this action. + * @param {OwnedUndoTypes|UndoTypes} undoTypes The undoTypes object which contains the "redo"-handler that should be used + * @return {undefined} + */ + redo: function (undoTypes) { + actionUndoRedo("redo", this.attributes); + } + }), + /** + * An UndoStack is a collection of UndoActions in + * chronological order. + */ + UndoStack = Backbone.Collection.extend({ + model: Action, + pointer: -1, // The pointer indicates the index where we are located within the stack. We start at -1 + track: false, + isCurrentlyUndoRedoing: false, + maximumStackLength: Infinity, + setMaxLength: function (val) { + this.maximumStackLength = val; + } + }), + /** + * An instance of UndoManager can keep track of + * changes to objects and helps to undo them. + */ + UndoManager = Backbone.Model.extend({ + defaults: { + maximumStackLength: Infinity, + track: false + }, + /** + * The constructor function. + * @param {attr} [attr] Object with parameters. The available parameters are: + * - maximumStackLength {number} Set the undo-stack's maximum size + * - track {boolean} Start tracking changes right away + * @return {undefined} + */ + initialize: function (attr) { + this.stack = new UndoStack; + this.objectRegistry = new ObjectRegistry(); + this.undoTypes = new OwnedUndoTypes(); - // If we're not waiting and attributes exist, save acts as - // `set(attr).save(null, opts)` with validation. Otherwise, check if - // the model will be valid when the attributes, if any, are set. - if (attrs && !wait) { - if (!this.set(attrs, options)) return false; - } else if (!this._validate(attrs, options)) { - return false; - } + // sync the maximumStackLength attribute with our stack + this.stack.setMaxLength(this.get("maximumStackLength")); + this.on("change:maximumStackLength", function (model, value) { + this.stack.setMaxLength(value); + }, this); - // After a successful server-side save, the client is (optionally) - // updated with the server-side state. - var model = this; - var success = options.success; - var attributes = this.attributes; - options.success = function(resp) { - // Ensure attributes are restored during synchronous saves. - model.attributes = attributes; - var serverAttrs = options.parse ? model.parse(resp, options) : resp; - if (wait) serverAttrs = _.extend({}, attrs, serverAttrs); - if (serverAttrs && !model.set(serverAttrs, options)) return false; - if (success) success.call(options.context, model, resp, options); - model.trigger('sync', model, resp, options); - }; - wrapError(this, options); + // Start tracking, if attr.track == true + if (attr && attr.track) { + this.startTracking(); + } - // Set temporary attributes if `{wait: true}` to properly find new ids. - if (attrs && wait) this.attributes = _.extend({}, attributes, attrs); + // Register objects passed in the "register" attribute + if (attr && attr.register) { + if (_.isArray(attr.register) || _.isArguments(attr.register)) { + apply(this.register, this, attr.register); + } else { + this.register(attr.register); + } + } + }, + /** + * Starts tracking. Changes of registered objects won't be processed until you've called this function + * @return {undefined} + */ + startTracking: function () { + this.set("track", true); + this.stack.track = true; + }, + /** + * Stops tracking. Afterwards changes of registered objects won't be processed. + * @return {undefined} + */ + stopTracking: function () { + this.set("track", false); + this.stack.track = false; + }, + /** + * Return the state of the tracking + * @return {boolean} + */ + isTracking: function () { + return this.get("track"); + }, + /** + * This is the "all"-handler which is bound to registered + * objects. It creates an UndoAction from the event and adds + * it to the stack. + * + * @param {String} type The event type + * @return {undefined} + */ + _addToStack: function (type) { + addToStack(this.stack, type, slice(arguments, 1), this.undoTypes); + }, + /** + * Registers one or more objects to track their changes. + * @param {...Object} obj The object or objects of which changes should be tracked + * @return {undefined} + */ + register: function () { + onoff("on", arguments, this._addToStack, this); + }, + /** + * Unregisters one or more objects. + * @param {...Object} obj The object or objects of which changes shouldn't be tracked any longer + * @return {undefined} + */ + unregister: function () { + onoff("off", arguments, this._addToStack, this); + }, + /** + * Unregisters all previously registered objects. + * @return {undefined} + */ + unregisterAll: function () { + apply(this.unregister, this, this.objectRegistry.get()); + }, + /** + * Undoes the last action or the last set of actions in case 'magic' is true. + * @param {Boolean} [magic] If true, all actions that happened basically at the same time are undone together + * @return {undefined} + */ + undo: function (magic) { + managerUndoRedo("undo", this, this.stack, magic); + }, - var method = this.isNew() ? 'create' : (options.patch ? 'patch' : 'update'); - if (method === 'patch' && !options.attrs) options.attrs = attrs; - var xhr = this.sync(method, this, options); + /** + * Undoes all actions ever tracked by the undo manager + * @return {undefined} + */ + undoAll: function () { + managerUndoRedo("undo", this, this.stack, false, true); + }, - // Restore attributes. - this.attributes = attributes; + /** + * Redoes a previously undone action or a set of actions. + * @param {Boolean} [magic] If true, all actions that happened basically at the same time are redone together + * @return {undefined} + */ + redo: function (magic) { + managerUndoRedo("redo", this, this.stack, magic); + }, - return xhr; - }, + /** + * Redoes all actions ever tracked by the undo manager + * @return {undefined} + */ + redoAll: function () { + managerUndoRedo("redo", this, this.stack, false, true); + }, + /** + * Checks if there's an action in the stack that can be undone / redone + * @param {String} type Either "undo" or "redo" + * @return {Boolean} True if there is a set of actions which can be undone / redone + */ + isAvailable: function (type) { + var s = this.stack, l = s.length; - // Destroy this model on the server if it was already persisted. - // Optimistically removes the model from its collection, if it has one. - // If `wait: true` is passed, waits for the server to respond before removal. - destroy: function(options) { - options = options ? _.clone(options) : {}; - var model = this; - var success = options.success; - var wait = options.wait; + switch (type) { + case "undo": return l > 0 && s.pointer > -1; + case "redo": return l > 0 && s.pointer < l - 1; + default: return false; + } + }, + /** + * Sets the stack-reference to the stack of another undoManager. + * @param {UndoManager} undoManager The undoManager whose stack-reference is set to this stack + * @return {undefined} + */ + merge: function (undoManager) { + // This sets the stack-reference to the stack of another + // undoManager so that the stack of this other undoManager + // is used by two different managers. + // This enables to set up a main-undoManager and besides it + // several others for special, exceptional cases (by using + // instance-based custom UndoTypes). Models / collections + // which need this special treatment are only registered at + // those special undoManagers. Those special ones are then + // merged into the main-undoManager to write on its stack. + // That way it's easier to manage exceptional cases. + var args = _.isArray(undoManager) ? undoManager : slice(arguments), manager; + while (manager = args.pop()) { + if (manager instanceof UndoManager && + manager.stack instanceof UndoStack) { + // set the stack reference to our stack + manager.stack = this.stack; + } + } + }, + /** + * Add an UndoType to this specific UndoManager-instance. + * @param {String} type The event this UndoType is made for + * @param {Object} fns An object of functions that are called to generate the data for an UndoAction or to process it. Must have the properties "undo", "redo" and "on". Can have the property "condition". + * @return {undefined} + */ + addUndoType: function (type, fns) { + manipulateUndoType(0, type, fns, this.undoTypes); + }, + /** + * Overwrite properties of an existing UndoType for this specific UndoManager-instance. + * @param {String} type The event the UndoType is made for + * @param {Object} fns An object of functions that are called to generate the data for an UndoAction or to process it. It extends the existing object. + * @return {undefined} + */ + changeUndoType: function (type, fns) { + manipulateUndoType(1, type, fns, this.undoTypes); + }, + /** + * Remove one or more UndoTypes of this specific UndoManager-instance to fall back to the global UndoTypes. + * @param {String|Array} type The event the UndoType that should be removed is made for. You can also pass an array of events. + * @return {undefined} + */ + removeUndoType: function (type) { + manipulateUndoType(2, type, undefined, this.undoTypes); + }, - var destroy = function() { - model.stopListening(); - model.trigger('destroy', model, model.collection, options); - }; + /** + * Removes all actions from the stack. + * @return {undefined} + */ + clear: function() { + this.stack.reset(); + this.stack.pointer = -1; + } + }); - options.success = function(resp) { - if (wait) destroy(); - if (success) success.call(options.context, model, resp, options); - if (!model.isNew()) model.trigger('sync', model, resp, options); - }; + _.extend(UndoManager, { + /** + * Change the UndoManager's default attributes + * @param {Object} defaultAttributes An object with the new default values. + * @return {undefined} + */ + defaults: function (defaultAttributes) { + _.extend(UndoManager.prototype.defaults, defaultAttributes); + }, + /** + * Add an UndoType to the global UndoTypes-object. + * @param {String} type The event this UndoType is made for + * @param {Object} fns An object of functions that are called to generate the data for an UndoAction or to process it. Must have the properties "undo", "redo" and "on". Can have the property "condition". + * @return {undefined} + */ + "addUndoType": function (type, fns) { + manipulateUndoType(0, type, fns, UndoTypes); + }, + /** + * Overwrite properties of an existing UndoType in the global UndoTypes-object. + * @param {String} type The event the UndoType is made for + * @param {Object} fns An object of functions that are called to generate the data for an UndoAction or to process it. It extends the existing object. + * @return {undefined} + */ + "changeUndoType": function (type, fns) { + manipulateUndoType(1, type, fns, UndoTypes) + }, + /** + * Remove one or more UndoTypes of this specific UndoManager-instance to fall back to the global UndoTypes. + * @param {String|Array} type The event the UndoType that should be removed is made for. You can also pass an array of events. + * @return {undefined} + */ + "removeUndoType": function (type) { + manipulateUndoType(2, type, undefined, UndoTypes); + } + }) - var xhr = false; - if (this.isNew()) { - _.defer(options.success); - } else { - wrapError(this, options); - xhr = this.sync('delete', this, options); - } - if (!wait) destroy(); - return xhr; - }, + return Backbone.UndoManager = UndoManager; - // Default URL for the model's representation on the server -- if you're - // using Backbone's restful methods, override this to change the endpoint - // that will be called. - url: function() { - var base = - _.result(this, 'urlRoot') || - _.result(this.collection, 'url') || - urlError(); - if (this.isNew()) return base; - var id = this.get(this.idAttribute); - return base.replace(/[^\/]$/, '$&/') + encodeURIComponent(id); - }, +}); - // **parse** converts a response into the hash of attributes to be `set` on - // the model. The default implementation is just to pass the response along. - parse: function(resp, options) { - return resp; - }, - // Create a new model with identical attributes to this one. - clone: function() { - return new this.constructor(this.attributes); - }, +/***/ }), - // A model is new if it has never been saved to the server, and lacks an id. - isNew: function() { - return !this.has(this.idAttribute); - }, +/***/ "./node_modules/backbone/backbone.js": +/*!*******************************************!*\ + !*** ./node_modules/backbone/backbone.js ***! + \*******************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { - // Check if the model is currently in a valid state. - isValid: function(options) { - return this._validate({}, _.extend({}, options, {validate: true})); - }, +/* WEBPACK VAR INJECTION */(function(global) {var __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;// Backbone.js 1.3.3 - // Run validation against the next complete set of model attributes, - // returning `true` if all is well. Otherwise, fire an `"invalid"` event. - _validate: function(attrs, options) { - if (!options.validate || !this.validate) return true; - attrs = _.extend({}, this.attributes, attrs); - var error = this.validationError = this.validate(attrs, options) || null; - if (!error) return true; - this.trigger('invalid', this, error, _.extend(options, {validationError: error})); - return false; - } +// (c) 2010-2016 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors +// Backbone may be freely distributed under the MIT license. +// For all details and documentation: +// http://backbonejs.org - }); +(function(factory) { - // Underscore methods that we want to implement on the Model, mapped to the - // number of arguments they take. - var modelMethods = {keys: 1, values: 1, pairs: 1, invert: 1, pick: 0, - omit: 0, chain: 1, isEmpty: 1}; + // Establish the root object, `window` (`self`) in the browser, or `global` on the server. + // We use `self` instead of `window` for `WebWorker` support. + var root = (typeof self == 'object' && self.self === self && self) || + (typeof global == 'object' && global.global === global && global); - // Mix in each Underscore method as a proxy to `Model#attributes`. - addUnderscoreMethods(Model, modelMethods, 'attributes'); + // Set up Backbone appropriately for the environment. Start with AMD. + if (true) { + !(__WEBPACK_AMD_DEFINE_ARRAY__ = [__webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"), __webpack_require__(/*! jquery */ "./node_modules/cash-dom/dist/cash.js"), exports], __WEBPACK_AMD_DEFINE_RESULT__ = (function(_, $, exports) { + // Export global even in AMD case in case this script is loaded with + // others that may still expect a global Backbone. + root.Backbone = factory(root, exports, _, $); + }).apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__), + __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)); - // Backbone.Collection - // ------------------- + // Next for Node.js or CommonJS. jQuery may not be needed as a module. + } else { var _, $; } - // If models tend to represent a single row of data, a Backbone Collection is - // more analogous to a table full of data ... or a small slice or page of that - // table, or a collection of rows that belong together for a particular reason - // -- all of the messages in this particular folder, all of the documents - // belonging to this particular author, and so on. Collections maintain - // indexes of their models, both in order, and for lookup by `id`. +})(function(root, Backbone, _, $) { - // Create a new **Collection**, perhaps to contain a specific type of `model`. - // If a `comparator` is specified, the Collection will maintain - // its models in sort order, as they're added and removed. - var Collection = Backbone.Collection = function(models, options) { - options || (options = {}); - if (options.model) this.model = options.model; - if (options.comparator !== void 0) this.comparator = options.comparator; - this._reset(); - this.initialize.apply(this, arguments); - if (models) this.reset(models, _.extend({silent: true}, options)); - }; + // Initial Setup + // ------------- - // Default options for `Collection#set`. - var setOptions = {add: true, remove: true, merge: true}; - var addOptions = {add: true, remove: false}; + // Save the previous value of the `Backbone` variable, so that it can be + // restored later on, if `noConflict` is used. + var previousBackbone = root.Backbone; - // Splices `insert` into `array` at index `at`. - var splice = function(array, insert, at) { - at = Math.min(Math.max(at, 0), array.length); - var tail = Array(array.length - at); - var length = insert.length; - var i; - for (i = 0; i < tail.length; i++) tail[i] = array[i + at]; - for (i = 0; i < length; i++) array[i + at] = insert[i]; - for (i = 0; i < tail.length; i++) array[i + length + at] = tail[i]; - }; + // Create a local reference to a common array method we'll want to use later. + var slice = Array.prototype.slice; - // Define the Collection's inheritable methods. - _.extend(Collection.prototype, Events, { + // Current version of the library. Keep in sync with `package.json`. + Backbone.VERSION = '1.3.3'; - // The default model for a collection is just a **Backbone.Model**. - // This should be overridden in most cases. - model: Model, + // For Backbone's purposes, jQuery, Zepto, Ender, or My Library (kidding) owns + // the `$` variable. + Backbone.$ = $; - // Initialize is an empty function by default. Override it with your own - // initialization logic. - initialize: function(){}, + // Runs Backbone.js in *noConflict* mode, returning the `Backbone` variable + // to its previous owner. Returns a reference to this Backbone object. + Backbone.noConflict = function() { + root.Backbone = previousBackbone; + return this; + }; - // The JSON representation of a Collection is an array of the - // models' attributes. - toJSON: function(options) { - return this.map(function(model) { return model.toJSON(options); }); - }, + // Turn on `emulateHTTP` to support legacy HTTP servers. Setting this option + // will fake `"PATCH"`, `"PUT"` and `"DELETE"` requests via the `_method` parameter and + // set a `X-Http-Method-Override` header. + Backbone.emulateHTTP = false; - // Proxy `Backbone.sync` by default. - sync: function() { - return Backbone.sync.apply(this, arguments); - }, + // Turn on `emulateJSON` to support legacy servers that can't deal with direct + // `application/json` requests ... this will encode the body as + // `application/x-www-form-urlencoded` instead and will send the model in a + // form param named `model`. + Backbone.emulateJSON = false; - // Add a model, or list of models to the set. `models` may be Backbone - // Models or raw JavaScript objects to be converted to Models, or any - // combination of the two. - add: function(models, options) { - return this.set(models, _.extend({merge: false}, options, addOptions)); - }, + // Proxy Backbone class methods to Underscore functions, wrapping the model's + // `attributes` object or collection's `models` array behind the scenes. + // + // collection.filter(function(model) { return model.get('age') > 10 }); + // collection.each(this.addView); + // + // `Function#apply` can be slow so we use the method's arg count, if we know it. + var addMethod = function(length, method, attribute) { + switch (length) { + case 1: return function() { + return _[method](this[attribute]); + }; + case 2: return function(value) { + return _[method](this[attribute], value); + }; + case 3: return function(iteratee, context) { + return _[method](this[attribute], cb(iteratee, this), context); + }; + case 4: return function(iteratee, defaultVal, context) { + return _[method](this[attribute], cb(iteratee, this), defaultVal, context); + }; + default: return function() { + var args = slice.call(arguments); + args.unshift(this[attribute]); + return _[method].apply(_, args); + }; + } + }; + var addUnderscoreMethods = function(Class, methods, attribute) { + _.each(methods, function(length, method) { + if (_[method]) Class.prototype[method] = addMethod(length, method, attribute); + }); + }; - // Remove a model, or a list of models from the set. - remove: function(models, options) { - options = _.extend({}, options); - var singular = !_.isArray(models); - models = singular ? [models] : models.slice(); - var removed = this._removeModels(models, options); - if (!options.silent && removed.length) { - options.changes = {added: [], merged: [], removed: removed}; - this.trigger('update', this, options); - } - return singular ? removed[0] : removed; - }, + // Support `collection.sortBy('attr')` and `collection.findWhere({id: 1})`. + var cb = function(iteratee, instance) { + if (_.isFunction(iteratee)) return iteratee; + if (_.isObject(iteratee) && !instance._isModel(iteratee)) return modelMatcher(iteratee); + if (_.isString(iteratee)) return function(model) { return model.get(iteratee); }; + return iteratee; + }; + var modelMatcher = function(attrs) { + var matcher = _.matches(attrs); + return function(model) { + return matcher(model.attributes); + }; + }; - // Update a collection by `set`-ing a new list of models, adding new ones, - // removing models that are no longer present, and merging models that - // already exist in the collection, as necessary. Similar to **Model#set**, - // the core operation for updating the data contained by the collection. - set: function(models, options) { - if (models == null) return; + // Backbone.Events + // --------------- - options = _.extend({}, setOptions, options); - if (options.parse && !this._isModel(models)) { - models = this.parse(models, options) || []; - } + // A module that can be mixed in to *any object* in order to provide it with + // a custom event channel. You may bind a callback to an event with `on` or + // remove with `off`; `trigger`-ing an event fires all callbacks in + // succession. + // + // var object = {}; + // _.extend(object, Backbone.Events); + // object.on('expand', function(){ alert('expanded'); }); + // object.trigger('expand'); + // + var Events = Backbone.Events = {}; - var singular = !_.isArray(models); - models = singular ? [models] : models.slice(); + // Regular expression used to split event strings. + var eventSplitter = /\s+/; - var at = options.at; - if (at != null) at = +at; - if (at > this.length) at = this.length; - if (at < 0) at += this.length + 1; + // Iterates over the standard `event, callback` (as well as the fancy multiple + // space-separated events `"change blur", callback` and jQuery-style event + // maps `{event: callback}`). + var eventsApi = function(iteratee, events, name, callback, opts) { + var i = 0, names; + if (name && typeof name === 'object') { + // Handle event maps. + if (callback !== void 0 && 'context' in opts && opts.context === void 0) opts.context = callback; + for (names = _.keys(name); i < names.length ; i++) { + events = eventsApi(iteratee, events, names[i], name[names[i]], opts); + } + } else if (name && eventSplitter.test(name)) { + // Handle space-separated event names by delegating them individually. + for (names = name.split(eventSplitter); i < names.length; i++) { + events = iteratee(events, names[i], callback, opts); + } + } else { + // Finally, standard events. + events = iteratee(events, name, callback, opts); + } + return events; + }; - var set = []; - var toAdd = []; - var toMerge = []; - var toRemove = []; - var modelMap = {}; + // Bind an event to a `callback` function. Passing `"all"` will bind + // the callback to all events fired. + Events.on = function(name, callback, context) { + return internalOn(this, name, callback, context); + }; - var add = options.add; - var merge = options.merge; - var remove = options.remove; + // Guard the `listening` argument from the public API. + var internalOn = function(obj, name, callback, context, listening) { + obj._events = eventsApi(onApi, obj._events || {}, name, callback, { + context: context, + ctx: obj, + listening: listening + }); - var sort = false; - var sortable = this.comparator && at == null && options.sort !== false; - var sortAttr = _.isString(this.comparator) ? this.comparator : null; + if (listening) { + var listeners = obj._listeners || (obj._listeners = {}); + listeners[listening.id] = listening; + } - // Turn bare objects into model references, and prevent invalid models - // from being added. - var model, i; - for (i = 0; i < models.length; i++) { - model = models[i]; + return obj; + }; - // If a duplicate is found, prevent it from being added and - // optionally merge it into the existing model. - var existing = this.get(model); - if (existing) { - if (merge && model !== existing) { - var attrs = this._isModel(model) ? model.attributes : model; - if (options.parse) attrs = existing.parse(attrs, options); - existing.set(attrs, options); - toMerge.push(existing); - if (sortable && !sort) sort = existing.hasChanged(sortAttr); - } - if (!modelMap[existing.cid]) { - modelMap[existing.cid] = true; - set.push(existing); - } - models[i] = existing; + // Inversion-of-control versions of `on`. Tell *this* object to listen to + // an event in another object... keeping track of what it's listening to + // for easier unbinding later. + Events.listenTo = function(obj, name, callback) { + if (!obj) return this; + var id = obj._listenId || (obj._listenId = _.uniqueId('l')); + var listeningTo = this._listeningTo || (this._listeningTo = {}); + var listening = listeningTo[id]; - // If this is a new, valid model, push it to the `toAdd` list. - } else if (add) { - model = models[i] = this._prepareModel(model, options); - if (model) { - toAdd.push(model); - this._addReference(model, options); - modelMap[model.cid] = true; - set.push(model); - } - } - } + // This object is not listening to any other events on `obj` yet. + // Setup the necessary references to track the listening callbacks. + if (!listening) { + var thisId = this._listenId || (this._listenId = _.uniqueId('l')); + listening = listeningTo[id] = {obj: obj, objId: id, id: thisId, listeningTo: listeningTo, count: 0}; + } - // Remove stale models. - if (remove) { - for (i = 0; i < this.length; i++) { - model = this.models[i]; - if (!modelMap[model.cid]) toRemove.push(model); - } - if (toRemove.length) this._removeModels(toRemove, options); - } + // Bind callbacks on obj, and keep track of them on listening. + internalOn(obj, name, callback, this, listening); + return this; + }; - // See if sorting is needed, update `length` and splice in new models. - var orderChanged = false; - var replace = !sortable && add && remove; - if (set.length && replace) { - orderChanged = this.length !== set.length || _.some(this.models, function(m, index) { - return m !== set[index]; - }); - this.models.length = 0; - splice(this.models, set, 0); - this.length = this.models.length; - } else if (toAdd.length) { - if (sortable) sort = true; - splice(this.models, toAdd, at == null ? this.length : at); - this.length = this.models.length; - } - - // Silently sort the collection if appropriate. - if (sort) this.sort({silent: true}); - - // Unless silenced, it's time to fire all appropriate add/sort/update events. - if (!options.silent) { - for (i = 0; i < toAdd.length; i++) { - if (at != null) options.index = at + i; - model = toAdd[i]; - model.trigger('add', model, this, options); - } - if (sort || orderChanged) this.trigger('sort', this, options); - if (toAdd.length || toRemove.length || toMerge.length) { - options.changes = { - added: toAdd, - removed: toRemove, - merged: toMerge - }; - this.trigger('update', this, options); - } - } + // The reducing API that adds a callback to the `events` object. + var onApi = function(events, name, callback, options) { + if (callback) { + var handlers = events[name] || (events[name] = []); + var context = options.context, ctx = options.ctx, listening = options.listening; + if (listening) listening.count++; - // Return the added (or merged) model (or models). - return singular ? models[0] : models; - }, + handlers.push({callback: callback, context: context, ctx: context || ctx, listening: listening}); + } + return events; + }; - // When you have more items than you want to add or remove individually, - // you can reset the entire set with a new list of models, without firing - // any granular `add` or `remove` events. Fires `reset` when finished. - // Useful for bulk operations and optimizations. - reset: function(models, options) { - options = options ? _.clone(options) : {}; - for (var i = 0; i < this.models.length; i++) { - this._removeReference(this.models[i], options); - } - options.previousModels = this.models; - this._reset(); - models = this.add(models, _.extend({silent: true}, options)); - if (!options.silent) this.trigger('reset', this, options); - return models; - }, + // Remove one or many callbacks. If `context` is null, removes all + // callbacks with that function. If `callback` is null, removes all + // callbacks for the event. If `name` is null, removes all bound + // callbacks for all events. + Events.off = function(name, callback, context) { + if (!this._events) return this; + this._events = eventsApi(offApi, this._events, name, callback, { + context: context, + listeners: this._listeners + }); + return this; + }; - // Add a model to the end of the collection. - push: function(model, options) { - return this.add(model, _.extend({at: this.length}, options)); - }, + // Tell this object to stop listening to either specific events ... or + // to every object it's currently listening to. + Events.stopListening = function(obj, name, callback) { + var listeningTo = this._listeningTo; + if (!listeningTo) return this; - // Remove a model from the end of the collection. - pop: function(options) { - var model = this.at(this.length - 1); - return this.remove(model, options); - }, + var ids = obj ? [obj._listenId] : _.keys(listeningTo); - // Add a model to the beginning of the collection. - unshift: function(model, options) { - return this.add(model, _.extend({at: 0}, options)); - }, + for (var i = 0; i < ids.length; i++) { + var listening = listeningTo[ids[i]]; - // Remove a model from the beginning of the collection. - shift: function(options) { - var model = this.at(0); - return this.remove(model, options); - }, + // If listening doesn't exist, this object is not currently + // listening to obj. Break out early. + if (!listening) break; - // Slice out a sub-array of models from the collection. - slice: function() { - return slice.apply(this.models, arguments); - }, + listening.obj.off(name, callback, this); + } - // Get a model from the set by id, cid, model object with id or cid - // properties, or an attributes object that is transformed through modelId. - get: function(obj) { - if (obj == null) return void 0; - return this._byId[obj] || - this._byId[this.modelId(obj.attributes || obj)] || - obj.cid && this._byId[obj.cid]; - }, + return this; + }; - // Returns `true` if the model is in the collection. - has: function(obj) { - return this.get(obj) != null; - }, + // The reducing API that removes a callback from the `events` object. + var offApi = function(events, name, callback, options) { + if (!events) return; - // Get the model at the given index. - at: function(index) { - if (index < 0) index += this.length; - return this.models[index]; - }, + var i = 0, listening; + var context = options.context, listeners = options.listeners; - // Return models with matching attributes. Useful for simple cases of - // `filter`. - where: function(attrs, first) { - return this[first ? 'find' : 'filter'](attrs); - }, + // Delete all events listeners and "drop" events. + if (!name && !callback && !context) { + var ids = _.keys(listeners); + for (; i < ids.length; i++) { + listening = listeners[ids[i]]; + delete listeners[listening.id]; + delete listening.listeningTo[listening.objId]; + } + return; + } - // Return the first model with matching attributes. Useful for simple cases - // of `find`. - findWhere: function(attrs) { - return this.where(attrs, true); - }, + var names = name ? [name] : _.keys(events); + for (; i < names.length; i++) { + name = names[i]; + var handlers = events[name]; - // Force the collection to re-sort itself. You don't need to call this under - // normal circumstances, as the set will maintain sort order as each item - // is added. - sort: function(options) { - var comparator = this.comparator; - if (!comparator) throw new Error('Cannot sort a set without a comparator'); - options || (options = {}); + // Bail out if there are no events stored. + if (!handlers) break; - var length = comparator.length; - if (_.isFunction(comparator)) comparator = _.bind(comparator, this); + // Replace events if there are any remaining. Otherwise, clean up. + var remaining = []; + for (var j = 0; j < handlers.length; j++) { + var handler = handlers[j]; + if ( + callback && callback !== handler.callback && + callback !== handler.callback._callback || + context && context !== handler.context + ) { + remaining.push(handler); + } else { + listening = handler.listening; + if (listening && --listening.count === 0) { + delete listeners[listening.id]; + delete listening.listeningTo[listening.objId]; + } + } + } - // Run sort based on type of `comparator`. - if (length === 1 || _.isString(comparator)) { - this.models = this.sortBy(comparator); + // Update tail event if the list has any events. Otherwise, clean up. + if (remaining.length) { + events[name] = remaining; } else { - this.models.sort(comparator); + delete events[name]; } - if (!options.silent) this.trigger('sort', this, options); - return this; - }, - - // Pluck an attribute from each model in the collection. - pluck: function(attr) { - return this.map(attr + ''); - }, - - // Fetch the default set of models for this collection, resetting the - // collection when they arrive. If `reset: true` is passed, the response - // data will be passed through the `reset` method instead of `set`. - fetch: function(options) { - options = _.extend({parse: true}, options); - var success = options.success; - var collection = this; - options.success = function(resp) { - var method = options.reset ? 'reset' : 'set'; - collection[method](resp, options); - if (success) success.call(options.context, collection, resp, options); - collection.trigger('sync', collection, resp, options); - }; - wrapError(this, options); - return this.sync('read', this, options); - }, + } + return events; + }; - // Create a new instance of a model in this collection. Add the model to the - // collection immediately, unless `wait: true` is passed, in which case we - // wait for the server to agree. - create: function(model, options) { - options = options ? _.clone(options) : {}; - var wait = options.wait; - model = this._prepareModel(model, options); - if (!model) return false; - if (!wait) this.add(model, options); - var collection = this; - var success = options.success; - options.success = function(m, resp, callbackOpts) { - if (wait) collection.add(m, callbackOpts); - if (success) success.call(callbackOpts.context, m, resp, callbackOpts); - }; - model.save(null, options); - return model; - }, + // Bind an event to only be triggered a single time. After the first time + // the callback is invoked, its listener will be removed. If multiple events + // are passed in using the space-separated syntax, the handler will fire + // once for each event, not once for a combination of all events. + Events.once = function(name, callback, context) { + // Map the event into a `{event: once}` object. + var events = eventsApi(onceMap, {}, name, callback, _.bind(this.off, this)); + if (typeof name === 'string' && context == null) callback = void 0; + return this.on(events, callback, context); + }; - // **parse** converts a response into a list of models to be added to the - // collection. The default implementation is just to pass it through. - parse: function(resp, options) { - return resp; - }, + // Inversion-of-control versions of `once`. + Events.listenToOnce = function(obj, name, callback) { + // Map the event into a `{event: once}` object. + var events = eventsApi(onceMap, {}, name, callback, _.bind(this.stopListening, this, obj)); + return this.listenTo(obj, events); + }; - // Create a new collection with an identical list of models as this one. - clone: function() { - return new this.constructor(this.models, { - model: this.model, - comparator: this.comparator + // Reduces the event callbacks into a map of `{event: onceWrapper}`. + // `offer` unbinds the `onceWrapper` after it has been called. + var onceMap = function(map, name, callback, offer) { + if (callback) { + var once = map[name] = _.once(function() { + offer(name, once); + callback.apply(this, arguments); }); - }, - - // Define how to uniquely identify models in the collection. - modelId: function(attrs) { - return attrs[this.model.prototype.idAttribute || 'id']; - }, - - // Private method to reset all internal state. Called when the collection - // is first initialized or reset. - _reset: function() { - this.length = 0; - this.models = []; - this._byId = {}; - }, - - // Prepare a hash of attributes (or other model) to be added to this - // collection. - _prepareModel: function(attrs, options) { - if (this._isModel(attrs)) { - if (!attrs.collection) attrs.collection = this; - return attrs; - } - options = options ? _.clone(options) : {}; - options.collection = this; - var model = new this.model(attrs, options); - if (!model.validationError) return model; - this.trigger('invalid', this, model.validationError, options); - return false; - }, - - // Internal method called by both remove and set. - _removeModels: function(models, options) { - var removed = []; - for (var i = 0; i < models.length; i++) { - var model = this.get(models[i]); - if (!model) continue; - - var index = this.indexOf(model); - this.models.splice(index, 1); - this.length--; - - // Remove references before triggering 'remove' event to prevent an - // infinite loop. #3693 - delete this._byId[model.cid]; - var id = this.modelId(model.attributes); - if (id != null) delete this._byId[id]; - - if (!options.silent) { - options.index = index; - model.trigger('remove', model, this, options); - } - - removed.push(model); - this._removeReference(model, options); - } - return removed; - }, + once._callback = callback; + } + return map; + }; - // Method for checking whether an object should be considered a model for - // the purposes of adding to the collection. - _isModel: function(model) { - return model instanceof Model; - }, + // Trigger one or many events, firing all bound callbacks. Callbacks are + // passed the same arguments as `trigger` is, apart from the event name + // (unless you're listening on `"all"`, which will cause your callback to + // receive the true name of the event as the first argument). + Events.trigger = function(name) { + if (!this._events) return this; - // Internal method to create a model's ties to a collection. - _addReference: function(model, options) { - this._byId[model.cid] = model; - var id = this.modelId(model.attributes); - if (id != null) this._byId[id] = model; - model.on('all', this._onModelEvent, this); - }, + var length = Math.max(0, arguments.length - 1); + var args = Array(length); + for (var i = 0; i < length; i++) args[i] = arguments[i + 1]; - // Internal method to sever a model's ties to a collection. - _removeReference: function(model, options) { - delete this._byId[model.cid]; - var id = this.modelId(model.attributes); - if (id != null) delete this._byId[id]; - if (this === model.collection) delete model.collection; - model.off('all', this._onModelEvent, this); - }, + eventsApi(triggerApi, this._events, name, void 0, args); + return this; + }; - // Internal method called every time a model in the set fires an event. - // Sets need to update their indexes when models change ids. All other - // events simply proxy through. "add" and "remove" events that originate - // in other collections are ignored. - _onModelEvent: function(event, model, collection, options) { - if (model) { - if ((event === 'add' || event === 'remove') && collection !== this) return; - if (event === 'destroy') this.remove(model, options); - if (event === 'change') { - var prevId = this.modelId(model.previousAttributes()); - var id = this.modelId(model.attributes); - if (prevId !== id) { - if (prevId != null) delete this._byId[prevId]; - if (id != null) this._byId[id] = model; - } - } - } - this.trigger.apply(this, arguments); + // Handles triggering the appropriate event callbacks. + var triggerApi = function(objEvents, name, callback, args) { + if (objEvents) { + var events = objEvents[name]; + var allEvents = objEvents.all; + if (events && allEvents) allEvents = allEvents.slice(); + if (events) triggerEvents(events, args); + if (allEvents) triggerEvents(allEvents, [name].concat(args)); } + return objEvents; + }; - }); + // A difficult-to-believe, but optimized internal dispatch function for + // triggering events. Tries to keep the usual cases speedy (most internal + // Backbone events have 3 arguments). + var triggerEvents = function(events, args) { + var ev, i = -1, l = events.length, a1 = args[0], a2 = args[1], a3 = args[2]; + switch (args.length) { + case 0: while (++i < l) (ev = events[i]).callback.call(ev.ctx); return; + case 1: while (++i < l) (ev = events[i]).callback.call(ev.ctx, a1); return; + case 2: while (++i < l) (ev = events[i]).callback.call(ev.ctx, a1, a2); return; + case 3: while (++i < l) (ev = events[i]).callback.call(ev.ctx, a1, a2, a3); return; + default: while (++i < l) (ev = events[i]).callback.apply(ev.ctx, args); return; + } + }; - // Underscore methods that we want to implement on the Collection. - // 90% of the core usefulness of Backbone Collections is actually implemented - // right here: - var collectionMethods = {forEach: 3, each: 3, map: 3, collect: 3, reduce: 0, - foldl: 0, inject: 0, reduceRight: 0, foldr: 0, find: 3, detect: 3, filter: 3, - select: 3, reject: 3, every: 3, all: 3, some: 3, any: 3, include: 3, includes: 3, - contains: 3, invoke: 0, max: 3, min: 3, toArray: 1, size: 1, first: 3, - head: 3, take: 3, initial: 3, rest: 3, tail: 3, drop: 3, last: 3, - without: 0, difference: 0, indexOf: 3, shuffle: 1, lastIndexOf: 3, - isEmpty: 1, chain: 1, sample: 3, partition: 3, groupBy: 3, countBy: 3, - sortBy: 3, indexBy: 3, findIndex: 3, findLastIndex: 3}; + // Aliases for backwards compatibility. + Events.bind = Events.on; + Events.unbind = Events.off; - // Mix in each Underscore method as a proxy to `Collection#models`. - addUnderscoreMethods(Collection, collectionMethods, 'models'); + // Allow the `Backbone` object to serve as a global event bus, for folks who + // want global "pubsub" in a convenient place. + _.extend(Backbone, Events); - // Backbone.View - // ------------- + // Backbone.Model + // -------------- - // Backbone Views are almost more convention than they are actual code. A View - // is simply a JavaScript object that represents a logical chunk of UI in the - // DOM. This might be a single item, an entire list, a sidebar or panel, or - // even the surrounding frame which wraps your whole app. Defining a chunk of - // UI as a **View** allows you to define your DOM events declaratively, without - // having to worry about render order ... and makes it easy for the view to - // react to specific changes in the state of your models. + // Backbone **Models** are the basic data object in the framework -- + // frequently representing a row in a table in a database on your server. + // A discrete chunk of data and a bunch of useful, related methods for + // performing computations and transformations on that data. - // Creating a Backbone.View creates its initial element outside of the DOM, - // if an existing element is not provided... - var View = Backbone.View = function(options) { - this.cid = _.uniqueId('view'); - _.extend(this, _.pick(options, viewOptions)); - this._ensureElement(); + // Create a new model with the specified attributes. A client id (`cid`) + // is automatically generated and assigned for you. + var Model = Backbone.Model = function(attributes, options) { + var attrs = attributes || {}; + options || (options = {}); + this.cid = _.uniqueId(this.cidPrefix); + this.attributes = {}; + if (options.collection) this.collection = options.collection; + if (options.parse) attrs = this.parse(attrs, options) || {}; + var defaults = _.result(this, 'defaults'); + attrs = _.defaults(_.extend({}, defaults, attrs), defaults); + this.set(attrs, options); + this.changed = {}; this.initialize.apply(this, arguments); }; - // Cached regex to split keys for `delegate`. - var delegateEventSplitter = /^(\S+)\s*(.*)$/; + // Attach all inheritable methods to the Model prototype. + _.extend(Model.prototype, Events, { - // List of view options to be set as properties. - var viewOptions = ['model', 'collection', 'el', 'id', 'attributes', 'className', 'tagName', 'events']; + // A hash of attributes whose current and previous value differ. + changed: null, - // Set up all inheritable **Backbone.View** properties and methods. - _.extend(View.prototype, Events, { + // The value returned during the last failed validation. + validationError: null, - // The default `tagName` of a View's element is `"div"`. - tagName: 'div', + // The default name for the JSON `id` attribute is `"id"`. MongoDB and + // CouchDB users may want to set this to `"_id"`. + idAttribute: 'id', - // jQuery delegate for element lookup, scoped to DOM elements within the - // current view. This should be preferred to global lookups where possible. - $: function(selector) { - return this.$el.find(selector); - }, + // The prefix is used to create the client id which is used to identify models locally. + // You may want to override this if you're experiencing name clashes with model ids. + cidPrefix: 'c', // Initialize is an empty function by default. Override it with your own // initialization logic. initialize: function(){}, - // **render** is the core function that your view should override, in order - // to populate its element (`this.el`), with the appropriate HTML. The - // convention is for **render** to always return `this`. - render: function() { - return this; + // Return a copy of the model's `attributes` object. + toJSON: function(options) { + return _.clone(this.attributes); }, - // Remove this view by taking the element out of the DOM, and removing any - // applicable Backbone.Events listeners. - remove: function() { - this._removeElement(); - this.stopListening(); - return this; + // Proxy `Backbone.sync` by default -- but override this if you need + // custom syncing semantics for *this* particular model. + sync: function() { + return Backbone.sync.apply(this, arguments); }, - // Remove this view's element from the document and all event listeners - // attached to it. Exposed for subclasses using an alternative DOM - // manipulation API. - _removeElement: function() { - this.$el.remove(); + // Get the value of an attribute. + get: function(attr) { + return this.attributes[attr]; }, - // Change the view's element (`this.el` property) and re-delegate the - // view's events on the new element. - setElement: function(element) { - this.undelegateEvents(); - this._setElement(element); - this.delegateEvents(); - return this; + // Get the HTML-escaped value of an attribute. + escape: function(attr) { + return _.escape(this.get(attr)); }, - // Creates the `this.el` and `this.$el` references for this view using the - // given `el`. `el` can be a CSS selector or an HTML string, a jQuery - // context or an element. Subclasses can override this to utilize an - // alternative DOM manipulation API and are only required to set the - // `this.el` property. - _setElement: function(el) { - this.$el = el instanceof Backbone.$ ? el : Backbone.$(el); - this.el = this.$el[0]; + // Returns `true` if the attribute contains a value that is not null + // or undefined. + has: function(attr) { + return this.get(attr) != null; }, - // Set callbacks, where `this.events` is a hash of - // - // *{"event selector": "callback"}* - // - // { - // 'mousedown .title': 'edit', - // 'click .button': 'save', - // 'click .open': function(e) { ... } - // } - // - // pairs. Callbacks will be bound to the view, with `this` set properly. - // Uses event delegation for efficiency. - // Omitting the selector binds the event to `this.el`. - delegateEvents: function(events) { - events || (events = _.result(this, 'events')); - if (!events) return this; - this.undelegateEvents(); - for (var key in events) { - var method = events[key]; - if (!_.isFunction(method)) method = this[method]; - if (!method) continue; - var match = key.match(delegateEventSplitter); - this.delegate(match[1], match[2], _.bind(method, this)); - } - return this; + // Special-cased proxy to underscore's `_.matches` method. + matches: function(attrs) { + return !!_.iteratee(attrs, this)(this.attributes); }, - // Add a single event listener to the view's element (or a child element - // using `selector`). This only works for delegate-able events: not `focus`, - // `blur`, and not `change`, `submit`, and `reset` in Internet Explorer. - delegate: function(eventName, selector, listener) { - this.$el.on(eventName + '.delegateEvents' + this.cid, selector, listener); + // Set a hash of model attributes on the object, firing `"change"`. This is + // the core primitive operation of a model, updating the data and notifying + // anyone who needs to know about the change in state. The heart of the beast. + set: function(key, val, options) { + if (key == null) return this; + + // Handle both `"key", value` and `{key: value}` -style arguments. + var attrs; + if (typeof key === 'object') { + attrs = key; + options = val; + } else { + (attrs = {})[key] = val; + } + + options || (options = {}); + + // Run validation. + if (!this._validate(attrs, options)) return false; + + // Extract attributes and options. + var unset = options.unset; + var silent = options.silent; + var changes = []; + var changing = this._changing; + this._changing = true; + + if (!changing) { + this._previousAttributes = _.clone(this.attributes); + this.changed = {}; + } + + var current = this.attributes; + var changed = this.changed; + var prev = this._previousAttributes; + + // For each `set` attribute, update or delete the current value. + for (var attr in attrs) { + val = attrs[attr]; + if (!_.isEqual(current[attr], val)) changes.push(attr); + if (!_.isEqual(prev[attr], val)) { + changed[attr] = val; + } else { + delete changed[attr]; + } + unset ? delete current[attr] : current[attr] = val; + } + + // Update the `id`. + if (this.idAttribute in attrs) this.id = this.get(this.idAttribute); + + // Trigger all relevant attribute changes. + if (!silent) { + if (changes.length) this._pending = options; + for (var i = 0; i < changes.length; i++) { + this.trigger('change:' + changes[i], this, current[changes[i]], options); + } + } + + // You might be wondering why there's a `while` loop here. Changes can + // be recursively nested within `"change"` events. + if (changing) return this; + if (!silent) { + while (this._pending) { + options = this._pending; + this._pending = false; + this.trigger('change', this, options); + } + } + this._pending = false; + this._changing = false; return this; }, - // Clears all callbacks previously bound to the view by `delegateEvents`. - // You usually don't need to use this, but may wish to if you have multiple - // Backbone views attached to the same DOM element. - undelegateEvents: function() { - if (this.$el) this.$el.off('.delegateEvents' + this.cid); - return this; + // Remove an attribute from the model, firing `"change"`. `unset` is a noop + // if the attribute doesn't exist. + unset: function(attr, options) { + return this.set(attr, void 0, _.extend({}, options, {unset: true})); }, - // A finer-grained `undelegateEvents` for removing a single delegated event. - // `selector` and `listener` are both optional. - undelegate: function(eventName, selector, listener) { - this.$el.off(eventName + '.delegateEvents' + this.cid, selector, listener); - return this; + // Clear all attributes on the model, firing `"change"`. + clear: function(options) { + var attrs = {}; + for (var key in this.attributes) attrs[key] = void 0; + return this.set(attrs, _.extend({}, options, {unset: true})); }, - // Produces a DOM element to be assigned to your view. Exposed for - // subclasses using an alternative DOM manipulation API. - _createElement: function(tagName) { - return document.createElement(tagName); + // Determine if the model has changed since the last `"change"` event. + // If you specify an attribute name, determine if that attribute has changed. + hasChanged: function(attr) { + if (attr == null) return !_.isEmpty(this.changed); + return _.has(this.changed, attr); }, - // Ensure that the View has a DOM element to render into. - // If `this.el` is a string, pass it through `$()`, take the first - // matching element, and re-assign it to `el`. Otherwise, create - // an element from the `id`, `className` and `tagName` properties. - _ensureElement: function() { - if (!this.el) { - var attrs = _.extend({}, _.result(this, 'attributes')); - if (this.id) attrs.id = _.result(this, 'id'); - if (this.className) attrs['class'] = _.result(this, 'className'); - this.setElement(this._createElement(_.result(this, 'tagName'))); - this._setAttributes(attrs); - } else { - this.setElement(_.result(this, 'el')); + // Return an object containing all the attributes that have changed, or + // false if there are no changed attributes. Useful for determining what + // parts of a view need to be updated and/or what attributes need to be + // persisted to the server. Unset attributes will be set to undefined. + // You can also pass an attributes object to diff against the model, + // determining if there *would be* a change. + changedAttributes: function(diff) { + if (!diff) return this.hasChanged() ? _.clone(this.changed) : false; + var old = this._changing ? this._previousAttributes : this.attributes; + var changed = {}; + for (var attr in diff) { + var val = diff[attr]; + if (_.isEqual(old[attr], val)) continue; + changed[attr] = val; } + return _.size(changed) ? changed : false; }, - // Set attributes from a hash on this view's element. Exposed for - // subclasses using an alternative DOM manipulation API. - _setAttributes: function(attributes) { - this.$el.attr(attributes); - } + // Get the previous value of an attribute, recorded at the time the last + // `"change"` event was fired. + previous: function(attr) { + if (attr == null || !this._previousAttributes) return null; + return this._previousAttributes[attr]; + }, - }); + // Get all of the attributes of the model at the time of the previous + // `"change"` event. + previousAttributes: function() { + return _.clone(this._previousAttributes); + }, - // Backbone.sync - // ------------- + // Fetch the model from the server, merging the response with the model's + // local attributes. Any changed attributes will trigger a "change" event. + fetch: function(options) { + options = _.extend({parse: true}, options); + var model = this; + var success = options.success; + options.success = function(resp) { + var serverAttrs = options.parse ? model.parse(resp, options) : resp; + if (!model.set(serverAttrs, options)) return false; + if (success) success.call(options.context, model, resp, options); + model.trigger('sync', model, resp, options); + }; + wrapError(this, options); + return this.sync('read', this, options); + }, - // Override this function to change the manner in which Backbone persists - // models to the server. You will be passed the type of request, and the - // model in question. By default, makes a RESTful Ajax request - // to the model's `url()`. Some possible customizations could be: - // - // * Use `setTimeout` to batch rapid-fire updates into a single request. - // * Send up the models as XML instead of JSON. - // * Persist models via WebSockets instead of Ajax. - // - // Turn on `Backbone.emulateHTTP` in order to send `PUT` and `DELETE` requests - // as `POST`, with a `_method` parameter containing the true HTTP method, - // as well as all requests with the body as `application/x-www-form-urlencoded` - // instead of `application/json` with the model in a param named `model`. - // Useful when interfacing with server-side languages like **PHP** that make - // it difficult to read the body of `PUT` requests. - Backbone.sync = function(method, model, options) { - var type = methodMap[method]; + // Set a hash of model attributes, and sync the model to the server. + // If the server returns an attributes hash that differs, the model's + // state will be `set` again. + save: function(key, val, options) { + // Handle both `"key", value` and `{key: value}` -style arguments. + var attrs; + if (key == null || typeof key === 'object') { + attrs = key; + options = val; + } else { + (attrs = {})[key] = val; + } - // Default options, unless specified. - _.defaults(options || (options = {}), { - emulateHTTP: Backbone.emulateHTTP, - emulateJSON: Backbone.emulateJSON - }); + options = _.extend({validate: true, parse: true}, options); + var wait = options.wait; - // Default JSON-request options. - var params = {type: type, dataType: 'json'}; + // If we're not waiting and attributes exist, save acts as + // `set(attr).save(null, opts)` with validation. Otherwise, check if + // the model will be valid when the attributes, if any, are set. + if (attrs && !wait) { + if (!this.set(attrs, options)) return false; + } else if (!this._validate(attrs, options)) { + return false; + } - // Ensure that we have a URL. - if (!options.url) { - params.url = _.result(model, 'url') || urlError(); - } - - // Ensure that we have the appropriate request data. - if (options.data == null && model && (method === 'create' || method === 'update' || method === 'patch')) { - params.contentType = 'application/json'; - params.data = JSON.stringify(options.attrs || model.toJSON(options)); - } - - // For older servers, emulate JSON by encoding the request into an HTML-form. - if (options.emulateJSON) { - params.contentType = 'application/x-www-form-urlencoded'; - params.data = params.data ? {model: params.data} : {}; - } - - // For older servers, emulate HTTP by mimicking the HTTP method with `_method` - // And an `X-HTTP-Method-Override` header. - if (options.emulateHTTP && (type === 'PUT' || type === 'DELETE' || type === 'PATCH')) { - params.type = 'POST'; - if (options.emulateJSON) params.data._method = type; - var beforeSend = options.beforeSend; - options.beforeSend = function(xhr) { - xhr.setRequestHeader('X-HTTP-Method-Override', type); - if (beforeSend) return beforeSend.apply(this, arguments); + // After a successful server-side save, the client is (optionally) + // updated with the server-side state. + var model = this; + var success = options.success; + var attributes = this.attributes; + options.success = function(resp) { + // Ensure attributes are restored during synchronous saves. + model.attributes = attributes; + var serverAttrs = options.parse ? model.parse(resp, options) : resp; + if (wait) serverAttrs = _.extend({}, attrs, serverAttrs); + if (serverAttrs && !model.set(serverAttrs, options)) return false; + if (success) success.call(options.context, model, resp, options); + model.trigger('sync', model, resp, options); }; - } - - // Don't process data on a non-GET request. - if (params.type !== 'GET' && !options.emulateJSON) { - params.processData = false; - } - - // Pass along `textStatus` and `errorThrown` from jQuery. - var error = options.error; - options.error = function(xhr, textStatus, errorThrown) { - options.textStatus = textStatus; - options.errorThrown = errorThrown; - if (error) error.call(options.context, xhr, textStatus, errorThrown); - }; - - // Make the request, allowing the user to override any Ajax options. - var xhr = options.xhr = Backbone.ajax(_.extend(params, options)); - model.trigger('request', model, xhr, options); - return xhr; - }; + wrapError(this, options); - // Map from CRUD to HTTP for our default `Backbone.sync` implementation. - var methodMap = { - 'create': 'POST', - 'update': 'PUT', - 'patch': 'PATCH', - 'delete': 'DELETE', - 'read': 'GET' - }; + // Set temporary attributes if `{wait: true}` to properly find new ids. + if (attrs && wait) this.attributes = _.extend({}, attributes, attrs); - // Set the default implementation of `Backbone.ajax` to proxy through to `$`. - // Override this if you'd like to use a different library. - Backbone.ajax = function() { - return Backbone.$.ajax.apply(Backbone.$, arguments); - }; + var method = this.isNew() ? 'create' : (options.patch ? 'patch' : 'update'); + if (method === 'patch' && !options.attrs) options.attrs = attrs; + var xhr = this.sync(method, this, options); - // Backbone.Router - // --------------- + // Restore attributes. + this.attributes = attributes; - // Routers map faux-URLs to actions, and fire events when routes are - // matched. Creating a new one sets its `routes` hash, if not set statically. - var Router = Backbone.Router = function(options) { - options || (options = {}); - if (options.routes) this.routes = options.routes; - this._bindRoutes(); - this.initialize.apply(this, arguments); - }; + return xhr; + }, - // Cached regular expressions for matching named param parts and splatted - // parts of route strings. - var optionalParam = /\((.*?)\)/g; - var namedParam = /(\(\?)?:\w+/g; - var splatParam = /\*\w+/g; - var escapeRegExp = /[\-{}\[\]+?.,\\\^$|#\s]/g; + // Destroy this model on the server if it was already persisted. + // Optimistically removes the model from its collection, if it has one. + // If `wait: true` is passed, waits for the server to respond before removal. + destroy: function(options) { + options = options ? _.clone(options) : {}; + var model = this; + var success = options.success; + var wait = options.wait; - // Set up all inheritable **Backbone.Router** properties and methods. - _.extend(Router.prototype, Events, { + var destroy = function() { + model.stopListening(); + model.trigger('destroy', model, model.collection, options); + }; - // Initialize is an empty function by default. Override it with your own - // initialization logic. - initialize: function(){}, + options.success = function(resp) { + if (wait) destroy(); + if (success) success.call(options.context, model, resp, options); + if (!model.isNew()) model.trigger('sync', model, resp, options); + }; - // Manually bind a single named route to a callback. For example: - // - // this.route('search/:query/p:num', 'search', function(query, num) { - // ... - // }); - // - route: function(route, name, callback) { - if (!_.isRegExp(route)) route = this._routeToRegExp(route); - if (_.isFunction(name)) { - callback = name; - name = ''; + var xhr = false; + if (this.isNew()) { + _.defer(options.success); + } else { + wrapError(this, options); + xhr = this.sync('delete', this, options); } - if (!callback) callback = this[name]; - var router = this; - Backbone.history.route(route, function(fragment) { - var args = router._extractParameters(route, fragment); - if (router.execute(callback, args, name) !== false) { - router.trigger.apply(router, ['route:' + name].concat(args)); - router.trigger('route', name, args); - Backbone.history.trigger('route', router, name, args); - } - }); - return this; + if (!wait) destroy(); + return xhr; }, - // Execute a route handler with the provided parameters. This is an - // excellent place to do pre-route setup or post-route cleanup. - execute: function(callback, args, name) { - if (callback) callback.apply(this, args); + // Default URL for the model's representation on the server -- if you're + // using Backbone's restful methods, override this to change the endpoint + // that will be called. + url: function() { + var base = + _.result(this, 'urlRoot') || + _.result(this.collection, 'url') || + urlError(); + if (this.isNew()) return base; + var id = this.get(this.idAttribute); + return base.replace(/[^\/]$/, '$&/') + encodeURIComponent(id); }, - // Simple proxy to `Backbone.history` to save a fragment into the history. - navigate: function(fragment, options) { - Backbone.history.navigate(fragment, options); - return this; + // **parse** converts a response into the hash of attributes to be `set` on + // the model. The default implementation is just to pass the response along. + parse: function(resp, options) { + return resp; }, - // Bind all defined routes to `Backbone.history`. We have to reverse the - // order of the routes here to support behavior where the most general - // routes can be defined at the bottom of the route map. - _bindRoutes: function() { - if (!this.routes) return; - this.routes = _.result(this, 'routes'); - var route, routes = _.keys(this.routes); - while ((route = routes.pop()) != null) { - this.route(route, this.routes[route]); - } + // Create a new model with identical attributes to this one. + clone: function() { + return new this.constructor(this.attributes); }, - // Convert a route string into a regular expression, suitable for matching - // against the current location hash. - _routeToRegExp: function(route) { - route = route.replace(escapeRegExp, '\\$&') - .replace(optionalParam, '(?:$1)?') - .replace(namedParam, function(match, optional) { - return optional ? match : '([^/?]+)'; - }) - .replace(splatParam, '([^?]*?)'); - return new RegExp('^' + route + '(?:\\?([\\s\\S]*))?$'); + // A model is new if it has never been saved to the server, and lacks an id. + isNew: function() { + return !this.has(this.idAttribute); }, - // Given a route, and a URL fragment that it matches, return the array of - // extracted decoded parameters. Empty or unmatched parameters will be - // treated as `null` to normalize cross-browser behavior. - _extractParameters: function(route, fragment) { - var params = route.exec(fragment).slice(1); - return _.map(params, function(param, i) { - // Don't decode the search params. - if (i === params.length - 1) return param || null; - return param ? decodeURIComponent(param) : null; - }); + // Check if the model is currently in a valid state. + isValid: function(options) { + return this._validate({}, _.extend({}, options, {validate: true})); + }, + + // Run validation against the next complete set of model attributes, + // returning `true` if all is well. Otherwise, fire an `"invalid"` event. + _validate: function(attrs, options) { + if (!options.validate || !this.validate) return true; + attrs = _.extend({}, this.attributes, attrs); + var error = this.validationError = this.validate(attrs, options) || null; + if (!error) return true; + this.trigger('invalid', this, error, _.extend(options, {validationError: error})); + return false; } }); - // Backbone.History - // ---------------- + // Underscore methods that we want to implement on the Model, mapped to the + // number of arguments they take. + var modelMethods = {keys: 1, values: 1, pairs: 1, invert: 1, pick: 0, + omit: 0, chain: 1, isEmpty: 1}; - // Handles cross-browser history management, based on either - // [pushState](http://diveintohtml5.info/history.html) and real URLs, or - // [onhashchange](https://developer.mozilla.org/en-US/docs/DOM/window.onhashchange) - // and URL fragments. If the browser supports neither (old IE, natch), - // falls back to polling. - var History = Backbone.History = function() { - this.handlers = []; - this.checkUrl = _.bind(this.checkUrl, this); + // Mix in each Underscore method as a proxy to `Model#attributes`. + addUnderscoreMethods(Model, modelMethods, 'attributes'); - // Ensure that `History` can be used outside of the browser. - if (typeof window !== 'undefined') { - this.location = window.location; - this.history = window.history; - } - }; + // Backbone.Collection + // ------------------- - // Cached regex for stripping a leading hash/slash and trailing space. - var routeStripper = /^[#\/]|\s+$/g; + // If models tend to represent a single row of data, a Backbone Collection is + // more analogous to a table full of data ... or a small slice or page of that + // table, or a collection of rows that belong together for a particular reason + // -- all of the messages in this particular folder, all of the documents + // belonging to this particular author, and so on. Collections maintain + // indexes of their models, both in order, and for lookup by `id`. - // Cached regex for stripping leading and trailing slashes. - var rootStripper = /^\/+|\/+$/g; + // Create a new **Collection**, perhaps to contain a specific type of `model`. + // If a `comparator` is specified, the Collection will maintain + // its models in sort order, as they're added and removed. + var Collection = Backbone.Collection = function(models, options) { + options || (options = {}); + if (options.model) this.model = options.model; + if (options.comparator !== void 0) this.comparator = options.comparator; + this._reset(); + this.initialize.apply(this, arguments); + if (models) this.reset(models, _.extend({silent: true}, options)); + }; - // Cached regex for stripping urls of hash. - var pathStripper = /#.*$/; + // Default options for `Collection#set`. + var setOptions = {add: true, remove: true, merge: true}; + var addOptions = {add: true, remove: false}; - // Has the history handling already been started? - History.started = false; + // Splices `insert` into `array` at index `at`. + var splice = function(array, insert, at) { + at = Math.min(Math.max(at, 0), array.length); + var tail = Array(array.length - at); + var length = insert.length; + var i; + for (i = 0; i < tail.length; i++) tail[i] = array[i + at]; + for (i = 0; i < length; i++) array[i + at] = insert[i]; + for (i = 0; i < tail.length; i++) array[i + length + at] = tail[i]; + }; - // Set up all inheritable **Backbone.History** properties and methods. - _.extend(History.prototype, Events, { + // Define the Collection's inheritable methods. + _.extend(Collection.prototype, Events, { - // The default interval to poll for hash changes, if necessary, is - // twenty times a second. - interval: 50, + // The default model for a collection is just a **Backbone.Model**. + // This should be overridden in most cases. + model: Model, - // Are we at the app root? - atRoot: function() { - var path = this.location.pathname.replace(/[^\/]$/, '$&/'); - return path === this.root && !this.getSearch(); - }, + // Initialize is an empty function by default. Override it with your own + // initialization logic. + initialize: function(){}, - // Does the pathname match the root? - matchRoot: function() { - var path = this.decodeFragment(this.location.pathname); - var rootPath = path.slice(0, this.root.length - 1) + '/'; - return rootPath === this.root; + // The JSON representation of a Collection is an array of the + // models' attributes. + toJSON: function(options) { + return this.map(function(model) { return model.toJSON(options); }); }, - // Unicode characters in `location.pathname` are percent encoded so they're - // decoded for comparison. `%25` should not be decoded since it may be part - // of an encoded parameter. - decodeFragment: function(fragment) { - return decodeURI(fragment.replace(/%25/g, '%2525')); + // Proxy `Backbone.sync` by default. + sync: function() { + return Backbone.sync.apply(this, arguments); }, - // In IE6, the hash fragment and search params are incorrect if the - // fragment contains `?`. - getSearch: function() { - var match = this.location.href.replace(/#.*/, '').match(/\?.+/); - return match ? match[0] : ''; + // Add a model, or list of models to the set. `models` may be Backbone + // Models or raw JavaScript objects to be converted to Models, or any + // combination of the two. + add: function(models, options) { + return this.set(models, _.extend({merge: false}, options, addOptions)); }, - // Gets the true hash value. Cannot use location.hash directly due to bug - // in Firefox where location.hash will always be decoded. - getHash: function(window) { - var match = (window || this).location.href.match(/#(.*)$/); - return match ? match[1] : ''; + // Remove a model, or a list of models from the set. + remove: function(models, options) { + options = _.extend({}, options); + var singular = !_.isArray(models); + models = singular ? [models] : models.slice(); + var removed = this._removeModels(models, options); + if (!options.silent && removed.length) { + options.changes = {added: [], merged: [], removed: removed}; + this.trigger('update', this, options); + } + return singular ? removed[0] : removed; }, - // Get the pathname and search params, without the root. - getPath: function() { - var path = this.decodeFragment( - this.location.pathname + this.getSearch() - ).slice(this.root.length - 1); - return path.charAt(0) === '/' ? path.slice(1) : path; - }, + // Update a collection by `set`-ing a new list of models, adding new ones, + // removing models that are no longer present, and merging models that + // already exist in the collection, as necessary. Similar to **Model#set**, + // the core operation for updating the data contained by the collection. + set: function(models, options) { + if (models == null) return; - // Get the cross-browser normalized URL fragment from the path or hash. - getFragment: function(fragment) { - if (fragment == null) { - if (this._usePushState || !this._wantsHashChange) { - fragment = this.getPath(); - } else { - fragment = this.getHash(); - } + options = _.extend({}, setOptions, options); + if (options.parse && !this._isModel(models)) { + models = this.parse(models, options) || []; } - return fragment.replace(routeStripper, ''); - }, - // Start the hash change handling, returning `true` if the current URL matches - // an existing route, and `false` otherwise. - start: function(options) { - if (History.started) throw new Error('Backbone.history has already been started'); - History.started = true; + var singular = !_.isArray(models); + models = singular ? [models] : models.slice(); - // Figure out the initial configuration. Do we need an iframe? - // Is pushState desired ... is it available? - this.options = _.extend({root: '/'}, this.options, options); - this.root = this.options.root; - this._wantsHashChange = this.options.hashChange !== false; - this._hasHashChange = 'onhashchange' in window && (document.documentMode === void 0 || document.documentMode > 7); - this._useHashChange = this._wantsHashChange && this._hasHashChange; - this._wantsPushState = !!this.options.pushState; - this._hasPushState = !!(this.history && this.history.pushState); - this._usePushState = this._wantsPushState && this._hasPushState; - this.fragment = this.getFragment(); + var at = options.at; + if (at != null) at = +at; + if (at > this.length) at = this.length; + if (at < 0) at += this.length + 1; - // Normalize root to always include a leading and trailing slash. - this.root = ('/' + this.root + '/').replace(rootStripper, '/'); + var set = []; + var toAdd = []; + var toMerge = []; + var toRemove = []; + var modelMap = {}; - // Transition from hashChange to pushState or vice versa if both are - // requested. - if (this._wantsHashChange && this._wantsPushState) { + var add = options.add; + var merge = options.merge; + var remove = options.remove; - // If we've started off with a route from a `pushState`-enabled - // browser, but we're currently in a browser that doesn't support it... - if (!this._hasPushState && !this.atRoot()) { - var rootPath = this.root.slice(0, -1) || '/'; - this.location.replace(rootPath + '#' + this.getPath()); - // Return immediately as browser will do redirect to new url - return true; + var sort = false; + var sortable = this.comparator && at == null && options.sort !== false; + var sortAttr = _.isString(this.comparator) ? this.comparator : null; - // Or if we've started out with a hash-based route, but we're currently - // in a browser where it could be `pushState`-based instead... - } else if (this._hasPushState && this.atRoot()) { - this.navigate(this.getHash(), {replace: true}); - } + // Turn bare objects into model references, and prevent invalid models + // from being added. + var model, i; + for (i = 0; i < models.length; i++) { + model = models[i]; - } + // If a duplicate is found, prevent it from being added and + // optionally merge it into the existing model. + var existing = this.get(model); + if (existing) { + if (merge && model !== existing) { + var attrs = this._isModel(model) ? model.attributes : model; + if (options.parse) attrs = existing.parse(attrs, options); + existing.set(attrs, options); + toMerge.push(existing); + if (sortable && !sort) sort = existing.hasChanged(sortAttr); + } + if (!modelMap[existing.cid]) { + modelMap[existing.cid] = true; + set.push(existing); + } + models[i] = existing; - // Proxy an iframe to handle location events if the browser doesn't - // support the `hashchange` event, HTML5 history, or the user wants - // `hashChange` but not `pushState`. - if (!this._hasHashChange && this._wantsHashChange && !this._usePushState) { - this.iframe = document.createElement('iframe'); - this.iframe.src = 'javascript:0'; - this.iframe.style.display = 'none'; - this.iframe.tabIndex = -1; - var body = document.body; - // Using `appendChild` will throw on IE < 9 if the document is not ready. - var iWindow = body.insertBefore(this.iframe, body.firstChild).contentWindow; - iWindow.document.open(); - iWindow.document.close(); - iWindow.location.hash = '#' + this.fragment; + // If this is a new, valid model, push it to the `toAdd` list. + } else if (add) { + model = models[i] = this._prepareModel(model, options); + if (model) { + toAdd.push(model); + this._addReference(model, options); + modelMap[model.cid] = true; + set.push(model); + } + } } - // Add a cross-platform `addEventListener` shim for older browsers. - var addEventListener = window.addEventListener || function(eventName, listener) { - return attachEvent('on' + eventName, listener); - }; + // Remove stale models. + if (remove) { + for (i = 0; i < this.length; i++) { + model = this.models[i]; + if (!modelMap[model.cid]) toRemove.push(model); + } + if (toRemove.length) this._removeModels(toRemove, options); + } - // Depending on whether we're using pushState or hashes, and whether - // 'onhashchange' is supported, determine how we check the URL state. - if (this._usePushState) { - addEventListener('popstate', this.checkUrl, false); - } else if (this._useHashChange && !this.iframe) { - addEventListener('hashchange', this.checkUrl, false); - } else if (this._wantsHashChange) { - this._checkUrlInterval = setInterval(this.checkUrl, this.interval); + // See if sorting is needed, update `length` and splice in new models. + var orderChanged = false; + var replace = !sortable && add && remove; + if (set.length && replace) { + orderChanged = this.length !== set.length || _.some(this.models, function(m, index) { + return m !== set[index]; + }); + this.models.length = 0; + splice(this.models, set, 0); + this.length = this.models.length; + } else if (toAdd.length) { + if (sortable) sort = true; + splice(this.models, toAdd, at == null ? this.length : at); + this.length = this.models.length; } - if (!this.options.silent) return this.loadUrl(); - }, + // Silently sort the collection if appropriate. + if (sort) this.sort({silent: true}); - // Disable Backbone.history, perhaps temporarily. Not useful in a real app, - // but possibly useful for unit testing Routers. - stop: function() { - // Add a cross-platform `removeEventListener` shim for older browsers. - var removeEventListener = window.removeEventListener || function(eventName, listener) { - return detachEvent('on' + eventName, listener); - }; - - // Remove window listeners. - if (this._usePushState) { - removeEventListener('popstate', this.checkUrl, false); - } else if (this._useHashChange && !this.iframe) { - removeEventListener('hashchange', this.checkUrl, false); - } - - // Clean up the iframe if necessary. - if (this.iframe) { - document.body.removeChild(this.iframe); - this.iframe = null; + // Unless silenced, it's time to fire all appropriate add/sort/update events. + if (!options.silent) { + for (i = 0; i < toAdd.length; i++) { + if (at != null) options.index = at + i; + model = toAdd[i]; + model.trigger('add', model, this, options); + } + if (sort || orderChanged) this.trigger('sort', this, options); + if (toAdd.length || toRemove.length || toMerge.length) { + options.changes = { + added: toAdd, + removed: toRemove, + merged: toMerge + }; + this.trigger('update', this, options); + } } - // Some environments will throw when clearing an undefined interval. - if (this._checkUrlInterval) clearInterval(this._checkUrlInterval); - History.started = false; + // Return the added (or merged) model (or models). + return singular ? models[0] : models; }, - // Add a route to be tested when the fragment changes. Routes added later - // may override previous routes. - route: function(route, callback) { - this.handlers.unshift({route: route, callback: callback}); + // When you have more items than you want to add or remove individually, + // you can reset the entire set with a new list of models, without firing + // any granular `add` or `remove` events. Fires `reset` when finished. + // Useful for bulk operations and optimizations. + reset: function(models, options) { + options = options ? _.clone(options) : {}; + for (var i = 0; i < this.models.length; i++) { + this._removeReference(this.models[i], options); + } + options.previousModels = this.models; + this._reset(); + models = this.add(models, _.extend({silent: true}, options)); + if (!options.silent) this.trigger('reset', this, options); + return models; }, - // Checks the current URL to see if it has changed, and if it has, - // calls `loadUrl`, normalizing across the hidden iframe. - checkUrl: function(e) { - var current = this.getFragment(); - - // If the user pressed the back button, the iframe's hash will have - // changed and we should use that for comparison. - if (current === this.fragment && this.iframe) { - current = this.getHash(this.iframe.contentWindow); - } + // Add a model to the end of the collection. + push: function(model, options) { + return this.add(model, _.extend({at: this.length}, options)); + }, - if (current === this.fragment) return false; - if (this.iframe) this.navigate(current); - this.loadUrl(); + // Remove a model from the end of the collection. + pop: function(options) { + var model = this.at(this.length - 1); + return this.remove(model, options); }, - // Attempt to load the current URL fragment. If a route succeeds with a - // match, returns `true`. If no defined routes matches the fragment, - // returns `false`. - loadUrl: function(fragment) { - // If the root doesn't match, no routes can match either. - if (!this.matchRoot()) return false; - fragment = this.fragment = this.getFragment(fragment); - return _.some(this.handlers, function(handler) { - if (handler.route.test(fragment)) { - handler.callback(fragment); - return true; - } - }); + // Add a model to the beginning of the collection. + unshift: function(model, options) { + return this.add(model, _.extend({at: 0}, options)); }, - // Save a fragment into the hash history, or replace the URL state if the - // 'replace' option is passed. You are responsible for properly URL-encoding - // the fragment in advance. - // - // The options object can contain `trigger: true` if you wish to have the - // route callback be fired (not usually desirable), or `replace: true`, if - // you wish to modify the current URL without adding an entry to the history. - navigate: function(fragment, options) { - if (!History.started) return false; - if (!options || options === true) options = {trigger: !!options}; + // Remove a model from the beginning of the collection. + shift: function(options) { + var model = this.at(0); + return this.remove(model, options); + }, - // Normalize the fragment. - fragment = this.getFragment(fragment || ''); + // Slice out a sub-array of models from the collection. + slice: function() { + return slice.apply(this.models, arguments); + }, - // Don't include a trailing slash on the root. - var rootPath = this.root; - if (fragment === '' || fragment.charAt(0) === '?') { - rootPath = rootPath.slice(0, -1) || '/'; - } - var url = rootPath + fragment; + // Get a model from the set by id, cid, model object with id or cid + // properties, or an attributes object that is transformed through modelId. + get: function(obj) { + if (obj == null) return void 0; + return this._byId[obj] || + this._byId[this.modelId(obj.attributes || obj)] || + obj.cid && this._byId[obj.cid]; + }, - // Strip the hash and decode for matching. - fragment = this.decodeFragment(fragment.replace(pathStripper, '')); + // Returns `true` if the model is in the collection. + has: function(obj) { + return this.get(obj) != null; + }, - if (this.fragment === fragment) return; - this.fragment = fragment; + // Get the model at the given index. + at: function(index) { + if (index < 0) index += this.length; + return this.models[index]; + }, - // If pushState is available, we use it to set the fragment as a real URL. - if (this._usePushState) { - this.history[options.replace ? 'replaceState' : 'pushState']({}, document.title, url); + // Return models with matching attributes. Useful for simple cases of + // `filter`. + where: function(attrs, first) { + return this[first ? 'find' : 'filter'](attrs); + }, - // If hash changes haven't been explicitly disabled, update the hash - // fragment to store history. - } else if (this._wantsHashChange) { - this._updateHash(this.location, fragment, options.replace); - if (this.iframe && fragment !== this.getHash(this.iframe.contentWindow)) { - var iWindow = this.iframe.contentWindow; + // Return the first model with matching attributes. Useful for simple cases + // of `find`. + findWhere: function(attrs) { + return this.where(attrs, true); + }, - // Opening and closing the iframe tricks IE7 and earlier to push a - // history entry on hash-tag change. When replace is true, we don't - // want this. - if (!options.replace) { - iWindow.document.open(); - iWindow.document.close(); - } + // Force the collection to re-sort itself. You don't need to call this under + // normal circumstances, as the set will maintain sort order as each item + // is added. + sort: function(options) { + var comparator = this.comparator; + if (!comparator) throw new Error('Cannot sort a set without a comparator'); + options || (options = {}); - this._updateHash(iWindow.location, fragment, options.replace); - } + var length = comparator.length; + if (_.isFunction(comparator)) comparator = _.bind(comparator, this); - // If you've told us that you explicitly don't want fallback hashchange- - // based history, then `navigate` becomes a page refresh. + // Run sort based on type of `comparator`. + if (length === 1 || _.isString(comparator)) { + this.models = this.sortBy(comparator); } else { - return this.location.assign(url); + this.models.sort(comparator); } - if (options.trigger) return this.loadUrl(fragment); + if (!options.silent) this.trigger('sort', this, options); + return this; }, - // Update the hash location, either replacing the current entry, or adding - // a new one to the browser history. - _updateHash: function(location, fragment, replace) { - if (replace) { - var href = location.href.replace(/(javascript:|#).*$/, ''); - location.replace(href + '#' + fragment); - } else { - // Some browsers require that `hash` contains a leading #. - location.hash = '#' + fragment; - } - } + // Pluck an attribute from each model in the collection. + pluck: function(attr) { + return this.map(attr + ''); + }, - }); + // Fetch the default set of models for this collection, resetting the + // collection when they arrive. If `reset: true` is passed, the response + // data will be passed through the `reset` method instead of `set`. + fetch: function(options) { + options = _.extend({parse: true}, options); + var success = options.success; + var collection = this; + options.success = function(resp) { + var method = options.reset ? 'reset' : 'set'; + collection[method](resp, options); + if (success) success.call(options.context, collection, resp, options); + collection.trigger('sync', collection, resp, options); + }; + wrapError(this, options); + return this.sync('read', this, options); + }, - // Create the default Backbone.history. - Backbone.history = new History; + // Create a new instance of a model in this collection. Add the model to the + // collection immediately, unless `wait: true` is passed, in which case we + // wait for the server to agree. + create: function(model, options) { + options = options ? _.clone(options) : {}; + var wait = options.wait; + model = this._prepareModel(model, options); + if (!model) return false; + if (!wait) this.add(model, options); + var collection = this; + var success = options.success; + options.success = function(m, resp, callbackOpts) { + if (wait) collection.add(m, callbackOpts); + if (success) success.call(callbackOpts.context, m, resp, callbackOpts); + }; + model.save(null, options); + return model; + }, - // Helpers - // ------- + // **parse** converts a response into a list of models to be added to the + // collection. The default implementation is just to pass it through. + parse: function(resp, options) { + return resp; + }, - // Helper function to correctly set up the prototype chain for subclasses. - // Similar to `goog.inherits`, but uses a hash of prototype properties and - // class properties to be extended. - var extend = function(protoProps, staticProps) { - var parent = this; - var child; + // Create a new collection with an identical list of models as this one. + clone: function() { + return new this.constructor(this.models, { + model: this.model, + comparator: this.comparator + }); + }, - // The constructor function for the new subclass is either defined by you - // (the "constructor" property in your `extend` definition), or defaulted - // by us to simply call the parent constructor. - if (protoProps && _.has(protoProps, 'constructor')) { - child = protoProps.constructor; - } else { - child = function(){ return parent.apply(this, arguments); }; - } + // Define how to uniquely identify models in the collection. + modelId: function(attrs) { + return attrs[this.model.prototype.idAttribute || 'id']; + }, - // Add static properties to the constructor function, if supplied. - _.extend(child, parent, staticProps); + // Private method to reset all internal state. Called when the collection + // is first initialized or reset. + _reset: function() { + this.length = 0; + this.models = []; + this._byId = {}; + }, - // Set the prototype chain to inherit from `parent`, without calling - // `parent`'s constructor function and add the prototype properties. - child.prototype = _.create(parent.prototype, protoProps); - child.prototype.constructor = child; + // Prepare a hash of attributes (or other model) to be added to this + // collection. + _prepareModel: function(attrs, options) { + if (this._isModel(attrs)) { + if (!attrs.collection) attrs.collection = this; + return attrs; + } + options = options ? _.clone(options) : {}; + options.collection = this; + var model = new this.model(attrs, options); + if (!model.validationError) return model; + this.trigger('invalid', this, model.validationError, options); + return false; + }, - // Set a convenience property in case the parent's prototype is needed - // later. - child.__super__ = parent.prototype; + // Internal method called by both remove and set. + _removeModels: function(models, options) { + var removed = []; + for (var i = 0; i < models.length; i++) { + var model = this.get(models[i]); + if (!model) continue; - return child; - }; + var index = this.indexOf(model); + this.models.splice(index, 1); + this.length--; - // Set up inheritance for the model, collection, router, view and history. - Model.extend = Collection.extend = Router.extend = View.extend = History.extend = extend; + // Remove references before triggering 'remove' event to prevent an + // infinite loop. #3693 + delete this._byId[model.cid]; + var id = this.modelId(model.attributes); + if (id != null) delete this._byId[id]; - // Throw an error when a URL is needed, and none is supplied. - var urlError = function() { - throw new Error('A "url" property or function must be specified'); - }; + if (!options.silent) { + options.index = index; + model.trigger('remove', model, this, options); + } - // Wrap an optional error callback with a fallback error event. - var wrapError = function(model, options) { - var error = options.error; - options.error = function(resp) { - if (error) error.call(options.context, model, resp, options); - model.trigger('error', model, resp, options); - }; - }; + removed.push(model); + this._removeReference(model, options); + } + return removed; + }, - return Backbone; -}); + // Method for checking whether an object should be considered a model for + // the purposes of adding to the collection. + _isModel: function(model) { + return model instanceof Model; + }, -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(16))) + // Internal method to create a model's ties to a collection. + _addReference: function(model, options) { + this._byId[model.cid] = model; + var id = this.modelId(model.attributes); + if (id != null) this._byId[id] = model; + model.on('all', this._onModelEvent, this); + }, -/***/ }), -/* 1 */ -/***/ (function(module, exports, __webpack_require__) { + // Internal method to sever a model's ties to a collection. + _removeReference: function(model, options) { + delete this._byId[model.cid]; + var id = this.modelId(model.attributes); + if (id != null) delete this._byId[id]; + if (this === model.collection) delete model.collection; + model.off('all', this._onModelEvent, this); + }, -var __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;// Underscore.js 1.8.3 -// http://underscorejs.org -// (c) 2009-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors -// Underscore may be freely distributed under the MIT license. + // Internal method called every time a model in the set fires an event. + // Sets need to update their indexes when models change ids. All other + // events simply proxy through. "add" and "remove" events that originate + // in other collections are ignored. + _onModelEvent: function(event, model, collection, options) { + if (model) { + if ((event === 'add' || event === 'remove') && collection !== this) return; + if (event === 'destroy') this.remove(model, options); + if (event === 'change') { + var prevId = this.modelId(model.previousAttributes()); + var id = this.modelId(model.attributes); + if (prevId !== id) { + if (prevId != null) delete this._byId[prevId]; + if (id != null) this._byId[id] = model; + } + } + } + this.trigger.apply(this, arguments); + } -(function() { + }); - // Baseline setup - // -------------- + // Underscore methods that we want to implement on the Collection. + // 90% of the core usefulness of Backbone Collections is actually implemented + // right here: + var collectionMethods = {forEach: 3, each: 3, map: 3, collect: 3, reduce: 0, + foldl: 0, inject: 0, reduceRight: 0, foldr: 0, find: 3, detect: 3, filter: 3, + select: 3, reject: 3, every: 3, all: 3, some: 3, any: 3, include: 3, includes: 3, + contains: 3, invoke: 0, max: 3, min: 3, toArray: 1, size: 1, first: 3, + head: 3, take: 3, initial: 3, rest: 3, tail: 3, drop: 3, last: 3, + without: 0, difference: 0, indexOf: 3, shuffle: 1, lastIndexOf: 3, + isEmpty: 1, chain: 1, sample: 3, partition: 3, groupBy: 3, countBy: 3, + sortBy: 3, indexBy: 3, findIndex: 3, findLastIndex: 3}; - // Establish the root object, `window` in the browser, or `exports` on the server. - var root = this; + // Mix in each Underscore method as a proxy to `Collection#models`. + addUnderscoreMethods(Collection, collectionMethods, 'models'); - // Save the previous value of the `_` variable. - var previousUnderscore = root._; + // Backbone.View + // ------------- - // Save bytes in the minified (but not gzipped) version: - var ArrayProto = Array.prototype, ObjProto = Object.prototype, FuncProto = Function.prototype; + // Backbone Views are almost more convention than they are actual code. A View + // is simply a JavaScript object that represents a logical chunk of UI in the + // DOM. This might be a single item, an entire list, a sidebar or panel, or + // even the surrounding frame which wraps your whole app. Defining a chunk of + // UI as a **View** allows you to define your DOM events declaratively, without + // having to worry about render order ... and makes it easy for the view to + // react to specific changes in the state of your models. - // Create quick reference variables for speed access to core prototypes. - var - push = ArrayProto.push, - slice = ArrayProto.slice, - toString = ObjProto.toString, - hasOwnProperty = ObjProto.hasOwnProperty; + // Creating a Backbone.View creates its initial element outside of the DOM, + // if an existing element is not provided... + var View = Backbone.View = function(options) { + this.cid = _.uniqueId('view'); + _.extend(this, _.pick(options, viewOptions)); + this._ensureElement(); + this.initialize.apply(this, arguments); + }; - // All **ECMAScript 5** native function implementations that we hope to use - // are declared here. - var - nativeIsArray = Array.isArray, - nativeKeys = Object.keys, - nativeBind = FuncProto.bind, - nativeCreate = Object.create; + // Cached regex to split keys for `delegate`. + var delegateEventSplitter = /^(\S+)\s*(.*)$/; - // Naked function reference for surrogate-prototype-swapping. - var Ctor = function(){}; + // List of view options to be set as properties. + var viewOptions = ['model', 'collection', 'el', 'id', 'attributes', 'className', 'tagName', 'events']; - // Create a safe reference to the Underscore object for use below. - var _ = function(obj) { - if (obj instanceof _) return obj; - if (!(this instanceof _)) return new _(obj); - this._wrapped = obj; - }; + // Set up all inheritable **Backbone.View** properties and methods. + _.extend(View.prototype, Events, { - // Export the Underscore object for **Node.js**, with - // backwards-compatibility for the old `require()` API. If we're in - // the browser, add `_` as a global object. - if (true) { - if (typeof module !== 'undefined' && module.exports) { - exports = module.exports = _; - } - exports._ = _; - } else { - root._ = _; - } + // The default `tagName` of a View's element is `"div"`. + tagName: 'div', - // Current version. - _.VERSION = '1.8.3'; + // jQuery delegate for element lookup, scoped to DOM elements within the + // current view. This should be preferred to global lookups where possible. + $: function(selector) { + return this.$el.find(selector); + }, - // Internal function that returns an efficient (for current engines) version - // of the passed-in callback, to be repeatedly applied in other Underscore - // functions. - var optimizeCb = function(func, context, argCount) { - if (context === void 0) return func; - switch (argCount == null ? 3 : argCount) { - case 1: return function(value) { - return func.call(context, value); - }; - case 2: return function(value, other) { - return func.call(context, value, other); - }; - case 3: return function(value, index, collection) { - return func.call(context, value, index, collection); - }; - case 4: return function(accumulator, value, index, collection) { - return func.call(context, accumulator, value, index, collection); - }; - } - return function() { - return func.apply(context, arguments); - }; - }; + // Initialize is an empty function by default. Override it with your own + // initialization logic. + initialize: function(){}, - // A mostly-internal function to generate callbacks that can be applied - // to each element in a collection, returning the desired result — either - // identity, an arbitrary callback, a property matcher, or a property accessor. - var cb = function(value, context, argCount) { - if (value == null) return _.identity; - if (_.isFunction(value)) return optimizeCb(value, context, argCount); - if (_.isObject(value)) return _.matcher(value); - return _.property(value); - }; - _.iteratee = function(value, context) { - return cb(value, context, Infinity); - }; + // **render** is the core function that your view should override, in order + // to populate its element (`this.el`), with the appropriate HTML. The + // convention is for **render** to always return `this`. + render: function() { + return this; + }, - // An internal function for creating assigner functions. - var createAssigner = function(keysFunc, undefinedOnly) { - return function(obj) { - var length = arguments.length; - if (length < 2 || obj == null) return obj; - for (var index = 1; index < length; index++) { - var source = arguments[index], - keys = keysFunc(source), - l = keys.length; - for (var i = 0; i < l; i++) { - var key = keys[i]; - if (!undefinedOnly || obj[key] === void 0) obj[key] = source[key]; - } - } - return obj; - }; - }; + // Remove this view by taking the element out of the DOM, and removing any + // applicable Backbone.Events listeners. + remove: function() { + this._removeElement(); + this.stopListening(); + return this; + }, - // An internal function for creating a new object that inherits from another. - var baseCreate = function(prototype) { - if (!_.isObject(prototype)) return {}; - if (nativeCreate) return nativeCreate(prototype); - Ctor.prototype = prototype; - var result = new Ctor; - Ctor.prototype = null; - return result; - }; - - var property = function(key) { - return function(obj) { - return obj == null ? void 0 : obj[key]; - }; - }; + // Remove this view's element from the document and all event listeners + // attached to it. Exposed for subclasses using an alternative DOM + // manipulation API. + _removeElement: function() { + this.$el.remove(); + }, - // Helper for collection methods to determine whether a collection - // should be iterated as an array or as an object - // Related: http://people.mozilla.org/~jorendorff/es6-draft.html#sec-tolength - // Avoids a very nasty iOS 8 JIT bug on ARM-64. #2094 - var MAX_ARRAY_INDEX = Math.pow(2, 53) - 1; - var getLength = property('length'); - var isArrayLike = function(collection) { - var length = getLength(collection); - return typeof length == 'number' && length >= 0 && length <= MAX_ARRAY_INDEX; - }; + // Change the view's element (`this.el` property) and re-delegate the + // view's events on the new element. + setElement: function(element) { + this.undelegateEvents(); + this._setElement(element); + this.delegateEvents(); + return this; + }, - // Collection Functions - // -------------------- + // Creates the `this.el` and `this.$el` references for this view using the + // given `el`. `el` can be a CSS selector or an HTML string, a jQuery + // context or an element. Subclasses can override this to utilize an + // alternative DOM manipulation API and are only required to set the + // `this.el` property. + _setElement: function(el) { + this.$el = el instanceof Backbone.$ ? el : Backbone.$(el); + this.el = this.$el[0]; + }, - // The cornerstone, an `each` implementation, aka `forEach`. - // Handles raw objects in addition to array-likes. Treats all - // sparse array-likes as if they were dense. - _.each = _.forEach = function(obj, iteratee, context) { - iteratee = optimizeCb(iteratee, context); - var i, length; - if (isArrayLike(obj)) { - for (i = 0, length = obj.length; i < length; i++) { - iteratee(obj[i], i, obj); - } - } else { - var keys = _.keys(obj); - for (i = 0, length = keys.length; i < length; i++) { - iteratee(obj[keys[i]], keys[i], obj); + // Set callbacks, where `this.events` is a hash of + // + // *{"event selector": "callback"}* + // + // { + // 'mousedown .title': 'edit', + // 'click .button': 'save', + // 'click .open': function(e) { ... } + // } + // + // pairs. Callbacks will be bound to the view, with `this` set properly. + // Uses event delegation for efficiency. + // Omitting the selector binds the event to `this.el`. + delegateEvents: function(events) { + events || (events = _.result(this, 'events')); + if (!events) return this; + this.undelegateEvents(); + for (var key in events) { + var method = events[key]; + if (!_.isFunction(method)) method = this[method]; + if (!method) continue; + var match = key.match(delegateEventSplitter); + this.delegate(match[1], match[2], _.bind(method, this)); } - } - return obj; - }; + return this; + }, - // Return the results of applying the iteratee to each element. - _.map = _.collect = function(obj, iteratee, context) { - iteratee = cb(iteratee, context); - var keys = !isArrayLike(obj) && _.keys(obj), - length = (keys || obj).length, - results = Array(length); - for (var index = 0; index < length; index++) { - var currentKey = keys ? keys[index] : index; - results[index] = iteratee(obj[currentKey], currentKey, obj); - } - return results; - }; + // Add a single event listener to the view's element (or a child element + // using `selector`). This only works for delegate-able events: not `focus`, + // `blur`, and not `change`, `submit`, and `reset` in Internet Explorer. + delegate: function(eventName, selector, listener) { + this.$el.on(eventName + '.delegateEvents' + this.cid, selector, listener); + return this; + }, - // Create a reducing function iterating left or right. - function createReduce(dir) { - // Optimized iterator function as using arguments.length - // in the main function will deoptimize the, see #1991. - function iterator(obj, iteratee, memo, keys, index, length) { - for (; index >= 0 && index < length; index += dir) { - var currentKey = keys ? keys[index] : index; - memo = iteratee(memo, obj[currentKey], currentKey, obj); - } - return memo; - } + // Clears all callbacks previously bound to the view by `delegateEvents`. + // You usually don't need to use this, but may wish to if you have multiple + // Backbone views attached to the same DOM element. + undelegateEvents: function() { + if (this.$el) this.$el.off('.delegateEvents' + this.cid); + return this; + }, - return function(obj, iteratee, memo, context) { - iteratee = optimizeCb(iteratee, context, 4); - var keys = !isArrayLike(obj) && _.keys(obj), - length = (keys || obj).length, - index = dir > 0 ? 0 : length - 1; - // Determine the initial value if none is provided. - if (arguments.length < 3) { - memo = obj[keys ? keys[index] : index]; - index += dir; - } - return iterator(obj, iteratee, memo, keys, index, length); - }; - } + // A finer-grained `undelegateEvents` for removing a single delegated event. + // `selector` and `listener` are both optional. + undelegate: function(eventName, selector, listener) { + this.$el.off(eventName + '.delegateEvents' + this.cid, selector, listener); + return this; + }, - // **Reduce** builds up a single result from a list of values, aka `inject`, - // or `foldl`. - _.reduce = _.foldl = _.inject = createReduce(1); + // Produces a DOM element to be assigned to your view. Exposed for + // subclasses using an alternative DOM manipulation API. + _createElement: function(tagName) { + return document.createElement(tagName); + }, - // The right-associative version of reduce, also known as `foldr`. - _.reduceRight = _.foldr = createReduce(-1); + // Ensure that the View has a DOM element to render into. + // If `this.el` is a string, pass it through `$()`, take the first + // matching element, and re-assign it to `el`. Otherwise, create + // an element from the `id`, `className` and `tagName` properties. + _ensureElement: function() { + if (!this.el) { + var attrs = _.extend({}, _.result(this, 'attributes')); + if (this.id) attrs.id = _.result(this, 'id'); + if (this.className) attrs['class'] = _.result(this, 'className'); + this.setElement(this._createElement(_.result(this, 'tagName'))); + this._setAttributes(attrs); + } else { + this.setElement(_.result(this, 'el')); + } + }, - // Return the first value which passes a truth test. Aliased as `detect`. - _.find = _.detect = function(obj, predicate, context) { - var key; - if (isArrayLike(obj)) { - key = _.findIndex(obj, predicate, context); - } else { - key = _.findKey(obj, predicate, context); + // Set attributes from a hash on this view's element. Exposed for + // subclasses using an alternative DOM manipulation API. + _setAttributes: function(attributes) { + this.$el.attr(attributes); } - if (key !== void 0 && key !== -1) return obj[key]; - }; - // Return all the elements that pass a truth test. - // Aliased as `select`. - _.filter = _.select = function(obj, predicate, context) { - var results = []; - predicate = cb(predicate, context); - _.each(obj, function(value, index, list) { - if (predicate(value, index, list)) results.push(value); + }); + + // Backbone.sync + // ------------- + + // Override this function to change the manner in which Backbone persists + // models to the server. You will be passed the type of request, and the + // model in question. By default, makes a RESTful Ajax request + // to the model's `url()`. Some possible customizations could be: + // + // * Use `setTimeout` to batch rapid-fire updates into a single request. + // * Send up the models as XML instead of JSON. + // * Persist models via WebSockets instead of Ajax. + // + // Turn on `Backbone.emulateHTTP` in order to send `PUT` and `DELETE` requests + // as `POST`, with a `_method` parameter containing the true HTTP method, + // as well as all requests with the body as `application/x-www-form-urlencoded` + // instead of `application/json` with the model in a param named `model`. + // Useful when interfacing with server-side languages like **PHP** that make + // it difficult to read the body of `PUT` requests. + Backbone.sync = function(method, model, options) { + var type = methodMap[method]; + + // Default options, unless specified. + _.defaults(options || (options = {}), { + emulateHTTP: Backbone.emulateHTTP, + emulateJSON: Backbone.emulateJSON }); - return results; - }; - // Return all the elements for which a truth test fails. - _.reject = function(obj, predicate, context) { - return _.filter(obj, _.negate(cb(predicate)), context); - }; + // Default JSON-request options. + var params = {type: type, dataType: 'json'}; - // Determine whether all of the elements match a truth test. - // Aliased as `all`. - _.every = _.all = function(obj, predicate, context) { - predicate = cb(predicate, context); - var keys = !isArrayLike(obj) && _.keys(obj), - length = (keys || obj).length; - for (var index = 0; index < length; index++) { - var currentKey = keys ? keys[index] : index; - if (!predicate(obj[currentKey], currentKey, obj)) return false; + // Ensure that we have a URL. + if (!options.url) { + params.url = _.result(model, 'url') || urlError(); } - return true; - }; - // Determine if at least one element in the object matches a truth test. - // Aliased as `any`. - _.some = _.any = function(obj, predicate, context) { - predicate = cb(predicate, context); - var keys = !isArrayLike(obj) && _.keys(obj), - length = (keys || obj).length; - for (var index = 0; index < length; index++) { - var currentKey = keys ? keys[index] : index; - if (predicate(obj[currentKey], currentKey, obj)) return true; + // Ensure that we have the appropriate request data. + if (options.data == null && model && (method === 'create' || method === 'update' || method === 'patch')) { + params.contentType = 'application/json'; + params.data = JSON.stringify(options.attrs || model.toJSON(options)); } - return false; - }; - // Determine if the array or object contains a given item (using `===`). - // Aliased as `includes` and `include`. - _.contains = _.includes = _.include = function(obj, item, fromIndex, guard) { - if (!isArrayLike(obj)) obj = _.values(obj); - if (typeof fromIndex != 'number' || guard) fromIndex = 0; - return _.indexOf(obj, item, fromIndex) >= 0; - }; + // For older servers, emulate JSON by encoding the request into an HTML-form. + if (options.emulateJSON) { + params.contentType = 'application/x-www-form-urlencoded'; + params.data = params.data ? {model: params.data} : {}; + } - // Invoke a method (with arguments) on every item in a collection. - _.invoke = function(obj, method) { - var args = slice.call(arguments, 2); - var isFunc = _.isFunction(method); - return _.map(obj, function(value) { - var func = isFunc ? method : value[method]; - return func == null ? func : func.apply(value, args); - }); - }; + // For older servers, emulate HTTP by mimicking the HTTP method with `_method` + // And an `X-HTTP-Method-Override` header. + if (options.emulateHTTP && (type === 'PUT' || type === 'DELETE' || type === 'PATCH')) { + params.type = 'POST'; + if (options.emulateJSON) params.data._method = type; + var beforeSend = options.beforeSend; + options.beforeSend = function(xhr) { + xhr.setRequestHeader('X-HTTP-Method-Override', type); + if (beforeSend) return beforeSend.apply(this, arguments); + }; + } - // Convenience version of a common use case of `map`: fetching a property. - _.pluck = function(obj, key) { - return _.map(obj, _.property(key)); + // Don't process data on a non-GET request. + if (params.type !== 'GET' && !options.emulateJSON) { + params.processData = false; + } + + // Pass along `textStatus` and `errorThrown` from jQuery. + var error = options.error; + options.error = function(xhr, textStatus, errorThrown) { + options.textStatus = textStatus; + options.errorThrown = errorThrown; + if (error) error.call(options.context, xhr, textStatus, errorThrown); + }; + + // Make the request, allowing the user to override any Ajax options. + var xhr = options.xhr = Backbone.ajax(_.extend(params, options)); + model.trigger('request', model, xhr, options); + return xhr; }; - // Convenience version of a common use case of `filter`: selecting only objects - // containing specific `key:value` pairs. - _.where = function(obj, attrs) { - return _.filter(obj, _.matcher(attrs)); + // Map from CRUD to HTTP for our default `Backbone.sync` implementation. + var methodMap = { + 'create': 'POST', + 'update': 'PUT', + 'patch': 'PATCH', + 'delete': 'DELETE', + 'read': 'GET' }; - // Convenience version of a common use case of `find`: getting the first object - // containing specific `key:value` pairs. - _.findWhere = function(obj, attrs) { - return _.find(obj, _.matcher(attrs)); + // Set the default implementation of `Backbone.ajax` to proxy through to `$`. + // Override this if you'd like to use a different library. + Backbone.ajax = function() { + return Backbone.$.ajax.apply(Backbone.$, arguments); }; - // Return the maximum element (or element-based computation). - _.max = function(obj, iteratee, context) { - var result = -Infinity, lastComputed = -Infinity, - value, computed; - if (iteratee == null && obj != null) { - obj = isArrayLike(obj) ? obj : _.values(obj); - for (var i = 0, length = obj.length; i < length; i++) { - value = obj[i]; - if (value > result) { - result = value; - } - } - } else { - iteratee = cb(iteratee, context); - _.each(obj, function(value, index, list) { - computed = iteratee(value, index, list); - if (computed > lastComputed || computed === -Infinity && result === -Infinity) { - result = value; - lastComputed = computed; - } - }); - } - return result; + // Backbone.Router + // --------------- + + // Routers map faux-URLs to actions, and fire events when routes are + // matched. Creating a new one sets its `routes` hash, if not set statically. + var Router = Backbone.Router = function(options) { + options || (options = {}); + if (options.routes) this.routes = options.routes; + this._bindRoutes(); + this.initialize.apply(this, arguments); }; - // Return the minimum element (or element-based computation). - _.min = function(obj, iteratee, context) { - var result = Infinity, lastComputed = Infinity, - value, computed; - if (iteratee == null && obj != null) { - obj = isArrayLike(obj) ? obj : _.values(obj); - for (var i = 0, length = obj.length; i < length; i++) { - value = obj[i]; - if (value < result) { - result = value; - } + // Cached regular expressions for matching named param parts and splatted + // parts of route strings. + var optionalParam = /\((.*?)\)/g; + var namedParam = /(\(\?)?:\w+/g; + var splatParam = /\*\w+/g; + var escapeRegExp = /[\-{}\[\]+?.,\\\^$|#\s]/g; + + // Set up all inheritable **Backbone.Router** properties and methods. + _.extend(Router.prototype, Events, { + + // Initialize is an empty function by default. Override it with your own + // initialization logic. + initialize: function(){}, + + // Manually bind a single named route to a callback. For example: + // + // this.route('search/:query/p:num', 'search', function(query, num) { + // ... + // }); + // + route: function(route, name, callback) { + if (!_.isRegExp(route)) route = this._routeToRegExp(route); + if (_.isFunction(name)) { + callback = name; + name = ''; } - } else { - iteratee = cb(iteratee, context); - _.each(obj, function(value, index, list) { - computed = iteratee(value, index, list); - if (computed < lastComputed || computed === Infinity && result === Infinity) { - result = value; - lastComputed = computed; + if (!callback) callback = this[name]; + var router = this; + Backbone.history.route(route, function(fragment) { + var args = router._extractParameters(route, fragment); + if (router.execute(callback, args, name) !== false) { + router.trigger.apply(router, ['route:' + name].concat(args)); + router.trigger('route', name, args); + Backbone.history.trigger('route', router, name, args); } }); - } - return result; - }; + return this; + }, - // Shuffle a collection, using the modern version of the - // [Fisher-Yates shuffle](http://en.wikipedia.org/wiki/Fisher–Yates_shuffle). - _.shuffle = function(obj) { - var set = isArrayLike(obj) ? obj : _.values(obj); - var length = set.length; - var shuffled = Array(length); - for (var index = 0, rand; index < length; index++) { - rand = _.random(0, index); - if (rand !== index) shuffled[index] = shuffled[rand]; - shuffled[rand] = set[index]; - } - return shuffled; - }; + // Execute a route handler with the provided parameters. This is an + // excellent place to do pre-route setup or post-route cleanup. + execute: function(callback, args, name) { + if (callback) callback.apply(this, args); + }, - // Sample **n** random values from a collection. - // If **n** is not specified, returns a single random element. - // The internal `guard` argument allows it to work with `map`. - _.sample = function(obj, n, guard) { - if (n == null || guard) { - if (!isArrayLike(obj)) obj = _.values(obj); - return obj[_.random(obj.length - 1)]; - } - return _.shuffle(obj).slice(0, Math.max(0, n)); - }; + // Simple proxy to `Backbone.history` to save a fragment into the history. + navigate: function(fragment, options) { + Backbone.history.navigate(fragment, options); + return this; + }, - // Sort the object's values by a criterion produced by an iteratee. - _.sortBy = function(obj, iteratee, context) { - iteratee = cb(iteratee, context); - return _.pluck(_.map(obj, function(value, index, list) { - return { - value: value, - index: index, - criteria: iteratee(value, index, list) - }; - }).sort(function(left, right) { - var a = left.criteria; - var b = right.criteria; - if (a !== b) { - if (a > b || a === void 0) return 1; - if (a < b || b === void 0) return -1; + // Bind all defined routes to `Backbone.history`. We have to reverse the + // order of the routes here to support behavior where the most general + // routes can be defined at the bottom of the route map. + _bindRoutes: function() { + if (!this.routes) return; + this.routes = _.result(this, 'routes'); + var route, routes = _.keys(this.routes); + while ((route = routes.pop()) != null) { + this.route(route, this.routes[route]); } - return left.index - right.index; - }), 'value'); - }; + }, - // An internal function used for aggregate "group by" operations. - var group = function(behavior) { - return function(obj, iteratee, context) { - var result = {}; - iteratee = cb(iteratee, context); - _.each(obj, function(value, index) { - var key = iteratee(value, index, obj); - behavior(result, value, key); + // Convert a route string into a regular expression, suitable for matching + // against the current location hash. + _routeToRegExp: function(route) { + route = route.replace(escapeRegExp, '\\$&') + .replace(optionalParam, '(?:$1)?') + .replace(namedParam, function(match, optional) { + return optional ? match : '([^/?]+)'; + }) + .replace(splatParam, '([^?]*?)'); + return new RegExp('^' + route + '(?:\\?([\\s\\S]*))?$'); + }, + + // Given a route, and a URL fragment that it matches, return the array of + // extracted decoded parameters. Empty or unmatched parameters will be + // treated as `null` to normalize cross-browser behavior. + _extractParameters: function(route, fragment) { + var params = route.exec(fragment).slice(1); + return _.map(params, function(param, i) { + // Don't decode the search params. + if (i === params.length - 1) return param || null; + return param ? decodeURIComponent(param) : null; }); - return result; - }; - }; + } - // Groups the object's values by a criterion. Pass either a string attribute - // to group by, or a function that returns the criterion. - _.groupBy = group(function(result, value, key) { - if (_.has(result, key)) result[key].push(value); else result[key] = [value]; }); - // Indexes the object's values by a criterion, similar to `groupBy`, but for - // when you know that your index values will be unique. - _.indexBy = group(function(result, value, key) { - result[key] = value; - }); + // Backbone.History + // ---------------- - // Counts instances of an object that group by a certain criterion. Pass - // either a string attribute to count by, or a function that returns the - // criterion. - _.countBy = group(function(result, value, key) { - if (_.has(result, key)) result[key]++; else result[key] = 1; - }); + // Handles cross-browser history management, based on either + // [pushState](http://diveintohtml5.info/history.html) and real URLs, or + // [onhashchange](https://developer.mozilla.org/en-US/docs/DOM/window.onhashchange) + // and URL fragments. If the browser supports neither (old IE, natch), + // falls back to polling. + var History = Backbone.History = function() { + this.handlers = []; + this.checkUrl = _.bind(this.checkUrl, this); - // Safely create a real, live array from anything iterable. - _.toArray = function(obj) { - if (!obj) return []; - if (_.isArray(obj)) return slice.call(obj); - if (isArrayLike(obj)) return _.map(obj, _.identity); - return _.values(obj); + // Ensure that `History` can be used outside of the browser. + if (typeof window !== 'undefined') { + this.location = window.location; + this.history = window.history; + } }; - // Return the number of elements in an object. - _.size = function(obj) { - if (obj == null) return 0; - return isArrayLike(obj) ? obj.length : _.keys(obj).length; - }; + // Cached regex for stripping a leading hash/slash and trailing space. + var routeStripper = /^[#\/]|\s+$/g; - // Split a collection into two arrays: one whose elements all satisfy the given - // predicate, and one whose elements all do not satisfy the predicate. - _.partition = function(obj, predicate, context) { - predicate = cb(predicate, context); - var pass = [], fail = []; - _.each(obj, function(value, key, obj) { - (predicate(value, key, obj) ? pass : fail).push(value); - }); - return [pass, fail]; - }; + // Cached regex for stripping leading and trailing slashes. + var rootStripper = /^\/+|\/+$/g; - // Array Functions - // --------------- + // Cached regex for stripping urls of hash. + var pathStripper = /#.*$/; - // Get the first element of an array. Passing **n** will return the first N - // values in the array. Aliased as `head` and `take`. The **guard** check - // allows it to work with `_.map`. - _.first = _.head = _.take = function(array, n, guard) { - if (array == null) return void 0; - if (n == null || guard) return array[0]; - return _.initial(array, array.length - n); - }; + // Has the history handling already been started? + History.started = false; - // Returns everything but the last entry of the array. Especially useful on - // the arguments object. Passing **n** will return all the values in - // the array, excluding the last N. - _.initial = function(array, n, guard) { - return slice.call(array, 0, Math.max(0, array.length - (n == null || guard ? 1 : n))); - }; + // Set up all inheritable **Backbone.History** properties and methods. + _.extend(History.prototype, Events, { - // Get the last element of an array. Passing **n** will return the last N - // values in the array. - _.last = function(array, n, guard) { - if (array == null) return void 0; - if (n == null || guard) return array[array.length - 1]; - return _.rest(array, Math.max(0, array.length - n)); - }; + // The default interval to poll for hash changes, if necessary, is + // twenty times a second. + interval: 50, - // Returns everything but the first entry of the array. Aliased as `tail` and `drop`. - // Especially useful on the arguments object. Passing an **n** will return - // the rest N values in the array. - _.rest = _.tail = _.drop = function(array, n, guard) { - return slice.call(array, n == null || guard ? 1 : n); - }; + // Are we at the app root? + atRoot: function() { + var path = this.location.pathname.replace(/[^\/]$/, '$&/'); + return path === this.root && !this.getSearch(); + }, - // Trim out all falsy values from an array. - _.compact = function(array) { - return _.filter(array, _.identity); - }; + // Does the pathname match the root? + matchRoot: function() { + var path = this.decodeFragment(this.location.pathname); + var rootPath = path.slice(0, this.root.length - 1) + '/'; + return rootPath === this.root; + }, - // Internal implementation of a recursive `flatten` function. - var flatten = function(input, shallow, strict, startIndex) { - var output = [], idx = 0; - for (var i = startIndex || 0, length = getLength(input); i < length; i++) { - var value = input[i]; - if (isArrayLike(value) && (_.isArray(value) || _.isArguments(value))) { - //flatten current level of array or arguments object - if (!shallow) value = flatten(value, shallow, strict); - var j = 0, len = value.length; - output.length += len; - while (j < len) { - output[idx++] = value[j++]; - } - } else if (!strict) { - output[idx++] = value; - } - } - return output; - }; + // Unicode characters in `location.pathname` are percent encoded so they're + // decoded for comparison. `%25` should not be decoded since it may be part + // of an encoded parameter. + decodeFragment: function(fragment) { + return decodeURI(fragment.replace(/%25/g, '%2525')); + }, - // Flatten out an array, either recursively (by default), or just one level. - _.flatten = function(array, shallow) { - return flatten(array, shallow, false); - }; + // In IE6, the hash fragment and search params are incorrect if the + // fragment contains `?`. + getSearch: function() { + var match = this.location.href.replace(/#.*/, '').match(/\?.+/); + return match ? match[0] : ''; + }, - // Return a version of the array that does not contain the specified value(s). - _.without = function(array) { - return _.difference(array, slice.call(arguments, 1)); - }; + // Gets the true hash value. Cannot use location.hash directly due to bug + // in Firefox where location.hash will always be decoded. + getHash: function(window) { + var match = (window || this).location.href.match(/#(.*)$/); + return match ? match[1] : ''; + }, - // Produce a duplicate-free version of the array. If the array has already - // been sorted, you have the option of using a faster algorithm. - // Aliased as `unique`. - _.uniq = _.unique = function(array, isSorted, iteratee, context) { - if (!_.isBoolean(isSorted)) { - context = iteratee; - iteratee = isSorted; - isSorted = false; - } - if (iteratee != null) iteratee = cb(iteratee, context); - var result = []; - var seen = []; - for (var i = 0, length = getLength(array); i < length; i++) { - var value = array[i], - computed = iteratee ? iteratee(value, i, array) : value; - if (isSorted) { - if (!i || seen !== computed) result.push(value); - seen = computed; - } else if (iteratee) { - if (!_.contains(seen, computed)) { - seen.push(computed); - result.push(value); + // Get the pathname and search params, without the root. + getPath: function() { + var path = this.decodeFragment( + this.location.pathname + this.getSearch() + ).slice(this.root.length - 1); + return path.charAt(0) === '/' ? path.slice(1) : path; + }, + + // Get the cross-browser normalized URL fragment from the path or hash. + getFragment: function(fragment) { + if (fragment == null) { + if (this._usePushState || !this._wantsHashChange) { + fragment = this.getPath(); + } else { + fragment = this.getHash(); } - } else if (!_.contains(result, value)) { - result.push(value); } - } - return result; - }; + return fragment.replace(routeStripper, ''); + }, - // Produce an array that contains the union: each distinct element from all of - // the passed-in arrays. - _.union = function() { - return _.uniq(flatten(arguments, true, true)); - }; + // Start the hash change handling, returning `true` if the current URL matches + // an existing route, and `false` otherwise. + start: function(options) { + if (History.started) throw new Error('Backbone.history has already been started'); + History.started = true; - // Produce an array that contains every item shared between all the - // passed-in arrays. - _.intersection = function(array) { - var result = []; - var argsLength = arguments.length; - for (var i = 0, length = getLength(array); i < length; i++) { - var item = array[i]; - if (_.contains(result, item)) continue; - for (var j = 1; j < argsLength; j++) { - if (!_.contains(arguments[j], item)) break; - } - if (j === argsLength) result.push(item); - } - return result; - }; + // Figure out the initial configuration. Do we need an iframe? + // Is pushState desired ... is it available? + this.options = _.extend({root: '/'}, this.options, options); + this.root = this.options.root; + this._wantsHashChange = this.options.hashChange !== false; + this._hasHashChange = 'onhashchange' in window && (document.documentMode === void 0 || document.documentMode > 7); + this._useHashChange = this._wantsHashChange && this._hasHashChange; + this._wantsPushState = !!this.options.pushState; + this._hasPushState = !!(this.history && this.history.pushState); + this._usePushState = this._wantsPushState && this._hasPushState; + this.fragment = this.getFragment(); - // Take the difference between one array and a number of other arrays. - // Only the elements present in just the first array will remain. - _.difference = function(array) { - var rest = flatten(arguments, true, true, 1); - return _.filter(array, function(value){ - return !_.contains(rest, value); - }); - }; + // Normalize root to always include a leading and trailing slash. + this.root = ('/' + this.root + '/').replace(rootStripper, '/'); - // Zip together multiple lists into a single array -- elements that share - // an index go together. - _.zip = function() { - return _.unzip(arguments); - }; + // Transition from hashChange to pushState or vice versa if both are + // requested. + if (this._wantsHashChange && this._wantsPushState) { - // Complement of _.zip. Unzip accepts an array of arrays and groups - // each array's elements on shared indices - _.unzip = function(array) { - var length = array && _.max(array, getLength).length || 0; - var result = Array(length); + // If we've started off with a route from a `pushState`-enabled + // browser, but we're currently in a browser that doesn't support it... + if (!this._hasPushState && !this.atRoot()) { + var rootPath = this.root.slice(0, -1) || '/'; + this.location.replace(rootPath + '#' + this.getPath()); + // Return immediately as browser will do redirect to new url + return true; - for (var index = 0; index < length; index++) { - result[index] = _.pluck(array, index); - } - return result; - }; + // Or if we've started out with a hash-based route, but we're currently + // in a browser where it could be `pushState`-based instead... + } else if (this._hasPushState && this.atRoot()) { + this.navigate(this.getHash(), {replace: true}); + } - // Converts lists into objects. Pass either a single array of `[key, value]` - // pairs, or two parallel arrays of the same length -- one of keys, and one of - // the corresponding values. - _.object = function(list, values) { - var result = {}; - for (var i = 0, length = getLength(list); i < length; i++) { - if (values) { - result[list[i]] = values[i]; - } else { - result[list[i][0]] = list[i][1]; } - } - return result; - }; - // Generator function to create the findIndex and findLastIndex functions - function createPredicateIndexFinder(dir) { - return function(array, predicate, context) { - predicate = cb(predicate, context); - var length = getLength(array); - var index = dir > 0 ? 0 : length - 1; - for (; index >= 0 && index < length; index += dir) { - if (predicate(array[index], index, array)) return index; + // Proxy an iframe to handle location events if the browser doesn't + // support the `hashchange` event, HTML5 history, or the user wants + // `hashChange` but not `pushState`. + if (!this._hasHashChange && this._wantsHashChange && !this._usePushState) { + this.iframe = document.createElement('iframe'); + this.iframe.src = 'javascript:0'; + this.iframe.style.display = 'none'; + this.iframe.tabIndex = -1; + var body = document.body; + // Using `appendChild` will throw on IE < 9 if the document is not ready. + var iWindow = body.insertBefore(this.iframe, body.firstChild).contentWindow; + iWindow.document.open(); + iWindow.document.close(); + iWindow.location.hash = '#' + this.fragment; } - return -1; - }; - } - - // Returns the first index on an array-like that passes a predicate test - _.findIndex = createPredicateIndexFinder(1); - _.findLastIndex = createPredicateIndexFinder(-1); - // Use a comparator function to figure out the smallest index at which - // an object should be inserted so as to maintain order. Uses binary search. - _.sortedIndex = function(array, obj, iteratee, context) { - iteratee = cb(iteratee, context, 1); - var value = iteratee(obj); - var low = 0, high = getLength(array); - while (low < high) { - var mid = Math.floor((low + high) / 2); - if (iteratee(array[mid]) < value) low = mid + 1; else high = mid; - } - return low; - }; + // Add a cross-platform `addEventListener` shim for older browsers. + var addEventListener = window.addEventListener || function(eventName, listener) { + return attachEvent('on' + eventName, listener); + }; - // Generator function to create the indexOf and lastIndexOf functions - function createIndexFinder(dir, predicateFind, sortedIndex) { - return function(array, item, idx) { - var i = 0, length = getLength(array); - if (typeof idx == 'number') { - if (dir > 0) { - i = idx >= 0 ? idx : Math.max(idx + length, i); - } else { - length = idx >= 0 ? Math.min(idx + 1, length) : idx + length + 1; - } - } else if (sortedIndex && idx && length) { - idx = sortedIndex(array, item); - return array[idx] === item ? idx : -1; + // Depending on whether we're using pushState or hashes, and whether + // 'onhashchange' is supported, determine how we check the URL state. + if (this._usePushState) { + addEventListener('popstate', this.checkUrl, false); + } else if (this._useHashChange && !this.iframe) { + addEventListener('hashchange', this.checkUrl, false); + } else if (this._wantsHashChange) { + this._checkUrlInterval = setInterval(this.checkUrl, this.interval); } - if (item !== item) { - idx = predicateFind(slice.call(array, i, length), _.isNaN); - return idx >= 0 ? idx + i : -1; + + if (!this.options.silent) return this.loadUrl(); + }, + + // Disable Backbone.history, perhaps temporarily. Not useful in a real app, + // but possibly useful for unit testing Routers. + stop: function() { + // Add a cross-platform `removeEventListener` shim for older browsers. + var removeEventListener = window.removeEventListener || function(eventName, listener) { + return detachEvent('on' + eventName, listener); + }; + + // Remove window listeners. + if (this._usePushState) { + removeEventListener('popstate', this.checkUrl, false); + } else if (this._useHashChange && !this.iframe) { + removeEventListener('hashchange', this.checkUrl, false); } - for (idx = dir > 0 ? i : length - 1; idx >= 0 && idx < length; idx += dir) { - if (array[idx] === item) return idx; + + // Clean up the iframe if necessary. + if (this.iframe) { + document.body.removeChild(this.iframe); + this.iframe = null; } - return -1; - }; - } - // Return the position of the first occurrence of an item in an array, - // or -1 if the item is not included in the array. - // If the array is large and already in sort order, pass `true` - // for **isSorted** to use binary search. - _.indexOf = createIndexFinder(1, _.findIndex, _.sortedIndex); - _.lastIndexOf = createIndexFinder(-1, _.findLastIndex); + // Some environments will throw when clearing an undefined interval. + if (this._checkUrlInterval) clearInterval(this._checkUrlInterval); + History.started = false; + }, - // Generate an integer Array containing an arithmetic progression. A port of - // the native Python `range()` function. See - // [the Python documentation](http://docs.python.org/library/functions.html#range). - _.range = function(start, stop, step) { - if (stop == null) { - stop = start || 0; - start = 0; - } - step = step || 1; + // Add a route to be tested when the fragment changes. Routes added later + // may override previous routes. + route: function(route, callback) { + this.handlers.unshift({route: route, callback: callback}); + }, - var length = Math.max(Math.ceil((stop - start) / step), 0); - var range = Array(length); + // Checks the current URL to see if it has changed, and if it has, + // calls `loadUrl`, normalizing across the hidden iframe. + checkUrl: function(e) { + var current = this.getFragment(); - for (var idx = 0; idx < length; idx++, start += step) { - range[idx] = start; - } + // If the user pressed the back button, the iframe's hash will have + // changed and we should use that for comparison. + if (current === this.fragment && this.iframe) { + current = this.getHash(this.iframe.contentWindow); + } - return range; - }; + if (current === this.fragment) return false; + if (this.iframe) this.navigate(current); + this.loadUrl(); + }, - // Function (ahem) Functions - // ------------------ + // Attempt to load the current URL fragment. If a route succeeds with a + // match, returns `true`. If no defined routes matches the fragment, + // returns `false`. + loadUrl: function(fragment) { + // If the root doesn't match, no routes can match either. + if (!this.matchRoot()) return false; + fragment = this.fragment = this.getFragment(fragment); + return _.some(this.handlers, function(handler) { + if (handler.route.test(fragment)) { + handler.callback(fragment); + return true; + } + }); + }, - // Determines whether to execute a function as a constructor - // or a normal function with the provided arguments - var executeBound = function(sourceFunc, boundFunc, context, callingContext, args) { - if (!(callingContext instanceof boundFunc)) return sourceFunc.apply(context, args); - var self = baseCreate(sourceFunc.prototype); - var result = sourceFunc.apply(self, args); - if (_.isObject(result)) return result; - return self; - }; + // Save a fragment into the hash history, or replace the URL state if the + // 'replace' option is passed. You are responsible for properly URL-encoding + // the fragment in advance. + // + // The options object can contain `trigger: true` if you wish to have the + // route callback be fired (not usually desirable), or `replace: true`, if + // you wish to modify the current URL without adding an entry to the history. + navigate: function(fragment, options) { + if (!History.started) return false; + if (!options || options === true) options = {trigger: !!options}; - // Create a function bound to a given object (assigning `this`, and arguments, - // optionally). Delegates to **ECMAScript 5**'s native `Function.bind` if - // available. - _.bind = function(func, context) { - if (nativeBind && func.bind === nativeBind) return nativeBind.apply(func, slice.call(arguments, 1)); - if (!_.isFunction(func)) throw new TypeError('Bind must be called on a function'); - var args = slice.call(arguments, 2); - var bound = function() { - return executeBound(func, bound, context, this, args.concat(slice.call(arguments))); - }; - return bound; - }; + // Normalize the fragment. + fragment = this.getFragment(fragment || ''); - // Partially apply a function by creating a version that has had some of its - // arguments pre-filled, without changing its dynamic `this` context. _ acts - // as a placeholder, allowing any combination of arguments to be pre-filled. - _.partial = function(func) { - var boundArgs = slice.call(arguments, 1); - var bound = function() { - var position = 0, length = boundArgs.length; - var args = Array(length); - for (var i = 0; i < length; i++) { - args[i] = boundArgs[i] === _ ? arguments[position++] : boundArgs[i]; + // Don't include a trailing slash on the root. + var rootPath = this.root; + if (fragment === '' || fragment.charAt(0) === '?') { + rootPath = rootPath.slice(0, -1) || '/'; } - while (position < arguments.length) args.push(arguments[position++]); - return executeBound(func, bound, this, this, args); - }; - return bound; - }; + var url = rootPath + fragment; - // Bind a number of an object's methods to that object. Remaining arguments - // are the method names to be bound. Useful for ensuring that all callbacks - // defined on an object belong to it. - _.bindAll = function(obj) { - var i, length = arguments.length, key; - if (length <= 1) throw new Error('bindAll must be passed function names'); - for (i = 1; i < length; i++) { - key = arguments[i]; - obj[key] = _.bind(obj[key], obj); - } - return obj; - }; + // Strip the hash and decode for matching. + fragment = this.decodeFragment(fragment.replace(pathStripper, '')); - // Memoize an expensive function by storing its results. - _.memoize = function(func, hasher) { - var memoize = function(key) { - var cache = memoize.cache; - var address = '' + (hasher ? hasher.apply(this, arguments) : key); - if (!_.has(cache, address)) cache[address] = func.apply(this, arguments); - return cache[address]; - }; - memoize.cache = {}; - return memoize; - }; + if (this.fragment === fragment) return; + this.fragment = fragment; - // Delays a function for the given number of milliseconds, and then calls - // it with the arguments supplied. - _.delay = function(func, wait) { - var args = slice.call(arguments, 2); - return setTimeout(function(){ - return func.apply(null, args); - }, wait); - }; + // If pushState is available, we use it to set the fragment as a real URL. + if (this._usePushState) { + this.history[options.replace ? 'replaceState' : 'pushState']({}, document.title, url); - // Defers a function, scheduling it to run after the current call stack has - // cleared. - _.defer = _.partial(_.delay, _, 1); + // If hash changes haven't been explicitly disabled, update the hash + // fragment to store history. + } else if (this._wantsHashChange) { + this._updateHash(this.location, fragment, options.replace); + if (this.iframe && fragment !== this.getHash(this.iframe.contentWindow)) { + var iWindow = this.iframe.contentWindow; - // Returns a function, that, when invoked, will only be triggered at most once - // during a given window of time. Normally, the throttled function will run - // as much as it can, without ever going more than once per `wait` duration; - // but if you'd like to disable the execution on the leading edge, pass - // `{leading: false}`. To disable execution on the trailing edge, ditto. - _.throttle = function(func, wait, options) { - var context, args, result; - var timeout = null; - var previous = 0; - if (!options) options = {}; - var later = function() { - previous = options.leading === false ? 0 : _.now(); - timeout = null; - result = func.apply(context, args); - if (!timeout) context = args = null; - }; - return function() { - var now = _.now(); - if (!previous && options.leading === false) previous = now; - var remaining = wait - (now - previous); - context = this; - args = arguments; - if (remaining <= 0 || remaining > wait) { - if (timeout) { - clearTimeout(timeout); - timeout = null; - } - previous = now; - result = func.apply(context, args); - if (!timeout) context = args = null; - } else if (!timeout && options.trailing !== false) { - timeout = setTimeout(later, remaining); - } - return result; - }; - }; + // Opening and closing the iframe tricks IE7 and earlier to push a + // history entry on hash-tag change. When replace is true, we don't + // want this. + if (!options.replace) { + iWindow.document.open(); + iWindow.document.close(); + } - // Returns a function, that, as long as it continues to be invoked, will not - // be triggered. The function will be called after it stops being called for - // N milliseconds. If `immediate` is passed, trigger the function on the - // leading edge, instead of the trailing. - _.debounce = function(func, wait, immediate) { - var timeout, args, context, timestamp, result; + this._updateHash(iWindow.location, fragment, options.replace); + } - var later = function() { - var last = _.now() - timestamp; + // If you've told us that you explicitly don't want fallback hashchange- + // based history, then `navigate` becomes a page refresh. + } else { + return this.location.assign(url); + } + if (options.trigger) return this.loadUrl(fragment); + }, - if (last < wait && last >= 0) { - timeout = setTimeout(later, wait - last); + // Update the hash location, either replacing the current entry, or adding + // a new one to the browser history. + _updateHash: function(location, fragment, replace) { + if (replace) { + var href = location.href.replace(/(javascript:|#).*$/, ''); + location.replace(href + '#' + fragment); } else { - timeout = null; - if (!immediate) { - result = func.apply(context, args); - if (!timeout) context = args = null; - } + // Some browsers require that `hash` contains a leading #. + location.hash = '#' + fragment; } - }; + } - return function() { - context = this; - args = arguments; - timestamp = _.now(); - var callNow = immediate && !timeout; - if (!timeout) timeout = setTimeout(later, wait); - if (callNow) { - result = func.apply(context, args); - context = args = null; - } + }); - return result; - }; - }; + // Create the default Backbone.history. + Backbone.history = new History; - // Returns the first function passed as an argument to the second, - // allowing you to adjust arguments, run code before and after, and - // conditionally execute the original function. - _.wrap = function(func, wrapper) { - return _.partial(wrapper, func); - }; + // Helpers + // ------- - // Returns a negated version of the passed-in predicate. - _.negate = function(predicate) { - return function() { - return !predicate.apply(this, arguments); - }; - }; + // Helper function to correctly set up the prototype chain for subclasses. + // Similar to `goog.inherits`, but uses a hash of prototype properties and + // class properties to be extended. + var extend = function(protoProps, staticProps) { + var parent = this; + var child; - // Returns a function that is the composition of a list of functions, each - // consuming the return value of the function that follows. - _.compose = function() { - var args = arguments; - var start = args.length - 1; - return function() { - var i = start; - var result = args[start].apply(this, arguments); - while (i--) result = args[i].call(this, result); - return result; - }; + // The constructor function for the new subclass is either defined by you + // (the "constructor" property in your `extend` definition), or defaulted + // by us to simply call the parent constructor. + if (protoProps && _.has(protoProps, 'constructor')) { + child = protoProps.constructor; + } else { + child = function(){ return parent.apply(this, arguments); }; + } + + // Add static properties to the constructor function, if supplied. + _.extend(child, parent, staticProps); + + // Set the prototype chain to inherit from `parent`, without calling + // `parent`'s constructor function and add the prototype properties. + child.prototype = _.create(parent.prototype, protoProps); + child.prototype.constructor = child; + + // Set a convenience property in case the parent's prototype is needed + // later. + child.__super__ = parent.prototype; + + return child; }; - // Returns a function that will only be executed on and after the Nth call. - _.after = function(times, func) { - return function() { - if (--times < 1) { - return func.apply(this, arguments); - } - }; + // Set up inheritance for the model, collection, router, view and history. + Model.extend = Collection.extend = Router.extend = View.extend = History.extend = extend; + + // Throw an error when a URL is needed, and none is supplied. + var urlError = function() { + throw new Error('A "url" property or function must be specified'); }; - // Returns a function that will only be executed up to (but not including) the Nth call. - _.before = function(times, func) { - var memo; - return function() { - if (--times > 0) { - memo = func.apply(this, arguments); - } - if (times <= 1) func = null; - return memo; + // Wrap an optional error callback with a fallback error event. + var wrapError = function(model, options) { + var error = options.error; + options.error = function(resp) { + if (error) error.call(options.context, model, resp, options); + model.trigger('error', model, resp, options); }; }; - // Returns a function that will be executed at most one time, no matter how - // often you call it. Useful for lazy initialization. - _.once = _.partial(_.before, 2); + return Backbone; +}); - // Object Functions - // ---------------- +/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./../webpack/buildin/global.js */ "./node_modules/webpack/buildin/global.js"))) - // Keys in IE < 9 that won't be iterated by `for key in ...` and thus missed. - var hasEnumBug = !{toString: null}.propertyIsEnumerable('toString'); - var nonEnumerableProps = ['valueOf', 'isPrototypeOf', 'toString', - 'propertyIsEnumerable', 'hasOwnProperty', 'toLocaleString']; +/***/ }), - function collectNonEnumProps(obj, keys) { - var nonEnumIdx = nonEnumerableProps.length; - var constructor = obj.constructor; - var proto = (_.isFunction(constructor) && constructor.prototype) || ObjProto; +/***/ "./node_modules/cash-dom/dist/cash.js": +/*!********************************************!*\ + !*** ./node_modules/cash-dom/dist/cash.js ***! + \********************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { - // Constructor is a special case. - var prop = 'constructor'; - if (_.has(obj, prop) && !_.contains(keys, prop)) keys.push(prop); +"use strict"; +var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_RESULT__; - while (nonEnumIdx--) { - prop = nonEnumerableProps[nonEnumIdx]; - if (prop in obj && obj[prop] !== proto[prop] && !_.contains(keys, prop)) { - keys.push(prop); - } - } - } +/*! cash-dom 1.3.7, https://github.com/kenwheeler/cash @license MIT */ +;(function (root, factory) { + if (true) { + !(__WEBPACK_AMD_DEFINE_FACTORY__ = (factory), + __WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ? + (__WEBPACK_AMD_DEFINE_FACTORY__.call(exports, __webpack_require__, exports, module)) : + __WEBPACK_AMD_DEFINE_FACTORY__), + __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)); + } else {} +})(this, function () { + var doc = document, win = window, ArrayProto = Array.prototype, slice = ArrayProto.slice, filter = ArrayProto.filter, push = ArrayProto.push; - // Retrieve the names of an object's own properties. - // Delegates to **ECMAScript 5**'s native `Object.keys` - _.keys = function(obj) { - if (!_.isObject(obj)) return []; - if (nativeKeys) return nativeKeys(obj); - var keys = []; - for (var key in obj) if (_.has(obj, key)) keys.push(key); - // Ahem, IE < 9. - if (hasEnumBug) collectNonEnumProps(obj, keys); - return keys; + var noop = function () {}, isFunction = function (item) { + // @see https://crbug.com/568448 + return typeof item === typeof noop && item.call; + }, isString = function (item) { + return typeof item === typeof ""; }; - // Retrieve all the property names of an object. - _.allKeys = function(obj) { - if (!_.isObject(obj)) return []; - var keys = []; - for (var key in obj) keys.push(key); - // Ahem, IE < 9. - if (hasEnumBug) collectNonEnumProps(obj, keys); - return keys; - }; + var idMatch = /^#[\w-]*$/, classMatch = /^\.[\w-]*$/, htmlMatch = /<.+>/, singlet = /^\w+$/; - // Retrieve the values of an object's properties. - _.values = function(obj) { - var keys = _.keys(obj); - var length = keys.length; - var values = Array(length); - for (var i = 0; i < length; i++) { - values[i] = obj[keys[i]]; + function find(selector, context) { + context = context || doc; + var elems = (classMatch.test(selector) ? context.getElementsByClassName(selector.slice(1)) : singlet.test(selector) ? context.getElementsByTagName(selector) : context.querySelectorAll(selector)); + return elems; + } + + var frag; + function parseHTML(str) { + if (!frag) { + frag = doc.implementation.createHTMLDocument(null); + var base = frag.createElement("base"); + base.href = doc.location.href; + frag.head.appendChild(base); } - return values; - }; - // Returns the results of applying the iteratee to each element of the object - // In contrast to _.map it returns an object - _.mapObject = function(obj, iteratee, context) { - iteratee = cb(iteratee, context); - var keys = _.keys(obj), - length = keys.length, - results = {}, - currentKey; - for (var index = 0; index < length; index++) { - currentKey = keys[index]; - results[currentKey] = iteratee(obj[currentKey], currentKey, obj); - } - return results; - }; + frag.body.innerHTML = str; - // Convert an object into a list of `[key, value]` pairs. - _.pairs = function(obj) { - var keys = _.keys(obj); - var length = keys.length; - var pairs = Array(length); - for (var i = 0; i < length; i++) { - pairs[i] = [keys[i], obj[keys[i]]]; + return frag.body.childNodes; + } + + function onReady(fn) { + if (doc.readyState !== "loading") { + setTimeout(fn); + } else { + doc.addEventListener("DOMContentLoaded", fn); } - return pairs; - }; + } - // Invert the keys and values of an object. The values must be serializable. - _.invert = function(obj) { - var result = {}; - var keys = _.keys(obj); - for (var i = 0, length = keys.length; i < length; i++) { - result[obj[keys[i]]] = keys[i]; + function Init(selector, context) { + if (!selector) { + return this; } - return result; - }; - // Return a sorted list of the function names available on the object. - // Aliased as `methods` - _.functions = _.methods = function(obj) { - var names = []; - for (var key in obj) { - if (_.isFunction(obj[key])) names.push(key); + // If already a cash collection, don't do any further processing + if (selector.cash && selector !== win) { + return selector; } - return names.sort(); - }; - // Extend a given object with all the properties in passed-in object(s). - _.extend = createAssigner(_.allKeys); + var elems = selector, i = 0, length; - // Assigns a given object with all the own properties in the passed-in object(s) - // (https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object/assign) - _.extendOwn = _.assign = createAssigner(_.keys); + if (isString(selector)) { + elems = (idMatch.test(selector) ? + // If an ID use the faster getElementById check + doc.getElementById(selector.slice(1)) : htmlMatch.test(selector) ? + // If HTML, parse it into real elements + parseHTML(selector) : + // else use `find` + find(selector, context)); - // Returns the first key on an object that passes a predicate test - _.findKey = function(obj, predicate, context) { - predicate = cb(predicate, context); - var keys = _.keys(obj), key; - for (var i = 0, length = keys.length; i < length; i++) { - key = keys[i]; - if (predicate(obj[key], key, obj)) return key; + // If function, use as shortcut for DOM ready + } else if (isFunction(selector)) { + onReady(selector);return this; } - }; - // Return a copy of the object only containing the whitelisted properties. - _.pick = function(object, oiteratee, context) { - var result = {}, obj = object, iteratee, keys; - if (obj == null) return result; - if (_.isFunction(oiteratee)) { - keys = _.allKeys(obj); - iteratee = optimizeCb(oiteratee, context); - } else { - keys = flatten(arguments, false, false, 1); - iteratee = function(value, key, obj) { return key in obj; }; - obj = Object(obj); - } - for (var i = 0, length = keys.length; i < length; i++) { - var key = keys[i]; - var value = obj[key]; - if (iteratee(value, key, obj)) result[key] = value; + if (!elems) { + return this; } - return result; - }; - // Return a copy of the object without the blacklisted properties. - _.omit = function(obj, iteratee, context) { - if (_.isFunction(iteratee)) { - iteratee = _.negate(iteratee); + // If a single DOM element is passed in or received via ID, return the single element + if (elems.nodeType || elems === win) { + this[0] = elems; + this.length = 1; } else { - var keys = _.map(flatten(arguments, false, false, 1), String); - iteratee = function(value, key) { - return !_.contains(keys, key); - }; + // Treat like an array and loop through each item. + length = this.length = elems.length; + for (; i < length; i++) { + this[i] = elems[i]; + } } - return _.pick(obj, iteratee, context); - }; - // Fill in a given object with default properties. - _.defaults = createAssigner(_.allKeys, true); + return this; + } - // Creates an object that inherits from the given prototype object. - // If additional properties are provided then they will be added to the - // created object. - _.create = function(prototype, props) { - var result = baseCreate(prototype); - if (props) _.extendOwn(result, props); - return result; - }; + function cash(selector, context) { + return new Init(selector, context); + } - // Create a (shallow-cloned) duplicate of an object. - _.clone = function(obj) { - if (!_.isObject(obj)) return obj; - return _.isArray(obj) ? obj.slice() : _.extend({}, obj); + var fn = cash.fn = cash.prototype = Init.prototype = { // jshint ignore:line + cash: true, + length: 0, + push: push, + splice: ArrayProto.splice, + map: ArrayProto.map, + init: Init }; - // Invokes interceptor with the obj, and then returns obj. - // The primary purpose of this method is to "tap into" a method chain, in - // order to perform operations on intermediate results within the chain. - _.tap = function(obj, interceptor) { - interceptor(obj); - return obj; - }; + Object.defineProperty(fn, "constructor", { value: cash }); - // Returns whether an object has a given set of `key:value` pairs. - _.isMatch = function(object, attrs) { - var keys = _.keys(attrs), length = keys.length; - if (object == null) return !length; - var obj = Object(object); - for (var i = 0; i < length; i++) { - var key = keys[i]; - if (attrs[key] !== obj[key] || !(key in obj)) return false; - } - return true; - }; + cash.parseHTML = parseHTML; + cash.noop = noop; + cash.isFunction = isFunction; + cash.isString = isString; + cash.extend = fn.extend = function (target) { + target = target || {}; - // Internal recursive comparison function for `isEqual`. - var eq = function(a, b, aStack, bStack) { - // Identical objects are equal. `0 === -0`, but they aren't identical. - // See the [Harmony `egal` proposal](http://wiki.ecmascript.org/doku.php?id=harmony:egal). - if (a === b) return a !== 0 || 1 / a === 1 / b; - // A strict comparison is necessary because `null == undefined`. - if (a == null || b == null) return a === b; - // Unwrap any wrapped objects. - if (a instanceof _) a = a._wrapped; - if (b instanceof _) b = b._wrapped; - // Compare `[[Class]]` names. - var className = toString.call(a); - if (className !== toString.call(b)) return false; - switch (className) { - // Strings, numbers, regular expressions, dates, and booleans are compared by value. - case '[object RegExp]': - // RegExps are coerced to strings for comparison (Note: '' + /a/i === '/a/i') - case '[object String]': - // Primitives and their corresponding object wrappers are equivalent; thus, `"5"` is - // equivalent to `new String("5")`. - return '' + a === '' + b; - case '[object Number]': - // `NaN`s are equivalent, but non-reflexive. - // Object(NaN) is equivalent to NaN - if (+a !== +a) return +b !== +b; - // An `egal` comparison is performed for other numeric values. - return +a === 0 ? 1 / +a === 1 / b : +a === +b; - case '[object Date]': - case '[object Boolean]': - // Coerce dates and booleans to numeric primitive values. Dates are compared by their - // millisecond representations. Note that invalid dates with millisecond representations - // of `NaN` are not equivalent. - return +a === +b; - } + var args = slice.call(arguments), length = args.length, i = 1; - var areArrays = className === '[object Array]'; - if (!areArrays) { - if (typeof a != 'object' || typeof b != 'object') return false; + if (args.length === 1) { + target = this; + i = 0; + } - // Objects with different constructors are not equivalent, but `Object`s or `Array`s - // from different frames are. - var aCtor = a.constructor, bCtor = b.constructor; - if (aCtor !== bCtor && !(_.isFunction(aCtor) && aCtor instanceof aCtor && - _.isFunction(bCtor) && bCtor instanceof bCtor) - && ('constructor' in a && 'constructor' in b)) { - return false; + for (; i < length; i++) { + if (!args[i]) { + continue; + } + for (var key in args[i]) { + if (args[i].hasOwnProperty(key)) { + target[key] = args[i][key]; + } } } - // Assume equality for cyclic structures. The algorithm for detecting cyclic - // structures is adapted from ES 5.1 section 15.12.3, abstract operation `JO`. - // Initializing stack of traversed objects. - // It's done here since we only need them for objects and arrays comparison. - aStack = aStack || []; - bStack = bStack || []; - var length = aStack.length; - while (length--) { - // Linear search. Performance is inversely proportional to the number of - // unique nested structures. - if (aStack[length] === a) return bStack[length] === b; - } + return target; + }; - // Add the first object to the stack of traversed objects. - aStack.push(a); - bStack.push(b); + function each(collection, callback) { + var l = collection.length, i = 0; - // Recursively compare objects and arrays. - if (areArrays) { - // Compare array lengths to determine if a deep comparison is necessary. - length = a.length; - if (length !== b.length) return false; - // Deep compare the contents, ignoring non-numeric properties. - while (length--) { - if (!eq(a[length], b[length], aStack, bStack)) return false; - } - } else { - // Deep compare objects. - var keys = _.keys(a), key; - length = keys.length; - // Ensure that both objects contain the same number of properties before comparing deep equality. - if (_.keys(b).length !== length) return false; - while (length--) { - // Deep compare each member - key = keys[length]; - if (!(_.has(b, key) && eq(a[key], b[key], aStack, bStack))) return false; + for (; i < l; i++) { + if (callback.call(collection[i], collection[i], i, collection) === false) { + break; } } - // Remove the first object from the stack of traversed objects. - aStack.pop(); - bStack.pop(); - return true; - }; + } - // Perform a deep comparison to check if two objects are equal. - _.isEqual = function(a, b) { - return eq(a, b); - }; + function matches(el, selector) { + var m = el && (el.matches || el.webkitMatchesSelector || el.mozMatchesSelector || el.msMatchesSelector || el.oMatchesSelector); + return !!m && m.call(el, selector); + } - // Is a given array, string, or object empty? - // An "empty" object has no enumerable own-properties. - _.isEmpty = function(obj) { - if (obj == null) return true; - if (isArrayLike(obj) && (_.isArray(obj) || _.isString(obj) || _.isArguments(obj))) return obj.length === 0; - return _.keys(obj).length === 0; - }; + function getCompareFunction(selector) { + return ( + /* Use browser's `matches` function if string */ + isString(selector) ? matches : + /* Match a cash element */ + selector.cash ? function (el) { + return selector.is(el); + } : + /* Direct comparison */ + function (el, selector) { + return el === selector; + }); + } - // Is a given value a DOM element? - _.isElement = function(obj) { - return !!(obj && obj.nodeType === 1); - }; + function unique(collection) { + return cash(slice.call(collection).filter(function (item, index, self) { + return self.indexOf(item) === index; + })); + } - // Is a given value an array? - // Delegates to ECMA5's native Array.isArray - _.isArray = nativeIsArray || function(obj) { - return toString.call(obj) === '[object Array]'; - }; + cash.extend({ + merge: function (first, second) { + var len = +second.length, i = first.length, j = 0; - // Is a given variable an object? - _.isObject = function(obj) { - var type = typeof obj; - return type === 'function' || type === 'object' && !!obj; - }; + for (; j < len; i++, j++) { + first[i] = second[j]; + } + + first.length = i; + return first; + }, + + each: each, + matches: matches, + unique: unique, + isArray: Array.isArray, + isNumeric: function (n) { + return !isNaN(parseFloat(n)) && isFinite(n); + } - // Add some isType methods: isArguments, isFunction, isString, isNumber, isDate, isRegExp, isError. - _.each(['Arguments', 'Function', 'String', 'Number', 'Date', 'RegExp', 'Error'], function(name) { - _['is' + name] = function(obj) { - return toString.call(obj) === '[object ' + name + ']'; - }; }); - // Define a fallback version of the method in browsers (ahem, IE < 9), where - // there isn't any inspectable "Arguments" type. - if (!_.isArguments(arguments)) { - _.isArguments = function(obj) { - return _.has(obj, 'callee'); - }; - } + var uid = cash.uid = "_cash" + Date.now(); - // Optimize `isFunction` if appropriate. Work around some typeof bugs in old v8, - // IE 11 (#1621), and in Safari 8 (#1929). - if (typeof /./ != 'function' && typeof Int8Array != 'object') { - _.isFunction = function(obj) { - return typeof obj == 'function' || false; - }; + function getDataCache(node) { + return (node[uid] = node[uid] || {}); } - // Is a given object a finite number? - _.isFinite = function(obj) { - return isFinite(obj) && !isNaN(parseFloat(obj)); - }; + function setData(node, key, value) { + return (getDataCache(node)[key] = value); + } - // Is the given value `NaN`? (NaN is the only number which does not equal itself). - _.isNaN = function(obj) { - return _.isNumber(obj) && obj !== +obj; - }; + function getData(node, key) { + var c = getDataCache(node); + if (c[key] === undefined) { + c[key] = node.dataset ? node.dataset[key] : cash(node).attr("data-" + key); + } + return c[key]; + } - // Is a given value a boolean? - _.isBoolean = function(obj) { - return obj === true || obj === false || toString.call(obj) === '[object Boolean]'; - }; - - // Is a given value equal to null? - _.isNull = function(obj) { - return obj === null; - }; - - // Is a given variable undefined? - _.isUndefined = function(obj) { - return obj === void 0; - }; - - // Shortcut function for checking if an object has a given property directly - // on itself (in other words, not on a prototype). - _.has = function(obj, key) { - return obj != null && hasOwnProperty.call(obj, key); - }; - - // Utility Functions - // ----------------- + function removeData(node, key) { + var c = getDataCache(node); + if (c) { + delete c[key]; + } else if (node.dataset) { + delete node.dataset[key]; + } else { + cash(node).removeAttr("data-" + name); + } + } - // Run Underscore.js in *noConflict* mode, returning the `_` variable to its - // previous owner. Returns a reference to the Underscore object. - _.noConflict = function() { - root._ = previousUnderscore; - return this; - }; + fn.extend({ + data: function (name, value) { + if (isString(name)) { + return (value === undefined ? getData(this[0], name) : this.each(function (v) { + return setData(v, name, value); + })); + } - // Keep the identity function around for default iteratees. - _.identity = function(value) { - return value; - }; + for (var key in name) { + this.data(key, name[key]); + } - // Predicate-generating functions. Often useful outside of Underscore. - _.constant = function(value) { - return function() { - return value; - }; - }; + return this; + }, - _.noop = function(){}; + removeData: function (key) { + return this.each(function (v) { + return removeData(v, key); + }); + } - _.property = property; + }); - // Generates a function for a given object that returns a given property. - _.propertyOf = function(obj) { - return obj == null ? function(){} : function(key) { - return obj[key]; - }; - }; + var notWhiteMatch = /\S+/g; - // Returns a predicate for checking whether an object has a given set of - // `key:value` pairs. - _.matcher = _.matches = function(attrs) { - attrs = _.extendOwn({}, attrs); - return function(obj) { - return _.isMatch(obj, attrs); - }; - }; + function getClasses(c) { + return isString(c) && c.match(notWhiteMatch); + } - // Run a function **n** times. - _.times = function(n, iteratee, context) { - var accum = Array(Math.max(0, n)); - iteratee = optimizeCb(iteratee, context, 1); - for (var i = 0; i < n; i++) accum[i] = iteratee(i); - return accum; - }; + function hasClass(v, c) { + return (v.classList ? v.classList.contains(c) : new RegExp("(^| )" + c + "( |$)", "gi").test(v.className)); + } - // Return a random integer between min and max (inclusive). - _.random = function(min, max) { - if (max == null) { - max = min; - min = 0; + function addClass(v, c) { + if (v.classList) { + v.classList.add(c); + } else if (!hasClass(v, c)) { + v.className += " " + c; } - return min + Math.floor(Math.random() * (max - min + 1)); - }; - - // A (possibly faster) way to get the current timestamp as an integer. - _.now = Date.now || function() { - return new Date().getTime(); - }; - - // List of HTML entities for escaping. - var escapeMap = { - '&': '&', - '<': '<', - '>': '>', - '"': '"', - "'": ''', - '`': '`' - }; - var unescapeMap = _.invert(escapeMap); - - // Functions for escaping and unescaping strings to/from HTML interpolation. - var createEscaper = function(map) { - var escaper = function(match) { - return map[match]; - }; - // Regexes for identifying a key that needs to be escaped - var source = '(?:' + _.keys(map).join('|') + ')'; - var testRegexp = RegExp(source); - var replaceRegexp = RegExp(source, 'g'); - return function(string) { - string = string == null ? '' : '' + string; - return testRegexp.test(string) ? string.replace(replaceRegexp, escaper) : string; - }; - }; - _.escape = createEscaper(escapeMap); - _.unescape = createEscaper(unescapeMap); + } - // If the value of the named `property` is a function then invoke it with the - // `object` as context; otherwise, return it. - _.result = function(object, property, fallback) { - var value = object == null ? void 0 : object[property]; - if (value === void 0) { - value = fallback; + function removeClass(v, c) { + if (v.classList) { + v.classList.remove(c); + } else { + v.className = v.className.replace(c, ""); } - return _.isFunction(value) ? value.call(object) : value; - }; - - // Generate a unique integer id (unique within the entire client session). - // Useful for temporary DOM ids. - var idCounter = 0; - _.uniqueId = function(prefix) { - var id = ++idCounter + ''; - return prefix ? prefix + id : id; - }; + } - // By default, Underscore uses ERB-style template delimiters, change the - // following template settings to use alternative delimiters. - _.templateSettings = { - evaluate : /<%([\s\S]+?)%>/g, - interpolate : /<%=([\s\S]+?)%>/g, - escape : /<%-([\s\S]+?)%>/g - }; + fn.extend({ + addClass: function (c) { + var classes = getClasses(c); - // When customizing `templateSettings`, if you don't want to define an - // interpolation, evaluation or escaping regex, we need one that is - // guaranteed not to match. - var noMatch = /(.)^/; + return (classes ? this.each(function (v) { + each(classes, function (c) { + addClass(v, c); + }); + }) : this); + }, - // Certain characters need to be escaped so that they can be put into a - // string literal. - var escapes = { - "'": "'", - '\\': '\\', - '\r': 'r', - '\n': 'n', - '\u2028': 'u2028', - '\u2029': 'u2029' - }; + attr: function (name, value) { + if (!name) { + return undefined; + } - var escaper = /\\|'|\r|\n|\u2028|\u2029/g; + if (isString(name)) { + if (value === undefined) { + return this[0] ? this[0].getAttribute ? this[0].getAttribute(name) : this[0][name] : undefined; + } - var escapeChar = function(match) { - return '\\' + escapes[match]; - }; + return this.each(function (v) { + if (v.setAttribute) { + v.setAttribute(name, value); + } else { + v[name] = value; + } + }); + } - // JavaScript micro-templating, similar to John Resig's implementation. - // Underscore templating handles arbitrary delimiters, preserves whitespace, - // and correctly escapes quotes within interpolated code. - // NB: `oldSettings` only exists for backwards compatibility. - _.template = function(text, settings, oldSettings) { - if (!settings && oldSettings) settings = oldSettings; - settings = _.defaults({}, settings, _.templateSettings); + for (var key in name) { + this.attr(key, name[key]); + } - // Combine delimiters into one regular expression via alternation. - var matcher = RegExp([ - (settings.escape || noMatch).source, - (settings.interpolate || noMatch).source, - (settings.evaluate || noMatch).source - ].join('|') + '|$', 'g'); + return this; + }, - // Compile the template source, escaping string literals appropriately. - var index = 0; - var source = "__p+='"; - text.replace(matcher, function(match, escape, interpolate, evaluate, offset) { - source += text.slice(index, offset).replace(escaper, escapeChar); - index = offset + match.length; + hasClass: function (c) { + var check = false, classes = getClasses(c); + if (classes && classes.length) { + this.each(function (v) { + check = hasClass(v, classes[0]); + return !check; + }); + } + return check; + }, - if (escape) { - source += "'+\n((__t=(" + escape + "))==null?'':_.escape(__t))+\n'"; - } else if (interpolate) { - source += "'+\n((__t=(" + interpolate + "))==null?'':__t)+\n'"; - } else if (evaluate) { - source += "';\n" + evaluate + "\n__p+='"; + prop: function (name, value) { + if (isString(name)) { + return (value === undefined ? this[0][name] : this.each(function (v) { + v[name] = value; + })); } - // Adobe VMs need the match returned to produce the correct offest. - return match; - }); - source += "';\n"; + for (var key in name) { + this.prop(key, name[key]); + } - // If a variable is not specified, place data values in local scope. - if (!settings.variable) source = 'with(obj||{}){\n' + source + '}\n'; + return this; + }, - source = "var __t,__p='',__j=Array.prototype.join," + - "print=function(){__p+=__j.call(arguments,'');};\n" + - source + 'return __p;\n'; + removeAttr: function (name) { + return this.each(function (v) { + if (v.removeAttribute) { + v.removeAttribute(name); + } else { + delete v[name]; + } + }); + }, - try { - var render = new Function(settings.variable || 'obj', '_', source); - } catch (e) { - e.source = source; - throw e; - } - - var template = function(data) { - return render.call(this, data, _); - }; - - // Provide the compiled source as a convenience for precompilation. - var argument = settings.variable || 'obj'; - template.source = 'function(' + argument + '){\n' + source + '}'; - - return template; - }; + removeClass: function (c) { + if (!arguments.length) { + return this.attr("class", ""); + } + var classes = getClasses(c); + return (classes ? this.each(function (v) { + each(classes, function (c) { + removeClass(v, c); + }); + }) : this); + }, - // Add a "chain" function. Start chaining a wrapped Underscore object. - _.chain = function(obj) { - var instance = _(obj); - instance._chain = true; - return instance; - }; + removeProp: function (name) { + return this.each(function (v) { + delete v[name]; + }); + }, - // OOP - // --------------- - // If Underscore is called as a function, it returns a wrapped object that - // can be used OO-style. This wrapper holds altered versions of all the - // underscore functions. Wrapped objects may be chained. + toggleClass: function (c, state) { + if (state !== undefined) { + return this[state ? "addClass" : "removeClass"](c); + } + var classes = getClasses(c); + return (classes ? this.each(function (v) { + each(classes, function (c) { + if (hasClass(v, c)) { + removeClass(v, c); + } else { + addClass(v, c); + } + }); + }) : this); + } }); - // Helper function to continue chaining intermediate results. - var result = function(instance, obj) { - return instance._chain ? _(obj).chain() : obj; - }; + fn.extend({ + add: function (selector, context) { + return unique(cash.merge(this, cash(selector, context))); + }, - // Add your own custom functions to the Underscore object. - _.mixin = function(obj) { - _.each(_.functions(obj), function(name) { - var func = _[name] = obj[name]; - _.prototype[name] = function() { - var args = [this._wrapped]; - push.apply(args, arguments); - return result(this, func.apply(_, args)); - }; - }); - }; + each: function (callback) { + each(this, callback); + return this; + }, - // Add all of the Underscore functions to the wrapper object. - _.mixin(_); + eq: function (index) { + return cash(this.get(index)); + }, - // Add all mutator Array functions to the wrapper. - _.each(['pop', 'push', 'reverse', 'shift', 'sort', 'splice', 'unshift'], function(name) { - var method = ArrayProto[name]; - _.prototype[name] = function() { - var obj = this._wrapped; - method.apply(obj, arguments); - if ((name === 'shift' || name === 'splice') && obj.length === 0) delete obj[0]; - return result(this, obj); - }; - }); + filter: function (selector) { + if (!selector) { + return this; + } - // Add all accessor Array functions to the wrapper. - _.each(['concat', 'join', 'slice'], function(name) { - var method = ArrayProto[name]; - _.prototype[name] = function() { - return result(this, method.apply(this._wrapped, arguments)); - }; - }); + var comparator = (isFunction(selector) ? selector : getCompareFunction(selector)); - // Extracts the result from a wrapped and chained object. - _.prototype.value = function() { - return this._wrapped; - }; + return cash(filter.call(this, function (e) { + return comparator(e, selector); + })); + }, - // Provide unwrapping proxy for some methods used in engine operations - // such as arithmetic and JSON stringification. - _.prototype.valueOf = _.prototype.toJSON = _.prototype.value; + first: function () { + return this.eq(0); + }, - _.prototype.toString = function() { - return '' + this._wrapped; - }; + get: function (index) { + if (index === undefined) { + return slice.call(this); + } + return (index < 0 ? this[index + this.length] : this[index]); + }, - // AMD registration happens at the end for compatibility with AMD loaders - // that may not enforce next-turn semantics on modules. Even though general - // practice for AMD registration is to be anonymous, underscore registers - // as a named module because, like jQuery, it is a base library that is - // popular enough to be bundled in a third party lib, but not be part of - // an AMD load request. Those cases could generate an error when an - // anonymous define() is called outside of a loader request. - if (true) { - !(__WEBPACK_AMD_DEFINE_ARRAY__ = [], __WEBPACK_AMD_DEFINE_RESULT__ = function() { - return _; - }.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__), - __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)); - } -}.call(this)); + index: function (elem) { + var child = elem ? cash(elem)[0] : this[0], collection = elem ? this : cash(child).parent().children(); + return slice.call(collection).indexOf(child); + }, + last: function () { + return this.eq(-1); + } -/***/ }), -/* 2 */ -/***/ (function(module, exports, __webpack_require__) { + }); -"use strict"; + var camelCase = (function () { + var camelRegex = /(?:^\w|[A-Z]|\b\w)/g, whiteSpace = /[\s-_]+/g; + return function (str) { + return str.replace(camelRegex, function (letter, index) { + return letter[index === 0 ? "toLowerCase" : "toUpperCase"](); + }).replace(whiteSpace, ""); + }; + }()); + var getPrefixedProp = (function () { + var cache = {}, doc = document, div = doc.createElement("div"), style = div.style; -Object.defineProperty(exports, "__esModule", { - value: true -}); -exports.getUnitFromValue = exports.normalizeFloat = exports.shallowDiff = exports.camelCase = exports.matches = exports.upFirst = exports.off = exports.on = undefined; + return function (prop) { + prop = camelCase(prop); + if (cache[prop]) { + return cache[prop]; + } -var _underscore = __webpack_require__(1); + var ucProp = prop.charAt(0).toUpperCase() + prop.slice(1), prefixes = ["webkit", "moz", "ms", "o"], props = (prop + " " + (prefixes).join(ucProp + " ") + ucProp).split(" "); -var elProt = window.Element.prototype; -var matches = elProt.matches || elProt.webkitMatchesSelector || elProt.mozMatchesSelector || elProt.msMatchesSelector; + each(props, function (p) { + if (p in style) { + cache[p] = prop = cache[prop] = p; + return false; + } + }); -/** - * Returns shallow diff between 2 objects - * @param {Object} objOrig - * @param {Objec} objNew - * @return {Object} - * @example - * var a = {foo: 'bar', baz: 1, faz: 'sop'}; - * var b = {foo: 'bar', baz: 2, bar: ''}; - * shallowDiff(a, b); - * // -> {baz: 2, faz: null, bar: ''}; - */ -var shallowDiff = function shallowDiff(objOrig, objNew) { - var result = {}; - var keysNew = (0, _underscore.keys)(objNew); + return cache[prop]; + }; + }()); - for (var prop in objOrig) { - if (objOrig.hasOwnProperty(prop)) { - var origValue = objOrig[prop]; - var newValue = objNew[prop]; + cash.prefixedProp = getPrefixedProp; + cash.camelCase = camelCase; - if (keysNew.indexOf(prop) >= 0) { - if (origValue !== newValue) { - result[prop] = newValue; - } - } else { - result[prop] = null; + fn.extend({ + css: function (prop, value) { + if (isString(prop)) { + prop = getPrefixedProp(prop); + return (arguments.length > 1 ? this.each(function (v) { + return v.style[prop] = value; + }) : win.getComputedStyle(this[0])[prop]); } - } - } - for (var _prop in objNew) { - if (objNew.hasOwnProperty(_prop)) { - if ((0, _underscore.isUndefined)(objOrig[_prop])) { - result[_prop] = objNew[_prop]; + for (var key in prop) { + this.css(key, prop[key]); } - } - } - return result; -}; - -var on = function on(el, ev, fn) { - ev = ev.split(/\s+/); - el = el instanceof Array ? el : [el]; + return this; + } - var _loop = function _loop(i) { - el.forEach(function (elem) { - return elem.addEventListener(ev[i], fn); - }); - }; + }); - for (var i = 0; i < ev.length; ++i) { - _loop(i); + function compute(el, prop) { + return parseInt(win.getComputedStyle(el[0], null)[prop], 10) || 0; } -}; -var off = function off(el, ev, fn) { - ev = ev.split(/\s+/); - el = el instanceof Array ? el : [el]; + each(["Width", "Height"], function (v) { + var lower = v.toLowerCase(); - var _loop2 = function _loop2(i) { - el.forEach(function (elem) { - return elem.removeEventListener(ev[i], fn); - }); - }; + fn[lower] = function () { + return this[0].getBoundingClientRect()[lower]; + }; - for (var i = 0; i < ev.length; ++i) { - _loop2(i); - } -}; + fn["inner" + v] = function () { + return this[0]["client" + v]; + }; -var getUnitFromValue = function getUnitFromValue(value) { - return value.replace(parseFloat(value), ''); -}; - -var upFirst = function upFirst(value) { - return value[0].toUpperCase() + value.toLowerCase().slice(1); -}; - -var camelCase = function camelCase(value) { - var values = value.split('-'); - return values[0].toLowerCase() + values.slice(1).map(upFirst); -}; - -var normalizeFloat = function normalizeFloat(value) { - var step = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1; - var valueDef = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0; - - var stepDecimals = 0; - if (isNaN(value)) return valueDef; - value = parseFloat(value); + fn["outer" + v] = function (margins) { + return this[0]["offset" + v] + (margins ? compute(this, "margin" + (v === "Width" ? "Left" : "Top")) + compute(this, "margin" + (v === "Width" ? "Right" : "Bottom")) : 0); + }; + }); - if (Math.floor(value) !== value) { - var side = step.toString().split('.')[1]; - stepDecimals = side ? side.length : 0; + function registerEvent(node, eventName, callback) { + var eventCache = getData(node, "_cashEvents") || setData(node, "_cashEvents", {}); + eventCache[eventName] = eventCache[eventName] || []; + eventCache[eventName].push(callback); + node.addEventListener(eventName, callback); } - return stepDecimals ? parseFloat(value.toFixed(stepDecimals)) : value; -}; + function removeEvent(node, eventName, callback) { + var events = getData(node, "_cashEvents"), eventCache = (events && events[eventName]), index; -exports.on = on; -exports.off = off; -exports.upFirst = upFirst; -exports.matches = matches; -exports.camelCase = camelCase; -exports.shallowDiff = shallowDiff; -exports.normalizeFloat = normalizeFloat; -exports.getUnitFromValue = getUnitFromValue; + if (!eventCache) { + return; + } -/***/ }), -/* 3 */ -/***/ (function(module, exports, __webpack_require__) { + if (callback) { + node.removeEventListener(eventName, callback); + index = eventCache.indexOf(callback); + if (index >= 0) { + eventCache.splice(index, 1); + } + } else { + each(eventCache, function (event) { + node.removeEventListener(eventName, event); + }); + eventCache = []; + } + } -"use strict"; -/* WEBPACK VAR INJECTION */(function(Backbone) { + fn.extend({ + off: function (eventName, callback) { + return this.each(function (v) { + return removeEvent(v, eventName, callback); + }); + }, -var _underscore = __webpack_require__(1); + on: function (eventName, delegate, callback, runOnce) { + // jshint ignore:line -var ComponentsView = __webpack_require__(50); + var originalCallback; -module.exports = Backbone.View.extend({ - className: function className() { - return this.getClasses(); - }, - tagName: function tagName() { - return this.model.get('tagName'); - }, - initialize: function initialize() { - var opt = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + if (!isString(eventName)) { + for (var key in eventName) { + this.on(key, delegate, eventName[key]); + } + return this; + } - var model = this.model; - var config = opt.config || {}; - this.opts = opt; - this.config = config; - this.em = config.em || ''; - this.pfx = config.stylePrefix || ''; - this.ppfx = config.pStylePrefix || ''; - this.attr = model.get('attributes'); - this.classe = this.attr.class || []; - var $el = this.$el; - var classes = model.get('classes'); - this.listenTo(model, 'destroy remove', this.remove); - this.listenTo(model, 'change:style', this.updateStyle); - this.listenTo(model, 'change:attributes', this.updateAttributes); - this.listenTo(model, 'change:highlightable', this.updateHighlight); - this.listenTo(model, 'change:status', this.updateStatus); - this.listenTo(model, 'change:state', this.updateState); - this.listenTo(model, 'change:script', this.render); - this.listenTo(model, 'change', this.handleChange); - this.listenTo(classes, 'add remove change', this.updateClasses); - $el.data('model', model); - $el.data('collection', model.get('components')); - model.view = this; - classes.length && this.importClasses(); - this.init(); - }, - remove: function remove() { - Backbone.View.prototype.remove.apply(this); - var children = this.childrenView; - children && children.stopListening(); - }, + if (isFunction(delegate)) { + callback = delegate; + delegate = null; + } + if (eventName === "ready") { + onReady(callback); + return this; + } - /** - * Initialize callback - */ - init: function init() {}, + if (delegate) { + originalCallback = callback; + callback = function (e) { + var t = e.target; + while (!matches(t, delegate)) { + if (t === this) { + return (t = false); + } + t = t.parentNode; + } - /** - * Handle any property change - * @private - */ - handleChange: function handleChange() { - var model = this.model; - model.emitUpdate(); + if (t) { + originalCallback.call(t, e); + } + }; + } - for (var prop in model.changed) { - model.emitUpdate(prop); - } - }, + return this.each(function (v) { + var finalCallback = callback; + if (runOnce) { + finalCallback = function () { + callback.apply(this, arguments); + removeEvent(v, eventName, finalCallback); + }; + } + registerEvent(v, eventName, finalCallback); + }); + }, + one: function (eventName, delegate, callback) { + return this.on(eventName, delegate, callback, true); + }, - /** - * Import, if possible, classes inside main container - * @private - * */ - importClasses: function importClasses() { - var clm = this.config.em.get('SelectorManager'); + ready: onReady, - if (clm) { - this.model.get('classes').each(function (m) { - clm.add(m.get('name')); + trigger: function (eventName, data) { + var evt = doc.createEvent("HTMLEvents"); + evt.data = data; + evt.initEvent(eventName, true, false); + return this.each(function (v) { + return v.dispatchEvent(evt); }); } - }, - - /** - * Fires on state update. If the state is not empty will add a helper class - * @param {Event} e - * @private - * */ - updateState: function updateState(e) { - var cl = 'hc-state'; - var state = this.model.get('state'); + }); - if (state) { - this.$el.addClass(cl); - } else { - this.$el.removeClass(cl); - } - }, + function encode(name, value) { + return "&" + encodeURIComponent(name) + "=" + encodeURIComponent(value).replace(/%20/g, "+"); + } + function getSelectMultiple_(el) { + var values = []; + each(el.options, function (o) { + if (o.selected) { + values.push(o.value); + } + }); + return values.length ? values : null; + } - /** - * Update item on status change - * @param {Event} e - * @private - * */ - updateStatus: function updateStatus(e) { - var el = this.el; - var status = this.model.get('status'); - var pfx = this.pfx; - var ppfx = this.ppfx; - var selectedCls = pfx + 'selected'; - var selectedParentCls = selectedCls + '-parent'; - var freezedCls = ppfx + 'freezed'; - var actualCls = el.getAttribute('class') || ''; - var cls = ''; + function getSelectSingle_(el) { + var selectedIndex = el.selectedIndex; + return selectedIndex >= 0 ? el.options[selectedIndex].value : null; + } - switch (status) { - case 'selected': - cls = actualCls + ' ' + selectedCls; - break; - case 'selected-parent': - cls = actualCls + ' ' + selectedParentCls; - break; - case 'freezed': - cls = actualCls + ' ' + freezedCls; - break; - default: - this.$el.removeClass(selectedCls + ' ' + selectedParentCls + ' ' + freezedCls); + function getValue(el) { + var type = el.type; + if (!type) { + return null; } - - cls = cls.trim(); - - if (cls) { - el.setAttribute('class', cls); + switch (type.toLowerCase()) { + case "select-one": + return getSelectSingle_(el); + case "select-multiple": + return getSelectMultiple_(el); + case "radio": + return (el.checked) ? el.value : null; + case "checkbox": + return (el.checked) ? el.value : null; + default: + return el.value ? el.value : null; } - }, - - - /** - * Update highlight attribute - * @private - * */ - updateHighlight: function updateHighlight() { - var hl = this.model.get('highlightable'); - this.setAttribute('data-highlightable', hl ? 1 : ''); - }, + } + fn.extend({ + serialize: function () { + var query = ""; - /** - * Update style attribute - * @private - * */ - updateStyle: function updateStyle() { - var em = this.em; - var model = this.model; + each(this[0].elements || this, function (el) { + if (el.disabled || el.tagName === "FIELDSET") { + return; + } + var name = el.name; + switch (el.type.toLowerCase()) { + case "file": + case "reset": + case "submit": + case "button": + break; + case "select-multiple": + var values = getValue(el); + if (values !== null) { + each(values, function (value) { + query += encode(name, value); + }); + } + break; + default: + var value = getValue(el); + if (value !== null) { + query += encode(name, value); + } + } + }); - if (em && em.get('avoidInlineStyle')) { - this.el.id = model.getId(); - model.setStyle(model.getStyle()); + return query.substr(1); + }, + + val: function (value) { + if (value === undefined) { + return getValue(this[0]); + } else { + return this.each(function (v) { + return v.value = value; + }); + } + } + + }); + + function insertElement(el, child, prepend) { + if (prepend) { + var first = el.childNodes[0]; + el.insertBefore(child, first); } else { - this.setAttribute('style', model.styleToString()); + el.appendChild(child); } - }, + } + function insertContent(parent, child, prepend) { + var str = isString(child); - /** - * Update classe attribute - * @private - * */ - updateClasses: function updateClasses() { - var str = this.model.get('classes').pluck('name').join(' '); - this.setAttribute('class', str); + if (!str && child.length) { + each(child, function (v) { + return insertContent(parent, v, prepend); + }); + return; + } - // Regenerate status class - this.updateStatus(); - }, + each(parent, str ? function (v) { + return v.insertAdjacentHTML(prepend ? "afterbegin" : "beforeend", child); + } : function (v, i) { + return insertElement(v, (i === 0 ? child : child.cloneNode(true)), prepend); + }); + } + fn.extend({ + after: function (selector) { + cash(selector).insertAfter(this); + return this; + }, - /** - * Update single attribute - * @param {[type]} name [description] - * @param {[type]} value [description] - */ - setAttribute: function setAttribute(name, value) { - var el = this.$el; - value ? el.attr(name, value) : el.removeAttr(name); - }, + append: function (content) { + insertContent(this, content); + return this; + }, + appendTo: function (parent) { + insertContent(cash(parent), this); + return this; + }, - /** - * Get classes from attributes. - * This method is called before initialize - * - * @return {Array}|null - * @private - * */ - getClasses: function getClasses() { - var attr = this.model.get("attributes"), - classes = attr['class'] || []; - classes = (0, _underscore.isArray)(classes) ? classes : [classes]; + before: function (selector) { + cash(selector).insertBefore(this); + return this; + }, - if (classes.length) { - return classes.join(' '); - } else { - return null; - } - }, + clone: function () { + return cash(this.map(function (v) { + return v.cloneNode(true); + })); + }, + empty: function () { + this.html(""); + return this; + }, - /** - * Update attributes - * @private - * */ - updateAttributes: function updateAttributes() { - var model = this.model; - var attrs = {}; - var attr = model.get('attributes'); - var src = model.get('src'); + html: function (content) { + if (content === undefined) { + return this[0].innerHTML; + } + var source = (content.nodeType ? content[0].outerHTML : content); + return this.each(function (v) { + return v.innerHTML = source; + }); + }, - for (var key in attr) { - attrs[key] = attr[key]; - } + insertAfter: function (selector) { + var _this = this; - src && (attrs.src = src); - this.$el.attr(attrs); - this.updateHighlight(); - this.updateStyle(); - }, + cash(selector).each(function (el, i) { + var parent = el.parentNode, sibling = el.nextSibling; + _this.each(function (v) { + parent.insertBefore((i === 0 ? v : v.cloneNode(true)), sibling); + }); + }); - /** - * Update component content - * @private - * */ - updateContent: function updateContent() { - this.getChildrenContainer().innerHTML = this.model.get('content'); - }, + return this; + }, + insertBefore: function (selector) { + var _this2 = this; + cash(selector).each(function (el, i) { + var parent = el.parentNode; + _this2.each(function (v) { + parent.insertBefore((i === 0 ? v : v.cloneNode(true)), el); + }); + }); + return this; + }, - /** - * Prevent default helper - * @param {Event} e - * @private - */ - prevDef: function prevDef(e) { - e.preventDefault(); - }, + prepend: function (content) { + insertContent(this, content, true); + return this; + }, + prependTo: function (parent) { + insertContent(cash(parent), this, true); + return this; + }, - /** - * Render component's script - * @private - */ - updateScript: function updateScript() { - if (!this.model.get('script')) { - return; - } + remove: function () { + return this.each(function (v) { + return v.parentNode.removeChild(v); + }); + }, - var em = this.em; - if (em) { - var canvas = em.get('Canvas'); - canvas.getCanvasView().updateScript(this); + text: function (content) { + if (content === undefined) { + return this[0].textContent; + } + return this.each(function (v) { + return v.textContent = content; + }); } - }, + }); - /** - * Return children container - * Differently from a simple component where children container is the - * component itself - * - * - * - * You could have the children container more deeper - * - *
- *
- *
- *
- * - *
- *
- *
- * @return HTMLElement - * @private - */ - getChildrenContainer: function getChildrenContainer() { - var container = this.el; + var docEl = doc.documentElement; - if (typeof this.getChildrenSelector == 'function') { - container = this.el.querySelector(this.getChildrenSelector()); - } else if (typeof this.getTemplate == 'function') { - // Need to find deepest first child - } + fn.extend({ + position: function () { + var el = this[0]; + return { + left: el.offsetLeft, + top: el.offsetTop + }; + }, - return container; - }, + offset: function () { + var rect = this[0].getBoundingClientRect(); + return { + top: rect.top + win.pageYOffset - docEl.clientTop, + left: rect.left + win.pageXOffset - docEl.clientLeft + }; + }, - - /** - * Render children components - * @private - */ - renderChildren: function renderChildren() { - var container = this.getChildrenContainer(); - var view = new ComponentsView({ - collection: this.model.get('components'), - config: this.config, - componentTypes: this.opts.componentTypes - }); - - view.render(container); - this.childrenView = view; - var childNodes = Array.prototype.slice.call(view.el.childNodes); - - for (var i = 0, len = childNodes.length; i < len; i++) { - container.appendChild(childNodes.shift()); - } - - // If the children container is not the same as the component - // (so likely fetched with getChildrenSelector()) is necessary - // to disable pointer-events for all nested components as they - // might prevent the component to be selected - if (container !== this.el) { - var disableNode = function disableNode(el) { - var children = Array.prototype.slice.call(el.children); - children.forEach(function (el) { - el.style['pointer-events'] = 'none'; - if (container !== el) { - disableNode(el); - } - }); - }; - disableNode(this.el); + offsetParent: function () { + return cash(this[0].offsetParent); } - }, - renderAttributes: function renderAttributes() { - this.updateAttributes(); - this.updateClasses(); - }, - render: function render() { - this.renderAttributes(); - this.updateContent(); - this.renderChildren(); - this.updateScript(); - return this; - } -}); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(0))) -/***/ }), -/* 4 */ -/***/ (function(module, exports, __webpack_require__) { + }); -"use strict"; + fn.extend({ + children: function (selector) { + var elems = []; + this.each(function (el) { + push.apply(elems, el.children); + }); + elems = unique(elems); + return (!selector ? elems : elems.filter(function (v) { + return matches(v, selector); + })); + }, -var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; + closest: function (selector) { + if (!selector || this.length < 1) { + return cash(); + } + if (this.is(selector)) { + return this.filter(selector); + } + return this.parent().closest(selector); + }, -var _underscore = __webpack_require__(1); + is: function (selector) { + if (!selector) { + return false; + } -var _mixins = __webpack_require__(2); + var match = false, comparator = getCompareFunction(selector); -var _Styleable = __webpack_require__(47); + this.each(function (el) { + match = comparator(el, selector); + return !match; + }); -var _Styleable2 = _interopRequireDefault(_Styleable); + return match; + }, -function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + find: function (selector) { + if (!selector || selector.nodeType) { + return cash(selector && this.has(selector).length ? selector : null); + } -var Backbone = __webpack_require__(0); -var Components = __webpack_require__(49); -var Selector = __webpack_require__(7); -var Selectors = __webpack_require__(10); -var Traits = __webpack_require__(152); + var elems = []; + this.each(function (el) { + push.apply(elems, find(selector, el)); + }); -var escapeRegExp = function escapeRegExp(str) { - return str.replace(/[|\\{}()[\]^$+*?.]/g, '\\$&'); -}; + return unique(elems); + }, -module.exports = Backbone.Model.extend(_Styleable2.default).extend({ + has: function (selector) { + var comparator = (isString(selector) ? function (el) { + return find(selector, el).length !== 0; + } : function (el) { + return el.contains(selector); + }); - defaults: { - // HTML tag of the component - tagName: 'div', + return this.filter(comparator); + }, - // Component type, eg. 'text', 'image', 'video', etc. - type: '', + next: function () { + return cash(this[0].nextElementSibling); + }, - // Name of the component. Will be used, for example, in layers and badges - name: '', + not: function (selector) { + if (!selector) { + return this; + } - // True if the component is removable from the canvas - removable: true, + var comparator = getCompareFunction(selector); - // Indicates if it's possible to drag the component inside others - // Tip: Indicate an array of selectors where it could be dropped inside - draggable: true, + return this.filter(function (el) { + return !comparator(el, selector); + }); + }, - // Indicates if it's possible to drop other components inside - // Tip: Indicate an array of selectors which could be dropped inside - droppable: true, + parent: function () { + var result = []; - // Set false if don't want to see the badge (with the name) over the component - badgable: true, + this.each(function (item) { + if (item && item.parentNode) { + result.push(item.parentNode); + } + }); - // True if it's possible to style it - // Tip: - // Indicate an array of CSS properties which is possible to style, eg. ['color', 'width'] - // All other properties will be hidden from the style manager - stylable: true, + return unique(result); + }, - // Indicate an array of style properties to show up which has been marked as `toRequire` - 'stylable-require': '', + parents: function (selector) { + var last, result = []; - // Indicate an array of style properties which should be hidden from the style manager - unstylable: '', + this.each(function (item) { + last = item; - // Highlightable with 'dotted' style if true - highlightable: true, + while (last && last.parentNode && last !== doc.body.parentNode) { + last = last.parentNode; - // True if it's possible to clone the component - copyable: true, + if (!selector || (selector && matches(last, selector))) { + result.push(last); + } + } + }); - // Indicates if it's possible to resize the component (at the moment implemented only on Image Components) - // It's also possible to pass an object as options for the Resizer - resizable: false, + return unique(result); + }, - // Allow to edit the content of the component (used on Text components) - editable: false, + prev: function () { + return cash(this[0].previousElementSibling); + }, - // Hide the component inside Layers - layerable: true, + siblings: function () { + var collection = this.parent().children(), el = this[0]; - // Allow component to be selected when clicked - selectable: true, + return collection.filter(function (i) { + return i !== el; + }); + } - // Shows a highlight outline when hovering on the element if true - hoverable: true, + }); - // This property is used by the HTML exporter as void elements do not - // have closing tag, eg.
,
, etc. - void: false, - // Indicates if the component is in some CSS state like ':hover', ':active', etc. - state: '', + return cash; +}); - // State, eg. 'selected' - status: '', +/***/ }), - // Content of the component (not escaped) which will be appended before children rendering - content: '', +/***/ "./node_modules/codemirror-formatting/formatting.js": +/*!**********************************************************!*\ + !*** ./node_modules/codemirror-formatting/formatting.js ***! + \**********************************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { - // Component icon, this string will be inserted before the name, eg. '' - icon: '', +(function(mod) { + if (true) // CommonJS + mod(__webpack_require__(/*! codemirror/lib/codemirror */ "./node_modules/codemirror/lib/codemirror.js")); + else {} +})(function(CodeMirror) { - // Component related style - style: '', + CodeMirror.extendMode("css", { + commentStart: "/*", + commentEnd: "*/", + newlineAfterToken: function(_type, content) { + return /^[;{}]$/.test(content); + } + }); - // Key-value object of the component's attributes - attributes: '', + CodeMirror.extendMode("javascript", { + commentStart: "/*", + commentEnd: "*/", + // FIXME semicolons inside of for + newlineAfterToken: function(_type, content, textAfter, state) { + if (this.jsonMode) { + return /^[\[,{]$/.test(content) || /^}/.test(textAfter); + } else { + if (content == ";" && state.lexical && state.lexical.type == ")") return false; + return /^[;{}]$/.test(content) && !/^;/.test(textAfter); + } + } + }); - // Array of classes - classes: '', + var inlineElements = /^(a|abbr|acronym|area|base|bdo|big|br|button|caption|cite|code|col|colgroup|dd|del|dfn|em|frame|hr|iframe|img|input|ins|kbd|label|legend|link|map|object|optgroup|option|param|q|samp|script|select|small|span|strong|sub|sup|textarea|tt|var)$/; - // Component's javascript - script: '', + CodeMirror.extendMode("xml", { + commentStart: "", + newlineAfterToken: function(type, content, textAfter, state) { + var inline = false; + if (this.configuration == "html") + inline = state.context ? inlineElements.test(state.context.tagName) : false; + return !inline && ((type == "tag" && />$/.test(content) && state.context) || + /^ -1 && endIndex > -1 && endIndex > startIndex) { + // Take string till comment start + selText = selText.substr(0, startIndex) + + // From comment start till comment end + selText.substring(startIndex + curMode.commentStart.length, endIndex) + + // From comment end till string end + selText.substr(endIndex + curMode.commentEnd.length); + } + cm.replaceRange(selText, from, to); + } + }); + }); - // Indicates an array of properties which will be inhereted by - // all NEW appended children - // - // If you create a model likes this - // removable: false, - // draggable: false, - // propagate: ['removable', 'draggable'] - // When you append some new component inside, the new added model - // will get the exact same properties indicated in `propagate` array - // (as the `propagate` property itself) - // - propagate: '', + // Applies automatic mode-aware indentation to the specified range + CodeMirror.defineExtension("autoIndentRange", function (from, to) { + var cmInstance = this; + this.operation(function () { + for (var i = from.line; i <= to.line; i++) { + cmInstance.indentLine(i, "smart"); + } + }); + }); - /** - * Set an array of items to show up inside the toolbar (eg. move, clone, delete) - * when the component is selected - * toolbar: [{ - * attributes: {class: 'fa fa-arrows'}, - * command: 'tlb-move', - * },{ - * attributes: {class: 'fa fa-clone'}, - * command: 'tlb-clone', - * }] - */ - toolbar: null - }, + // Applies automatic formatting to the specified range + CodeMirror.defineExtension("autoFormatRange", function (from, to) { + var cm = this; + var outer = cm.getMode(), text = cm.getRange(from, to).split("\n"); + var state = CodeMirror.copyState(outer, cm.getTokenAt(from).state); + var tabSize = cm.getOption("tabSize"); - initialize: function initialize() { - var _this = this; + var out = "", lines = 0, atSol = from.ch === 0; + function newline() { + out += "\n"; + atSol = true; + ++lines; + } - var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; - var opt = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + for (var i = 0; i < text.length; ++i) { + var stream = new CodeMirror.StringStream(text[i], tabSize); + while (!stream.eol()) { + var inner = CodeMirror.innerMode(outer, state); + var style = outer.token(stream, state), cur = stream.current(); + stream.start = stream.pos; + if (!atSol || /\S/.test(cur)) { + out += cur; + atSol = false; + } + if (!atSol && inner.mode.newlineAfterToken && + inner.mode.newlineAfterToken(style, cur, stream.string.slice(stream.pos) || text[i+1] || "", inner.state)) + newline(); + } + if (!stream.pos && outer.blankLine) outer.blankLine(state); + if (!atSol && i < text.length - 1) newline(); + } - var em = opt.sm || opt.em || ''; + cm.operation(function () { + cm.replaceRange(out, from, to); + for (var cur = from.line + 1, end = from.line + lines; cur <= end; ++cur) + cm.indentLine(cur, "smart"); + cm.setSelection(from, cm.getCursor(false)); + }); + }); +}); - // Propagate properties from parent if indicated - var parent = this.parent(); - var parentAttr = parent && parent.attributes; - if (parentAttr && parentAttr.propagate) { - var newAttr = {}; - var toPropagate = parentAttr.propagate; - toPropagate.forEach(function (prop) { - return newAttr[prop] = parent.get(prop); - }); - newAttr.propagate = toPropagate; - newAttr = _extends({}, newAttr, props); - this.set(newAttr); - } +/***/ }), - var propagate = this.get('propagate'); - propagate && this.set('propagate', (0, _underscore.isArray)(propagate) ? propagate : [propagate]); +/***/ "./node_modules/codemirror/lib/codemirror.js": +/*!***************************************************!*\ + !*** ./node_modules/codemirror/lib/codemirror.js ***! + \***************************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { - // Check void elements - if (opt && opt.config && opt.config.voidElements.indexOf(this.get('tagName')) >= 0) { - this.set('void', true); - } +// CodeMirror, copyright (c) by Marijn Haverbeke and others +// Distributed under an MIT license: https://codemirror.net/LICENSE - opt.em = em; - this.opt = opt; - this.sm = em; - this.em = em; - this.config = opt.config || {}; - this.set('attributes', this.get('attributes') || {}); - this.listenTo(this, 'change:script', this.scriptUpdated); - this.listenTo(this, 'change:traits', this.traitsUpdated); - this.listenTo(this, 'change:tagName', this.tagUpdated); - this.listenTo(this, 'change:attributes', this.attrUpdated); - this.initClasses(); - this.loadTraits(); - this.initComponents(); - this.initToolbar(); - this.set('status', ''); - this.listenTo(this.get('classes'), 'add remove change', function () { - return _this.emitUpdate('classes'); - }); - this.init(); - }, +// This is CodeMirror (https://codemirror.net), a code editor +// implemented in JavaScript on top of the browser's DOM. +// +// You can find some technical background for some of the code below +// at http://marijnhaverbeke.nl/blog/#cm-internals . +(function (global, factory) { + true ? module.exports = factory() : + undefined; +}(this, (function () { 'use strict'; - /** - * Check component's type - * @param {string} type Component type - * @return {Boolean} - * @example - * model.is('image') - * // -> false - */ - is: function is(type) { - return !!(this.get('type') == type); - }, + // Kludges for bugs and behavior differences that can't be feature + // detected are enabled based on userAgent etc sniffing. + var userAgent = navigator.userAgent; + var platform = navigator.platform; + + var gecko = /gecko\/\d/i.test(userAgent); + var ie_upto10 = /MSIE \d/.test(userAgent); + var ie_11up = /Trident\/(?:[7-9]|\d{2,})\..*rv:(\d+)/.exec(userAgent); + var edge = /Edge\/(\d+)/.exec(userAgent); + var ie = ie_upto10 || ie_11up || edge; + var ie_version = ie && (ie_upto10 ? document.documentMode || 6 : +(edge || ie_11up)[1]); + var webkit = !edge && /WebKit\//.test(userAgent); + var qtwebkit = webkit && /Qt\/\d+\.\d+/.test(userAgent); + var chrome = !edge && /Chrome\//.test(userAgent); + var presto = /Opera\//.test(userAgent); + var safari = /Apple Computer/.test(navigator.vendor); + var mac_geMountainLion = /Mac OS X 1\d\D([8-9]|\d\d)\D/.test(userAgent); + var phantom = /PhantomJS/.test(userAgent); + + var ios = !edge && /AppleWebKit/.test(userAgent) && /Mobile\/\w+/.test(userAgent); + var android = /Android/.test(userAgent); + // This is woefully incomplete. Suggestions for alternative methods welcome. + var mobile = ios || android || /webOS|BlackBerry|Opera Mini|Opera Mobi|IEMobile/i.test(userAgent); + var mac = ios || /Mac/.test(platform); + var chromeOS = /\bCrOS\b/.test(userAgent); + var windows = /win/i.test(platform); + + var presto_version = presto && userAgent.match(/Version\/(\d*\.\d*)/); + if (presto_version) { presto_version = Number(presto_version[1]); } + if (presto_version && presto_version >= 15) { presto = false; webkit = true; } + // Some browsers use the wrong event properties to signal cmd/ctrl on OS X + var flipCtrlCmd = mac && (qtwebkit || presto && (presto_version == null || presto_version < 12.11)); + var captureRightClick = gecko || (ie && ie_version >= 9); + + function classTest(cls) { return new RegExp("(^|\\s)" + cls + "(?:$|\\s)\\s*") } + + var rmClass = function(node, cls) { + var current = node.className; + var match = classTest(cls).exec(current); + if (match) { + var after = current.slice(match.index + match[0].length); + node.className = current.slice(0, match.index) + (after ? match[1] + after : ""); + } + }; + + function removeChildren(e) { + for (var count = e.childNodes.length; count > 0; --count) + { e.removeChild(e.firstChild); } + return e + } + + function removeChildrenAndAdd(parent, e) { + return removeChildren(parent).appendChild(e) + } + + function elt(tag, content, className, style) { + var e = document.createElement(tag); + if (className) { e.className = className; } + if (style) { e.style.cssText = style; } + if (typeof content == "string") { e.appendChild(document.createTextNode(content)); } + else if (content) { for (var i = 0; i < content.length; ++i) { e.appendChild(content[i]); } } + return e + } + // wrapper for elt, which removes the elt from the accessibility tree + function eltP(tag, content, className, style) { + var e = elt(tag, content, className, style); + e.setAttribute("role", "presentation"); + return e + } + + var range; + if (document.createRange) { range = function(node, start, end, endNode) { + var r = document.createRange(); + r.setEnd(endNode || node, end); + r.setStart(node, start); + return r + }; } + else { range = function(node, start, end) { + var r = document.body.createTextRange(); + try { r.moveToElementText(node.parentNode); } + catch(e) { return r } + r.collapse(true); + r.moveEnd("character", end); + r.moveStart("character", start); + return r + }; } + function contains(parent, child) { + if (child.nodeType == 3) // Android browser always returns false when child is a textnode + { child = child.parentNode; } + if (parent.contains) + { return parent.contains(child) } + do { + if (child.nodeType == 11) { child = child.host; } + if (child == parent) { return true } + } while (child = child.parentNode) + } - /** - * Find inner models by query string - * ATTENTION: this method works only with alredy rendered component - * @param {string} query Query string - * @return {Array} Array of models - * @example - * model.find('div > .class'); - * // -> [Component, Component, ...] - */ - find: function find(query) { - var result = []; + function activeElt() { + // IE and Edge may throw an "Unspecified Error" when accessing document.activeElement. + // IE < 10 will throw when accessed while the page is loading or in an iframe. + // IE > 9 and Edge will throw when accessed in an iframe if document.body is unavailable. + var activeElement; + try { + activeElement = document.activeElement; + } catch(e) { + activeElement = document.body || null; + } + while (activeElement && activeElement.shadowRoot && activeElement.shadowRoot.activeElement) + { activeElement = activeElement.shadowRoot.activeElement; } + return activeElement + } - this.view.$el.find(query).each(function (el, i, $els) { - var $el = $els.eq(i); - var model = $el.data('model'); - model && result.push(model); - }); + function addClass(node, cls) { + var current = node.className; + if (!classTest(cls).test(current)) { node.className += (current ? " " : "") + cls; } + } + function joinClasses(a, b) { + var as = a.split(" "); + for (var i = 0; i < as.length; i++) + { if (as[i] && !classTest(as[i]).test(b)) { b += " " + as[i]; } } + return b + } - return result; - }, + var selectInput = function(node) { node.select(); }; + if (ios) // Mobile Safari apparently has a bug where select() is broken. + { selectInput = function(node) { node.selectionStart = 0; node.selectionEnd = node.value.length; }; } + else if (ie) // Suppress mysterious IE10 errors + { selectInput = function(node) { try { node.select(); } catch(_e) {} }; } + function bind(f) { + var args = Array.prototype.slice.call(arguments, 1); + return function(){return f.apply(null, args)} + } - /** - * Once the tag is updated I have to remove the node and replace it - */ - tagUpdated: function tagUpdated() { - var coll = this.collection; - var at = coll.indexOf(this); - coll.remove(this); - coll.add(this, { at: at }); - }, + function copyObj(obj, target, overwrite) { + if (!target) { target = {}; } + for (var prop in obj) + { if (obj.hasOwnProperty(prop) && (overwrite !== false || !target.hasOwnProperty(prop))) + { target[prop] = obj[prop]; } } + return target + } + // Counts the column offset in a string, taking tabs into account. + // Used mostly to find indentation. + function countColumn(string, end, tabSize, startIndex, startValue) { + if (end == null) { + end = string.search(/[^\s\u00a0]/); + if (end == -1) { end = string.length; } + } + for (var i = startIndex || 0, n = startValue || 0;;) { + var nextTab = string.indexOf("\t", i); + if (nextTab < 0 || nextTab >= end) + { return n + (end - i) } + n += nextTab - i; + n += tabSize - (n % tabSize); + i = nextTab + 1; + } + } - /** - * Emit changes for each updated attribute - */ - attrUpdated: function attrUpdated() { - var _this2 = this; + var Delayed = function() {this.id = null;}; + Delayed.prototype.set = function (ms, f) { + clearTimeout(this.id); + this.id = setTimeout(f, ms); + }; - var attrPrev = _extends({}, this.previous('attributes')); - var attrCurrent = _extends({}, this.get('attributes')); - var diff = (0, _mixins.shallowDiff)(attrPrev, attrCurrent); - (0, _underscore.keys)(diff).forEach(function (pr) { - return _this2.trigger('change:attributes:' + pr); - }); - }, + function indexOf(array, elt) { + for (var i = 0; i < array.length; ++i) + { if (array[i] == elt) { return i } } + return -1 + } + // Number of pixels added to scroller and sizer to hide scrollbar + var scrollerGap = 30; - /** - * Update attributes of the model - * @param {Object} attrs Key value attributes - * @example - * model.setAttributes({id: 'test', 'data-key': 'value'}); - */ - setAttributes: function setAttributes(attrs) { - attrs = _extends({}, attrs); + // Returned or thrown by various protocols to signal 'I'm not + // handling this'. + var Pass = {toString: function(){return "CodeMirror.Pass"}}; - // Handle classes - var classes = attrs.class; - classes && this.setClass(classes); - delete attrs.class; + // Reused option objects for setSelection & friends + var sel_dontScroll = {scroll: false}, sel_mouse = {origin: "*mouse"}, sel_move = {origin: "+move"}; - // Handle style - var style = attrs.style; - style && this.setStyle(style); - delete attrs.style; + // The inverse of countColumn -- find the offset that corresponds to + // a particular column. + function findColumn(string, goal, tabSize) { + for (var pos = 0, col = 0;;) { + var nextTab = string.indexOf("\t", pos); + if (nextTab == -1) { nextTab = string.length; } + var skipped = nextTab - pos; + if (nextTab == string.length || col + skipped >= goal) + { return pos + Math.min(skipped, goal - col) } + col += nextTab - pos; + col += tabSize - (col % tabSize); + pos = nextTab + 1; + if (col >= goal) { return pos } + } + } - this.set('attributes', attrs); - }, - getStyle: function getStyle() { - var em = this.em; + var spaceStrs = [""]; + function spaceStr(n) { + while (spaceStrs.length <= n) + { spaceStrs.push(lst(spaceStrs) + " "); } + return spaceStrs[n] + } - if (em && em.getConfig('avoidInlineStyle')) { - var state = this.get('state'); - var cc = em.get('CssComposer'); - var rule = cc.getIdRule(this.getId(), { state: state }); - this.rule = rule; + function lst(arr) { return arr[arr.length-1] } - if (rule) { - return rule.getStyle(); - } + function map(array, f) { + var out = []; + for (var i = 0; i < array.length; i++) { out[i] = f(array[i], i); } + return out + } + + function insertSorted(array, value, score) { + var pos = 0, priority = score(value); + while (pos < array.length && score(array[pos]) <= priority) { pos++; } + array.splice(pos, 0, value); + } + + function nothing() {} + + function createObj(base, props) { + var inst; + if (Object.create) { + inst = Object.create(base); + } else { + nothing.prototype = base; + inst = new nothing(); } + if (props) { copyObj(props, inst); } + return inst + } - return _Styleable2.default.getStyle.call(this); - }, - setStyle: function setStyle() { - var _this3 = this; + var nonASCIISingleCaseWordChar = /[\u00df\u0587\u0590-\u05f4\u0600-\u06ff\u3040-\u309f\u30a0-\u30ff\u3400-\u4db5\u4e00-\u9fcc\uac00-\ud7af]/; + function isWordCharBasic(ch) { + return /\w/.test(ch) || ch > "\x80" && + (ch.toUpperCase() != ch.toLowerCase() || nonASCIISingleCaseWordChar.test(ch)) + } + function isWordChar(ch, helper) { + if (!helper) { return isWordCharBasic(ch) } + if (helper.source.indexOf("\\w") > -1 && isWordCharBasic(ch)) { return true } + return helper.test(ch) + } - var prop = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; - var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + function isEmpty(obj) { + for (var n in obj) { if (obj.hasOwnProperty(n) && obj[n]) { return false } } + return true + } - var em = this.em; + // Extending unicode characters. A series of a non-extending char + + // any number of extending chars is treated as a single unit as far + // as editing and measuring is concerned. This is not fully correct, + // since some scripts/fonts/browsers also treat other configurations + // of code points as a group. + var extendingChars = /[\u0300-\u036f\u0483-\u0489\u0591-\u05bd\u05bf\u05c1\u05c2\u05c4\u05c5\u05c7\u0610-\u061a\u064b-\u065e\u0670\u06d6-\u06dc\u06de-\u06e4\u06e7\u06e8\u06ea-\u06ed\u0711\u0730-\u074a\u07a6-\u07b0\u07eb-\u07f3\u0816-\u0819\u081b-\u0823\u0825-\u0827\u0829-\u082d\u0900-\u0902\u093c\u0941-\u0948\u094d\u0951-\u0955\u0962\u0963\u0981\u09bc\u09be\u09c1-\u09c4\u09cd\u09d7\u09e2\u09e3\u0a01\u0a02\u0a3c\u0a41\u0a42\u0a47\u0a48\u0a4b-\u0a4d\u0a51\u0a70\u0a71\u0a75\u0a81\u0a82\u0abc\u0ac1-\u0ac5\u0ac7\u0ac8\u0acd\u0ae2\u0ae3\u0b01\u0b3c\u0b3e\u0b3f\u0b41-\u0b44\u0b4d\u0b56\u0b57\u0b62\u0b63\u0b82\u0bbe\u0bc0\u0bcd\u0bd7\u0c3e-\u0c40\u0c46-\u0c48\u0c4a-\u0c4d\u0c55\u0c56\u0c62\u0c63\u0cbc\u0cbf\u0cc2\u0cc6\u0ccc\u0ccd\u0cd5\u0cd6\u0ce2\u0ce3\u0d3e\u0d41-\u0d44\u0d4d\u0d57\u0d62\u0d63\u0dca\u0dcf\u0dd2-\u0dd4\u0dd6\u0ddf\u0e31\u0e34-\u0e3a\u0e47-\u0e4e\u0eb1\u0eb4-\u0eb9\u0ebb\u0ebc\u0ec8-\u0ecd\u0f18\u0f19\u0f35\u0f37\u0f39\u0f71-\u0f7e\u0f80-\u0f84\u0f86\u0f87\u0f90-\u0f97\u0f99-\u0fbc\u0fc6\u102d-\u1030\u1032-\u1037\u1039\u103a\u103d\u103e\u1058\u1059\u105e-\u1060\u1071-\u1074\u1082\u1085\u1086\u108d\u109d\u135f\u1712-\u1714\u1732-\u1734\u1752\u1753\u1772\u1773\u17b7-\u17bd\u17c6\u17c9-\u17d3\u17dd\u180b-\u180d\u18a9\u1920-\u1922\u1927\u1928\u1932\u1939-\u193b\u1a17\u1a18\u1a56\u1a58-\u1a5e\u1a60\u1a62\u1a65-\u1a6c\u1a73-\u1a7c\u1a7f\u1b00-\u1b03\u1b34\u1b36-\u1b3a\u1b3c\u1b42\u1b6b-\u1b73\u1b80\u1b81\u1ba2-\u1ba5\u1ba8\u1ba9\u1c2c-\u1c33\u1c36\u1c37\u1cd0-\u1cd2\u1cd4-\u1ce0\u1ce2-\u1ce8\u1ced\u1dc0-\u1de6\u1dfd-\u1dff\u200c\u200d\u20d0-\u20f0\u2cef-\u2cf1\u2de0-\u2dff\u302a-\u302f\u3099\u309a\ua66f-\ua672\ua67c\ua67d\ua6f0\ua6f1\ua802\ua806\ua80b\ua825\ua826\ua8c4\ua8e0-\ua8f1\ua926-\ua92d\ua947-\ua951\ua980-\ua982\ua9b3\ua9b6-\ua9b9\ua9bc\uaa29-\uaa2e\uaa31\uaa32\uaa35\uaa36\uaa43\uaa4c\uaab0\uaab2-\uaab4\uaab7\uaab8\uaabe\uaabf\uaac1\uabe5\uabe8\uabed\udc00-\udfff\ufb1e\ufe00-\ufe0f\ufe20-\ufe26\uff9e\uff9f]/; + function isExtendingChar(ch) { return ch.charCodeAt(0) >= 768 && extendingChars.test(ch) } - if (em && em.getConfig('avoidInlineStyle')) { - prop = (0, _underscore.isString)(prop) ? this.parseStyle(prop) : prop; - var state = this.get('state'); - var cc = em.get('CssComposer'); - var propOrig = this.getStyle(); - this.rule = cc.setIdRule(this.getId(), prop, _extends({}, opts, { state: state })); - var diff = (0, _mixins.shallowDiff)(propOrig, prop); - (0, _underscore.keys)(diff).forEach(function (pr) { - return _this3.trigger('change:style:' + pr); - }); - } else { - prop = _Styleable2.default.setStyle.apply(this, arguments); + // Returns a number from the range [`0`; `str.length`] unless `pos` is outside that range. + function skipExtendingChars(str, pos, dir) { + while ((dir < 0 ? pos > 0 : pos < str.length) && isExtendingChar(str.charAt(pos))) { pos += dir; } + return pos + } + + // Returns the value from the range [`from`; `to`] that satisfies + // `pred` and is closest to `from`. Assumes that at least `to` + // satisfies `pred`. Supports `from` being greater than `to`. + function findFirst(pred, from, to) { + // At any point we are certain `to` satisfies `pred`, don't know + // whether `from` does. + var dir = from > to ? -1 : 1; + for (;;) { + if (from == to) { return from } + var midF = (from + to) / 2, mid = dir < 0 ? Math.ceil(midF) : Math.floor(midF); + if (mid == from) { return pred(mid) ? from : to } + if (pred(mid)) { to = mid; } + else { from = mid + dir; } + } + } + + // BIDI HELPERS + + function iterateBidiSections(order, from, to, f) { + if (!order) { return f(from, to, "ltr", 0) } + var found = false; + for (var i = 0; i < order.length; ++i) { + var part = order[i]; + if (part.from < to && part.to > from || from == to && part.to == from) { + f(Math.max(part.from, from), Math.min(part.to, to), part.level == 1 ? "rtl" : "ltr", i); + found = true; + } + } + if (!found) { f(from, to, "ltr"); } + } + + var bidiOther = null; + function getBidiPartAt(order, ch, sticky) { + var found; + bidiOther = null; + for (var i = 0; i < order.length; ++i) { + var cur = order[i]; + if (cur.from < ch && cur.to > ch) { return i } + if (cur.to == ch) { + if (cur.from != cur.to && sticky == "before") { found = i; } + else { bidiOther = i; } + } + if (cur.from == ch) { + if (cur.from != cur.to && sticky != "before") { found = i; } + else { bidiOther = i; } + } + } + return found != null ? found : bidiOther + } + + // Bidirectional ordering algorithm + // See http://unicode.org/reports/tr9/tr9-13.html for the algorithm + // that this (partially) implements. + + // One-char codes used for character types: + // L (L): Left-to-Right + // R (R): Right-to-Left + // r (AL): Right-to-Left Arabic + // 1 (EN): European Number + // + (ES): European Number Separator + // % (ET): European Number Terminator + // n (AN): Arabic Number + // , (CS): Common Number Separator + // m (NSM): Non-Spacing Mark + // b (BN): Boundary Neutral + // s (B): Paragraph Separator + // t (S): Segment Separator + // w (WS): Whitespace + // N (ON): Other Neutrals + + // Returns null if characters are ordered as they appear + // (left-to-right), or an array of sections ({from, to, level} + // objects) in the order in which they occur visually. + var bidiOrdering = (function() { + // Character types for codepoints 0 to 0xff + var lowTypes = "bbbbbbbbbtstwsbbbbbbbbbbbbbbssstwNN%%%NNNNNN,N,N1111111111NNNNNNNLLLLLLLLLLLLLLLLLLLLLLLLLLNNNNNNLLLLLLLLLLLLLLLLLLLLLLLLLLNNNNbbbbbbsbbbbbbbbbbbbbbbbbbbbbbbbbb,N%%%%NNNNLNNNNN%%11NLNNN1LNNNNNLLLLLLLLLLLLLLLLLLLLLLLNLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLN"; + // Character types for codepoints 0x600 to 0x6f9 + var arabicTypes = "nnnnnnNNr%%r,rNNmmmmmmmmmmmrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrmmmmmmmmmmmmmmmmmmmmmnnnnnnnnnn%nnrrrmrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrmmmmmmmnNmmmmmmrrmmNmmmmrr1111111111"; + function charType(code) { + if (code <= 0xf7) { return lowTypes.charAt(code) } + else if (0x590 <= code && code <= 0x5f4) { return "R" } + else if (0x600 <= code && code <= 0x6f9) { return arabicTypes.charAt(code - 0x600) } + else if (0x6ee <= code && code <= 0x8ac) { return "r" } + else if (0x2000 <= code && code <= 0x200b) { return "w" } + else if (code == 0x200c) { return "b" } + else { return "L" } + } + + var bidiRE = /[\u0590-\u05f4\u0600-\u06ff\u0700-\u08ac]/; + var isNeutral = /[stwN]/, isStrong = /[LRr]/, countsAsLeft = /[Lb1n]/, countsAsNum = /[1n]/; + + function BidiSpan(level, from, to) { + this.level = level; + this.from = from; this.to = to; + } + + return function(str, direction) { + var outerType = direction == "ltr" ? "L" : "R"; + + if (str.length == 0 || direction == "ltr" && !bidiRE.test(str)) { return false } + var len = str.length, types = []; + for (var i = 0; i < len; ++i) + { types.push(charType(str.charCodeAt(i))); } + + // W1. Examine each non-spacing mark (NSM) in the level run, and + // change the type of the NSM to the type of the previous + // character. If the NSM is at the start of the level run, it will + // get the type of sor. + for (var i$1 = 0, prev = outerType; i$1 < len; ++i$1) { + var type = types[i$1]; + if (type == "m") { types[i$1] = prev; } + else { prev = type; } + } + + // W2. Search backwards from each instance of a European number + // until the first strong type (R, L, AL, or sor) is found. If an + // AL is found, change the type of the European number to Arabic + // number. + // W3. Change all ALs to R. + for (var i$2 = 0, cur = outerType; i$2 < len; ++i$2) { + var type$1 = types[i$2]; + if (type$1 == "1" && cur == "r") { types[i$2] = "n"; } + else if (isStrong.test(type$1)) { cur = type$1; if (type$1 == "r") { types[i$2] = "R"; } } + } + + // W4. A single European separator between two European numbers + // changes to a European number. A single common separator between + // two numbers of the same type changes to that type. + for (var i$3 = 1, prev$1 = types[0]; i$3 < len - 1; ++i$3) { + var type$2 = types[i$3]; + if (type$2 == "+" && prev$1 == "1" && types[i$3+1] == "1") { types[i$3] = "1"; } + else if (type$2 == "," && prev$1 == types[i$3+1] && + (prev$1 == "1" || prev$1 == "n")) { types[i$3] = prev$1; } + prev$1 = type$2; + } + + // W5. A sequence of European terminators adjacent to European + // numbers changes to all European numbers. + // W6. Otherwise, separators and terminators change to Other + // Neutral. + for (var i$4 = 0; i$4 < len; ++i$4) { + var type$3 = types[i$4]; + if (type$3 == ",") { types[i$4] = "N"; } + else if (type$3 == "%") { + var end = (void 0); + for (end = i$4 + 1; end < len && types[end] == "%"; ++end) {} + var replace = (i$4 && types[i$4-1] == "!") || (end < len && types[end] == "1") ? "1" : "N"; + for (var j = i$4; j < end; ++j) { types[j] = replace; } + i$4 = end - 1; + } + } + + // W7. Search backwards from each instance of a European number + // until the first strong type (R, L, or sor) is found. If an L is + // found, then change the type of the European number to L. + for (var i$5 = 0, cur$1 = outerType; i$5 < len; ++i$5) { + var type$4 = types[i$5]; + if (cur$1 == "L" && type$4 == "1") { types[i$5] = "L"; } + else if (isStrong.test(type$4)) { cur$1 = type$4; } + } + + // N1. A sequence of neutrals takes the direction of the + // surrounding strong text if the text on both sides has the same + // direction. European and Arabic numbers act as if they were R in + // terms of their influence on neutrals. Start-of-level-run (sor) + // and end-of-level-run (eor) are used at level run boundaries. + // N2. Any remaining neutrals take the embedding direction. + for (var i$6 = 0; i$6 < len; ++i$6) { + if (isNeutral.test(types[i$6])) { + var end$1 = (void 0); + for (end$1 = i$6 + 1; end$1 < len && isNeutral.test(types[end$1]); ++end$1) {} + var before = (i$6 ? types[i$6-1] : outerType) == "L"; + var after = (end$1 < len ? types[end$1] : outerType) == "L"; + var replace$1 = before == after ? (before ? "L" : "R") : outerType; + for (var j$1 = i$6; j$1 < end$1; ++j$1) { types[j$1] = replace$1; } + i$6 = end$1 - 1; + } + } + + // Here we depart from the documented algorithm, in order to avoid + // building up an actual levels array. Since there are only three + // levels (0, 1, 2) in an implementation that doesn't take + // explicit embedding into account, we can build up the order on + // the fly, without following the level-based algorithm. + var order = [], m; + for (var i$7 = 0; i$7 < len;) { + if (countsAsLeft.test(types[i$7])) { + var start = i$7; + for (++i$7; i$7 < len && countsAsLeft.test(types[i$7]); ++i$7) {} + order.push(new BidiSpan(0, start, i$7)); + } else { + var pos = i$7, at = order.length; + for (++i$7; i$7 < len && types[i$7] != "L"; ++i$7) {} + for (var j$2 = pos; j$2 < i$7;) { + if (countsAsNum.test(types[j$2])) { + if (pos < j$2) { order.splice(at, 0, new BidiSpan(1, pos, j$2)); } + var nstart = j$2; + for (++j$2; j$2 < i$7 && countsAsNum.test(types[j$2]); ++j$2) {} + order.splice(at, 0, new BidiSpan(2, nstart, j$2)); + pos = j$2; + } else { ++j$2; } + } + if (pos < i$7) { order.splice(at, 0, new BidiSpan(1, pos, i$7)); } + } + } + if (direction == "ltr") { + if (order[0].level == 1 && (m = str.match(/^\s+/))) { + order[0].from = m[0].length; + order.unshift(new BidiSpan(0, 0, m[0].length)); + } + if (lst(order).level == 1 && (m = str.match(/\s+$/))) { + lst(order).to -= m[0].length; + order.push(new BidiSpan(0, len - m[0].length, len)); + } + } + + return direction == "rtl" ? order.reverse() : order } + })(); - return prop; - }, + // Get the bidi ordering for the given line (and cache it). Returns + // false for lines that are fully left-to-right, and an array of + // BidiSpan objects otherwise. + function getOrder(line, direction) { + var order = line.order; + if (order == null) { order = line.order = bidiOrdering(line.text, direction); } + return order + } + // EVENT HANDLING - /** - * Return attributes - * @return {Object} - */ - getAttributes: function getAttributes() { - var classes = []; - var attributes = _extends({}, this.get('attributes')); + // Lightweight event framework. on/off also work on DOM nodes, + // registering native DOM handlers. - // Add classes - this.get('classes').each(function (cls) { - return classes.push(cls.get('name')); - }); - classes.length && (attributes.class = classes.join(' ')); + var noHandlers = []; - // If style is not empty I need an ID attached to the component - if (!(0, _underscore.isEmpty)(this.getStyle()) && !(0, _underscore.has)(attributes, 'id')) { - attributes.id = this.getId(); + var on = function(emitter, type, f) { + if (emitter.addEventListener) { + emitter.addEventListener(type, f, false); + } else if (emitter.attachEvent) { + emitter.attachEvent("on" + type, f); + } else { + var map$$1 = emitter._handlers || (emitter._handlers = {}); + map$$1[type] = (map$$1[type] || noHandlers).concat(f); } + }; - return attributes; - }, + function getHandlers(emitter, type) { + return emitter._handlers && emitter._handlers[type] || noHandlers + } + function off(emitter, type, f) { + if (emitter.removeEventListener) { + emitter.removeEventListener(type, f, false); + } else if (emitter.detachEvent) { + emitter.detachEvent("on" + type, f); + } else { + var map$$1 = emitter._handlers, arr = map$$1 && map$$1[type]; + if (arr) { + var index = indexOf(arr, f); + if (index > -1) + { map$$1[type] = arr.slice(0, index).concat(arr.slice(index + 1)); } + } + } + } - /** - * Add classes - * @param {Array|string} classes Array or string of classes - * @return {Array} Array of added selectors - * @example - * model.addClass('class1'); - * model.addClass('class1 class2'); - * model.addClass(['class1', 'class2']); - * // -> [SelectorObject, ...] - */ - addClass: function addClass(classes) { - var added = this.em.get('SelectorManager').addClass(classes); - return this.get('classes').add(added); - }, + function signal(emitter, type /*, values...*/) { + var handlers = getHandlers(emitter, type); + if (!handlers.length) { return } + var args = Array.prototype.slice.call(arguments, 2); + for (var i = 0; i < handlers.length; ++i) { handlers[i].apply(null, args); } + } + // The DOM events that CodeMirror handles can be overridden by + // registering a (non-DOM) handler on the editor for the event name, + // and preventDefault-ing the event in that handler. + function signalDOMEvent(cm, e, override) { + if (typeof e == "string") + { e = {type: e, preventDefault: function() { this.defaultPrevented = true; }}; } + signal(cm, override || e.type, cm, e); + return e_defaultPrevented(e) || e.codemirrorIgnore + } - /** - * Set classes (resets current collection) - * @param {Array|string} classes Array or string of classes - * @return {Array} Array of added selectors - * @example - * model.setClass('class1'); - * model.setClass('class1 class2'); - * model.setClass(['class1', 'class2']); - * // -> [SelectorObject, ...] - */ - setClass: function setClass(classes) { - this.get('classes').reset(); - return this.addClass(classes); - }, + function signalCursorActivity(cm) { + var arr = cm._handlers && cm._handlers.cursorActivity; + if (!arr) { return } + var set = cm.curOp.cursorActivityHandlers || (cm.curOp.cursorActivityHandlers = []); + for (var i = 0; i < arr.length; ++i) { if (indexOf(set, arr[i]) == -1) + { set.push(arr[i]); } } + } + function hasHandler(emitter, type) { + return getHandlers(emitter, type).length > 0 + } - /** - * Remove classes - * @param {Array|string} classes Array or string of classes - * @return {Array} Array of removed selectors - * @example - * model.removeClass('class1'); - * model.removeClass('class1 class2'); - * model.removeClass(['class1', 'class2']); - * // -> [SelectorObject, ...] - */ - removeClass: function removeClass(classes) { - var removed = []; - classes = (0, _underscore.isArray)(classes) ? classes : [classes]; - var selectors = this.get('classes'); - var type = Selector.TYPE_CLASS; + // Add on and off methods to a constructor's prototype, to make + // registering events on such objects more convenient. + function eventMixin(ctor) { + ctor.prototype.on = function(type, f) {on(this, type, f);}; + ctor.prototype.off = function(type, f) {off(this, type, f);}; + } - classes.forEach(function (classe) { - var classes = classe.split(' '); - classes.forEach(function (name) { - var selector = selectors.where({ name: name, type: type })[0]; - selector && removed.push(selectors.remove(selector)); - }); - }); + // Due to the fact that we still support jurassic IE versions, some + // compatibility wrappers are needed. - return removed; - }, - initClasses: function initClasses() { - var classes = this.normalizeClasses(this.get('classes') || []); - this.set('classes', new Selectors(classes)); - return this; - }, - initComponents: function initComponents() { - // Have to add components after the init, otherwise the parent - // is not visible - var comps = new Components(null, this.opt); - comps.parent = this; - comps.reset(this.get('components')); - this.set('components', comps); - return this; - }, + function e_preventDefault(e) { + if (e.preventDefault) { e.preventDefault(); } + else { e.returnValue = false; } + } + function e_stopPropagation(e) { + if (e.stopPropagation) { e.stopPropagation(); } + else { e.cancelBubble = true; } + } + function e_defaultPrevented(e) { + return e.defaultPrevented != null ? e.defaultPrevented : e.returnValue == false + } + function e_stop(e) {e_preventDefault(e); e_stopPropagation(e);} + function e_target(e) {return e.target || e.srcElement} + function e_button(e) { + var b = e.which; + if (b == null) { + if (e.button & 1) { b = 1; } + else if (e.button & 2) { b = 3; } + else if (e.button & 4) { b = 2; } + } + if (mac && e.ctrlKey && b == 1) { b = 3; } + return b + } - /** - * Initialize callback - */ - init: function init() {}, + // Detect drag-and-drop + var dragAndDrop = function() { + // There is *some* kind of drag-and-drop support in IE6-8, but I + // couldn't get it to work yet. + if (ie && ie_version < 9) { return false } + var div = elt('div'); + return "draggable" in div || "dragDrop" in div + }(); + var zwspSupported; + function zeroWidthElement(measure) { + if (zwspSupported == null) { + var test = elt("span", "\u200b"); + removeChildrenAndAdd(measure, elt("span", [test, document.createTextNode("x")])); + if (measure.firstChild.offsetHeight != 0) + { zwspSupported = test.offsetWidth <= 1 && test.offsetHeight > 2 && !(ie && ie_version < 8); } + } + var node = zwspSupported ? elt("span", "\u200b") : + elt("span", "\u00a0", null, "display: inline-block; width: 1px; margin-right: -1px"); + node.setAttribute("cm-text", ""); + return node + } + + // Feature-detect IE's crummy client rect reporting for bidi text + var badBidiRects; + function hasBadBidiRects(measure) { + if (badBidiRects != null) { return badBidiRects } + var txt = removeChildrenAndAdd(measure, document.createTextNode("A\u062eA")); + var r0 = range(txt, 0, 1).getBoundingClientRect(); + var r1 = range(txt, 1, 2).getBoundingClientRect(); + removeChildren(measure); + if (!r0 || r0.left == r0.right) { return false } // Safari returns null in some cases (#2780) + return badBidiRects = (r1.right - r0.right < 3) + } + + // See if "".split is the broken IE version, if so, provide an + // alternative way to split lines. + var splitLinesAuto = "\n\nb".split(/\n/).length != 3 ? function (string) { + var pos = 0, result = [], l = string.length; + while (pos <= l) { + var nl = string.indexOf("\n", pos); + if (nl == -1) { nl = string.length; } + var line = string.slice(pos, string.charAt(nl - 1) == "\r" ? nl - 1 : nl); + var rt = line.indexOf("\r"); + if (rt != -1) { + result.push(line.slice(0, rt)); + pos += rt + 1; + } else { + result.push(line); + pos = nl + 1; + } + } + return result + } : function (string) { return string.split(/\r\n?|\n/); }; - /** - * Add new component children - * @param {Component|string} components Component to add - * @param {Object} [opts={}] Options, same as in `model.add()`(from backbone) - * @return {Array} Array of appended components - * @example - * someModel.get('components').lenght // -> 0 - * const videoComponent = someModel.append('
')[0]; - * // This will add 2 components (`video` and `div`) to your `someModel` - * someModel.get('components').lenght // -> 2 - * // You can pass components directly - * otherModel.append(otherModel2); - * otherModel.append([otherModel3, otherModel4]); - */ - append: function append(components) { - var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + var hasSelection = window.getSelection ? function (te) { + try { return te.selectionStart != te.selectionEnd } + catch(e) { return false } + } : function (te) { + var range$$1; + try {range$$1 = te.ownerDocument.selection.createRange();} + catch(e) {} + if (!range$$1 || range$$1.parentElement() != te) { return false } + return range$$1.compareEndPoints("StartToEnd", range$$1) != 0 + }; + + var hasCopyEvent = (function () { + var e = elt("div"); + if ("oncopy" in e) { return true } + e.setAttribute("oncopy", "return;"); + return typeof e.oncopy == "function" + })(); + + var badZoomedRects = null; + function hasBadZoomedRects(measure) { + if (badZoomedRects != null) { return badZoomedRects } + var node = removeChildrenAndAdd(measure, elt("span", "x")); + var normal = node.getBoundingClientRect(); + var fromRange = range(node, 0, 1).getBoundingClientRect(); + return badZoomedRects = Math.abs(normal.left - fromRange.left) > 1 + } + + // Known modes, by name and by MIME + var modes = {}, mimeModes = {}; + + // Extra arguments are stored as the mode's dependencies, which is + // used by (legacy) mechanisms like loadmode.js to automatically + // load a mode. (Preferred mechanism is the require/define calls.) + function defineMode(name, mode) { + if (arguments.length > 2) + { mode.dependencies = Array.prototype.slice.call(arguments, 2); } + modes[name] = mode; + } + + function defineMIME(mime, spec) { + mimeModes[mime] = spec; + } + + // Given a MIME type, a {name, ...options} config object, or a name + // string, return a mode config object. + function resolveMode(spec) { + if (typeof spec == "string" && mimeModes.hasOwnProperty(spec)) { + spec = mimeModes[spec]; + } else if (spec && typeof spec.name == "string" && mimeModes.hasOwnProperty(spec.name)) { + var found = mimeModes[spec.name]; + if (typeof found == "string") { found = {name: found}; } + spec = createObj(found, spec); + spec.name = found.name; + } else if (typeof spec == "string" && /^[\w\-]+\/[\w\-]+\+xml$/.test(spec)) { + return resolveMode("application/xml") + } else if (typeof spec == "string" && /^[\w\-]+\/[\w\-]+\+json$/.test(spec)) { + return resolveMode("application/json") + } + if (typeof spec == "string") { return {name: spec} } + else { return spec || {name: "null"} } + } + + // Given a mode spec (anything that resolveMode accepts), find and + // initialize an actual mode object. + function getMode(options, spec) { + spec = resolveMode(spec); + var mfactory = modes[spec.name]; + if (!mfactory) { return getMode(options, "text/plain") } + var modeObj = mfactory(options, spec); + if (modeExtensions.hasOwnProperty(spec.name)) { + var exts = modeExtensions[spec.name]; + for (var prop in exts) { + if (!exts.hasOwnProperty(prop)) { continue } + if (modeObj.hasOwnProperty(prop)) { modeObj["_" + prop] = modeObj[prop]; } + modeObj[prop] = exts[prop]; + } + } + modeObj.name = spec.name; + if (spec.helperType) { modeObj.helperType = spec.helperType; } + if (spec.modeProps) { for (var prop$1 in spec.modeProps) + { modeObj[prop$1] = spec.modeProps[prop$1]; } } + + return modeObj + } + + // This can be used to attach properties to mode objects from + // outside the actual mode definition. + var modeExtensions = {}; + function extendMode(mode, properties) { + var exts = modeExtensions.hasOwnProperty(mode) ? modeExtensions[mode] : (modeExtensions[mode] = {}); + copyObj(properties, exts); + } + + function copyState(mode, state) { + if (state === true) { return state } + if (mode.copyState) { return mode.copyState(state) } + var nstate = {}; + for (var n in state) { + var val = state[n]; + if (val instanceof Array) { val = val.concat([]); } + nstate[n] = val; + } + return nstate + } + + // Given a mode and a state (for that mode), find the inner mode and + // state at the position that the state refers to. + function innerMode(mode, state) { + var info; + while (mode.innerMode) { + info = mode.innerMode(state); + if (!info || info.mode == mode) { break } + state = info.state; + mode = info.mode; + } + return info || {mode: mode, state: state} + } + + function startState(mode, a1, a2) { + return mode.startState ? mode.startState(a1, a2) : true + } + + // STRING STREAM + + // Fed to the mode parsers, provides helper functions to make + // parsers more succinct. + + var StringStream = function(string, tabSize, lineOracle) { + this.pos = this.start = 0; + this.string = string; + this.tabSize = tabSize || 8; + this.lastColumnPos = this.lastColumnValue = 0; + this.lineStart = 0; + this.lineOracle = lineOracle; + }; + + StringStream.prototype.eol = function () {return this.pos >= this.string.length}; + StringStream.prototype.sol = function () {return this.pos == this.lineStart}; + StringStream.prototype.peek = function () {return this.string.charAt(this.pos) || undefined}; + StringStream.prototype.next = function () { + if (this.pos < this.string.length) + { return this.string.charAt(this.pos++) } + }; + StringStream.prototype.eat = function (match) { + var ch = this.string.charAt(this.pos); + var ok; + if (typeof match == "string") { ok = ch == match; } + else { ok = ch && (match.test ? match.test(ch) : match(ch)); } + if (ok) {++this.pos; return ch} + }; + StringStream.prototype.eatWhile = function (match) { + var start = this.pos; + while (this.eat(match)){} + return this.pos > start + }; + StringStream.prototype.eatSpace = function () { + var this$1 = this; - var result = this.components().add(components, opts); - return (0, _underscore.isArray)(result) ? result : [result]; - }, + var start = this.pos; + while (/[\s\u00a0]/.test(this.string.charAt(this.pos))) { ++this$1.pos; } + return this.pos > start + }; + StringStream.prototype.skipToEnd = function () {this.pos = this.string.length;}; + StringStream.prototype.skipTo = function (ch) { + var found = this.string.indexOf(ch, this.pos); + if (found > -1) {this.pos = found; return true} + }; + StringStream.prototype.backUp = function (n) {this.pos -= n;}; + StringStream.prototype.column = function () { + if (this.lastColumnPos < this.start) { + this.lastColumnValue = countColumn(this.string, this.start, this.tabSize, this.lastColumnPos, this.lastColumnValue); + this.lastColumnPos = this.start; + } + return this.lastColumnValue - (this.lineStart ? countColumn(this.string, this.lineStart, this.tabSize) : 0) + }; + StringStream.prototype.indentation = function () { + return countColumn(this.string, null, this.tabSize) - + (this.lineStart ? countColumn(this.string, this.lineStart, this.tabSize) : 0) + }; + StringStream.prototype.match = function (pattern, consume, caseInsensitive) { + if (typeof pattern == "string") { + var cased = function (str) { return caseInsensitive ? str.toLowerCase() : str; }; + var substr = this.string.substr(this.pos, pattern.length); + if (cased(substr) == cased(pattern)) { + if (consume !== false) { this.pos += pattern.length; } + return true + } + } else { + var match = this.string.slice(this.pos).match(pattern); + if (match && match.index > 0) { return null } + if (match && consume !== false) { this.pos += match[0].length; } + return match + } + }; + StringStream.prototype.current = function (){return this.string.slice(this.start, this.pos)}; + StringStream.prototype.hideFirstChars = function (n, inner) { + this.lineStart += n; + try { return inner() } + finally { this.lineStart -= n; } + }; + StringStream.prototype.lookAhead = function (n) { + var oracle = this.lineOracle; + return oracle && oracle.lookAhead(n) + }; + StringStream.prototype.baseToken = function () { + var oracle = this.lineOracle; + return oracle && oracle.baseToken(this.pos) + }; + + // Find the line object corresponding to the given line number. + function getLine(doc, n) { + n -= doc.first; + if (n < 0 || n >= doc.size) { throw new Error("There is no line " + (n + doc.first) + " in the document.") } + var chunk = doc; + while (!chunk.lines) { + for (var i = 0;; ++i) { + var child = chunk.children[i], sz = child.chunkSize(); + if (n < sz) { chunk = child; break } + n -= sz; + } + } + return chunk.lines[n] + } + + // Get the part of a document between two positions, as an array of + // strings. + function getBetween(doc, start, end) { + var out = [], n = start.line; + doc.iter(start.line, end.line + 1, function (line) { + var text = line.text; + if (n == end.line) { text = text.slice(0, end.ch); } + if (n == start.line) { text = text.slice(start.ch); } + out.push(text); + ++n; + }); + return out + } + // Get the lines between from and to, as array of strings. + function getLines(doc, from, to) { + var out = []; + doc.iter(from, to, function (line) { out.push(line.text); }); // iter aborts when callback returns truthy value + return out + } + // Update the height of a line, propagating the height change + // upwards to parent nodes. + function updateLineHeight(line, height) { + var diff = height - line.height; + if (diff) { for (var n = line; n; n = n.parent) { n.height += diff; } } + } - /** - * Set new collection if `components` are provided, otherwise the - * current collection is returned - * @param {Component|string} [components] Components to set - * @return {Collection|undefined} - * @example - * // Get current collection - * const collection = model.components(); - * // Set new collection - * model.components('
'); - */ - components: function components(_components) { - var coll = this.get('components'); + // Given a line object, find its line number by walking up through + // its parent links. + function lineNo(line) { + if (line.parent == null) { return null } + var cur = line.parent, no = indexOf(cur.lines, line); + for (var chunk = cur.parent; chunk; cur = chunk, chunk = chunk.parent) { + for (var i = 0;; ++i) { + if (chunk.children[i] == cur) { break } + no += chunk.children[i].chunkSize(); + } + } + return no + cur.first + } - if ((0, _underscore.isUndefined)(_components)) { - return coll; - } else { - coll.reset(); - _components && this.append(_components); + // Find the line at the given vertical position, using the height + // information in the document tree. + function lineAtHeight(chunk, h) { + var n = chunk.first; + outer: do { + for (var i$1 = 0; i$1 < chunk.children.length; ++i$1) { + var child = chunk.children[i$1], ch = child.height; + if (h < ch) { chunk = child; continue outer } + h -= ch; + n += child.chunkSize(); + } + return n + } while (!chunk.lines) + var i = 0; + for (; i < chunk.lines.length; ++i) { + var line = chunk.lines[i], lh = line.height; + if (h < lh) { break } + h -= lh; } - }, + return n + i + } + function isLine(doc, l) {return l >= doc.first && l < doc.first + doc.size} - /** - * Get parent model - * @return {Component} - */ - parent: function parent() { - var coll = this.collection; - return coll && coll.parent; - }, + function lineNumberFor(options, i) { + return String(options.lineNumberFormatter(i + options.firstLineNumber)) + } + // A Pos instance represents a position within the text. + function Pos(line, ch, sticky) { + if ( sticky === void 0 ) sticky = null; - /** - * Script updated - */ - scriptUpdated: function scriptUpdated() { - this.set('scriptUpdated', 1); - }, + if (!(this instanceof Pos)) { return new Pos(line, ch, sticky) } + this.line = line; + this.ch = ch; + this.sticky = sticky; + } + // Compare two positions, return 0 if they are the same, a negative + // number when a is less, and a positive number otherwise. + function cmp(a, b) { return a.line - b.line || a.ch - b.ch } - /** - * Once traits are updated I have to populates model's attributes - */ - traitsUpdated: function traitsUpdated() { - var found = 0; - var attrs = _extends({}, this.get('attributes')); - var traits = this.get('traits'); + function equalCursorPos(a, b) { return a.sticky == b.sticky && cmp(a, b) == 0 } - if (!(traits instanceof Traits)) { - this.loadTraits(); - return; - } + function copyPos(x) {return Pos(x.line, x.ch)} + function maxPos(a, b) { return cmp(a, b) < 0 ? b : a } + function minPos(a, b) { return cmp(a, b) < 0 ? a : b } - traits.each(function (trait) { - found = 1; - if (!trait.get('changeProp')) { - var value = trait.getInitValue(); - if (value) { - attrs[trait.get('name')] = value; + // Most of the external API clips given positions to make sure they + // actually exist within the document. + function clipLine(doc, n) {return Math.max(doc.first, Math.min(n, doc.first + doc.size - 1))} + function clipPos(doc, pos) { + if (pos.line < doc.first) { return Pos(doc.first, 0) } + var last = doc.first + doc.size - 1; + if (pos.line > last) { return Pos(last, getLine(doc, last).text.length) } + return clipToLen(pos, getLine(doc, pos.line).text.length) + } + function clipToLen(pos, linelen) { + var ch = pos.ch; + if (ch == null || ch > linelen) { return Pos(pos.line, linelen) } + else if (ch < 0) { return Pos(pos.line, 0) } + else { return pos } + } + function clipPosArray(doc, array) { + var out = []; + for (var i = 0; i < array.length; i++) { out[i] = clipPos(doc, array[i]); } + return out + } + + var SavedContext = function(state, lookAhead) { + this.state = state; + this.lookAhead = lookAhead; + }; + + var Context = function(doc, state, line, lookAhead) { + this.state = state; + this.doc = doc; + this.line = line; + this.maxLookAhead = lookAhead || 0; + this.baseTokens = null; + this.baseTokenPos = 1; + }; + + Context.prototype.lookAhead = function (n) { + var line = this.doc.getLine(this.line + n); + if (line != null && n > this.maxLookAhead) { this.maxLookAhead = n; } + return line + }; + + Context.prototype.baseToken = function (n) { + var this$1 = this; + + if (!this.baseTokens) { return null } + while (this.baseTokens[this.baseTokenPos] <= n) + { this$1.baseTokenPos += 2; } + var type = this.baseTokens[this.baseTokenPos + 1]; + return {type: type && type.replace(/( |^)overlay .*/, ""), + size: this.baseTokens[this.baseTokenPos] - n} + }; + + Context.prototype.nextLine = function () { + this.line++; + if (this.maxLookAhead > 0) { this.maxLookAhead--; } + }; + + Context.fromSaved = function (doc, saved, line) { + if (saved instanceof SavedContext) + { return new Context(doc, copyState(doc.mode, saved.state), line, saved.lookAhead) } + else + { return new Context(doc, copyState(doc.mode, saved), line) } + }; + + Context.prototype.save = function (copy) { + var state = copy !== false ? copyState(this.doc.mode, this.state) : this.state; + return this.maxLookAhead > 0 ? new SavedContext(state, this.maxLookAhead) : state + }; + + + // Compute a style array (an array starting with a mode generation + // -- for invalidation -- followed by pairs of end positions and + // style strings), which is used to highlight the tokens on the + // line. + function highlightLine(cm, line, context, forceToEnd) { + // A styles array always starts with a number identifying the + // mode/overlays that it is based on (for easy invalidation). + var st = [cm.state.modeGen], lineClasses = {}; + // Compute the base array of styles + runMode(cm, line.text, cm.doc.mode, context, function (end, style) { return st.push(end, style); }, + lineClasses, forceToEnd); + var state = context.state; + + // Run overlays, adjust style array. + var loop = function ( o ) { + context.baseTokens = st; + var overlay = cm.state.overlays[o], i = 1, at = 0; + context.state = true; + runMode(cm, line.text, overlay.mode, context, function (end, style) { + var start = i; + // Ensure there's a token end at the current position, and that i points at it + while (at < end) { + var i_end = st[i]; + if (i_end > end) + { st.splice(i, 1, end, st[i+1], i_end); } + i += 2; + at = Math.min(end, i_end); + } + if (!style) { return } + if (overlay.opaque) { + st.splice(start, i - start, end, "overlay " + style); + i = start + 2; + } else { + for (; start < i; start += 2) { + var cur = st[start+1]; + st[start+1] = (cur ? cur + " " : "") + "overlay " + style; + } } - } - }); + }, lineClasses); + context.state = state; + context.baseTokens = null; + context.baseTokenPos = 1; + }; - found && this.set('attributes', attrs); - }, + for (var o = 0; o < cm.state.overlays.length; ++o) loop( o ); + return {styles: st, classes: lineClasses.bgClass || lineClasses.textClass ? lineClasses : null} + } - /** - * Init toolbar - */ - initToolbar: function initToolbar() { - var model = this; - if (!model.get('toolbar')) { - var tb = []; - if (model.collection) { - tb.push({ - attributes: { class: 'fa fa-arrow-up' }, - command: 'select-parent' - }); - } - if (model.get('draggable')) { - tb.push({ - attributes: { class: 'fa fa-arrows' }, - command: 'tlb-move' - }); - } - if (model.get('copyable')) { - tb.push({ - attributes: { class: 'fa fa-clone' }, - command: 'tlb-clone' - }); - } - if (model.get('removable')) { - tb.push({ - attributes: { class: 'fa fa-trash-o' }, - command: 'tlb-delete' - }); + function getLineStyles(cm, line, updateFrontier) { + if (!line.styles || line.styles[0] != cm.state.modeGen) { + var context = getContextBefore(cm, lineNo(line)); + var resetState = line.text.length > cm.options.maxHighlightLength && copyState(cm.doc.mode, context.state); + var result = highlightLine(cm, line, context); + if (resetState) { context.state = resetState; } + line.stateAfter = context.save(!resetState); + line.styles = result.styles; + if (result.classes) { line.styleClasses = result.classes; } + else if (line.styleClasses) { line.styleClasses = null; } + if (updateFrontier === cm.doc.highlightFrontier) + { cm.doc.modeFrontier = Math.max(cm.doc.modeFrontier, ++cm.doc.highlightFrontier); } + } + return line.styles + } + + function getContextBefore(cm, n, precise) { + var doc = cm.doc, display = cm.display; + if (!doc.mode.startState) { return new Context(doc, true, n) } + var start = findStartLine(cm, n, precise); + var saved = start > doc.first && getLine(doc, start - 1).stateAfter; + var context = saved ? Context.fromSaved(doc, saved, start) : new Context(doc, startState(doc.mode), start); + + doc.iter(start, n, function (line) { + processLine(cm, line.text, context); + var pos = context.line; + line.stateAfter = pos == n - 1 || pos % 5 == 0 || pos >= display.viewFrom && pos < display.viewTo ? context.save() : null; + context.nextLine(); + }); + if (precise) { doc.modeFrontier = context.line; } + return context + } + + // Lightweight form of highlight -- proceed over this line and + // update state, but don't save a style array. Used for lines that + // aren't currently visible. + function processLine(cm, text, context, startAt) { + var mode = cm.doc.mode; + var stream = new StringStream(text, cm.options.tabSize, context); + stream.start = stream.pos = startAt || 0; + if (text == "") { callBlankLine(mode, context.state); } + while (!stream.eol()) { + readToken(mode, stream, context.state); + stream.start = stream.pos; + } + } + + function callBlankLine(mode, state) { + if (mode.blankLine) { return mode.blankLine(state) } + if (!mode.innerMode) { return } + var inner = innerMode(mode, state); + if (inner.mode.blankLine) { return inner.mode.blankLine(inner.state) } + } + + function readToken(mode, stream, state, inner) { + for (var i = 0; i < 10; i++) { + if (inner) { inner[0] = innerMode(mode, state).mode; } + var style = mode.token(stream, state); + if (stream.pos > stream.start) { return style } + } + throw new Error("Mode " + mode.name + " failed to advance stream.") + } + + var Token = function(stream, type, state) { + this.start = stream.start; this.end = stream.pos; + this.string = stream.current(); + this.type = type || null; + this.state = state; + }; + + // Utility for getTokenAt and getLineTokens + function takeToken(cm, pos, precise, asArray) { + var doc = cm.doc, mode = doc.mode, style; + pos = clipPos(doc, pos); + var line = getLine(doc, pos.line), context = getContextBefore(cm, pos.line, precise); + var stream = new StringStream(line.text, cm.options.tabSize, context), tokens; + if (asArray) { tokens = []; } + while ((asArray || stream.pos < pos.ch) && !stream.eol()) { + stream.start = stream.pos; + style = readToken(mode, stream, context.state); + if (asArray) { tokens.push(new Token(stream, style, copyState(doc.mode, context.state))); } + } + return asArray ? tokens : new Token(stream, style, context.state) + } + + function extractLineClasses(type, output) { + if (type) { for (;;) { + var lineClass = type.match(/(?:^|\s+)line-(background-)?(\S+)/); + if (!lineClass) { break } + type = type.slice(0, lineClass.index) + type.slice(lineClass.index + lineClass[0].length); + var prop = lineClass[1] ? "bgClass" : "textClass"; + if (output[prop] == null) + { output[prop] = lineClass[2]; } + else if (!(new RegExp("(?:^|\s)" + lineClass[2] + "(?:$|\s)")).test(output[prop])) + { output[prop] += " " + lineClass[2]; } + } } + return type + } + + // Run the given mode's parser over a line, calling f for each token. + function runMode(cm, text, mode, context, f, lineClasses, forceToEnd) { + var flattenSpans = mode.flattenSpans; + if (flattenSpans == null) { flattenSpans = cm.options.flattenSpans; } + var curStart = 0, curStyle = null; + var stream = new StringStream(text, cm.options.tabSize, context), style; + var inner = cm.options.addModeClass && [null]; + if (text == "") { extractLineClasses(callBlankLine(mode, context.state), lineClasses); } + while (!stream.eol()) { + if (stream.pos > cm.options.maxHighlightLength) { + flattenSpans = false; + if (forceToEnd) { processLine(cm, text, context, stream.pos); } + stream.pos = text.length; + style = null; + } else { + style = extractLineClasses(readToken(mode, stream, context.state, inner), lineClasses); + } + if (inner) { + var mName = inner[0].name; + if (mName) { style = "m-" + (style ? mName + " " + style : mName); } + } + if (!flattenSpans || curStyle != style) { + while (curStart < stream.start) { + curStart = Math.min(stream.start, curStart + 5000); + f(curStart, curStyle); + } + curStyle = style; + } + stream.start = stream.pos; + } + while (curStart < stream.pos) { + // Webkit seems to refuse to render text nodes longer than 57444 + // characters, and returns inaccurate measurements in nodes + // starting around 5000 chars. + var pos = Math.min(stream.pos, curStart + 5000); + f(pos, curStyle); + curStart = pos; + } + } + + // Finds the line to start with when starting a parse. Tries to + // find a line with a stateAfter, so that it can start with a + // valid state. If that fails, it returns the line with the + // smallest indentation, which tends to need the least context to + // parse correctly. + function findStartLine(cm, n, precise) { + var minindent, minline, doc = cm.doc; + var lim = precise ? -1 : n - (cm.doc.mode.innerMode ? 1000 : 100); + for (var search = n; search > lim; --search) { + if (search <= doc.first) { return doc.first } + var line = getLine(doc, search - 1), after = line.stateAfter; + if (after && (!precise || search + (after instanceof SavedContext ? after.lookAhead : 0) <= doc.modeFrontier)) + { return search } + var indented = countColumn(line.text, null, cm.options.tabSize); + if (minline == null || minindent > indented) { + minline = search - 1; + minindent = indented; + } + } + return minline + } + + function retreatFrontier(doc, n) { + doc.modeFrontier = Math.min(doc.modeFrontier, n); + if (doc.highlightFrontier < n - 10) { return } + var start = doc.first; + for (var line = n - 1; line > start; line--) { + var saved = getLine(doc, line).stateAfter; + // change is on 3 + // state on line 1 looked ahead 2 -- so saw 3 + // test 1 + 2 < 3 should cover this + if (saved && (!(saved instanceof SavedContext) || line + saved.lookAhead < n)) { + start = line + 1; + break } - model.set('toolbar', tb); } - }, + doc.highlightFrontier = Math.min(doc.highlightFrontier, start); + } + // Optimize some code when these features are not used. + var sawReadOnlySpans = false, sawCollapsedSpans = false; - /** - * Load traits - * @param {Array} traits - * @private - */ - loadTraits: function loadTraits(traits) { - var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + function seeReadOnlySpans() { + sawReadOnlySpans = true; + } - var trt = new Traits([], this.opt); - trt.setTarget(this); - traits = traits || this.get('traits'); + function seeCollapsedSpans() { + sawCollapsedSpans = true; + } - if (traits.length) { - trt.add(traits); - } + // TEXTMARKER SPANS - this.set('traits', trt, opts); - return this; - }, + function MarkedSpan(marker, from, to) { + this.marker = marker; + this.from = from; this.to = to; + } + // Search an array of spans for a span matching the given marker. + function getMarkedSpanFor(spans, marker) { + if (spans) { for (var i = 0; i < spans.length; ++i) { + var span = spans[i]; + if (span.marker == marker) { return span } + } } + } + // Remove a span from an array, returning undefined if no spans are + // left (we don't store arrays for lines without spans). + function removeMarkedSpan(spans, span) { + var r; + for (var i = 0; i < spans.length; ++i) + { if (spans[i] != span) { (r || (r = [])).push(spans[i]); } } + return r + } + // Add a span to a line. + function addMarkedSpan(line, span) { + line.markedSpans = line.markedSpans ? line.markedSpans.concat([span]) : [span]; + span.marker.attachLine(line); + } + + // Used for the algorithm that adjusts markers for a change in the + // document. These functions cut an array of spans at a given + // character position, returning an array of remaining chunks (or + // undefined if nothing remains). + function markedSpansBefore(old, startCh, isInsert) { + var nw; + if (old) { for (var i = 0; i < old.length; ++i) { + var span = old[i], marker = span.marker; + var startsBefore = span.from == null || (marker.inclusiveLeft ? span.from <= startCh : span.from < startCh); + if (startsBefore || span.from == startCh && marker.type == "bookmark" && (!isInsert || !span.marker.insertLeft)) { + var endsAfter = span.to == null || (marker.inclusiveRight ? span.to >= startCh : span.to > startCh) + ;(nw || (nw = [])).push(new MarkedSpan(marker, span.from, endsAfter ? null : span.to)); + } + } } + return nw + } + function markedSpansAfter(old, endCh, isInsert) { + var nw; + if (old) { for (var i = 0; i < old.length; ++i) { + var span = old[i], marker = span.marker; + var endsAfter = span.to == null || (marker.inclusiveRight ? span.to >= endCh : span.to > endCh); + if (endsAfter || span.from == endCh && marker.type == "bookmark" && (!isInsert || span.marker.insertLeft)) { + var startsBefore = span.from == null || (marker.inclusiveLeft ? span.from <= endCh : span.from < endCh) + ;(nw || (nw = [])).push(new MarkedSpan(marker, startsBefore ? null : span.from - endCh, + span.to == null ? null : span.to - endCh)); + } + } } + return nw + } + + // Given a change object, compute the new set of marker spans that + // cover the line in which the change took place. Removes spans + // entirely within the change, reconnects spans belonging to the + // same marker that appear on both sides of the change, and cuts off + // spans partially within the change. Returns an array of span + // arrays with one element for each line in (after) the change. + function stretchSpansOverChange(doc, change) { + if (change.full) { return null } + var oldFirst = isLine(doc, change.from.line) && getLine(doc, change.from.line).markedSpans; + var oldLast = isLine(doc, change.to.line) && getLine(doc, change.to.line).markedSpans; + if (!oldFirst && !oldLast) { return null } + + var startCh = change.from.ch, endCh = change.to.ch, isInsert = cmp(change.from, change.to) == 0; + // Get the spans that 'stick out' on both sides + var first = markedSpansBefore(oldFirst, startCh, isInsert); + var last = markedSpansAfter(oldLast, endCh, isInsert); + + // Next, merge those two ends + var sameLine = change.text.length == 1, offset = lst(change.text).length + (sameLine ? startCh : 0); + if (first) { + // Fix up .to properties of first + for (var i = 0; i < first.length; ++i) { + var span = first[i]; + if (span.to == null) { + var found = getMarkedSpanFor(last, span.marker); + if (!found) { span.to = startCh; } + else if (sameLine) { span.to = found.to == null ? null : found.to + offset; } + } + } + } + if (last) { + // Fix up .from in last (or move them into first in case of sameLine) + for (var i$1 = 0; i$1 < last.length; ++i$1) { + var span$1 = last[i$1]; + if (span$1.to != null) { span$1.to += offset; } + if (span$1.from == null) { + var found$1 = getMarkedSpanFor(first, span$1.marker); + if (!found$1) { + span$1.from = offset; + if (sameLine) { (first || (first = [])).push(span$1); } + } + } else { + span$1.from += offset; + if (sameLine) { (first || (first = [])).push(span$1); } + } + } + } + // Make sure we didn't create any zero-length spans + if (first) { first = clearEmptySpans(first); } + if (last && last != first) { last = clearEmptySpans(last); } - /** - * Normalize input classes from array to array of objects - * @param {Array} arr - * @return {Array} - * @private - */ - normalizeClasses: function normalizeClasses(arr) { - var res = []; + var newMarkers = [first]; + if (!sameLine) { + // Fill gap with whole-line-spans + var gap = change.text.length - 2, gapMarkers; + if (gap > 0 && first) + { for (var i$2 = 0; i$2 < first.length; ++i$2) + { if (first[i$2].to == null) + { (gapMarkers || (gapMarkers = [])).push(new MarkedSpan(first[i$2].marker, null, null)); } } } + for (var i$3 = 0; i$3 < gap; ++i$3) + { newMarkers.push(gapMarkers); } + newMarkers.push(last); + } + return newMarkers + } - if (!this.sm.get) return; + // Remove spans that are empty and don't have a clearWhenEmpty + // option of false. + function clearEmptySpans(spans) { + for (var i = 0; i < spans.length; ++i) { + var span = spans[i]; + if (span.from != null && span.from == span.to && span.marker.clearWhenEmpty !== false) + { spans.splice(i--, 1); } + } + if (!spans.length) { return null } + return spans + } - var clm = this.sm.get('SelectorManager'); - if (!clm) return; + // Used to 'clip' out readOnly ranges when making a change. + function removeReadOnlyRanges(doc, from, to) { + var markers = null; + doc.iter(from.line, to.line + 1, function (line) { + if (line.markedSpans) { for (var i = 0; i < line.markedSpans.length; ++i) { + var mark = line.markedSpans[i].marker; + if (mark.readOnly && (!markers || indexOf(markers, mark) == -1)) + { (markers || (markers = [])).push(mark); } + } } + }); + if (!markers) { return null } + var parts = [{from: from, to: to}]; + for (var i = 0; i < markers.length; ++i) { + var mk = markers[i], m = mk.find(0); + for (var j = 0; j < parts.length; ++j) { + var p = parts[j]; + if (cmp(p.to, m.from) < 0 || cmp(p.from, m.to) > 0) { continue } + var newParts = [j, 1], dfrom = cmp(p.from, m.from), dto = cmp(p.to, m.to); + if (dfrom < 0 || !mk.inclusiveLeft && !dfrom) + { newParts.push({from: p.from, to: m.from}); } + if (dto > 0 || !mk.inclusiveRight && !dto) + { newParts.push({from: m.to, to: p.to}); } + parts.splice.apply(parts, newParts); + j += newParts.length - 3; + } + } + return parts + } - arr.forEach(function (val) { - var name = ''; + // Connect or disconnect spans from a line. + function detachMarkedSpans(line) { + var spans = line.markedSpans; + if (!spans) { return } + for (var i = 0; i < spans.length; ++i) + { spans[i].marker.detachLine(line); } + line.markedSpans = null; + } + function attachMarkedSpans(line, spans) { + if (!spans) { return } + for (var i = 0; i < spans.length; ++i) + { spans[i].marker.attachLine(line); } + line.markedSpans = spans; + } + + // Helpers used when computing which overlapping collapsed span + // counts as the larger one. + function extraLeft(marker) { return marker.inclusiveLeft ? -1 : 0 } + function extraRight(marker) { return marker.inclusiveRight ? 1 : 0 } + + // Returns a number indicating which of two overlapping collapsed + // spans is larger (and thus includes the other). Falls back to + // comparing ids when the spans cover exactly the same range. + function compareCollapsedMarkers(a, b) { + var lenDiff = a.lines.length - b.lines.length; + if (lenDiff != 0) { return lenDiff } + var aPos = a.find(), bPos = b.find(); + var fromCmp = cmp(aPos.from, bPos.from) || extraLeft(a) - extraLeft(b); + if (fromCmp) { return -fromCmp } + var toCmp = cmp(aPos.to, bPos.to) || extraRight(a) - extraRight(b); + if (toCmp) { return toCmp } + return b.id - a.id + } + + // Find out whether a line ends or starts in a collapsed span. If + // so, return the marker for that span. + function collapsedSpanAtSide(line, start) { + var sps = sawCollapsedSpans && line.markedSpans, found; + if (sps) { for (var sp = (void 0), i = 0; i < sps.length; ++i) { + sp = sps[i]; + if (sp.marker.collapsed && (start ? sp.from : sp.to) == null && + (!found || compareCollapsedMarkers(found, sp.marker) < 0)) + { found = sp.marker; } + } } + return found + } + function collapsedSpanAtStart(line) { return collapsedSpanAtSide(line, true) } + function collapsedSpanAtEnd(line) { return collapsedSpanAtSide(line, false) } - if (typeof val === 'string') name = val;else name = val.name; + function collapsedSpanAround(line, ch) { + var sps = sawCollapsedSpans && line.markedSpans, found; + if (sps) { for (var i = 0; i < sps.length; ++i) { + var sp = sps[i]; + if (sp.marker.collapsed && (sp.from == null || sp.from < ch) && (sp.to == null || sp.to > ch) && + (!found || compareCollapsedMarkers(found, sp.marker) < 0)) { found = sp.marker; } + } } + return found + } - var model = clm.add(name); - res.push(model); + // Test whether there exists a collapsed span that partially + // overlaps (covers the start or end, but not both) of a new span. + // Such overlap is not allowed. + function conflictingCollapsedRange(doc, lineNo$$1, from, to, marker) { + var line = getLine(doc, lineNo$$1); + var sps = sawCollapsedSpans && line.markedSpans; + if (sps) { for (var i = 0; i < sps.length; ++i) { + var sp = sps[i]; + if (!sp.marker.collapsed) { continue } + var found = sp.marker.find(0); + var fromCmp = cmp(found.from, from) || extraLeft(sp.marker) - extraLeft(marker); + var toCmp = cmp(found.to, to) || extraRight(sp.marker) - extraRight(marker); + if (fromCmp >= 0 && toCmp <= 0 || fromCmp <= 0 && toCmp >= 0) { continue } + if (fromCmp <= 0 && (sp.marker.inclusiveRight && marker.inclusiveLeft ? cmp(found.to, from) >= 0 : cmp(found.to, from) > 0) || + fromCmp >= 0 && (sp.marker.inclusiveRight && marker.inclusiveLeft ? cmp(found.from, to) <= 0 : cmp(found.from, to) < 0)) + { return true } + } } + } + + // A visual line is a line as drawn on the screen. Folding, for + // example, can cause multiple logical lines to appear on the same + // visual line. This finds the start of the visual line that the + // given line is part of (usually that is the line itself). + function visualLine(line) { + var merged; + while (merged = collapsedSpanAtStart(line)) + { line = merged.find(-1, true).line; } + return line + } + + function visualLineEnd(line) { + var merged; + while (merged = collapsedSpanAtEnd(line)) + { line = merged.find(1, true).line; } + return line + } + + // Returns an array of logical lines that continue the visual line + // started by the argument, or undefined if there are no such lines. + function visualLineContinued(line) { + var merged, lines; + while (merged = collapsedSpanAtEnd(line)) { + line = merged.find(1, true).line + ;(lines || (lines = [])).push(line); + } + return lines + } + + // Get the line number of the start of the visual line that the + // given line number is part of. + function visualLineNo(doc, lineN) { + var line = getLine(doc, lineN), vis = visualLine(line); + if (line == vis) { return lineN } + return lineNo(vis) + } + + // Get the line number of the start of the next visual line after + // the given line. + function visualLineEndNo(doc, lineN) { + if (lineN > doc.lastLine()) { return lineN } + var line = getLine(doc, lineN), merged; + if (!lineIsHidden(doc, line)) { return lineN } + while (merged = collapsedSpanAtEnd(line)) + { line = merged.find(1, true).line; } + return lineNo(line) + 1 + } + + // Compute whether a line is hidden. Lines count as hidden when they + // are part of a visual line that starts with another line, or when + // they are entirely covered by collapsed, non-widget span. + function lineIsHidden(doc, line) { + var sps = sawCollapsedSpans && line.markedSpans; + if (sps) { for (var sp = (void 0), i = 0; i < sps.length; ++i) { + sp = sps[i]; + if (!sp.marker.collapsed) { continue } + if (sp.from == null) { return true } + if (sp.marker.widgetNode) { continue } + if (sp.from == 0 && sp.marker.inclusiveLeft && lineIsHiddenInner(doc, line, sp)) + { return true } + } } + } + function lineIsHiddenInner(doc, line, span) { + if (span.to == null) { + var end = span.marker.find(1, true); + return lineIsHiddenInner(doc, end.line, getMarkedSpanFor(end.line.markedSpans, span.marker)) + } + if (span.marker.inclusiveRight && span.to == line.text.length) + { return true } + for (var sp = (void 0), i = 0; i < line.markedSpans.length; ++i) { + sp = line.markedSpans[i]; + if (sp.marker.collapsed && !sp.marker.widgetNode && sp.from == span.to && + (sp.to == null || sp.to != span.from) && + (sp.marker.inclusiveLeft || span.marker.inclusiveRight) && + lineIsHiddenInner(doc, line, sp)) { return true } + } + } + + // Find the height above the given line. + function heightAtLine(lineObj) { + lineObj = visualLine(lineObj); + + var h = 0, chunk = lineObj.parent; + for (var i = 0; i < chunk.lines.length; ++i) { + var line = chunk.lines[i]; + if (line == lineObj) { break } + else { h += line.height; } + } + for (var p = chunk.parent; p; chunk = p, p = chunk.parent) { + for (var i$1 = 0; i$1 < p.children.length; ++i$1) { + var cur = p.children[i$1]; + if (cur == chunk) { break } + else { h += cur.height; } + } + } + return h + } + + // Compute the character length of a line, taking into account + // collapsed ranges (see markText) that might hide parts, and join + // other lines onto it. + function lineLength(line) { + if (line.height == 0) { return 0 } + var len = line.text.length, merged, cur = line; + while (merged = collapsedSpanAtStart(cur)) { + var found = merged.find(0, true); + cur = found.from.line; + len += found.from.ch - found.to.ch; + } + cur = line; + while (merged = collapsedSpanAtEnd(cur)) { + var found$1 = merged.find(0, true); + len -= cur.text.length - found$1.from.ch; + cur = found$1.to.line; + len += cur.text.length - found$1.to.ch; + } + return len + } + + // Find the longest line in the document. + function findMaxLine(cm) { + var d = cm.display, doc = cm.doc; + d.maxLine = getLine(doc, doc.first); + d.maxLineLength = lineLength(d.maxLine); + d.maxLineChanged = true; + doc.iter(function (line) { + var len = lineLength(line); + if (len > d.maxLineLength) { + d.maxLineLength = len; + d.maxLine = line; + } }); - return res; - }, + } + // LINE DATA STRUCTURE - /** - * Override original clone method - * @private - */ - clone: function clone(reset) { - var em = this.em; - var style = this.getStyle(); - var attr = _extends({}, this.attributes); - attr.attributes = _extends({}, attr.attributes); - delete attr.attributes.id; - attr.components = []; - attr.classes = []; - attr.traits = []; + // Line objects. These hold state related to a line, including + // highlighting info (the styles array). + var Line = function(text, markedSpans, estimateHeight) { + this.text = text; + attachMarkedSpans(this, markedSpans); + this.height = estimateHeight ? estimateHeight(this) : 1; + }; - this.get('components').each(function (md, i) { - attr.components[i] = md.clone(1); - }); - this.get('traits').each(function (md, i) { - attr.traits[i] = md.clone(); - }); - this.get('classes').each(function (md, i) { - attr.classes[i] = md.get('name'); - }); + Line.prototype.lineNo = function () { return lineNo(this) }; + eventMixin(Line); - attr.status = ''; - attr.view = ''; + // Change the content (text, markers) of a line. Automatically + // invalidates cached information and tries to re-estimate the + // line's height. + function updateLine(line, text, markedSpans, estimateHeight) { + line.text = text; + if (line.stateAfter) { line.stateAfter = null; } + if (line.styles) { line.styles = null; } + if (line.order != null) { line.order = null; } + detachMarkedSpans(line); + attachMarkedSpans(line, markedSpans); + var estHeight = estimateHeight ? estimateHeight(line) : 1; + if (estHeight != line.height) { updateLineHeight(line, estHeight); } + } - if (reset) { - this.opt.collection = null; + // Detach a line from the document tree and its markers. + function cleanUpLine(line) { + line.parent = null; + detachMarkedSpans(line); + } + + // Convert a style as returned by a mode (either null, or a string + // containing one or more styles) to a CSS style. This is cached, + // and also looks for line-wide styles. + var styleToClassCache = {}, styleToClassCacheWithMode = {}; + function interpretTokenStyle(style, options) { + if (!style || /^\s*$/.test(style)) { return null } + var cache = options.addModeClass ? styleToClassCacheWithMode : styleToClassCache; + return cache[style] || + (cache[style] = style.replace(/\S+/g, "cm-$&")) + } + + // Render the DOM representation of the text of a line. Also builds + // up a 'line map', which points at the DOM nodes that represent + // specific stretches of text, and is used by the measuring code. + // The returned object contains the DOM node, this map, and + // information about line-wide styles that were set by the mode. + function buildLineContent(cm, lineView) { + // The padding-right forces the element to have a 'border', which + // is needed on Webkit to be able to get line-level bounding + // rectangles for it (in measureChar). + var content = eltP("span", null, null, webkit ? "padding-right: .1px" : null); + var builder = {pre: eltP("pre", [content], "CodeMirror-line"), content: content, + col: 0, pos: 0, cm: cm, + trailingSpace: false, + splitSpaces: cm.getOption("lineWrapping")}; + lineView.measure = {}; + + // Iterate over the logical lines that make up this visual line. + for (var i = 0; i <= (lineView.rest ? lineView.rest.length : 0); i++) { + var line = i ? lineView.rest[i - 1] : lineView.line, order = (void 0); + builder.pos = 0; + builder.addToken = buildToken; + // Optionally wire in some hacks into the token-rendering + // algorithm, to deal with browser quirks. + if (hasBadBidiRects(cm.display.measure) && (order = getOrder(line, cm.doc.direction))) + { builder.addToken = buildTokenBadBidi(builder.addToken, order); } + builder.map = []; + var allowFrontierUpdate = lineView != cm.display.externalMeasured && lineNo(line); + insertLineContent(line, builder, getLineStyles(cm, line, allowFrontierUpdate)); + if (line.styleClasses) { + if (line.styleClasses.bgClass) + { builder.bgClass = joinClasses(line.styleClasses.bgClass, builder.bgClass || ""); } + if (line.styleClasses.textClass) + { builder.textClass = joinClasses(line.styleClasses.textClass, builder.textClass || ""); } + } + + // Ensure at least a single node is present, for measuring. + if (builder.map.length == 0) + { builder.map.push(0, 0, builder.content.appendChild(zeroWidthElement(cm.display.measure))); } + + // Store the map and a cache object for the current logical line + if (i == 0) { + lineView.measure.map = builder.map; + lineView.measure.cache = {}; + } else { + (lineView.measure.maps || (lineView.measure.maps = [])).push(builder.map) + ;(lineView.measure.caches || (lineView.measure.caches = [])).push({}); + } } - if (em && em.getConfig('avoidInlineStyle') && !(0, _underscore.isEmpty)(style)) { - attr.style = style; + // See issue #2901 + if (webkit) { + var last = builder.content.lastChild; + if (/\bcm-tab\b/.test(last.className) || (last.querySelector && last.querySelector(".cm-tab"))) + { builder.content.className = "cm-tab-wrap-hack"; } } - return new this.constructor(attr, this.opt); - }, + signal(cm, "renderLine", cm, lineView.line, builder.pre); + if (builder.pre.className) + { builder.textClass = joinClasses(builder.pre.className, builder.textClass || ""); } + return builder + } - /** - * Get the name of the component - * @return {string} - * */ - getName: function getName() { - var customName = this.get('name') || this.get('custom-name'); - var tag = this.get('tagName'); - tag = tag == 'div' ? 'box' : tag; - var name = this.get('type') || tag; - name = name.charAt(0).toUpperCase() + name.slice(1); - return customName || name; - }, + function defaultSpecialCharPlaceholder(ch) { + var token = elt("span", "\u2022", "cm-invalidchar"); + token.title = "\\u" + ch.charCodeAt(0).toString(16); + token.setAttribute("aria-label", token.title); + return token + } + // Build up the DOM representation for a single token, and add it to + // the line map. Takes care to render special characters separately. + function buildToken(builder, text, style, startStyle, endStyle, css, attributes) { + if (!text) { return } + var displayText = builder.splitSpaces ? splitSpaces(text, builder.trailingSpace) : text; + var special = builder.cm.state.specialChars, mustWrap = false; + var content; + if (!special.test(text)) { + builder.col += text.length; + content = document.createTextNode(displayText); + builder.map.push(builder.pos, builder.pos + text.length, content); + if (ie && ie_version < 9) { mustWrap = true; } + builder.pos += text.length; + } else { + content = document.createDocumentFragment(); + var pos = 0; + while (true) { + special.lastIndex = pos; + var m = special.exec(text); + var skipped = m ? m.index - pos : text.length - pos; + if (skipped) { + var txt = document.createTextNode(displayText.slice(pos, pos + skipped)); + if (ie && ie_version < 9) { content.appendChild(elt("span", [txt])); } + else { content.appendChild(txt); } + builder.map.push(builder.pos, builder.pos + skipped, txt); + builder.col += skipped; + builder.pos += skipped; + } + if (!m) { break } + pos += skipped + 1; + var txt$1 = (void 0); + if (m[0] == "\t") { + var tabSize = builder.cm.options.tabSize, tabWidth = tabSize - builder.col % tabSize; + txt$1 = content.appendChild(elt("span", spaceStr(tabWidth), "cm-tab")); + txt$1.setAttribute("role", "presentation"); + txt$1.setAttribute("cm-text", "\t"); + builder.col += tabWidth; + } else if (m[0] == "\r" || m[0] == "\n") { + txt$1 = content.appendChild(elt("span", m[0] == "\r" ? "\u240d" : "\u2424", "cm-invalidchar")); + txt$1.setAttribute("cm-text", m[0]); + builder.col += 1; + } else { + txt$1 = builder.cm.options.specialCharPlaceholder(m[0]); + txt$1.setAttribute("cm-text", m[0]); + if (ie && ie_version < 9) { content.appendChild(elt("span", [txt$1])); } + else { content.appendChild(txt$1); } + builder.col += 1; + } + builder.map.push(builder.pos, builder.pos + 1, txt$1); + builder.pos++; + } + } + builder.trailingSpace = displayText.charCodeAt(text.length - 1) == 32; + if (style || startStyle || endStyle || mustWrap || css) { + var fullStyle = style || ""; + if (startStyle) { fullStyle += startStyle; } + if (endStyle) { fullStyle += endStyle; } + var token = elt("span", [content], fullStyle, css); + if (attributes) { + for (var attr in attributes) { if (attributes.hasOwnProperty(attr) && attr != "style" && attr != "class") + { token.setAttribute(attr, attributes[attr]); } } + } + return builder.content.appendChild(token) + } + builder.content.appendChild(content); + } + + // Change some spaces to NBSP to prevent the browser from collapsing + // trailing spaces at the end of a line when rendering text (issue #1362). + function splitSpaces(text, trailingBefore) { + if (text.length > 1 && !/ /.test(text)) { return text } + var spaceBefore = trailingBefore, result = ""; + for (var i = 0; i < text.length; i++) { + var ch = text.charAt(i); + if (ch == " " && spaceBefore && (i == text.length - 1 || text.charCodeAt(i + 1) == 32)) + { ch = "\u00a0"; } + result += ch; + spaceBefore = ch == " "; + } + return result + } - /** - * Get the icon string - * @return {string} - */ - getIcon: function getIcon() { - var icon = this.get('icon'); - return icon ? icon + ' ' : ''; - }, + // Work around nonsense dimensions being reported for stretches of + // right-to-left text. + function buildTokenBadBidi(inner, order) { + return function (builder, text, style, startStyle, endStyle, css, attributes) { + style = style ? style + " cm-force-border" : "cm-force-border"; + var start = builder.pos, end = start + text.length; + for (;;) { + // Find the part that overlaps with the start of this text + var part = (void 0); + for (var i = 0; i < order.length; i++) { + part = order[i]; + if (part.to > start && part.from <= start) { break } + } + if (part.to >= end) { return inner(builder, text, style, startStyle, endStyle, css, attributes) } + inner(builder, text.slice(0, part.to - start), style, startStyle, null, css, attributes); + startStyle = null; + text = text.slice(part.to - start); + start = part.to; + } + } + } + function buildCollapsedSpan(builder, size, marker, ignoreWidget) { + var widget = !ignoreWidget && marker.widgetNode; + if (widget) { builder.map.push(builder.pos, builder.pos + size, widget); } + if (!ignoreWidget && builder.cm.display.input.needsContentAttribute) { + if (!widget) + { widget = builder.content.appendChild(document.createElement("span")); } + widget.setAttribute("cm-marker", marker.id); + } + if (widget) { + builder.cm.display.input.setUneditable(widget); + builder.content.appendChild(widget); + } + builder.pos += size; + builder.trailingSpace = false; + } - /** - * Return HTML string of the component - * @param {Object} opts Options - * @return {string} HTML string - * @private - */ - toHTML: function toHTML(opts) { - var model = this; - var attrs = []; - var classes = []; - var tag = model.get('tagName'); - var sTag = model.get('void'); - var attributes = this.getAttrToHTML(); + // Outputs a number of spans to make up a line, taking highlighting + // and marked text into account. + function insertLineContent(line, builder, styles) { + var spans = line.markedSpans, allText = line.text, at = 0; + if (!spans) { + for (var i$1 = 1; i$1 < styles.length; i$1+=2) + { builder.addToken(builder, allText.slice(at, at = styles[i$1]), interpretTokenStyle(styles[i$1+1], builder.cm.options)); } + return + } - for (var attr in attributes) { - var value = attributes[attr]; + var len = allText.length, pos = 0, i = 1, text = "", style, css; + var nextChange = 0, spanStyle, spanEndStyle, spanStartStyle, collapsed, attributes; + for (;;) { + if (nextChange == pos) { // Update current marker set + spanStyle = spanEndStyle = spanStartStyle = css = ""; + attributes = null; + collapsed = null; nextChange = Infinity; + var foundBookmarks = [], endStyles = (void 0); + for (var j = 0; j < spans.length; ++j) { + var sp = spans[j], m = sp.marker; + if (m.type == "bookmark" && sp.from == pos && m.widgetNode) { + foundBookmarks.push(m); + } else if (sp.from <= pos && (sp.to == null || sp.to > pos || m.collapsed && sp.to == pos && sp.from == pos)) { + if (sp.to != null && sp.to != pos && nextChange > sp.to) { + nextChange = sp.to; + spanEndStyle = ""; + } + if (m.className) { spanStyle += " " + m.className; } + if (m.css) { css = (css ? css + ";" : "") + m.css; } + if (m.startStyle && sp.from == pos) { spanStartStyle += " " + m.startStyle; } + if (m.endStyle && sp.to == nextChange) { (endStyles || (endStyles = [])).push(m.endStyle, sp.to); } + // support for the old title property + // https://github.com/codemirror/CodeMirror/pull/5673 + if (m.title) { (attributes || (attributes = {})).title = m.title; } + if (m.attributes) { + for (var attr in m.attributes) + { (attributes || (attributes = {}))[attr] = m.attributes[attr]; } + } + if (m.collapsed && (!collapsed || compareCollapsedMarkers(collapsed.marker, m) < 0)) + { collapsed = sp; } + } else if (sp.from > pos && nextChange > sp.from) { + nextChange = sp.from; + } + } + if (endStyles) { for (var j$1 = 0; j$1 < endStyles.length; j$1 += 2) + { if (endStyles[j$1 + 1] == nextChange) { spanEndStyle += " " + endStyles[j$1]; } } } - if (!(0, _underscore.isUndefined)(value)) { - attrs.push(attr + '="' + value + '"'); + if (!collapsed || collapsed.from == pos) { for (var j$2 = 0; j$2 < foundBookmarks.length; ++j$2) + { buildCollapsedSpan(builder, 0, foundBookmarks[j$2]); } } + if (collapsed && (collapsed.from || 0) == pos) { + buildCollapsedSpan(builder, (collapsed.to == null ? len + 1 : collapsed.to) - pos, + collapsed.marker, collapsed.from == null); + if (collapsed.to == null) { return } + if (collapsed.to == pos) { collapsed = false; } + } } - } + if (pos >= len) { break } - var attrString = attrs.length ? ' ' + attrs.join(' ') : ''; - var code = '<' + tag + attrString + (sTag ? '/' : '') + '>' + model.get('content'); - model.get('components').each(function (comp) { - return code += comp.toHTML(); - }); - !sTag && (code += ''); + var upto = Math.min(len, nextChange); + while (true) { + if (text) { + var end = pos + text.length; + if (!collapsed) { + var tokenText = end > upto ? text.slice(0, upto - pos) : text; + builder.addToken(builder, tokenText, style ? style + spanStyle : spanStyle, + spanStartStyle, pos + tokenText.length == nextChange ? spanEndStyle : "", css, attributes); + } + if (end >= upto) {text = text.slice(upto - pos); pos = upto; break} + pos = end; + spanStartStyle = ""; + } + text = allText.slice(at, at = styles[i++]); + style = interpretTokenStyle(styles[i++], builder.cm.options); + } + } + } - return code; - }, + // These objects are used to represent the visible (currently drawn) + // part of the document. A LineView may correspond to multiple + // logical lines, if those are connected by collapsed ranges. + function LineView(doc, line, lineN) { + // The starting line + this.line = line; + // Continuing lines, if any + this.rest = visualLineContinued(line); + // Number of logical lines in this visual line + this.size = this.rest ? lineNo(lst(this.rest)) - lineN + 1 : 1; + this.node = this.text = null; + this.hidden = lineIsHidden(doc, line); + } - /** - * Returns object of attributes for HTML - * @return {Object} - * @private - */ - getAttrToHTML: function getAttrToHTML() { - var attr = this.getAttributes(); - delete attr.style; - return attr; - }, + // Create a range of LineView objects for the given lines. + function buildViewArray(cm, from, to) { + var array = [], nextPos; + for (var pos = from; pos < to; pos = nextPos) { + var view = new LineView(cm.doc, getLine(cm.doc, pos), pos); + nextPos = pos + view.size; + array.push(view); + } + return array + } + var operationGroup = null; - /** - * Return a shallow copy of the model's attributes for JSON - * stringification. - * @return {Object} - * @private - */ - toJSON: function toJSON() { - for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) { - args[_key] = arguments[_key]; + function pushOperation(op) { + if (operationGroup) { + operationGroup.ops.push(op); + } else { + op.ownsGroup = operationGroup = { + ops: [op], + delayedCallbacks: [] + }; } + } - var obj = Backbone.Model.prototype.toJSON.apply(this, args); - var scriptStr = this.getScriptString(); - delete obj.toolbar; + function fireCallbacksForOps(group) { + // Calls delayed callbacks and cursorActivity handlers until no + // new ones appear + var callbacks = group.delayedCallbacks, i = 0; + do { + for (; i < callbacks.length; i++) + { callbacks[i].call(null); } + for (var j = 0; j < group.ops.length; j++) { + var op = group.ops[j]; + if (op.cursorActivityHandlers) + { while (op.cursorActivityCalled < op.cursorActivityHandlers.length) + { op.cursorActivityHandlers[op.cursorActivityCalled++].call(null, op.cm); } } + } + } while (i < callbacks.length) + } + + function finishOperation(op, endCb) { + var group = op.ownsGroup; + if (!group) { return } + + try { fireCallbacksForOps(group); } + finally { + operationGroup = null; + endCb(group); + } + } + + var orphanDelayedCallbacks = null; + + // Often, we want to signal events at a point where we are in the + // middle of some work, but don't want the handler to start calling + // other methods on the editor, which might be in an inconsistent + // state or simply not expect any other events to happen. + // signalLater looks whether there are any handlers, and schedules + // them to be executed when the last operation ends, or, if no + // operation is active, when a timeout fires. + function signalLater(emitter, type /*, values...*/) { + var arr = getHandlers(emitter, type); + if (!arr.length) { return } + var args = Array.prototype.slice.call(arguments, 2), list; + if (operationGroup) { + list = operationGroup.delayedCallbacks; + } else if (orphanDelayedCallbacks) { + list = orphanDelayedCallbacks; + } else { + list = orphanDelayedCallbacks = []; + setTimeout(fireOrphanDelayed, 0); + } + var loop = function ( i ) { + list.push(function () { return arr[i].apply(null, args); }); + }; - if (scriptStr) { - obj.script = scriptStr; + for (var i = 0; i < arr.length; ++i) + loop( i ); + } + + function fireOrphanDelayed() { + var delayed = orphanDelayedCallbacks; + orphanDelayedCallbacks = null; + for (var i = 0; i < delayed.length; ++i) { delayed[i](); } + } + + // When an aspect of a line changes, a string is added to + // lineView.changes. This updates the relevant part of the line's + // DOM structure. + function updateLineForChanges(cm, lineView, lineN, dims) { + for (var j = 0; j < lineView.changes.length; j++) { + var type = lineView.changes[j]; + if (type == "text") { updateLineText(cm, lineView); } + else if (type == "gutter") { updateLineGutter(cm, lineView, lineN, dims); } + else if (type == "class") { updateLineClasses(cm, lineView); } + else if (type == "widget") { updateLineWidgets(cm, lineView, dims); } + } + lineView.changes = null; + } + + // Lines with gutter elements, widgets or a background class need to + // be wrapped, and have the extra elements added to the wrapper div + function ensureLineWrapped(lineView) { + if (lineView.node == lineView.text) { + lineView.node = elt("div", null, null, "position: relative"); + if (lineView.text.parentNode) + { lineView.text.parentNode.replaceChild(lineView.node, lineView.text); } + lineView.node.appendChild(lineView.text); + if (ie && ie_version < 8) { lineView.node.style.zIndex = 2; } + } + return lineView.node + } + + function updateLineBackground(cm, lineView) { + var cls = lineView.bgClass ? lineView.bgClass + " " + (lineView.line.bgClass || "") : lineView.line.bgClass; + if (cls) { cls += " CodeMirror-linebackground"; } + if (lineView.background) { + if (cls) { lineView.background.className = cls; } + else { lineView.background.parentNode.removeChild(lineView.background); lineView.background = null; } + } else if (cls) { + var wrap = ensureLineWrapped(lineView); + lineView.background = wrap.insertBefore(elt("div", null, cls), wrap.firstChild); + cm.display.input.setUneditable(lineView.background); + } + } + + // Wrapper around buildLineContent which will reuse the structure + // in display.externalMeasured when possible. + function getLineContent(cm, lineView) { + var ext = cm.display.externalMeasured; + if (ext && ext.line == lineView.line) { + cm.display.externalMeasured = null; + lineView.measure = ext.measure; + return ext.built + } + return buildLineContent(cm, lineView) + } + + // Redraw the line's text. Interacts with the background and text + // classes because the mode may output tokens that influence these + // classes. + function updateLineText(cm, lineView) { + var cls = lineView.text.className; + var built = getLineContent(cm, lineView); + if (lineView.text == lineView.node) { lineView.node = built.pre; } + lineView.text.parentNode.replaceChild(built.pre, lineView.text); + lineView.text = built.pre; + if (built.bgClass != lineView.bgClass || built.textClass != lineView.textClass) { + lineView.bgClass = built.bgClass; + lineView.textClass = built.textClass; + updateLineClasses(cm, lineView); + } else if (cls) { + lineView.text.className = cls; + } + } + + function updateLineClasses(cm, lineView) { + updateLineBackground(cm, lineView); + if (lineView.line.wrapClass) + { ensureLineWrapped(lineView).className = lineView.line.wrapClass; } + else if (lineView.node != lineView.text) + { lineView.node.className = ""; } + var textClass = lineView.textClass ? lineView.textClass + " " + (lineView.line.textClass || "") : lineView.line.textClass; + lineView.text.className = textClass || ""; + } + + function updateLineGutter(cm, lineView, lineN, dims) { + if (lineView.gutter) { + lineView.node.removeChild(lineView.gutter); + lineView.gutter = null; + } + if (lineView.gutterBackground) { + lineView.node.removeChild(lineView.gutterBackground); + lineView.gutterBackground = null; + } + if (lineView.line.gutterClass) { + var wrap = ensureLineWrapped(lineView); + lineView.gutterBackground = elt("div", null, "CodeMirror-gutter-background " + lineView.line.gutterClass, + ("left: " + (cm.options.fixedGutter ? dims.fixedPos : -dims.gutterTotalWidth) + "px; width: " + (dims.gutterTotalWidth) + "px")); + cm.display.input.setUneditable(lineView.gutterBackground); + wrap.insertBefore(lineView.gutterBackground, lineView.text); + } + var markers = lineView.line.gutterMarkers; + if (cm.options.lineNumbers || markers) { + var wrap$1 = ensureLineWrapped(lineView); + var gutterWrap = lineView.gutter = elt("div", null, "CodeMirror-gutter-wrapper", ("left: " + (cm.options.fixedGutter ? dims.fixedPos : -dims.gutterTotalWidth) + "px")); + cm.display.input.setUneditable(gutterWrap); + wrap$1.insertBefore(gutterWrap, lineView.text); + if (lineView.line.gutterClass) + { gutterWrap.className += " " + lineView.line.gutterClass; } + if (cm.options.lineNumbers && (!markers || !markers["CodeMirror-linenumbers"])) + { lineView.lineNumber = gutterWrap.appendChild( + elt("div", lineNumberFor(cm.options, lineN), + "CodeMirror-linenumber CodeMirror-gutter-elt", + ("left: " + (dims.gutterLeft["CodeMirror-linenumbers"]) + "px; width: " + (cm.display.lineNumInnerWidth) + "px"))); } + if (markers) { for (var k = 0; k < cm.display.gutterSpecs.length; ++k) { + var id = cm.display.gutterSpecs[k].className, found = markers.hasOwnProperty(id) && markers[id]; + if (found) + { gutterWrap.appendChild(elt("div", [found], "CodeMirror-gutter-elt", + ("left: " + (dims.gutterLeft[id]) + "px; width: " + (dims.gutterWidth[id]) + "px"))); } + } } } + } - return obj; - }, + function updateLineWidgets(cm, lineView, dims) { + if (lineView.alignable) { lineView.alignable = null; } + for (var node = lineView.node.firstChild, next = (void 0); node; node = next) { + next = node.nextSibling; + if (node.className == "CodeMirror-linewidget") + { lineView.node.removeChild(node); } + } + insertLineWidgets(cm, lineView, dims); + } + // Build a line's DOM representation from scratch + function buildLineElement(cm, lineView, lineN, dims) { + var built = getLineContent(cm, lineView); + lineView.text = lineView.node = built.pre; + if (built.bgClass) { lineView.bgClass = built.bgClass; } + if (built.textClass) { lineView.textClass = built.textClass; } - /** - * Return model id - * @return {string} - */ - getId: function getId() { - var attrs = this.get('attributes') || {}; - return attrs.id || this.cid; - }, + updateLineClasses(cm, lineView); + updateLineGutter(cm, lineView, lineN, dims); + insertLineWidgets(cm, lineView, dims); + return lineView.node + } + // A lineView may contain multiple logical lines (when merged by + // collapsed spans). The widgets for all of them need to be drawn. + function insertLineWidgets(cm, lineView, dims) { + insertLineWidgetsFor(cm, lineView.line, lineView, dims, true); + if (lineView.rest) { for (var i = 0; i < lineView.rest.length; i++) + { insertLineWidgetsFor(cm, lineView.rest[i], lineView, dims, false); } } + } - /** - * Return script in string format, cleans 'function() {..' from scripts - * if it's a function - * @param {string|Function} script - * @return {string} - * @private - */ - getScriptString: function getScriptString(script) { - var _this4 = this; + function insertLineWidgetsFor(cm, line, lineView, dims, allowAbove) { + if (!line.widgets) { return } + var wrap = ensureLineWrapped(lineView); + for (var i = 0, ws = line.widgets; i < ws.length; ++i) { + var widget = ws[i], node = elt("div", [widget.node], "CodeMirror-linewidget"); + if (!widget.handleMouseEvents) { node.setAttribute("cm-ignore-events", "true"); } + positionLineWidget(widget, node, lineView, dims); + cm.display.input.setUneditable(node); + if (allowAbove && widget.above) + { wrap.insertBefore(node, lineView.gutter || lineView.text); } + else + { wrap.appendChild(node); } + signalLater(widget, "redraw"); + } + } - var scr = script || this.get('script'); + function positionLineWidget(widget, node, lineView, dims) { + if (widget.noHScroll) { + (lineView.alignable || (lineView.alignable = [])).push(node); + var width = dims.wrapperWidth; + node.style.left = dims.fixedPos + "px"; + if (!widget.coverGutter) { + width -= dims.gutterTotalWidth; + node.style.paddingLeft = dims.gutterTotalWidth + "px"; + } + node.style.width = width + "px"; + } + if (widget.coverGutter) { + node.style.zIndex = 5; + node.style.position = "relative"; + if (!widget.noHScroll) { node.style.marginLeft = -dims.gutterTotalWidth + "px"; } + } + } - if (!scr) { - return scr; + function widgetHeight(widget) { + if (widget.height != null) { return widget.height } + var cm = widget.doc.cm; + if (!cm) { return 0 } + if (!contains(document.body, widget.node)) { + var parentStyle = "position: relative;"; + if (widget.coverGutter) + { parentStyle += "margin-left: -" + cm.display.gutters.offsetWidth + "px;"; } + if (widget.noHScroll) + { parentStyle += "width: " + cm.display.wrapper.clientWidth + "px;"; } + removeChildrenAndAdd(cm.display.measure, elt("div", [widget.node], null, parentStyle)); } - - // Need to convert script functions to strings - if (typeof scr == 'function') { - var scrStr = scr.toString().trim(); - scrStr = scrStr.replace(/^function[\s\w]*\(\)\s?\{/, '').replace(/\}$/, ''); - scr = scrStr.trim(); + return widget.height = widget.node.parentNode.offsetHeight + } + + // Return true when the given mouse event happened in a widget + function eventInWidget(display, e) { + for (var n = e_target(e); n != display.wrapper; n = n.parentNode) { + if (!n || (n.nodeType == 1 && n.getAttribute("cm-ignore-events") == "true") || + (n.parentNode == display.sizer && n != display.mover)) + { return true } + } + } + + // POSITION MEASUREMENT + + function paddingTop(display) {return display.lineSpace.offsetTop} + function paddingVert(display) {return display.mover.offsetHeight - display.lineSpace.offsetHeight} + function paddingH(display) { + if (display.cachedPaddingH) { return display.cachedPaddingH } + var e = removeChildrenAndAdd(display.measure, elt("pre", "x", "CodeMirror-line-like")); + var style = window.getComputedStyle ? window.getComputedStyle(e) : e.currentStyle; + var data = {left: parseInt(style.paddingLeft), right: parseInt(style.paddingRight)}; + if (!isNaN(data.left) && !isNaN(data.right)) { display.cachedPaddingH = data; } + return data + } + + function scrollGap(cm) { return scrollerGap - cm.display.nativeBarWidth } + function displayWidth(cm) { + return cm.display.scroller.clientWidth - scrollGap(cm) - cm.display.barWidth + } + function displayHeight(cm) { + return cm.display.scroller.clientHeight - scrollGap(cm) - cm.display.barHeight + } + + // Ensure the lineView.wrapping.heights array is populated. This is + // an array of bottom offsets for the lines that make up a drawn + // line. When lineWrapping is on, there might be more than one + // height. + function ensureLineHeights(cm, lineView, rect) { + var wrapping = cm.options.lineWrapping; + var curWidth = wrapping && displayWidth(cm); + if (!lineView.measure.heights || wrapping && lineView.measure.width != curWidth) { + var heights = lineView.measure.heights = []; + if (wrapping) { + lineView.measure.width = curWidth; + var rects = lineView.text.firstChild.getClientRects(); + for (var i = 0; i < rects.length - 1; i++) { + var cur = rects[i], next = rects[i + 1]; + if (Math.abs(cur.bottom - next.bottom) > 2) + { heights.push((cur.bottom + next.top) / 2 - rect.top); } + } + } + heights.push(rect.bottom - rect.top); + } + } + + // Find a line map (mapping character offsets to text nodes) and a + // measurement cache for the given line number. (A line view might + // contain multiple lines when collapsed ranges are present.) + function mapFromLineView(lineView, line, lineN) { + if (lineView.line == line) + { return {map: lineView.measure.map, cache: lineView.measure.cache} } + for (var i = 0; i < lineView.rest.length; i++) + { if (lineView.rest[i] == line) + { return {map: lineView.measure.maps[i], cache: lineView.measure.caches[i]} } } + for (var i$1 = 0; i$1 < lineView.rest.length; i$1++) + { if (lineNo(lineView.rest[i$1]) > lineN) + { return {map: lineView.measure.maps[i$1], cache: lineView.measure.caches[i$1], before: true} } } + } + + // Render a line into the hidden node display.externalMeasured. Used + // when measurement is needed for a line that's not in the viewport. + function updateExternalMeasurement(cm, line) { + line = visualLine(line); + var lineN = lineNo(line); + var view = cm.display.externalMeasured = new LineView(cm.doc, line, lineN); + view.lineN = lineN; + var built = view.built = buildLineContent(cm, view); + view.text = built.pre; + removeChildrenAndAdd(cm.display.lineMeasure, built.pre); + return view + } + + // Get a {top, bottom, left, right} box (in line-local coordinates) + // for a given character. + function measureChar(cm, line, ch, bias) { + return measureCharPrepared(cm, prepareMeasureForLine(cm, line), ch, bias) + } + + // Find a line view that corresponds to the given line number. + function findViewForLine(cm, lineN) { + if (lineN >= cm.display.viewFrom && lineN < cm.display.viewTo) + { return cm.display.view[findViewIndex(cm, lineN)] } + var ext = cm.display.externalMeasured; + if (ext && lineN >= ext.lineN && lineN < ext.lineN + ext.size) + { return ext } + } + + // Measurement can be split in two steps, the set-up work that + // applies to the whole line, and the measurement of the actual + // character. Functions like coordsChar, that need to do a lot of + // measurements in a row, can thus ensure that the set-up work is + // only done once. + function prepareMeasureForLine(cm, line) { + var lineN = lineNo(line); + var view = findViewForLine(cm, lineN); + if (view && !view.text) { + view = null; + } else if (view && view.changes) { + updateLineForChanges(cm, view, lineN, getDimensions(cm)); + cm.curOp.forceUpdate = true; } + if (!view) + { view = updateExternalMeasurement(cm, line); } - var config = this.sm.config || {}; - var tagVarStart = escapeRegExp(config.tagVarStart || '{[ '); - var tagVarEnd = escapeRegExp(config.tagVarEnd || ' ]}'); - var reg = new RegExp(tagVarStart + '([\\w\\d-]*)' + tagVarEnd, 'g'); - scr = scr.replace(reg, function (match, v) { - // If at least one match is found I have to track this change for a - // better optimization inside JS generator - _this4.scriptUpdated(); - return _this4.attributes[v] || ''; - }); - - return scr; - }, - emitUpdate: function emitUpdate(property) { - var em = this.em; - var event = 'component:update' + (property ? ':' + property : ''); - em && em.trigger(event, this.model); + var info = mapFromLineView(view, line, lineN); + return { + line: line, view: view, rect: null, + map: info.map, cache: info.cache, before: info.before, + hasHeights: false + } } -}, { - /** - * Detect if the passed element is a valid component. - * In case the element is valid an object abstracted - * from the element will be returned - * @param {HTMLElement} - * @return {Object} - * @private - */ - isComponent: function isComponent(el) { - return { tagName: el.tagName ? el.tagName.toLowerCase() : '' }; + // Given a prepared measurement object, measures the position of an + // actual character (or fetches it from the cache). + function measureCharPrepared(cm, prepared, ch, bias, varHeight) { + if (prepared.before) { ch = -1; } + var key = ch + (bias || ""), found; + if (prepared.cache.hasOwnProperty(key)) { + found = prepared.cache[key]; + } else { + if (!prepared.rect) + { prepared.rect = prepared.view.text.getBoundingClientRect(); } + if (!prepared.hasHeights) { + ensureLineHeights(cm, prepared.view, prepared.rect); + prepared.hasHeights = true; + } + found = measureCharInner(cm, prepared, ch, bias); + if (!found.bogus) { prepared.cache[key] = found; } + } + return {left: found.left, right: found.right, + top: varHeight ? found.rtop : found.top, + bottom: varHeight ? found.rbottom : found.bottom} + } + + var nullRect = {left: 0, right: 0, top: 0, bottom: 0}; + + function nodeAndOffsetInLineMap(map$$1, ch, bias) { + var node, start, end, collapse, mStart, mEnd; + // First, search the line map for the text node corresponding to, + // or closest to, the target character. + for (var i = 0; i < map$$1.length; i += 3) { + mStart = map$$1[i]; + mEnd = map$$1[i + 1]; + if (ch < mStart) { + start = 0; end = 1; + collapse = "left"; + } else if (ch < mEnd) { + start = ch - mStart; + end = start + 1; + } else if (i == map$$1.length - 3 || ch == mEnd && map$$1[i + 3] > ch) { + end = mEnd - mStart; + start = end - 1; + if (ch >= mEnd) { collapse = "right"; } + } + if (start != null) { + node = map$$1[i + 2]; + if (mStart == mEnd && bias == (node.insertLeft ? "left" : "right")) + { collapse = bias; } + if (bias == "left" && start == 0) + { while (i && map$$1[i - 2] == map$$1[i - 3] && map$$1[i - 1].insertLeft) { + node = map$$1[(i -= 3) + 2]; + collapse = "left"; + } } + if (bias == "right" && start == mEnd - mStart) + { while (i < map$$1.length - 3 && map$$1[i + 3] == map$$1[i + 4] && !map$$1[i + 5].insertLeft) { + node = map$$1[(i += 3) + 2]; + collapse = "right"; + } } + break + } + } + return {node: node, start: start, end: end, collapse: collapse, coverStart: mStart, coverEnd: mEnd} } -}); -/***/ }), -/* 5 */ -/***/ (function(module, exports, __webpack_require__) { + function getUsefulRect(rects, bias) { + var rect = nullRect; + if (bias == "left") { for (var i = 0; i < rects.length; i++) { + if ((rect = rects[i]).left != rect.right) { break } + } } else { for (var i$1 = rects.length - 1; i$1 >= 0; i$1--) { + if ((rect = rects[i$1]).left != rect.right) { break } + } } + return rect + } -"use strict"; -/* WEBPACK VAR INJECTION */(function(Backbone) { + function measureCharInner(cm, prepared, ch, bias) { + var place = nodeAndOffsetInLineMap(prepared.map, ch, bias); + var node = place.node, start = place.start, end = place.end, collapse = place.collapse; -var _underscore = __webpack_require__(1); + var rect; + if (node.nodeType == 3) { // If it is a text node, use a range to retrieve the coordinates. + for (var i$1 = 0; i$1 < 4; i$1++) { // Retry a maximum of 4 times when nonsense rectangles are returned + while (start && isExtendingChar(prepared.line.text.charAt(place.coverStart + start))) { --start; } + while (place.coverStart + end < place.coverEnd && isExtendingChar(prepared.line.text.charAt(place.coverStart + end))) { ++end; } + if (ie && ie_version < 9 && start == 0 && end == place.coverEnd - place.coverStart) + { rect = node.parentNode.getBoundingClientRect(); } + else + { rect = getUsefulRect(range(node, start, end).getClientRects(), bias); } + if (rect.left || rect.right || start == 0) { break } + end = start; + start = start - 1; + collapse = "right"; + } + if (ie && ie_version < 11) { rect = maybeUpdateRectForZooming(cm.display.measure, rect); } + } else { // If it is a widget, simply get the box for the whole widget. + if (start > 0) { collapse = bias = "right"; } + var rects; + if (cm.options.lineWrapping && (rects = node.getClientRects()).length > 1) + { rect = rects[bias == "right" ? rects.length - 1 : 0]; } + else + { rect = node.getBoundingClientRect(); } + } + if (ie && ie_version < 9 && !start && (!rect || !rect.left && !rect.right)) { + var rSpan = node.parentNode.getClientRects()[0]; + if (rSpan) + { rect = {left: rSpan.left, right: rSpan.left + charWidth(cm.display), top: rSpan.top, bottom: rSpan.bottom}; } + else + { rect = nullRect; } + } + + var rtop = rect.top - prepared.rect.top, rbot = rect.bottom - prepared.rect.top; + var mid = (rtop + rbot) / 2; + var heights = prepared.view.measure.heights; + var i = 0; + for (; i < heights.length - 1; i++) + { if (mid < heights[i]) { break } } + var top = i ? heights[i - 1] : 0, bot = heights[i]; + var result = {left: (collapse == "right" ? rect.right : rect.left) - prepared.rect.left, + right: (collapse == "left" ? rect.left : rect.right) - prepared.rect.left, + top: top, bottom: bot}; + if (!rect.left && !rect.right) { result.bogus = true; } + if (!cm.options.singleCursorHeightPerLine) { result.rtop = rtop; result.rbottom = rbot; } -var _mixins = __webpack_require__(2); + return result + } -function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; } + // Work around problem with bounding client rects on ranges being + // returned incorrectly when zoomed on IE10 and below. + function maybeUpdateRectForZooming(measure, rect) { + if (!window.screen || screen.logicalXDPI == null || + screen.logicalXDPI == screen.deviceXDPI || !hasBadZoomedRects(measure)) + { return rect } + var scaleX = screen.logicalXDPI / screen.deviceXDPI; + var scaleY = screen.logicalYDPI / screen.deviceYDPI; + return {left: rect.left * scaleX, right: rect.right * scaleX, + top: rect.top * scaleY, bottom: rect.bottom * scaleY} + } -var clearProp = 'data-clear-style'; + function clearLineMeasurementCacheFor(lineView) { + if (lineView.measure) { + lineView.measure.cache = {}; + lineView.measure.heights = null; + if (lineView.rest) { for (var i = 0; i < lineView.rest.length; i++) + { lineView.measure.caches[i] = {}; } } + } + } -module.exports = Backbone.View.extend({ - template: function template(model) { - var pfx = this.pfx; - return '\n
\n ' + this.templateLabel(model) + '\n
\n
\n ' + this.templateInput(model) + '\n
\n '; - }, - templateLabel: function templateLabel(model) { - var pfx = this.pfx; - var icon = model.get('icon'); - var info = model.get('info'); - return '\n \n ' + model.get('name') + '\n \n \n '; - }, - templateInput: function templateInput(model) { - return '\n
\n \n
\n '; - }, + function clearLineMeasurementCache(cm) { + cm.display.externalMeasure = null; + removeChildren(cm.display.lineMeasure); + for (var i = 0; i < cm.display.view.length; i++) + { clearLineMeasurementCacheFor(cm.display.view[i]); } + } + function clearCaches(cm) { + clearLineMeasurementCache(cm); + cm.display.cachedCharWidth = cm.display.cachedTextHeight = cm.display.cachedPaddingH = null; + if (!cm.options.lineWrapping) { cm.display.maxLineChanged = true; } + cm.display.lineNumChars = null; + } - events: _defineProperty({ - 'change': 'inputValueChanged' - }, 'click [' + clearProp + ']', 'clear'), + function pageScrollX() { + // Work around https://bugs.chromium.org/p/chromium/issues/detail?id=489206 + // which causes page_Offset and bounding client rects to use + // different reference viewports and invalidate our calculations. + if (chrome && android) { return -(document.body.getBoundingClientRect().left - parseInt(getComputedStyle(document.body).marginLeft)) } + return window.pageXOffset || (document.documentElement || document.body).scrollLeft + } + function pageScrollY() { + if (chrome && android) { return -(document.body.getBoundingClientRect().top - parseInt(getComputedStyle(document.body).marginTop)) } + return window.pageYOffset || (document.documentElement || document.body).scrollTop + } - initialize: function initialize() { - var o = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + function widgetTopHeight(lineObj) { + var height = 0; + if (lineObj.widgets) { for (var i = 0; i < lineObj.widgets.length; ++i) { if (lineObj.widgets[i].above) + { height += widgetHeight(lineObj.widgets[i]); } } } + return height + } + + // Converts a {top, bottom, left, right} box from line-local + // coordinates into another coordinate system. Context may be one of + // "line", "div" (display.lineDiv), "local"./null (editor), "window", + // or "page". + function intoCoordSystem(cm, lineObj, rect, context, includeWidgets) { + if (!includeWidgets) { + var height = widgetTopHeight(lineObj); + rect.top += height; rect.bottom += height; + } + if (context == "line") { return rect } + if (!context) { context = "local"; } + var yOff = heightAtLine(lineObj); + if (context == "local") { yOff += paddingTop(cm.display); } + else { yOff -= cm.display.viewOffset; } + if (context == "page" || context == "window") { + var lOff = cm.display.lineSpace.getBoundingClientRect(); + yOff += lOff.top + (context == "window" ? 0 : pageScrollY()); + var xOff = lOff.left + (context == "window" ? 0 : pageScrollX()); + rect.left += xOff; rect.right += xOff; + } + rect.top += yOff; rect.bottom += yOff; + return rect + } + + // Coverts a box from "div" coords to another coordinate system. + // Context may be "window", "page", "div", or "local"./null. + function fromCoordSystem(cm, coords, context) { + if (context == "div") { return coords } + var left = coords.left, top = coords.top; + // First move into "page" coordinate system + if (context == "page") { + left -= pageScrollX(); + top -= pageScrollY(); + } else if (context == "local" || !context) { + var localBox = cm.display.sizer.getBoundingClientRect(); + left += localBox.left; + top += localBox.top; + } + + var lineSpaceBox = cm.display.lineSpace.getBoundingClientRect(); + return {left: left - lineSpaceBox.left, top: top - lineSpaceBox.top} + } + + function charCoords(cm, pos, context, lineObj, bias) { + if (!lineObj) { lineObj = getLine(cm.doc, pos.line); } + return intoCoordSystem(cm, lineObj, measureChar(cm, lineObj, pos.ch, bias), context) + } + + // Returns a box for a given cursor position, which may have an + // 'other' property containing the position of the secondary cursor + // on a bidi boundary. + // A cursor Pos(line, char, "before") is on the same visual line as `char - 1` + // and after `char - 1` in writing order of `char - 1` + // A cursor Pos(line, char, "after") is on the same visual line as `char` + // and before `char` in writing order of `char` + // Examples (upper-case letters are RTL, lower-case are LTR): + // Pos(0, 1, ...) + // before after + // ab a|b a|b + // aB a|B aB| + // Ab |Ab A|b + // AB B|A B|A + // Every position after the last character on a line is considered to stick + // to the last character on the line. + function cursorCoords(cm, pos, context, lineObj, preparedMeasure, varHeight) { + lineObj = lineObj || getLine(cm.doc, pos.line); + if (!preparedMeasure) { preparedMeasure = prepareMeasureForLine(cm, lineObj); } + function get(ch, right) { + var m = measureCharPrepared(cm, preparedMeasure, ch, right ? "right" : "left", varHeight); + if (right) { m.left = m.right; } else { m.right = m.left; } + return intoCoordSystem(cm, lineObj, m, context) + } + var order = getOrder(lineObj, cm.doc.direction), ch = pos.ch, sticky = pos.sticky; + if (ch >= lineObj.text.length) { + ch = lineObj.text.length; + sticky = "before"; + } else if (ch <= 0) { + ch = 0; + sticky = "after"; + } + if (!order) { return get(sticky == "before" ? ch - 1 : ch, sticky == "before") } + + function getBidi(ch, partPos, invert) { + var part = order[partPos], right = part.level == 1; + return get(invert ? ch - 1 : ch, right != invert) + } + var partPos = getBidiPartAt(order, ch, sticky); + var other = bidiOther; + var val = getBidi(ch, partPos, sticky == "before"); + if (other != null) { val.other = getBidi(ch, other, sticky != "before"); } + return val + } + + // Used to cheaply estimate the coordinates for a position. Used for + // intermediate scroll updates. + function estimateCoords(cm, pos) { + var left = 0; + pos = clipPos(cm.doc, pos); + if (!cm.options.lineWrapping) { left = charWidth(cm.display) * pos.ch; } + var lineObj = getLine(cm.doc, pos.line); + var top = heightAtLine(lineObj) + paddingTop(cm.display); + return {left: left, right: left, top: top, bottom: top + lineObj.height} + } + + // Positions returned by coordsChar contain some extra information. + // xRel is the relative x position of the input coordinates compared + // to the found position (so xRel > 0 means the coordinates are to + // the right of the character position, for example). When outside + // is true, that means the coordinates lie outside the line's + // vertical range. + function PosWithInfo(line, ch, sticky, outside, xRel) { + var pos = Pos(line, ch, sticky); + pos.xRel = xRel; + if (outside) { pos.outside = outside; } + return pos + } - (0, _underscore.bindAll)(this, 'targetUpdated'); - this.config = o.config || {}; - var em = this.config.em; - this.em = em; - this.pfx = this.config.stylePrefix || ''; - this.ppfx = this.config.pStylePrefix || ''; - this.target = o.target || {}; - this.propTarget = o.propTarget || {}; - this.onChange = o.onChange; - this.onInputRender = o.onInputRender || {}; - this.customValue = o.customValue || {}; - var model = this.model; - this.property = model.get('property'); - this.input = null; - var pfx = this.pfx; - this.inputHolderId = '#' + pfx + 'input-holder'; - this.sector = model.collection && model.collection.sector; - model.view = this; + // Compute the character position closest to the given coordinates. + // Input must be lineSpace-local ("div" coordinate system). + function coordsChar(cm, x, y) { + var doc = cm.doc; + y += cm.display.viewOffset; + if (y < 0) { return PosWithInfo(doc.first, 0, null, -1, -1) } + var lineN = lineAtHeight(doc, y), last = doc.first + doc.size - 1; + if (lineN > last) + { return PosWithInfo(doc.first + doc.size - 1, getLine(doc, last).text.length, null, 1, 1) } + if (x < 0) { x = 0; } - if (!model.get('value')) { - model.set('value', model.getDefaultValue()); + var lineObj = getLine(doc, lineN); + for (;;) { + var found = coordsCharInner(cm, lineObj, lineN, x, y); + var collapsed = collapsedSpanAround(lineObj, found.ch + (found.xRel > 0 || found.outside > 0 ? 1 : 0)); + if (!collapsed) { return found } + var rangeEnd = collapsed.find(1); + if (rangeEnd.line == lineN) { return rangeEnd } + lineObj = getLine(doc, lineN = rangeEnd.line); } + } - em && em.on('update:component:style:' + this.property, this.targetUpdated); - this.listenTo(this.propTarget, 'update', this.targetUpdated); - this.listenTo(model, 'destroy remove', this.remove); - this.listenTo(model, 'change:value', this.modelValueChanged); - this.listenTo(model, 'targetUpdated', this.targetUpdated); - this.listenTo(model, 'change:visible', this.updateVisibility); - this.listenTo(model, 'change:status', this.updateStatus); + function wrappedLineExtent(cm, lineObj, preparedMeasure, y) { + y -= widgetTopHeight(lineObj); + var end = lineObj.text.length; + var begin = findFirst(function (ch) { return measureCharPrepared(cm, preparedMeasure, ch - 1).bottom <= y; }, end, 0); + end = findFirst(function (ch) { return measureCharPrepared(cm, preparedMeasure, ch).top > y; }, begin, end); + return {begin: begin, end: end} + } - var init = this.init && this.init.bind(this); - init && init(); - }, + function wrappedLineExtentChar(cm, lineObj, preparedMeasure, target) { + if (!preparedMeasure) { preparedMeasure = prepareMeasureForLine(cm, lineObj); } + var targetTop = intoCoordSystem(cm, lineObj, measureCharPrepared(cm, preparedMeasure, target), "line").top; + return wrappedLineExtent(cm, lineObj, preparedMeasure, targetTop) + } + // Returns true if the given side of a box is after the given + // coordinates, in top-to-bottom, left-to-right order. + function boxIsAfter(box, x, y, left) { + return box.bottom <= y ? false : box.top > y ? true : (left ? box.left : box.right) > x + } - /** - * Triggers when the status changes. The status indicates if the value of - * the proprerty is changed or inherited - * @private - */ - updateStatus: function updateStatus() { - var status = this.model.get('status'); - var pfx = this.pfx; - var ppfx = this.ppfx; - var config = this.config; - var updatedCls = ppfx + 'four-color'; - var computedCls = ppfx + 'color-warn'; - var labelEl = this.$el.children('.' + pfx + 'label'); - var clearStyle = this.getClearEl().style; - labelEl.removeClass(updatedCls + ' ' + computedCls); - clearStyle.display = 'none'; + function coordsCharInner(cm, lineObj, lineNo$$1, x, y) { + // Move y into line-local coordinate space + y -= heightAtLine(lineObj); + var preparedMeasure = prepareMeasureForLine(cm, lineObj); + // When directly calling `measureCharPrepared`, we have to adjust + // for the widgets at this line. + var widgetHeight$$1 = widgetTopHeight(lineObj); + var begin = 0, end = lineObj.text.length, ltr = true; - switch (status) { - case 'updated': - labelEl.addClass(updatedCls); + var order = getOrder(lineObj, cm.doc.direction); + // If the line isn't plain left-to-right text, first figure out + // which bidi section the coordinates fall into. + if (order) { + var part = (cm.options.lineWrapping ? coordsBidiPartWrapped : coordsBidiPart) + (cm, lineObj, lineNo$$1, preparedMeasure, order, x, y); + ltr = part.level != 1; + // The awkward -1 offsets are needed because findFirst (called + // on these below) will treat its first bound as inclusive, + // second as exclusive, but we want to actually address the + // characters in the part's range + begin = ltr ? part.from : part.to - 1; + end = ltr ? part.to : part.from - 1; + } + + // A binary search to find the first character whose bounding box + // starts after the coordinates. If we run across any whose box wrap + // the coordinates, store that. + var chAround = null, boxAround = null; + var ch = findFirst(function (ch) { + var box = measureCharPrepared(cm, preparedMeasure, ch); + box.top += widgetHeight$$1; box.bottom += widgetHeight$$1; + if (!boxIsAfter(box, x, y, false)) { return false } + if (box.top <= y && box.left <= x) { + chAround = ch; + boxAround = box; + } + return true + }, begin, end); + + var baseX, sticky, outside = false; + // If a box around the coordinates was found, use that + if (boxAround) { + // Distinguish coordinates nearer to the left or right side of the box + var atLeft = x - boxAround.left < boxAround.right - x, atStart = atLeft == ltr; + ch = chAround + (atStart ? 0 : 1); + sticky = atStart ? "after" : "before"; + baseX = atLeft ? boxAround.left : boxAround.right; + } else { + // (Adjust for extended bound, if necessary.) + if (!ltr && (ch == end || ch == begin)) { ch++; } + // To determine which side to associate with, get the box to the + // left of the character and compare it's vertical position to the + // coordinates + sticky = ch == 0 ? "after" : ch == lineObj.text.length ? "before" : + (measureCharPrepared(cm, preparedMeasure, ch - (ltr ? 1 : 0)).bottom + widgetHeight$$1 <= y) == ltr ? + "after" : "before"; + // Now get accurate coordinates for this place, in order to get a + // base X position + var coords = cursorCoords(cm, Pos(lineNo$$1, ch, sticky), "line", lineObj, preparedMeasure); + baseX = coords.left; + outside = y < coords.top ? -1 : y >= coords.bottom ? 1 : 0; + } + + ch = skipExtendingChars(lineObj.text, ch, 1); + return PosWithInfo(lineNo$$1, ch, sticky, outside, x - baseX) + } + + function coordsBidiPart(cm, lineObj, lineNo$$1, preparedMeasure, order, x, y) { + // Bidi parts are sorted left-to-right, and in a non-line-wrapping + // situation, we can take this ordering to correspond to the visual + // ordering. This finds the first part whose end is after the given + // coordinates. + var index = findFirst(function (i) { + var part = order[i], ltr = part.level != 1; + return boxIsAfter(cursorCoords(cm, Pos(lineNo$$1, ltr ? part.to : part.from, ltr ? "before" : "after"), + "line", lineObj, preparedMeasure), x, y, true) + }, 0, order.length - 1); + var part = order[index]; + // If this isn't the first part, the part's start is also after + // the coordinates, and the coordinates aren't on the same line as + // that start, move one part back. + if (index > 0) { + var ltr = part.level != 1; + var start = cursorCoords(cm, Pos(lineNo$$1, ltr ? part.from : part.to, ltr ? "after" : "before"), + "line", lineObj, preparedMeasure); + if (boxIsAfter(start, x, y, true) && start.top > y) + { part = order[index - 1]; } + } + return part + } + + function coordsBidiPartWrapped(cm, lineObj, _lineNo, preparedMeasure, order, x, y) { + // In a wrapped line, rtl text on wrapping boundaries can do things + // that don't correspond to the ordering in our `order` array at + // all, so a binary search doesn't work, and we want to return a + // part that only spans one line so that the binary search in + // coordsCharInner is safe. As such, we first find the extent of the + // wrapped line, and then do a flat search in which we discard any + // spans that aren't on the line. + var ref = wrappedLineExtent(cm, lineObj, preparedMeasure, y); + var begin = ref.begin; + var end = ref.end; + if (/\s/.test(lineObj.text.charAt(end - 1))) { end--; } + var part = null, closestDist = null; + for (var i = 0; i < order.length; i++) { + var p = order[i]; + if (p.from >= end || p.to <= begin) { continue } + var ltr = p.level != 1; + var endX = measureCharPrepared(cm, preparedMeasure, ltr ? Math.min(end, p.to) - 1 : Math.max(begin, p.from)).right; + // Weigh against spans ending before this, so that they are only + // picked if nothing ends after + var dist = endX < x ? x - endX + 1e9 : endX - x; + if (!part || closestDist > dist) { + part = p; + closestDist = dist; + } + } + if (!part) { part = order[order.length - 1]; } + // Clip the part to the wrapped line. + if (part.from < begin) { part = {from: begin, to: part.to, level: part.level}; } + if (part.to > end) { part = {from: part.from, to: end, level: part.level}; } + return part + } + + var measureText; + // Compute the default text height. + function textHeight(display) { + if (display.cachedTextHeight != null) { return display.cachedTextHeight } + if (measureText == null) { + measureText = elt("pre", null, "CodeMirror-line-like"); + // Measure a bunch of lines, for browsers that compute + // fractional heights. + for (var i = 0; i < 49; ++i) { + measureText.appendChild(document.createTextNode("x")); + measureText.appendChild(elt("br")); + } + measureText.appendChild(document.createTextNode("x")); + } + removeChildrenAndAdd(display.measure, measureText); + var height = measureText.offsetHeight / 50; + if (height > 3) { display.cachedTextHeight = height; } + removeChildren(display.measure); + return height || 1 + } + + // Compute the default character width. + function charWidth(display) { + if (display.cachedCharWidth != null) { return display.cachedCharWidth } + var anchor = elt("span", "xxxxxxxxxx"); + var pre = elt("pre", [anchor], "CodeMirror-line-like"); + removeChildrenAndAdd(display.measure, pre); + var rect = anchor.getBoundingClientRect(), width = (rect.right - rect.left) / 10; + if (width > 2) { display.cachedCharWidth = width; } + return width || 10 + } + + // Do a bulk-read of the DOM positions and sizes needed to draw the + // view, so that we don't interleave reading and writing to the DOM. + function getDimensions(cm) { + var d = cm.display, left = {}, width = {}; + var gutterLeft = d.gutters.clientLeft; + for (var n = d.gutters.firstChild, i = 0; n; n = n.nextSibling, ++i) { + var id = cm.display.gutterSpecs[i].className; + left[id] = n.offsetLeft + n.clientLeft + gutterLeft; + width[id] = n.clientWidth; + } + return {fixedPos: compensateForHScroll(d), + gutterTotalWidth: d.gutters.offsetWidth, + gutterLeft: left, + gutterWidth: width, + wrapperWidth: d.wrapper.clientWidth} + } + + // Computes display.scroller.scrollLeft + display.gutters.offsetWidth, + // but using getBoundingClientRect to get a sub-pixel-accurate + // result. + function compensateForHScroll(display) { + return display.scroller.getBoundingClientRect().left - display.sizer.getBoundingClientRect().left + } + + // Returns a function that estimates the height of a line, to use as + // first approximation until the line becomes visible (and is thus + // properly measurable). + function estimateHeight(cm) { + var th = textHeight(cm.display), wrapping = cm.options.lineWrapping; + var perLine = wrapping && Math.max(5, cm.display.scroller.clientWidth / charWidth(cm.display) - 3); + return function (line) { + if (lineIsHidden(cm.doc, line)) { return 0 } + + var widgetsHeight = 0; + if (line.widgets) { for (var i = 0; i < line.widgets.length; i++) { + if (line.widgets[i].height) { widgetsHeight += line.widgets[i].height; } + } } - if (config.clearProperties) { - clearStyle.display = 'inline'; - } - break; - case 'computed': - labelEl.addClass(computedCls); - break; + if (wrapping) + { return widgetsHeight + (Math.ceil(line.text.length / perLine) || 1) * th } + else + { return widgetsHeight + th } } - }, + } + function estimateLineHeights(cm) { + var doc = cm.doc, est = estimateHeight(cm); + doc.iter(function (line) { + var estHeight = est(line); + if (estHeight != line.height) { updateLineHeight(line, estHeight); } + }); + } - /** - * Clear the property from the target - */ - clear: function clear() { - var target = this.getTargetModel(); - target.removeStyle(this.model.get('property')); - this.targetUpdated(); - }, - - - /** - * Get clear element - * @return {HTMLElement} - */ - getClearEl: function getClearEl() { - return this.el.querySelector('[' + clearProp + ']'); - }, + // Given a mouse event, find the corresponding position. If liberal + // is false, it checks whether a gutter or scrollbar was clicked, + // and returns null if it was. forRect is used by rectangular + // selections, and tries to estimate a character position even for + // coordinates beyond the right of the text. + function posFromMouse(cm, e, liberal, forRect) { + var display = cm.display; + if (!liberal && e_target(e).getAttribute("cm-not-content") == "true") { return null } + + var x, y, space = display.lineSpace.getBoundingClientRect(); + // Fails unpredictably on IE[67] when mouse is dragged around quickly. + try { x = e.clientX - space.left; y = e.clientY - space.top; } + catch (e) { return null } + var coords = coordsChar(cm, x, y), line; + if (forRect && coords.xRel == 1 && (line = getLine(cm.doc, coords.line).text).length == coords.ch) { + var colDiff = countColumn(line, line.length, cm.options.tabSize) - line.length; + coords = Pos(coords.line, Math.max(0, Math.round((x - paddingH(cm.display).left) / charWidth(cm.display)) - colDiff)); + } + return coords + } + + // Find the view element corresponding to a given line. Return null + // when the line isn't visible. + function findViewIndex(cm, n) { + if (n >= cm.display.viewTo) { return null } + n -= cm.display.viewFrom; + if (n < 0) { return null } + var view = cm.display.view; + for (var i = 0; i < view.length; i++) { + n -= view[i].size; + if (n < 0) { return i } + } + } + + // Updates the display.view data structure for a given change to the + // document. From and to are in pre-change coordinates. Lendiff is + // the amount of lines added or subtracted by the change. This is + // used for changes that span multiple lines, or change the way + // lines are divided into visual lines. regLineChange (below) + // registers single-line changes. + function regChange(cm, from, to, lendiff) { + if (from == null) { from = cm.doc.first; } + if (to == null) { to = cm.doc.first + cm.doc.size; } + if (!lendiff) { lendiff = 0; } + + var display = cm.display; + if (lendiff && to < display.viewTo && + (display.updateLineNumbers == null || display.updateLineNumbers > from)) + { display.updateLineNumbers = from; } + + cm.curOp.viewChanged = true; + + if (from >= display.viewTo) { // Change after + if (sawCollapsedSpans && visualLineNo(cm.doc, from) < display.viewTo) + { resetView(cm); } + } else if (to <= display.viewFrom) { // Change before + if (sawCollapsedSpans && visualLineEndNo(cm.doc, to + lendiff) > display.viewFrom) { + resetView(cm); + } else { + display.viewFrom += lendiff; + display.viewTo += lendiff; + } + } else if (from <= display.viewFrom && to >= display.viewTo) { // Full overlap + resetView(cm); + } else if (from <= display.viewFrom) { // Top overlap + var cut = viewCuttingPoint(cm, to, to + lendiff, 1); + if (cut) { + display.view = display.view.slice(cut.index); + display.viewFrom = cut.lineN; + display.viewTo += lendiff; + } else { + resetView(cm); + } + } else if (to >= display.viewTo) { // Bottom overlap + var cut$1 = viewCuttingPoint(cm, from, from, -1); + if (cut$1) { + display.view = display.view.slice(0, cut$1.index); + display.viewTo = cut$1.lineN; + } else { + resetView(cm); + } + } else { // Gap in the middle + var cutTop = viewCuttingPoint(cm, from, from, -1); + var cutBot = viewCuttingPoint(cm, to, to + lendiff, 1); + if (cutTop && cutBot) { + display.view = display.view.slice(0, cutTop.index) + .concat(buildViewArray(cm, cutTop.lineN, cutBot.lineN)) + .concat(display.view.slice(cutBot.index)); + display.viewTo += lendiff; + } else { + resetView(cm); + } + } + var ext = display.externalMeasured; + if (ext) { + if (to < ext.lineN) + { ext.lineN += lendiff; } + else if (from < ext.lineN + ext.size) + { display.externalMeasured = null; } + } + } - /** - * Returns selected target which should have 'style' property - * @return {Model|null} - */ - getTarget: function getTarget() { - return this.getTargetModel(); - }, + // Register a change to a single line. Type must be one of "text", + // "gutter", "class", "widget" + function regLineChange(cm, line, type) { + cm.curOp.viewChanged = true; + var display = cm.display, ext = cm.display.externalMeasured; + if (ext && line >= ext.lineN && line < ext.lineN + ext.size) + { display.externalMeasured = null; } + if (line < display.viewFrom || line >= display.viewTo) { return } + var lineView = display.view[findViewIndex(cm, line)]; + if (lineView.node == null) { return } + var arr = lineView.changes || (lineView.changes = []); + if (indexOf(arr, type) == -1) { arr.push(type); } + } + + // Clear the view. + function resetView(cm) { + cm.display.viewFrom = cm.display.viewTo = cm.doc.first; + cm.display.view = []; + cm.display.viewOffset = 0; + } + + function viewCuttingPoint(cm, oldN, newN, dir) { + var index = findViewIndex(cm, oldN), diff, view = cm.display.view; + if (!sawCollapsedSpans || newN == cm.doc.first + cm.doc.size) + { return {index: index, lineN: newN} } + var n = cm.display.viewFrom; + for (var i = 0; i < index; i++) + { n += view[i].size; } + if (n != oldN) { + if (dir > 0) { + if (index == view.length - 1) { return null } + diff = (n + view[index].size) - oldN; + index++; + } else { + diff = n - oldN; + } + oldN += diff; newN += diff; + } + while (visualLineNo(cm.doc, newN) != newN) { + if (index == (dir < 0 ? 0 : view.length - 1)) { return null } + newN += dir * view[index - (dir < 0 ? 1 : 0)].size; + index += dir; + } + return {index: index, lineN: newN} + } - /** - * Returns Styleable model - * @return {Model|null} - */ - getTargetModel: function getTargetModel() { - return this.propTarget && this.propTarget.model; - }, + // Force the view to cover a given range, adding empty view element + // or clipping off existing ones as needed. + function adjustView(cm, from, to) { + var display = cm.display, view = display.view; + if (view.length == 0 || from >= display.viewTo || to <= display.viewFrom) { + display.view = buildViewArray(cm, from, to); + display.viewFrom = from; + } else { + if (display.viewFrom > from) + { display.view = buildViewArray(cm, from, display.viewFrom).concat(display.view); } + else if (display.viewFrom < from) + { display.view = display.view.slice(findViewIndex(cm, from)); } + display.viewFrom = from; + if (display.viewTo < to) + { display.view = display.view.concat(buildViewArray(cm, display.viewTo, to)); } + else if (display.viewTo > to) + { display.view = display.view.slice(0, findViewIndex(cm, to)); } + } + display.viewTo = to; + } + // Count the number of lines in the view whose DOM representation is + // out of date (or nonexistent). + function countDirtyView(cm) { + var view = cm.display.view, dirty = 0; + for (var i = 0; i < view.length; i++) { + var lineView = view[i]; + if (!lineView.hidden && (!lineView.node || lineView.changes)) { ++dirty; } + } + return dirty + } - /** - * Returns helper Styleable model - * @return {Model|null} - */ - getHelperModel: function getHelperModel() { - return this.propTarget && this.propTarget.helper; - }, + function updateSelection(cm) { + cm.display.input.showSelection(cm.display.input.prepareSelection()); + } + function prepareSelection(cm, primary) { + if ( primary === void 0 ) primary = true; - /** - * Triggers when the value of element input/s is changed, so have to update - * the value of the model which will propogate those changes to the target - */ - inputValueChanged: function inputValueChanged(e) { - e && e.stopPropagation(); - this.model.setValue(this.getInputValue(), 1, { fromInput: 1 }); - this.elementUpdated(); - }, + var doc = cm.doc, result = {}; + var curFragment = result.cursors = document.createDocumentFragment(); + var selFragment = result.selection = document.createDocumentFragment(); + for (var i = 0; i < doc.sel.ranges.length; i++) { + if (!primary && i == doc.sel.primIndex) { continue } + var range$$1 = doc.sel.ranges[i]; + if (range$$1.from().line >= cm.display.viewTo || range$$1.to().line < cm.display.viewFrom) { continue } + var collapsed = range$$1.empty(); + if (collapsed || cm.options.showCursorWhenSelecting) + { drawSelectionCursor(cm, range$$1.head, curFragment); } + if (!collapsed) + { drawSelectionRange(cm, range$$1, selFragment); } + } + return result + } - /** - * Fired when the element of the property is updated - */ - elementUpdated: function elementUpdated() { - this.setStatus('updated'); - }, - setStatus: function setStatus(value) { - this.model.set('status', value); - var parent = this.model.parent; - parent && parent.set('status', value); - }, + // Draws a cursor for the given range + function drawSelectionCursor(cm, head, output) { + var pos = cursorCoords(cm, head, "div", null, null, !cm.options.singleCursorHeightPerLine); + var cursor = output.appendChild(elt("div", "\u00a0", "CodeMirror-cursor")); + cursor.style.left = pos.left + "px"; + cursor.style.top = pos.top + "px"; + cursor.style.height = Math.max(0, pos.bottom - pos.top) * cm.options.cursorHeight + "px"; - /** - * Fired when the target is changed - * */ - targetUpdated: function targetUpdated() { - if (!this.checkVisibility()) { - return; + if (pos.other) { + // Secondary cursor, shown when on a 'jump' in bi-directional text + var otherCursor = output.appendChild(elt("div", "\u00a0", "CodeMirror-cursor CodeMirror-secondarycursor")); + otherCursor.style.display = ""; + otherCursor.style.left = pos.other.left + "px"; + otherCursor.style.top = pos.other.top + "px"; + otherCursor.style.height = (pos.other.bottom - pos.other.top) * .85 + "px"; } + } - var config = this.config; - var em = config.em; - var model = this.model; - var value = ''; - var status = ''; - var targetValue = this.getTargetValue({ ignoreDefault: 1 }); - var defaultValue = model.getDefaultValue(); - var computedValue = this.getComputedValue(); + function cmpCoords(a, b) { return a.top - b.top || a.left - b.left } - if (targetValue) { - value = targetValue; + // Draws the given range as a highlighted selection + function drawSelectionRange(cm, range$$1, output) { + var display = cm.display, doc = cm.doc; + var fragment = document.createDocumentFragment(); + var padding = paddingH(cm.display), leftSide = padding.left; + var rightSide = Math.max(display.sizerWidth, displayWidth(cm) - display.sizer.offsetLeft) - padding.right; + var docLTR = doc.direction == "ltr"; + + function add(left, top, width, bottom) { + if (top < 0) { top = 0; } + top = Math.round(top); + bottom = Math.round(bottom); + fragment.appendChild(elt("div", null, "CodeMirror-selected", ("position: absolute; left: " + left + "px;\n top: " + top + "px; width: " + (width == null ? rightSide - left : width) + "px;\n height: " + (bottom - top) + "px"))); + } + + function drawForLine(line, fromArg, toArg) { + var lineObj = getLine(doc, line); + var lineLen = lineObj.text.length; + var start, end; + function coords(ch, bias) { + return charCoords(cm, Pos(line, ch), "div", lineObj, bias) + } + + function wrapX(pos, dir, side) { + var extent = wrappedLineExtentChar(cm, lineObj, null, pos); + var prop = (dir == "ltr") == (side == "after") ? "left" : "right"; + var ch = side == "after" ? extent.begin : extent.end - (/\s/.test(lineObj.text.charAt(extent.end - 1)) ? 2 : 1); + return coords(ch, prop)[prop] + } + + var order = getOrder(lineObj, doc.direction); + iterateBidiSections(order, fromArg || 0, toArg == null ? lineLen : toArg, function (from, to, dir, i) { + var ltr = dir == "ltr"; + var fromPos = coords(from, ltr ? "left" : "right"); + var toPos = coords(to - 1, ltr ? "right" : "left"); + + var openStart = fromArg == null && from == 0, openEnd = toArg == null && to == lineLen; + var first = i == 0, last = !order || i == order.length - 1; + if (toPos.top - fromPos.top <= 3) { // Single line + var openLeft = (docLTR ? openStart : openEnd) && first; + var openRight = (docLTR ? openEnd : openStart) && last; + var left = openLeft ? leftSide : (ltr ? fromPos : toPos).left; + var right = openRight ? rightSide : (ltr ? toPos : fromPos).right; + add(left, fromPos.top, right - left, fromPos.bottom); + } else { // Multiple lines + var topLeft, topRight, botLeft, botRight; + if (ltr) { + topLeft = docLTR && openStart && first ? leftSide : fromPos.left; + topRight = docLTR ? rightSide : wrapX(from, dir, "before"); + botLeft = docLTR ? leftSide : wrapX(to, dir, "after"); + botRight = docLTR && openEnd && last ? rightSide : toPos.right; + } else { + topLeft = !docLTR ? leftSide : wrapX(from, dir, "before"); + topRight = !docLTR && openStart && first ? rightSide : fromPos.right; + botLeft = !docLTR && openEnd && last ? leftSide : toPos.left; + botRight = !docLTR ? rightSide : wrapX(to, dir, "after"); + } + add(topLeft, fromPos.top, topRight - topLeft, fromPos.bottom); + if (fromPos.bottom < toPos.top) { add(leftSide, fromPos.bottom, null, toPos.top); } + add(botLeft, toPos.top, botRight - botLeft, toPos.bottom); + } - if (config.highlightChanged) { - status = 'updated'; - } - } else if (computedValue && config.showComputed && computedValue != defaultValue) { - value = computedValue; + if (!start || cmpCoords(fromPos, start) < 0) { start = fromPos; } + if (cmpCoords(toPos, start) < 0) { start = toPos; } + if (!end || cmpCoords(fromPos, end) < 0) { end = fromPos; } + if (cmpCoords(toPos, end) < 0) { end = toPos; } + }); + return {start: start, end: end} + } - if (config.highlightComputed) { - status = 'computed'; - } + var sFrom = range$$1.from(), sTo = range$$1.to(); + if (sFrom.line == sTo.line) { + drawForLine(sFrom.line, sFrom.ch, sTo.ch); } else { - value = defaultValue; - status = ''; + var fromLine = getLine(doc, sFrom.line), toLine = getLine(doc, sTo.line); + var singleVLine = visualLine(fromLine) == visualLine(toLine); + var leftEnd = drawForLine(sFrom.line, sFrom.ch, singleVLine ? fromLine.text.length + 1 : null).end; + var rightStart = drawForLine(sTo.line, singleVLine ? 0 : null, sTo.ch).start; + if (singleVLine) { + if (leftEnd.top < rightStart.top - 2) { + add(leftEnd.right, leftEnd.top, null, leftEnd.bottom); + add(leftSide, rightStart.top, rightStart.left, rightStart.bottom); + } else { + add(leftEnd.right, leftEnd.top, rightStart.left - leftEnd.right, leftEnd.bottom); + } + } + if (leftEnd.bottom < rightStart.top) + { add(leftSide, leftEnd.bottom, null, rightStart.top); } } - model.setValue(value, 0, { fromTarget: 1 }); - this.setStatus(status); + output.appendChild(fragment); + } - if (em) { - em.trigger('styleManager:change', this); - em.trigger('styleManager:change:' + model.get('property'), this); - } - }, - checkVisibility: function checkVisibility() { - var result = 1; + // Cursor-blinking + function restartBlink(cm) { + if (!cm.state.focused) { return } + var display = cm.display; + clearInterval(display.blinker); + var on = true; + display.cursorDiv.style.visibility = ""; + if (cm.options.cursorBlinkRate > 0) + { display.blinker = setInterval(function () { return display.cursorDiv.style.visibility = (on = !on) ? "" : "hidden"; }, + cm.options.cursorBlinkRate); } + else if (cm.options.cursorBlinkRate < 0) + { display.cursorDiv.style.visibility = "hidden"; } + } - // Check if need to hide the property - if (this.config.hideNotStylable) { - if (!this.isTargetStylable() || !this.isComponentStylable()) { - this.hide(); - result = 0; + function ensureFocus(cm) { + if (!cm.state.focused) { cm.display.input.focus(); onFocus(cm); } + } + + function delayBlurEvent(cm) { + cm.state.delayingBlurEvent = true; + setTimeout(function () { if (cm.state.delayingBlurEvent) { + cm.state.delayingBlurEvent = false; + onBlur(cm); + } }, 100); + } + + function onFocus(cm, e) { + if (cm.state.delayingBlurEvent) { cm.state.delayingBlurEvent = false; } + + if (cm.options.readOnly == "nocursor") { return } + if (!cm.state.focused) { + signal(cm, "focus", cm, e); + cm.state.focused = true; + addClass(cm.display.wrapper, "CodeMirror-focused"); + // This test prevents this from firing when a context + // menu is closed (since the input reset would kill the + // select-all detection hack) + if (!cm.curOp && cm.display.selForContextMenu != cm.doc.sel) { + cm.display.input.reset(); + if (webkit) { setTimeout(function () { return cm.display.input.reset(true); }, 20); } // Issue #1730 + } + cm.display.input.receivedFocus(); + } + restartBlink(cm); + } + function onBlur(cm, e) { + if (cm.state.delayingBlurEvent) { return } + + if (cm.state.focused) { + signal(cm, "blur", cm, e); + cm.state.focused = false; + rmClass(cm.display.wrapper, "CodeMirror-focused"); + } + clearInterval(cm.display.blinker); + setTimeout(function () { if (!cm.state.focused) { cm.display.shift = false; } }, 150); + } + + // Read the actual heights of the rendered lines, and update their + // stored heights to match. + function updateHeightsInViewport(cm) { + var display = cm.display; + var prevBottom = display.lineDiv.offsetTop; + for (var i = 0; i < display.view.length; i++) { + var cur = display.view[i], wrapping = cm.options.lineWrapping; + var height = (void 0), width = 0; + if (cur.hidden) { continue } + if (ie && ie_version < 8) { + var bot = cur.node.offsetTop + cur.node.offsetHeight; + height = bot - prevBottom; + prevBottom = bot; } else { - this.show(); + var box = cur.node.getBoundingClientRect(); + height = box.bottom - box.top; + // Check that lines don't extend past the right of the current + // editor width + if (!wrapping && cur.text.firstChild) + { width = cur.text.firstChild.getBoundingClientRect().right - box.left - 1; } } - // Sector is not passed to Composite and Stack types - if (this.sector) { - this.sector.trigger('updateVisibility'); + var diff = cur.line.height - height; + if (diff > .005 || diff < -.005) { + updateLineHeight(cur.line, height); + updateWidgetHeight(cur.line); + if (cur.rest) { for (var j = 0; j < cur.rest.length; j++) + { updateWidgetHeight(cur.rest[j]); } } + } + if (width > cm.display.sizerWidth) { + var chWidth = Math.ceil(width / charWidth(cm.display)); + if (chWidth > cm.display.maxLineLength) { + cm.display.maxLineLength = chWidth; + cm.display.maxLine = cur.line; + cm.display.maxLineChanged = true; + } } } + } - return result; - }, + // Read and store the height of line widgets associated with the + // given line. + function updateWidgetHeight(line) { + if (line.widgets) { for (var i = 0; i < line.widgets.length; ++i) { + var w = line.widgets[i], parent = w.node.parentNode; + if (parent) { w.height = parent.offsetHeight; } + } } + } + // Compute the lines that are visible in a given viewport (defaults + // the the current scroll position). viewport may contain top, + // height, and ensure (see op.scrollToPos) properties. + function visibleLines(display, doc, viewport) { + var top = viewport && viewport.top != null ? Math.max(0, viewport.top) : display.scroller.scrollTop; + top = Math.floor(top - paddingTop(display)); + var bottom = viewport && viewport.bottom != null ? viewport.bottom : top + display.wrapper.clientHeight; + + var from = lineAtHeight(doc, top), to = lineAtHeight(doc, bottom); + // Ensure is a {from: {line, ch}, to: {line, ch}} object, and + // forces those lines into the viewport (if possible). + if (viewport && viewport.ensure) { + var ensureFrom = viewport.ensure.from.line, ensureTo = viewport.ensure.to.line; + if (ensureFrom < from) { + from = ensureFrom; + to = lineAtHeight(doc, heightAtLine(getLine(doc, ensureFrom)) + display.wrapper.clientHeight); + } else if (Math.min(ensureTo, doc.lastLine()) >= to) { + from = lineAtHeight(doc, heightAtLine(getLine(doc, ensureTo)) - display.wrapper.clientHeight); + to = ensureTo; + } + } + return {from: from, to: Math.max(to, from + 1)} + } + + // SCROLLING THINGS INTO VIEW + + // If an editor sits on the top or bottom of the window, partially + // scrolled out of view, this ensures that the cursor is visible. + function maybeScrollWindow(cm, rect) { + if (signalDOMEvent(cm, "scrollCursorIntoView")) { return } + + var display = cm.display, box = display.sizer.getBoundingClientRect(), doScroll = null; + if (rect.top + box.top < 0) { doScroll = true; } + else if (rect.bottom + box.top > (window.innerHeight || document.documentElement.clientHeight)) { doScroll = false; } + if (doScroll != null && !phantom) { + var scrollNode = elt("div", "\u200b", null, ("position: absolute;\n top: " + (rect.top - display.viewOffset - paddingTop(cm.display)) + "px;\n height: " + (rect.bottom - rect.top + scrollGap(cm) + display.barHeight) + "px;\n left: " + (rect.left) + "px; width: " + (Math.max(2, rect.right - rect.left)) + "px;")); + cm.display.lineSpace.appendChild(scrollNode); + scrollNode.scrollIntoView(doScroll); + cm.display.lineSpace.removeChild(scrollNode); + } + } + + // Scroll a given position into view (immediately), verifying that + // it actually became visible (as line heights are accurately + // measured, the position of something may 'drift' during drawing). + function scrollPosIntoView(cm, pos, end, margin) { + if (margin == null) { margin = 0; } + var rect; + if (!cm.options.lineWrapping && pos == end) { + // Set pos and end to the cursor positions around the character pos sticks to + // If pos.sticky == "before", that is around pos.ch - 1, otherwise around pos.ch + // If pos == Pos(_, 0, "before"), pos and end are unchanged + pos = pos.ch ? Pos(pos.line, pos.sticky == "before" ? pos.ch - 1 : pos.ch, "after") : pos; + end = pos.sticky == "before" ? Pos(pos.line, pos.ch + 1, "before") : pos; + } + for (var limit = 0; limit < 5; limit++) { + var changed = false; + var coords = cursorCoords(cm, pos); + var endCoords = !end || end == pos ? coords : cursorCoords(cm, end); + rect = {left: Math.min(coords.left, endCoords.left), + top: Math.min(coords.top, endCoords.top) - margin, + right: Math.max(coords.left, endCoords.left), + bottom: Math.max(coords.bottom, endCoords.bottom) + margin}; + var scrollPos = calculateScrollPos(cm, rect); + var startTop = cm.doc.scrollTop, startLeft = cm.doc.scrollLeft; + if (scrollPos.scrollTop != null) { + updateScrollTop(cm, scrollPos.scrollTop); + if (Math.abs(cm.doc.scrollTop - startTop) > 1) { changed = true; } + } + if (scrollPos.scrollLeft != null) { + setScrollLeft(cm, scrollPos.scrollLeft); + if (Math.abs(cm.doc.scrollLeft - startLeft) > 1) { changed = true; } + } + if (!changed) { break } + } + return rect + } + + // Scroll a given set of coordinates into view (immediately). + function scrollIntoView(cm, rect) { + var scrollPos = calculateScrollPos(cm, rect); + if (scrollPos.scrollTop != null) { updateScrollTop(cm, scrollPos.scrollTop); } + if (scrollPos.scrollLeft != null) { setScrollLeft(cm, scrollPos.scrollLeft); } + } + + // Calculate a new scroll position needed to scroll the given + // rectangle into view. Returns an object with scrollTop and + // scrollLeft properties. When these are undefined, the + // vertical/horizontal position does not need to be adjusted. + function calculateScrollPos(cm, rect) { + var display = cm.display, snapMargin = textHeight(cm.display); + if (rect.top < 0) { rect.top = 0; } + var screentop = cm.curOp && cm.curOp.scrollTop != null ? cm.curOp.scrollTop : display.scroller.scrollTop; + var screen = displayHeight(cm), result = {}; + if (rect.bottom - rect.top > screen) { rect.bottom = rect.top + screen; } + var docBottom = cm.doc.height + paddingVert(display); + var atTop = rect.top < snapMargin, atBottom = rect.bottom > docBottom - snapMargin; + if (rect.top < screentop) { + result.scrollTop = atTop ? 0 : rect.top; + } else if (rect.bottom > screentop + screen) { + var newTop = Math.min(rect.top, (atBottom ? docBottom : rect.bottom) - screen); + if (newTop != screentop) { result.scrollTop = newTop; } + } + + var screenleft = cm.curOp && cm.curOp.scrollLeft != null ? cm.curOp.scrollLeft : display.scroller.scrollLeft; + var screenw = displayWidth(cm) - (cm.options.fixedGutter ? display.gutters.offsetWidth : 0); + var tooWide = rect.right - rect.left > screenw; + if (tooWide) { rect.right = rect.left + screenw; } + if (rect.left < 10) + { result.scrollLeft = 0; } + else if (rect.left < screenleft) + { result.scrollLeft = Math.max(0, rect.left - (tooWide ? 0 : 10)); } + else if (rect.right > screenw + screenleft - 3) + { result.scrollLeft = rect.right + (tooWide ? 0 : 10) - screenw; } + return result + } - /** - * Get the value of this property from the target (eg, Component, CSSRule) - * @param {Object} [opts] Options - * @param {Boolean} [options.fetchFromFunction] - * @param {Boolean} [options.ignoreDefault] - * @return string - * @private - */ - getTargetValue: function getTargetValue() { - var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + // Store a relative adjustment to the scroll position in the current + // operation (to be applied when the operation finishes). + function addToScrollTop(cm, top) { + if (top == null) { return } + resolveScrollToPos(cm); + cm.curOp.scrollTop = (cm.curOp.scrollTop == null ? cm.doc.scrollTop : cm.curOp.scrollTop) + top; + } - var result; - var model = this.model; - var target = this.getTargetModel(); - var customFetchValue = this.customValue; + // Make sure that at the end of the operation the current cursor is + // shown. + function ensureCursorVisible(cm) { + resolveScrollToPos(cm); + var cur = cm.getCursor(); + cm.curOp.scrollToPos = {from: cur, to: cur, margin: cm.options.cursorScrollMargin}; + } - if (!target) { - return result; - } + function scrollToCoords(cm, x, y) { + if (x != null || y != null) { resolveScrollToPos(cm); } + if (x != null) { cm.curOp.scrollLeft = x; } + if (y != null) { cm.curOp.scrollTop = y; } + } - result = target.getStyle()[model.get('property')]; + function scrollToRange(cm, range$$1) { + resolveScrollToPos(cm); + cm.curOp.scrollToPos = range$$1; + } - if (!result && !opts.ignoreDefault) { - result = model.getDefaultValue(); + // When an operation has its scrollToPos property set, and another + // scroll action is applied before the end of the operation, this + // 'simulates' scrolling that position into view in a cheap way, so + // that the effect of intermediate scroll commands is not ignored. + function resolveScrollToPos(cm) { + var range$$1 = cm.curOp.scrollToPos; + if (range$$1) { + cm.curOp.scrollToPos = null; + var from = estimateCoords(cm, range$$1.from), to = estimateCoords(cm, range$$1.to); + scrollToCoordsRange(cm, from, to, range$$1.margin); } + } - if (typeof customFetchValue == 'function' && !opts.ignoreCustomValue) { - var index = model.collection.indexOf(model); - var customValue = customFetchValue(this, index); - - if (customValue) { - result = customValue; - } - } + function scrollToCoordsRange(cm, from, to, margin) { + var sPos = calculateScrollPos(cm, { + left: Math.min(from.left, to.left), + top: Math.min(from.top, to.top) - margin, + right: Math.max(from.right, to.right), + bottom: Math.max(from.bottom, to.bottom) + margin + }); + scrollToCoords(cm, sPos.scrollLeft, sPos.scrollTop); + } - return result; - }, + // Sync the scrollable area and scrollbars, ensure the viewport + // covers the visible area. + function updateScrollTop(cm, val) { + if (Math.abs(cm.doc.scrollTop - val) < 2) { return } + if (!gecko) { updateDisplaySimple(cm, {top: val}); } + setScrollTop(cm, val, true); + if (gecko) { updateDisplaySimple(cm); } + startWorker(cm, 100); + } + function setScrollTop(cm, val, forceScroll) { + val = Math.min(cm.display.scroller.scrollHeight - cm.display.scroller.clientHeight, val); + if (cm.display.scroller.scrollTop == val && !forceScroll) { return } + cm.doc.scrollTop = val; + cm.display.scrollbars.setScrollTop(val); + if (cm.display.scroller.scrollTop != val) { cm.display.scroller.scrollTop = val; } + } - /** - * Returns computed value - * @return {String} - * @private - */ - getComputedValue: function getComputedValue() { - var target = this.propTarget; - var computed = target.computed || {}; - var computedDef = target.computedDefault || {}; - var avoid = this.config.avoidComputed || []; - var property = this.model.get('property'); - var notToSkip = avoid.indexOf(property) < 0; - var value = computed[property]; - var valueDef = computedDef[(0, _mixins.camelCase)(property)]; - return computed && notToSkip && valueDef !== value && value; - }, + // Sync scroller and scrollbar, ensure the gutter elements are + // aligned. + function setScrollLeft(cm, val, isScroller, forceScroll) { + val = Math.min(val, cm.display.scroller.scrollWidth - cm.display.scroller.clientWidth); + if ((isScroller ? val == cm.doc.scrollLeft : Math.abs(cm.doc.scrollLeft - val) < 2) && !forceScroll) { return } + cm.doc.scrollLeft = val; + alignHorizontally(cm); + if (cm.display.scroller.scrollLeft != val) { cm.display.scroller.scrollLeft = val; } + cm.display.scrollbars.setScrollLeft(val); + } + // SCROLLBARS - /** - * Returns value from input - * @return {string} - */ - getInputValue: function getInputValue() { - var input = this.getInputEl(); - return input ? input.value : ''; - }, + // Prepare DOM reads needed to update the scrollbars. Done in one + // shot to minimize update/measure roundtrips. + function measureForScrollbars(cm) { + var d = cm.display, gutterW = d.gutters.offsetWidth; + var docH = Math.round(cm.doc.height + paddingVert(cm.display)); + return { + clientHeight: d.scroller.clientHeight, + viewHeight: d.wrapper.clientHeight, + scrollWidth: d.scroller.scrollWidth, clientWidth: d.scroller.clientWidth, + viewWidth: d.wrapper.clientWidth, + barLeft: cm.options.fixedGutter ? gutterW : 0, + docHeight: docH, + scrollHeight: docH + scrollGap(cm) + d.barHeight, + nativeBarWidth: d.nativeBarWidth, + gutterWidth: gutterW + } + } + + var NativeScrollbars = function(place, scroll, cm) { + this.cm = cm; + var vert = this.vert = elt("div", [elt("div", null, null, "min-width: 1px")], "CodeMirror-vscrollbar"); + var horiz = this.horiz = elt("div", [elt("div", null, null, "height: 100%; min-height: 1px")], "CodeMirror-hscrollbar"); + vert.tabIndex = horiz.tabIndex = -1; + place(vert); place(horiz); + + on(vert, "scroll", function () { + if (vert.clientHeight) { scroll(vert.scrollTop, "vertical"); } + }); + on(horiz, "scroll", function () { + if (horiz.clientWidth) { scroll(horiz.scrollLeft, "horizontal"); } + }); + this.checkedZeroWidth = false; + // Need to set a minimum width to see the scrollbar on IE7 (but must not set it on IE8). + if (ie && ie_version < 8) { this.horiz.style.minHeight = this.vert.style.minWidth = "18px"; } + }; - /** - * Triggers when the `value` of the model changes, so the target and - * the input element should be updated - * @param {Object} e Event - * @param {Mixed} val Value - * @param {Object} opt Options - * */ - modelValueChanged: function modelValueChanged(e, val) { - var opt = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + NativeScrollbars.prototype.update = function (measure) { + var needsH = measure.scrollWidth > measure.clientWidth + 1; + var needsV = measure.scrollHeight > measure.clientHeight + 1; + var sWidth = measure.nativeBarWidth; - var em = this.config.em; - var model = this.model; - var value = model.getFullValue(); - var target = this.getTarget(); - var onChange = this.onChange; + if (needsV) { + this.vert.style.display = "block"; + this.vert.style.bottom = needsH ? sWidth + "px" : "0"; + var totalHeight = measure.viewHeight - (needsH ? sWidth : 0); + // A bug in IE8 can cause this value to be negative, so guard it. + this.vert.firstChild.style.height = + Math.max(0, measure.scrollHeight - measure.clientHeight + totalHeight) + "px"; + } else { + this.vert.style.display = ""; + this.vert.firstChild.style.height = "0"; + } - // Avoid element update if the change comes from it - if (!opt.fromInput) { - this.setValue(value); + if (needsH) { + this.horiz.style.display = "block"; + this.horiz.style.right = needsV ? sWidth + "px" : "0"; + this.horiz.style.left = measure.barLeft + "px"; + var totalWidth = measure.viewWidth - measure.barLeft - (needsV ? sWidth : 0); + this.horiz.firstChild.style.width = + Math.max(0, measure.scrollWidth - measure.clientWidth + totalWidth) + "px"; + } else { + this.horiz.style.display = ""; + this.horiz.firstChild.style.width = "0"; } - // Check if component is allowed to be styled - if (!target || !this.isTargetStylable() || !this.isComponentStylable()) { - return; + if (!this.checkedZeroWidth && measure.clientHeight > 0) { + if (sWidth == 0) { this.zeroWidthHack(); } + this.checkedZeroWidth = true; } - // Avoid target update if the changes comes from it - if (!opt.fromTarget) { - // The onChange is used by Composite/Stack properties, so I'd avoid sending - // it back if the change comes from one of those - if (onChange && !opt.fromParent) { - onChange(target, this, opt); - } else { - this.updateTargetStyle(value, null, opt); - } + return {right: needsV ? sWidth : 0, bottom: needsH ? sWidth : 0} + }; + + NativeScrollbars.prototype.setScrollLeft = function (pos) { + if (this.horiz.scrollLeft != pos) { this.horiz.scrollLeft = pos; } + if (this.disableHoriz) { this.enableZeroWidthBar(this.horiz, this.disableHoriz, "horiz"); } + }; + + NativeScrollbars.prototype.setScrollTop = function (pos) { + if (this.vert.scrollTop != pos) { this.vert.scrollTop = pos; } + if (this.disableVert) { this.enableZeroWidthBar(this.vert, this.disableVert, "vert"); } + }; + + NativeScrollbars.prototype.zeroWidthHack = function () { + var w = mac && !mac_geMountainLion ? "12px" : "18px"; + this.horiz.style.height = this.vert.style.width = w; + this.horiz.style.pointerEvents = this.vert.style.pointerEvents = "none"; + this.disableHoriz = new Delayed; + this.disableVert = new Delayed; + }; + + NativeScrollbars.prototype.enableZeroWidthBar = function (bar, delay, type) { + bar.style.pointerEvents = "auto"; + function maybeDisable() { + // To find out whether the scrollbar is still visible, we + // check whether the element under the pixel in the bottom + // right corner of the scrollbar box is the scrollbar box + // itself (when the bar is still visible) or its filler child + // (when the bar is hidden). If it is still visible, we keep + // it enabled, if it's hidden, we disable pointer events. + var box = bar.getBoundingClientRect(); + var elt$$1 = type == "vert" ? document.elementFromPoint(box.right - 1, (box.top + box.bottom) / 2) + : document.elementFromPoint((box.right + box.left) / 2, box.bottom - 1); + if (elt$$1 != bar) { bar.style.pointerEvents = "none"; } + else { delay.set(1000, maybeDisable); } } + delay.set(1000, maybeDisable); + }; - if (em) { - em.trigger('component:update', target); - em.trigger('component:styleUpdate', target); - em.trigger('component:styleUpdate:' + model.get('property'), target); + NativeScrollbars.prototype.clear = function () { + var parent = this.horiz.parentNode; + parent.removeChild(this.horiz); + parent.removeChild(this.vert); + }; + + var NullScrollbars = function () {}; + + NullScrollbars.prototype.update = function () { return {bottom: 0, right: 0} }; + NullScrollbars.prototype.setScrollLeft = function () {}; + NullScrollbars.prototype.setScrollTop = function () {}; + NullScrollbars.prototype.clear = function () {}; + + function updateScrollbars(cm, measure) { + if (!measure) { measure = measureForScrollbars(cm); } + var startWidth = cm.display.barWidth, startHeight = cm.display.barHeight; + updateScrollbarsInner(cm, measure); + for (var i = 0; i < 4 && startWidth != cm.display.barWidth || startHeight != cm.display.barHeight; i++) { + if (startWidth != cm.display.barWidth && cm.options.lineWrapping) + { updateHeightsInViewport(cm); } + updateScrollbarsInner(cm, measureForScrollbars(cm)); + startWidth = cm.display.barWidth; startHeight = cm.display.barHeight; } - }, + } + // Re-synchronize the fake scrollbars with the actual size of the + // content. + function updateScrollbarsInner(cm, measure) { + var d = cm.display; + var sizes = d.scrollbars.update(measure); - /** - * Update target style - * @param {string} value - * @param {string} name - * @param {Object} opts - */ - updateTargetStyle: function updateTargetStyle(value) { - var name = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : ''; - var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; - - var property = name || this.model.get('property'); - var target = this.getTarget(); - var style = target.getStyle(); - - if (value) { - style[property] = value; - } else { - delete style[property]; - } - - target.setStyle(style, opts); + d.sizer.style.paddingRight = (d.barWidth = sizes.right) + "px"; + d.sizer.style.paddingBottom = (d.barHeight = sizes.bottom) + "px"; + d.heightForcer.style.borderBottom = sizes.bottom + "px solid transparent"; - // Helper is used by `states` like ':hover' to show its preview - var helper = this.getHelperModel(); - helper && helper.setStyle(style, opts); - }, + if (sizes.right && sizes.bottom) { + d.scrollbarFiller.style.display = "block"; + d.scrollbarFiller.style.height = sizes.bottom + "px"; + d.scrollbarFiller.style.width = sizes.right + "px"; + } else { d.scrollbarFiller.style.display = ""; } + if (sizes.bottom && cm.options.coverGutterNextToScrollbar && cm.options.fixedGutter) { + d.gutterFiller.style.display = "block"; + d.gutterFiller.style.height = sizes.bottom + "px"; + d.gutterFiller.style.width = measure.gutterWidth + "px"; + } else { d.gutterFiller.style.display = ""; } + } + var scrollbarModel = {"native": NativeScrollbars, "null": NullScrollbars}; - /** - * Check if target is stylable with this property - * The target could be the Component as the CSS Rule - * @return {Boolean} - */ - isTargetStylable: function isTargetStylable(target) { - if (this.model.get('id') == 'flex-width') { - //debugger; + function initScrollbars(cm) { + if (cm.display.scrollbars) { + cm.display.scrollbars.clear(); + if (cm.display.scrollbars.addClass) + { rmClass(cm.display.wrapper, cm.display.scrollbars.addClass); } } - var trg = target || this.getTarget(); - var model = this.model; - var property = model.get('property'); - var toRequire = model.get('toRequire'); - var unstylable = trg.get('unstylable'); - var stylableReq = trg.get('stylable-require'); - var stylable = trg.get('stylable'); - // Stylable could also be an array indicating with which property - // the target could be styled - if ((0, _underscore.isArray)(stylable)) { - stylable = stylable.indexOf(property) >= 0; - } + cm.display.scrollbars = new scrollbarModel[cm.options.scrollbarStyle](function (node) { + cm.display.wrapper.insertBefore(node, cm.display.scrollbarFiller); + // Prevent clicks in the scrollbars from killing focus + on(node, "mousedown", function () { + if (cm.state.focused) { setTimeout(function () { return cm.display.input.focus(); }, 0); } + }); + node.setAttribute("cm-not-content", "true"); + }, function (pos, axis) { + if (axis == "horizontal") { setScrollLeft(cm, pos); } + else { updateScrollTop(cm, pos); } + }, cm); + if (cm.display.scrollbars.addClass) + { addClass(cm.display.wrapper, cm.display.scrollbars.addClass); } + } + + // Operations are used to wrap a series of changes to the editor + // state in such a way that each change won't have to update the + // cursor and display (which would be awkward, slow, and + // error-prone). Instead, display updates are batched and then all + // combined and executed at once. + + var nextOpId = 0; + // Start a new operation. + function startOperation(cm) { + cm.curOp = { + cm: cm, + viewChanged: false, // Flag that indicates that lines might need to be redrawn + startHeight: cm.doc.height, // Used to detect need to update scrollbar + forceUpdate: false, // Used to force a redraw + updateInput: 0, // Whether to reset the input textarea + typing: false, // Whether this reset should be careful to leave existing text (for compositing) + changeObjs: null, // Accumulated changes, for firing change events + cursorActivityHandlers: null, // Set of handlers to fire cursorActivity on + cursorActivityCalled: 0, // Tracks which cursorActivity handlers have been called already + selectionChanged: false, // Whether the selection needs to be redrawn + updateMaxLine: false, // Set when the widest line needs to be determined anew + scrollLeft: null, scrollTop: null, // Intermediate scroll position, not pushed to DOM yet + scrollToPos: null, // Used to scroll to a specific position + focus: false, + id: ++nextOpId // Unique ID + }; + pushOperation(cm.curOp); + } - // Check if the property was signed as unstylable - if ((0, _underscore.isArray)(unstylable)) { - stylable = unstylable.indexOf(property) < 0; - } + // Finish an operation, updating the display and signalling delayed events + function endOperation(cm) { + var op = cm.curOp; + if (op) { finishOperation(op, function (group) { + for (var i = 0; i < group.ops.length; i++) + { group.ops[i].cm.curOp = null; } + endOperations(group); + }); } + } - // Check if the property is available only if requested - if (toRequire) { - stylable = stylableReq && stylableReq.indexOf(property) >= 0 || !target; - } + // The DOM updates done when an operation finishes are batched so + // that the minimum number of relayouts are required. + function endOperations(group) { + var ops = group.ops; + for (var i = 0; i < ops.length; i++) // Read DOM + { endOperation_R1(ops[i]); } + for (var i$1 = 0; i$1 < ops.length; i$1++) // Write DOM (maybe) + { endOperation_W1(ops[i$1]); } + for (var i$2 = 0; i$2 < ops.length; i$2++) // Read DOM + { endOperation_R2(ops[i$2]); } + for (var i$3 = 0; i$3 < ops.length; i$3++) // Write DOM (maybe) + { endOperation_W2(ops[i$3]); } + for (var i$4 = 0; i$4 < ops.length; i$4++) // Read DOM + { endOperation_finish(ops[i$4]); } + } - return stylable; - }, + function endOperation_R1(op) { + var cm = op.cm, display = cm.display; + maybeClipScrollbars(cm); + if (op.updateMaxLine) { findMaxLine(cm); } + op.mustUpdate = op.viewChanged || op.forceUpdate || op.scrollTop != null || + op.scrollToPos && (op.scrollToPos.from.line < display.viewFrom || + op.scrollToPos.to.line >= display.viewTo) || + display.maxLineChanged && cm.options.lineWrapping; + op.update = op.mustUpdate && + new DisplayUpdate(cm, op.mustUpdate && {top: op.scrollTop, ensure: op.scrollToPos}, op.forceUpdate); + } - /** - * Check if the selected component is stylable with this property - * The target could be the Component as the CSS Rule - * @return {Boolean} - */ - isComponentStylable: function isComponentStylable() { - var em = this.em; - var component = em && em.get('selectedComponent'); + function endOperation_W1(op) { + op.updatedDisplay = op.mustUpdate && updateDisplayIfNeeded(op.cm, op.update); + } - if (!component) { - return true; - } + function endOperation_R2(op) { + var cm = op.cm, display = cm.display; + if (op.updatedDisplay) { updateHeightsInViewport(cm); } - return this.isTargetStylable(component); - }, + op.barMeasure = measureForScrollbars(cm); + // If the max line changed since it was last measured, measure it, + // and ensure the document's width matches it. + // updateDisplay_W2 will use these properties to do the actual resizing + if (display.maxLineChanged && !cm.options.lineWrapping) { + op.adjustWidthTo = measureChar(cm, display.maxLine, display.maxLine.text.length).left + 3; + cm.display.sizerWidth = op.adjustWidthTo; + op.barMeasure.scrollWidth = + Math.max(display.scroller.clientWidth, display.sizer.offsetLeft + op.adjustWidthTo + scrollGap(cm) + cm.display.barWidth); + op.maxScrollLeft = Math.max(0, display.sizer.offsetLeft + op.adjustWidthTo - displayWidth(cm)); + } - /** - * Passed a raw value you have to update the input element, generally - * is the value fetched from targets, so you can receive values with - * functions, units, etc. (eg. `rotateY(45deg)`) - * get also - * @param {string} value - * @private - */ - setRawValue: function setRawValue(value) { - this.setValue(this.model.parseValue(value)); - }, + if (op.updatedDisplay || op.selectionChanged) + { op.preparedSelection = display.input.prepareSelection(); } + } + function endOperation_W2(op) { + var cm = op.cm; - /** - * Update the element input. - * Usually the value is a result of `model.getFullValue()` - * @param {String} value The value from the model - * */ - setValue: function setValue(value) { - var model = this.model; - var val = value || model.getDefaultValue(); - var input = this.getInputEl(); - input && (input.value = val); - }, - getInputEl: function getInputEl() { - if (!this.input) { - this.input = this.el.querySelector('input'); + if (op.adjustWidthTo != null) { + cm.display.sizer.style.minWidth = op.adjustWidthTo + "px"; + if (op.maxScrollLeft < cm.doc.scrollLeft) + { setScrollLeft(cm, Math.min(cm.display.scroller.scrollLeft, op.maxScrollLeft), true); } + cm.display.maxLineChanged = false; } - return this.input; - }, - updateVisibility: function updateVisibility() { - this.el.style.display = this.model.get('visible') ? 'block' : 'none'; - }, - show: function show() { - this.model.set('visible', 1); - }, - hide: function hide() { - this.model.set('visible', 0); - }, - + var takeFocus = op.focus && op.focus == activeElt(); + if (op.preparedSelection) + { cm.display.input.showSelection(op.preparedSelection, takeFocus); } + if (op.updatedDisplay || op.startHeight != cm.doc.height) + { updateScrollbars(cm, op.barMeasure); } + if (op.updatedDisplay) + { setDocumentHeight(cm, op.barMeasure); } - /** - * Clean input - * */ - cleanValue: function cleanValue() { - this.setValue(''); - }, - render: function render() { - var pfx = this.pfx; - var model = this.model; - var el = this.el; - el.innerHTML = this.template(model); - el.className = pfx + 'property ' + pfx + model.get('type'); - this.updateStatus(); + if (op.selectionChanged) { restartBlink(cm); } - var onRender = this.onRender && this.onRender.bind(this); - onRender && onRender(); - this.setValue(model.get('value'), { targetUpdate: 1 }); + if (cm.state.focused && op.updateInput) + { cm.display.input.reset(op.typing); } + if (takeFocus) { ensureFocus(op.cm); } } -}); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(0))) - -/***/ }), -/* 6 */ -/***/ (function(module, exports, __webpack_require__) { - -// CodeMirror, copyright (c) by Marijn Haverbeke and others -// Distributed under an MIT license: http://codemirror.net/LICENSE -// This is CodeMirror (http://codemirror.net), a code editor -// implemented in JavaScript on top of the browser's DOM. -// -// You can find some technical background for some of the code below -// at http://marijnhaverbeke.nl/blog/#cm-internals . + function endOperation_finish(op) { + var cm = op.cm, display = cm.display, doc = cm.doc; -(function (global, factory) { - true ? module.exports = factory() : - typeof define === 'function' && define.amd ? define(factory) : - (global.CodeMirror = factory()); -}(this, (function () { 'use strict'; + if (op.updatedDisplay) { postUpdateDisplay(cm, op.update); } -// Kludges for bugs and behavior differences that can't be feature -// detected are enabled based on userAgent etc sniffing. -var userAgent = navigator.userAgent; -var platform = navigator.platform; - -var gecko = /gecko\/\d/i.test(userAgent); -var ie_upto10 = /MSIE \d/.test(userAgent); -var ie_11up = /Trident\/(?:[7-9]|\d{2,})\..*rv:(\d+)/.exec(userAgent); -var edge = /Edge\/(\d+)/.exec(userAgent); -var ie = ie_upto10 || ie_11up || edge; -var ie_version = ie && (ie_upto10 ? document.documentMode || 6 : +(edge || ie_11up)[1]); -var webkit = !edge && /WebKit\//.test(userAgent); -var qtwebkit = webkit && /Qt\/\d+\.\d+/.test(userAgent); -var chrome = !edge && /Chrome\//.test(userAgent); -var presto = /Opera\//.test(userAgent); -var safari = /Apple Computer/.test(navigator.vendor); -var mac_geMountainLion = /Mac OS X 1\d\D([8-9]|\d\d)\D/.test(userAgent); -var phantom = /PhantomJS/.test(userAgent); - -var ios = !edge && /AppleWebKit/.test(userAgent) && /Mobile\/\w+/.test(userAgent); -var android = /Android/.test(userAgent); -// This is woefully incomplete. Suggestions for alternative methods welcome. -var mobile = ios || android || /webOS|BlackBerry|Opera Mini|Opera Mobi|IEMobile/i.test(userAgent); -var mac = ios || /Mac/.test(platform); -var chromeOS = /\bCrOS\b/.test(userAgent); -var windows = /win/i.test(platform); - -var presto_version = presto && userAgent.match(/Version\/(\d*\.\d*)/); -if (presto_version) { presto_version = Number(presto_version[1]); } -if (presto_version && presto_version >= 15) { presto = false; webkit = true; } -// Some browsers use the wrong event properties to signal cmd/ctrl on OS X -var flipCtrlCmd = mac && (qtwebkit || presto && (presto_version == null || presto_version < 12.11)); -var captureRightClick = gecko || (ie && ie_version >= 9); - -function classTest(cls) { return new RegExp("(^|\\s)" + cls + "(?:$|\\s)\\s*") } - -var rmClass = function(node, cls) { - var current = node.className; - var match = classTest(cls).exec(current); - if (match) { - var after = current.slice(match.index + match[0].length); - node.className = current.slice(0, match.index) + (after ? match[1] + after : ""); - } -}; + // Abort mouse wheel delta measurement, when scrolling explicitly + if (display.wheelStartX != null && (op.scrollTop != null || op.scrollLeft != null || op.scrollToPos)) + { display.wheelStartX = display.wheelStartY = null; } -function removeChildren(e) { - for (var count = e.childNodes.length; count > 0; --count) - { e.removeChild(e.firstChild); } - return e -} + // Propagate the scroll position to the actual DOM scroller + if (op.scrollTop != null) { setScrollTop(cm, op.scrollTop, op.forceScroll); } -function removeChildrenAndAdd(parent, e) { - return removeChildren(parent).appendChild(e) -} + if (op.scrollLeft != null) { setScrollLeft(cm, op.scrollLeft, true, true); } + // If we need to scroll a specific position into view, do so. + if (op.scrollToPos) { + var rect = scrollPosIntoView(cm, clipPos(doc, op.scrollToPos.from), + clipPos(doc, op.scrollToPos.to), op.scrollToPos.margin); + maybeScrollWindow(cm, rect); + } -function elt(tag, content, className, style) { - var e = document.createElement(tag); - if (className) { e.className = className; } - if (style) { e.style.cssText = style; } - if (typeof content == "string") { e.appendChild(document.createTextNode(content)); } - else if (content) { for (var i = 0; i < content.length; ++i) { e.appendChild(content[i]); } } - return e -} -// wrapper for elt, which removes the elt from the accessibility tree -function eltP(tag, content, className, style) { - var e = elt(tag, content, className, style); - e.setAttribute("role", "presentation"); - return e -} + // Fire events for markers that are hidden/unidden by editing or + // undoing + var hidden = op.maybeHiddenMarkers, unhidden = op.maybeUnhiddenMarkers; + if (hidden) { for (var i = 0; i < hidden.length; ++i) + { if (!hidden[i].lines.length) { signal(hidden[i], "hide"); } } } + if (unhidden) { for (var i$1 = 0; i$1 < unhidden.length; ++i$1) + { if (unhidden[i$1].lines.length) { signal(unhidden[i$1], "unhide"); } } } -var range; -if (document.createRange) { range = function(node, start, end, endNode) { - var r = document.createRange(); - r.setEnd(endNode || node, end); - r.setStart(node, start); - return r -}; } -else { range = function(node, start, end) { - var r = document.body.createTextRange(); - try { r.moveToElementText(node.parentNode); } - catch(e) { return r } - r.collapse(true); - r.moveEnd("character", end); - r.moveStart("character", start); - return r -}; } - -function contains(parent, child) { - if (child.nodeType == 3) // Android browser always returns false when child is a textnode - { child = child.parentNode; } - if (parent.contains) - { return parent.contains(child) } - do { - if (child.nodeType == 11) { child = child.host; } - if (child == parent) { return true } - } while (child = child.parentNode) -} + if (display.wrapper.offsetHeight) + { doc.scrollTop = cm.display.scroller.scrollTop; } -function activeElt() { - // IE and Edge may throw an "Unspecified Error" when accessing document.activeElement. - // IE < 10 will throw when accessed while the page is loading or in an iframe. - // IE > 9 and Edge will throw when accessed in an iframe if document.body is unavailable. - var activeElement; - try { - activeElement = document.activeElement; - } catch(e) { - activeElement = document.body || null; + // Fire change events, and delayed event handlers + if (op.changeObjs) + { signal(cm, "changes", cm, op.changeObjs); } + if (op.update) + { op.update.finish(); } } - while (activeElement && activeElement.shadowRoot && activeElement.shadowRoot.activeElement) - { activeElement = activeElement.shadowRoot.activeElement; } - return activeElement -} -function addClass(node, cls) { - var current = node.className; - if (!classTest(cls).test(current)) { node.className += (current ? " " : "") + cls; } -} -function joinClasses(a, b) { - var as = a.split(" "); - for (var i = 0; i < as.length; i++) - { if (as[i] && !classTest(as[i]).test(b)) { b += " " + as[i]; } } - return b -} + // Run the given function in an operation + function runInOp(cm, f) { + if (cm.curOp) { return f() } + startOperation(cm); + try { return f() } + finally { endOperation(cm); } + } + // Wraps a function in an operation. Returns the wrapped function. + function operation(cm, f) { + return function() { + if (cm.curOp) { return f.apply(cm, arguments) } + startOperation(cm); + try { return f.apply(cm, arguments) } + finally { endOperation(cm); } + } + } + // Used to add methods to editor and doc instances, wrapping them in + // operations. + function methodOp(f) { + return function() { + if (this.curOp) { return f.apply(this, arguments) } + startOperation(this); + try { return f.apply(this, arguments) } + finally { endOperation(this); } + } + } + function docMethodOp(f) { + return function() { + var cm = this.cm; + if (!cm || cm.curOp) { return f.apply(this, arguments) } + startOperation(cm); + try { return f.apply(this, arguments) } + finally { endOperation(cm); } + } + } + + // HIGHLIGHT WORKER + + function startWorker(cm, time) { + if (cm.doc.highlightFrontier < cm.display.viewTo) + { cm.state.highlight.set(time, bind(highlightWorker, cm)); } + } + + function highlightWorker(cm) { + var doc = cm.doc; + if (doc.highlightFrontier >= cm.display.viewTo) { return } + var end = +new Date + cm.options.workTime; + var context = getContextBefore(cm, doc.highlightFrontier); + var changedLines = []; + + doc.iter(context.line, Math.min(doc.first + doc.size, cm.display.viewTo + 500), function (line) { + if (context.line >= cm.display.viewFrom) { // Visible + var oldStyles = line.styles; + var resetState = line.text.length > cm.options.maxHighlightLength ? copyState(doc.mode, context.state) : null; + var highlighted = highlightLine(cm, line, context, true); + if (resetState) { context.state = resetState; } + line.styles = highlighted.styles; + var oldCls = line.styleClasses, newCls = highlighted.classes; + if (newCls) { line.styleClasses = newCls; } + else if (oldCls) { line.styleClasses = null; } + var ischange = !oldStyles || oldStyles.length != line.styles.length || + oldCls != newCls && (!oldCls || !newCls || oldCls.bgClass != newCls.bgClass || oldCls.textClass != newCls.textClass); + for (var i = 0; !ischange && i < oldStyles.length; ++i) { ischange = oldStyles[i] != line.styles[i]; } + if (ischange) { changedLines.push(context.line); } + line.stateAfter = context.save(); + context.nextLine(); + } else { + if (line.text.length <= cm.options.maxHighlightLength) + { processLine(cm, line.text, context); } + line.stateAfter = context.line % 5 == 0 ? context.save() : null; + context.nextLine(); + } + if (+new Date > end) { + startWorker(cm, cm.options.workDelay); + return true + } + }); + doc.highlightFrontier = context.line; + doc.modeFrontier = Math.max(doc.modeFrontier, context.line); + if (changedLines.length) { runInOp(cm, function () { + for (var i = 0; i < changedLines.length; i++) + { regLineChange(cm, changedLines[i], "text"); } + }); } + } -var selectInput = function(node) { node.select(); }; -if (ios) // Mobile Safari apparently has a bug where select() is broken. - { selectInput = function(node) { node.selectionStart = 0; node.selectionEnd = node.value.length; }; } -else if (ie) // Suppress mysterious IE10 errors - { selectInput = function(node) { try { node.select(); } catch(_e) {} }; } + // DISPLAY DRAWING -function bind(f) { - var args = Array.prototype.slice.call(arguments, 1); - return function(){return f.apply(null, args)} -} + var DisplayUpdate = function(cm, viewport, force) { + var display = cm.display; -function copyObj(obj, target, overwrite) { - if (!target) { target = {}; } - for (var prop in obj) - { if (obj.hasOwnProperty(prop) && (overwrite !== false || !target.hasOwnProperty(prop))) - { target[prop] = obj[prop]; } } - return target -} + this.viewport = viewport; + // Store some values that we'll need later (but don't want to force a relayout for) + this.visible = visibleLines(display, cm.doc, viewport); + this.editorIsHidden = !display.wrapper.offsetWidth; + this.wrapperHeight = display.wrapper.clientHeight; + this.wrapperWidth = display.wrapper.clientWidth; + this.oldDisplayWidth = displayWidth(cm); + this.force = force; + this.dims = getDimensions(cm); + this.events = []; + }; -// Counts the column offset in a string, taking tabs into account. -// Used mostly to find indentation. -function countColumn(string, end, tabSize, startIndex, startValue) { - if (end == null) { - end = string.search(/[^\s\u00a0]/); - if (end == -1) { end = string.length; } - } - for (var i = startIndex || 0, n = startValue || 0;;) { - var nextTab = string.indexOf("\t", i); - if (nextTab < 0 || nextTab >= end) - { return n + (end - i) } - n += nextTab - i; - n += tabSize - (n % tabSize); - i = nextTab + 1; - } -} + DisplayUpdate.prototype.signal = function (emitter, type) { + if (hasHandler(emitter, type)) + { this.events.push(arguments); } + }; + DisplayUpdate.prototype.finish = function () { + var this$1 = this; -var Delayed = function() {this.id = null;}; -Delayed.prototype.set = function (ms, f) { - clearTimeout(this.id); - this.id = setTimeout(f, ms); -}; + for (var i = 0; i < this.events.length; i++) + { signal.apply(null, this$1.events[i]); } + }; -function indexOf(array, elt) { - for (var i = 0; i < array.length; ++i) - { if (array[i] == elt) { return i } } - return -1 -} + function maybeClipScrollbars(cm) { + var display = cm.display; + if (!display.scrollbarsClipped && display.scroller.offsetWidth) { + display.nativeBarWidth = display.scroller.offsetWidth - display.scroller.clientWidth; + display.heightForcer.style.height = scrollGap(cm) + "px"; + display.sizer.style.marginBottom = -display.nativeBarWidth + "px"; + display.sizer.style.borderRightWidth = scrollGap(cm) + "px"; + display.scrollbarsClipped = true; + } + } -// Number of pixels added to scroller and sizer to hide scrollbar -var scrollerGap = 30; - -// Returned or thrown by various protocols to signal 'I'm not -// handling this'. -var Pass = {toString: function(){return "CodeMirror.Pass"}}; - -// Reused option objects for setSelection & friends -var sel_dontScroll = {scroll: false}; -var sel_mouse = {origin: "*mouse"}; -var sel_move = {origin: "+move"}; - -// The inverse of countColumn -- find the offset that corresponds to -// a particular column. -function findColumn(string, goal, tabSize) { - for (var pos = 0, col = 0;;) { - var nextTab = string.indexOf("\t", pos); - if (nextTab == -1) { nextTab = string.length; } - var skipped = nextTab - pos; - if (nextTab == string.length || col + skipped >= goal) - { return pos + Math.min(skipped, goal - col) } - col += nextTab - pos; - col += tabSize - (col % tabSize); - pos = nextTab + 1; - if (col >= goal) { return pos } + function selectionSnapshot(cm) { + if (cm.hasFocus()) { return null } + var active = activeElt(); + if (!active || !contains(cm.display.lineDiv, active)) { return null } + var result = {activeElt: active}; + if (window.getSelection) { + var sel = window.getSelection(); + if (sel.anchorNode && sel.extend && contains(cm.display.lineDiv, sel.anchorNode)) { + result.anchorNode = sel.anchorNode; + result.anchorOffset = sel.anchorOffset; + result.focusNode = sel.focusNode; + result.focusOffset = sel.focusOffset; + } + } + return result } -} -var spaceStrs = [""]; -function spaceStr(n) { - while (spaceStrs.length <= n) - { spaceStrs.push(lst(spaceStrs) + " "); } - return spaceStrs[n] -} + function restoreSelection(snapshot) { + if (!snapshot || !snapshot.activeElt || snapshot.activeElt == activeElt()) { return } + snapshot.activeElt.focus(); + if (snapshot.anchorNode && contains(document.body, snapshot.anchorNode) && contains(document.body, snapshot.focusNode)) { + var sel = window.getSelection(), range$$1 = document.createRange(); + range$$1.setEnd(snapshot.anchorNode, snapshot.anchorOffset); + range$$1.collapse(false); + sel.removeAllRanges(); + sel.addRange(range$$1); + sel.extend(snapshot.focusNode, snapshot.focusOffset); + } + } -function lst(arr) { return arr[arr.length-1] } + // Does the actual updating of the line display. Bails out + // (returning false) when there is nothing to be done and forced is + // false. + function updateDisplayIfNeeded(cm, update) { + var display = cm.display, doc = cm.doc; -function map(array, f) { - var out = []; - for (var i = 0; i < array.length; i++) { out[i] = f(array[i], i); } - return out -} + if (update.editorIsHidden) { + resetView(cm); + return false + } -function insertSorted(array, value, score) { - var pos = 0, priority = score(value); - while (pos < array.length && score(array[pos]) <= priority) { pos++; } - array.splice(pos, 0, value); -} + // Bail out if the visible area is already rendered and nothing changed. + if (!update.force && + update.visible.from >= display.viewFrom && update.visible.to <= display.viewTo && + (display.updateLineNumbers == null || display.updateLineNumbers >= display.viewTo) && + display.renderedView == display.view && countDirtyView(cm) == 0) + { return false } -function nothing() {} + if (maybeUpdateLineNumberWidth(cm)) { + resetView(cm); + update.dims = getDimensions(cm); + } + + // Compute a suitable new viewport (from & to) + var end = doc.first + doc.size; + var from = Math.max(update.visible.from - cm.options.viewportMargin, doc.first); + var to = Math.min(end, update.visible.to + cm.options.viewportMargin); + if (display.viewFrom < from && from - display.viewFrom < 20) { from = Math.max(doc.first, display.viewFrom); } + if (display.viewTo > to && display.viewTo - to < 20) { to = Math.min(end, display.viewTo); } + if (sawCollapsedSpans) { + from = visualLineNo(cm.doc, from); + to = visualLineEndNo(cm.doc, to); + } + + var different = from != display.viewFrom || to != display.viewTo || + display.lastWrapHeight != update.wrapperHeight || display.lastWrapWidth != update.wrapperWidth; + adjustView(cm, from, to); + + display.viewOffset = heightAtLine(getLine(cm.doc, display.viewFrom)); + // Position the mover div to align with the current scroll position + cm.display.mover.style.top = display.viewOffset + "px"; + + var toUpdate = countDirtyView(cm); + if (!different && toUpdate == 0 && !update.force && display.renderedView == display.view && + (display.updateLineNumbers == null || display.updateLineNumbers >= display.viewTo)) + { return false } + + // For big changes, we hide the enclosing element during the + // update, since that speeds up the operations on most browsers. + var selSnapshot = selectionSnapshot(cm); + if (toUpdate > 4) { display.lineDiv.style.display = "none"; } + patchDisplay(cm, display.updateLineNumbers, update.dims); + if (toUpdate > 4) { display.lineDiv.style.display = ""; } + display.renderedView = display.view; + // There might have been a widget with a focused element that got + // hidden or updated, if so re-focus it. + restoreSelection(selSnapshot); + + // Prevent selection and cursors from interfering with the scroll + // width and height. + removeChildren(display.cursorDiv); + removeChildren(display.selectionDiv); + display.gutters.style.height = display.sizer.style.minHeight = 0; + + if (different) { + display.lastWrapHeight = update.wrapperHeight; + display.lastWrapWidth = update.wrapperWidth; + startWorker(cm, 400); + } + + display.updateLineNumbers = null; -function createObj(base, props) { - var inst; - if (Object.create) { - inst = Object.create(base); - } else { - nothing.prototype = base; - inst = new nothing(); + return true } - if (props) { copyObj(props, inst); } - return inst -} - -var nonASCIISingleCaseWordChar = /[\u00df\u0587\u0590-\u05f4\u0600-\u06ff\u3040-\u309f\u30a0-\u30ff\u3400-\u4db5\u4e00-\u9fcc\uac00-\ud7af]/; -function isWordCharBasic(ch) { - return /\w/.test(ch) || ch > "\x80" && - (ch.toUpperCase() != ch.toLowerCase() || nonASCIISingleCaseWordChar.test(ch)) -} -function isWordChar(ch, helper) { - if (!helper) { return isWordCharBasic(ch) } - if (helper.source.indexOf("\\w") > -1 && isWordCharBasic(ch)) { return true } - return helper.test(ch) -} - -function isEmpty(obj) { - for (var n in obj) { if (obj.hasOwnProperty(n) && obj[n]) { return false } } - return true -} -// Extending unicode characters. A series of a non-extending char + -// any number of extending chars is treated as a single unit as far -// as editing and measuring is concerned. This is not fully correct, -// since some scripts/fonts/browsers also treat other configurations -// of code points as a group. -var extendingChars = /[\u0300-\u036f\u0483-\u0489\u0591-\u05bd\u05bf\u05c1\u05c2\u05c4\u05c5\u05c7\u0610-\u061a\u064b-\u065e\u0670\u06d6-\u06dc\u06de-\u06e4\u06e7\u06e8\u06ea-\u06ed\u0711\u0730-\u074a\u07a6-\u07b0\u07eb-\u07f3\u0816-\u0819\u081b-\u0823\u0825-\u0827\u0829-\u082d\u0900-\u0902\u093c\u0941-\u0948\u094d\u0951-\u0955\u0962\u0963\u0981\u09bc\u09be\u09c1-\u09c4\u09cd\u09d7\u09e2\u09e3\u0a01\u0a02\u0a3c\u0a41\u0a42\u0a47\u0a48\u0a4b-\u0a4d\u0a51\u0a70\u0a71\u0a75\u0a81\u0a82\u0abc\u0ac1-\u0ac5\u0ac7\u0ac8\u0acd\u0ae2\u0ae3\u0b01\u0b3c\u0b3e\u0b3f\u0b41-\u0b44\u0b4d\u0b56\u0b57\u0b62\u0b63\u0b82\u0bbe\u0bc0\u0bcd\u0bd7\u0c3e-\u0c40\u0c46-\u0c48\u0c4a-\u0c4d\u0c55\u0c56\u0c62\u0c63\u0cbc\u0cbf\u0cc2\u0cc6\u0ccc\u0ccd\u0cd5\u0cd6\u0ce2\u0ce3\u0d3e\u0d41-\u0d44\u0d4d\u0d57\u0d62\u0d63\u0dca\u0dcf\u0dd2-\u0dd4\u0dd6\u0ddf\u0e31\u0e34-\u0e3a\u0e47-\u0e4e\u0eb1\u0eb4-\u0eb9\u0ebb\u0ebc\u0ec8-\u0ecd\u0f18\u0f19\u0f35\u0f37\u0f39\u0f71-\u0f7e\u0f80-\u0f84\u0f86\u0f87\u0f90-\u0f97\u0f99-\u0fbc\u0fc6\u102d-\u1030\u1032-\u1037\u1039\u103a\u103d\u103e\u1058\u1059\u105e-\u1060\u1071-\u1074\u1082\u1085\u1086\u108d\u109d\u135f\u1712-\u1714\u1732-\u1734\u1752\u1753\u1772\u1773\u17b7-\u17bd\u17c6\u17c9-\u17d3\u17dd\u180b-\u180d\u18a9\u1920-\u1922\u1927\u1928\u1932\u1939-\u193b\u1a17\u1a18\u1a56\u1a58-\u1a5e\u1a60\u1a62\u1a65-\u1a6c\u1a73-\u1a7c\u1a7f\u1b00-\u1b03\u1b34\u1b36-\u1b3a\u1b3c\u1b42\u1b6b-\u1b73\u1b80\u1b81\u1ba2-\u1ba5\u1ba8\u1ba9\u1c2c-\u1c33\u1c36\u1c37\u1cd0-\u1cd2\u1cd4-\u1ce0\u1ce2-\u1ce8\u1ced\u1dc0-\u1de6\u1dfd-\u1dff\u200c\u200d\u20d0-\u20f0\u2cef-\u2cf1\u2de0-\u2dff\u302a-\u302f\u3099\u309a\ua66f-\ua672\ua67c\ua67d\ua6f0\ua6f1\ua802\ua806\ua80b\ua825\ua826\ua8c4\ua8e0-\ua8f1\ua926-\ua92d\ua947-\ua951\ua980-\ua982\ua9b3\ua9b6-\ua9b9\ua9bc\uaa29-\uaa2e\uaa31\uaa32\uaa35\uaa36\uaa43\uaa4c\uaab0\uaab2-\uaab4\uaab7\uaab8\uaabe\uaabf\uaac1\uabe5\uabe8\uabed\udc00-\udfff\ufb1e\ufe00-\ufe0f\ufe20-\ufe26\uff9e\uff9f]/; -function isExtendingChar(ch) { return ch.charCodeAt(0) >= 768 && extendingChars.test(ch) } - -// Returns a number from the range [`0`; `str.length`] unless `pos` is outside that range. -function skipExtendingChars(str, pos, dir) { - while ((dir < 0 ? pos > 0 : pos < str.length) && isExtendingChar(str.charAt(pos))) { pos += dir; } - return pos -} + function postUpdateDisplay(cm, update) { + var viewport = update.viewport; -// Returns the value from the range [`from`; `to`] that satisfies -// `pred` and is closest to `from`. Assumes that at least `to` -// satisfies `pred`. Supports `from` being greater than `to`. -function findFirst(pred, from, to) { - // At any point we are certain `to` satisfies `pred`, don't know - // whether `from` does. - var dir = from > to ? -1 : 1; - for (;;) { - if (from == to) { return from } - var midF = (from + to) / 2, mid = dir < 0 ? Math.ceil(midF) : Math.floor(midF); - if (mid == from) { return pred(mid) ? from : to } - if (pred(mid)) { to = mid; } - else { from = mid + dir; } + for (var first = true;; first = false) { + if (!first || !cm.options.lineWrapping || update.oldDisplayWidth == displayWidth(cm)) { + // Clip forced viewport to actual scrollable area. + if (viewport && viewport.top != null) + { viewport = {top: Math.min(cm.doc.height + paddingVert(cm.display) - displayHeight(cm), viewport.top)}; } + // Updated line heights might result in the drawn area not + // actually covering the viewport. Keep looping until it does. + update.visible = visibleLines(cm.display, cm.doc, viewport); + if (update.visible.from >= cm.display.viewFrom && update.visible.to <= cm.display.viewTo) + { break } + } + if (!updateDisplayIfNeeded(cm, update)) { break } + updateHeightsInViewport(cm); + var barMeasure = measureForScrollbars(cm); + updateSelection(cm); + updateScrollbars(cm, barMeasure); + setDocumentHeight(cm, barMeasure); + update.force = false; + } + + update.signal(cm, "update", cm); + if (cm.display.viewFrom != cm.display.reportedViewFrom || cm.display.viewTo != cm.display.reportedViewTo) { + update.signal(cm, "viewportChange", cm, cm.display.viewFrom, cm.display.viewTo); + cm.display.reportedViewFrom = cm.display.viewFrom; cm.display.reportedViewTo = cm.display.viewTo; + } + } + + function updateDisplaySimple(cm, viewport) { + var update = new DisplayUpdate(cm, viewport); + if (updateDisplayIfNeeded(cm, update)) { + updateHeightsInViewport(cm); + postUpdateDisplay(cm, update); + var barMeasure = measureForScrollbars(cm); + updateSelection(cm); + updateScrollbars(cm, barMeasure); + setDocumentHeight(cm, barMeasure); + update.finish(); + } + } + + // Sync the actual display DOM structure with display.view, removing + // nodes for lines that are no longer in view, and creating the ones + // that are not there yet, and updating the ones that are out of + // date. + function patchDisplay(cm, updateNumbersFrom, dims) { + var display = cm.display, lineNumbers = cm.options.lineNumbers; + var container = display.lineDiv, cur = container.firstChild; + + function rm(node) { + var next = node.nextSibling; + // Works around a throw-scroll bug in OS X Webkit + if (webkit && mac && cm.display.currentWheelTarget == node) + { node.style.display = "none"; } + else + { node.parentNode.removeChild(node); } + return next + } + + var view = display.view, lineN = display.viewFrom; + // Loop over the elements in the view, syncing cur (the DOM nodes + // in display.lineDiv) with the view as we go. + for (var i = 0; i < view.length; i++) { + var lineView = view[i]; + if (lineView.hidden) ; else if (!lineView.node || lineView.node.parentNode != container) { // Not drawn yet + var node = buildLineElement(cm, lineView, lineN, dims); + container.insertBefore(node, cur); + } else { // Already drawn + while (cur != lineView.node) { cur = rm(cur); } + var updateNumber = lineNumbers && updateNumbersFrom != null && + updateNumbersFrom <= lineN && lineView.lineNumber; + if (lineView.changes) { + if (indexOf(lineView.changes, "gutter") > -1) { updateNumber = false; } + updateLineForChanges(cm, lineView, lineN, dims); + } + if (updateNumber) { + removeChildren(lineView.lineNumber); + lineView.lineNumber.appendChild(document.createTextNode(lineNumberFor(cm.options, lineN))); + } + cur = lineView.node.nextSibling; + } + lineN += lineView.size; + } + while (cur) { cur = rm(cur); } + } + + function updateGutterSpace(display) { + var width = display.gutters.offsetWidth; + display.sizer.style.marginLeft = width + "px"; + } + + function setDocumentHeight(cm, measure) { + cm.display.sizer.style.minHeight = measure.docHeight + "px"; + cm.display.heightForcer.style.top = measure.docHeight + "px"; + cm.display.gutters.style.height = (measure.docHeight + cm.display.barHeight + scrollGap(cm)) + "px"; + } + + // Re-align line numbers and gutter marks to compensate for + // horizontal scrolling. + function alignHorizontally(cm) { + var display = cm.display, view = display.view; + if (!display.alignWidgets && (!display.gutters.firstChild || !cm.options.fixedGutter)) { return } + var comp = compensateForHScroll(display) - display.scroller.scrollLeft + cm.doc.scrollLeft; + var gutterW = display.gutters.offsetWidth, left = comp + "px"; + for (var i = 0; i < view.length; i++) { if (!view[i].hidden) { + if (cm.options.fixedGutter) { + if (view[i].gutter) + { view[i].gutter.style.left = left; } + if (view[i].gutterBackground) + { view[i].gutterBackground.style.left = left; } + } + var align = view[i].alignable; + if (align) { for (var j = 0; j < align.length; j++) + { align[j].style.left = left; } } + } } + if (cm.options.fixedGutter) + { display.gutters.style.left = (comp + gutterW) + "px"; } + } + + // Used to ensure that the line number gutter is still the right + // size for the current document size. Returns true when an update + // is needed. + function maybeUpdateLineNumberWidth(cm) { + if (!cm.options.lineNumbers) { return false } + var doc = cm.doc, last = lineNumberFor(cm.options, doc.first + doc.size - 1), display = cm.display; + if (last.length != display.lineNumChars) { + var test = display.measure.appendChild(elt("div", [elt("div", last)], + "CodeMirror-linenumber CodeMirror-gutter-elt")); + var innerW = test.firstChild.offsetWidth, padding = test.offsetWidth - innerW; + display.lineGutter.style.width = ""; + display.lineNumInnerWidth = Math.max(innerW, display.lineGutter.offsetWidth - padding) + 1; + display.lineNumWidth = display.lineNumInnerWidth + padding; + display.lineNumChars = display.lineNumInnerWidth ? last.length : -1; + display.lineGutter.style.width = display.lineNumWidth + "px"; + updateGutterSpace(cm.display); + return true + } + return false } -} -// The display handles the DOM integration, both for input reading -// and content drawing. It holds references to DOM nodes and -// display-related state. - -function Display(place, doc, input) { - var d = this; - this.input = input; - - // Covers bottom-right square when both scrollbars are present. - d.scrollbarFiller = elt("div", null, "CodeMirror-scrollbar-filler"); - d.scrollbarFiller.setAttribute("cm-not-content", "true"); - // Covers bottom of gutter when coverGutterNextToScrollbar is on - // and h scrollbar is present. - d.gutterFiller = elt("div", null, "CodeMirror-gutter-filler"); - d.gutterFiller.setAttribute("cm-not-content", "true"); - // Will contain the actual code, positioned to cover the viewport. - d.lineDiv = eltP("div", null, "CodeMirror-code"); - // Elements are added to these to represent selection and cursors. - d.selectionDiv = elt("div", null, null, "position: relative; z-index: 1"); - d.cursorDiv = elt("div", null, "CodeMirror-cursors"); - // A visibility: hidden element used to find the size of things. - d.measure = elt("div", null, "CodeMirror-measure"); - // When lines outside of the viewport are measured, they are drawn in this. - d.lineMeasure = elt("div", null, "CodeMirror-measure"); - // Wraps everything that needs to exist inside the vertically-padded coordinate system - d.lineSpace = eltP("div", [d.measure, d.lineMeasure, d.selectionDiv, d.cursorDiv, d.lineDiv], - null, "position: relative; outline: none"); - var lines = eltP("div", [d.lineSpace], "CodeMirror-lines"); - // Moved around its parent to cover visible view. - d.mover = elt("div", [lines], null, "position: relative"); - // Set to the height of the document, allowing scrolling. - d.sizer = elt("div", [d.mover], "CodeMirror-sizer"); - d.sizerWidth = null; - // Behavior of elts with overflow: auto and padding is - // inconsistent across browsers. This is used to ensure the - // scrollable area is big enough. - d.heightForcer = elt("div", null, null, "position: absolute; height: " + scrollerGap + "px; width: 1px;"); - // Will contain the gutters, if any. - d.gutters = elt("div", null, "CodeMirror-gutters"); - d.lineGutter = null; - // Actual scrollable element. - d.scroller = elt("div", [d.sizer, d.heightForcer, d.gutters], "CodeMirror-scroll"); - d.scroller.setAttribute("tabIndex", "-1"); - // The element in which the editor lives. - d.wrapper = elt("div", [d.scrollbarFiller, d.gutterFiller, d.scroller], "CodeMirror"); - - // Work around IE7 z-index bug (not perfect, hence IE7 not really being supported) - if (ie && ie_version < 8) { d.gutters.style.zIndex = -1; d.scroller.style.paddingRight = 0; } - if (!webkit && !(gecko && mobile)) { d.scroller.draggable = true; } - - if (place) { - if (place.appendChild) { place.appendChild(d.wrapper); } - else { place(d.wrapper); } - } - - // Current rendered range (may be bigger than the view window). - d.viewFrom = d.viewTo = doc.first; - d.reportedViewFrom = d.reportedViewTo = doc.first; - // Information about the rendered lines. - d.view = []; - d.renderedView = null; - // Holds info about a single rendered line when it was rendered - // for measurement, while not in view. - d.externalMeasured = null; - // Empty space (in pixels) above the view - d.viewOffset = 0; - d.lastWrapHeight = d.lastWrapWidth = 0; - d.updateLineNumbers = null; - - d.nativeBarWidth = d.barHeight = d.barWidth = 0; - d.scrollbarsClipped = false; - - // Used to only resize the line number gutter when necessary (when - // the amount of lines crosses a boundary that makes its width change) - d.lineNumWidth = d.lineNumInnerWidth = d.lineNumChars = null; - // Set to true when a non-horizontal-scrolling line widget is - // added. As an optimization, line widget aligning is skipped when - // this is false. - d.alignWidgets = false; - - d.cachedCharWidth = d.cachedTextHeight = d.cachedPaddingH = null; - - // Tracks the maximum line length so that the horizontal scrollbar - // can be kept static when scrolling. - d.maxLine = null; - d.maxLineLength = 0; - d.maxLineChanged = false; - - // Used for measuring wheel scrolling granularity - d.wheelDX = d.wheelDY = d.wheelStartX = d.wheelStartY = null; - - // True when shift is held down. - d.shift = false; - - // Used to track whether anything happened since the context menu - // was opened. - d.selForContextMenu = null; - - d.activeTouch = null; - - input.init(d); -} - -// Find the line object corresponding to the given line number. -function getLine(doc, n) { - n -= doc.first; - if (n < 0 || n >= doc.size) { throw new Error("There is no line " + (n + doc.first) + " in the document.") } - var chunk = doc; - while (!chunk.lines) { - for (var i = 0;; ++i) { - var child = chunk.children[i], sz = child.chunkSize(); - if (n < sz) { chunk = child; break } - n -= sz; + function getGutters(gutters, lineNumbers) { + var result = [], sawLineNumbers = false; + for (var i = 0; i < gutters.length; i++) { + var name = gutters[i], style = null; + if (typeof name != "string") { style = name.style; name = name.className; } + if (name == "CodeMirror-linenumbers") { + if (!lineNumbers) { continue } + else { sawLineNumbers = true; } + } + result.push({className: name, style: style}); } + if (lineNumbers && !sawLineNumbers) { result.push({className: "CodeMirror-linenumbers", style: null}); } + return result } - return chunk.lines[n] -} - -// Get the part of a document between two positions, as an array of -// strings. -function getBetween(doc, start, end) { - var out = [], n = start.line; - doc.iter(start.line, end.line + 1, function (line) { - var text = line.text; - if (n == end.line) { text = text.slice(0, end.ch); } - if (n == start.line) { text = text.slice(start.ch); } - out.push(text); - ++n; - }); - return out -} -// Get the lines between from and to, as array of strings. -function getLines(doc, from, to) { - var out = []; - doc.iter(from, to, function (line) { out.push(line.text); }); // iter aborts when callback returns truthy value - return out -} - -// Update the height of a line, propagating the height change -// upwards to parent nodes. -function updateLineHeight(line, height) { - var diff = height - line.height; - if (diff) { for (var n = line; n; n = n.parent) { n.height += diff; } } -} -// Given a line object, find its line number by walking up through -// its parent links. -function lineNo(line) { - if (line.parent == null) { return null } - var cur = line.parent, no = indexOf(cur.lines, line); - for (var chunk = cur.parent; chunk; cur = chunk, chunk = chunk.parent) { - for (var i = 0;; ++i) { - if (chunk.children[i] == cur) { break } - no += chunk.children[i].chunkSize(); + // Rebuild the gutter elements, ensure the margin to the left of the + // code matches their width. + function renderGutters(display) { + var gutters = display.gutters, specs = display.gutterSpecs; + removeChildren(gutters); + display.lineGutter = null; + for (var i = 0; i < specs.length; ++i) { + var ref = specs[i]; + var className = ref.className; + var style = ref.style; + var gElt = gutters.appendChild(elt("div", null, "CodeMirror-gutter " + className)); + if (style) { gElt.style.cssText = style; } + if (className == "CodeMirror-linenumbers") { + display.lineGutter = gElt; + gElt.style.width = (display.lineNumWidth || 1) + "px"; + } } + gutters.style.display = specs.length ? "" : "none"; + updateGutterSpace(display); } - return no + cur.first -} - -// Find the line at the given vertical position, using the height -// information in the document tree. -function lineAtHeight(chunk, h) { - var n = chunk.first; - outer: do { - for (var i$1 = 0; i$1 < chunk.children.length; ++i$1) { - var child = chunk.children[i$1], ch = child.height; - if (h < ch) { chunk = child; continue outer } - h -= ch; - n += child.chunkSize(); - } - return n - } while (!chunk.lines) - var i = 0; - for (; i < chunk.lines.length; ++i) { - var line = chunk.lines[i], lh = line.height; - if (h < lh) { break } - h -= lh; - } - return n + i -} -function isLine(doc, l) {return l >= doc.first && l < doc.first + doc.size} + function updateGutters(cm) { + renderGutters(cm.display); + regChange(cm); + alignHorizontally(cm); + } + + // The display handles the DOM integration, both for input reading + // and content drawing. It holds references to DOM nodes and + // display-related state. + + function Display(place, doc, input, options) { + var d = this; + this.input = input; + + // Covers bottom-right square when both scrollbars are present. + d.scrollbarFiller = elt("div", null, "CodeMirror-scrollbar-filler"); + d.scrollbarFiller.setAttribute("cm-not-content", "true"); + // Covers bottom of gutter when coverGutterNextToScrollbar is on + // and h scrollbar is present. + d.gutterFiller = elt("div", null, "CodeMirror-gutter-filler"); + d.gutterFiller.setAttribute("cm-not-content", "true"); + // Will contain the actual code, positioned to cover the viewport. + d.lineDiv = eltP("div", null, "CodeMirror-code"); + // Elements are added to these to represent selection and cursors. + d.selectionDiv = elt("div", null, null, "position: relative; z-index: 1"); + d.cursorDiv = elt("div", null, "CodeMirror-cursors"); + // A visibility: hidden element used to find the size of things. + d.measure = elt("div", null, "CodeMirror-measure"); + // When lines outside of the viewport are measured, they are drawn in this. + d.lineMeasure = elt("div", null, "CodeMirror-measure"); + // Wraps everything that needs to exist inside the vertically-padded coordinate system + d.lineSpace = eltP("div", [d.measure, d.lineMeasure, d.selectionDiv, d.cursorDiv, d.lineDiv], + null, "position: relative; outline: none"); + var lines = eltP("div", [d.lineSpace], "CodeMirror-lines"); + // Moved around its parent to cover visible view. + d.mover = elt("div", [lines], null, "position: relative"); + // Set to the height of the document, allowing scrolling. + d.sizer = elt("div", [d.mover], "CodeMirror-sizer"); + d.sizerWidth = null; + // Behavior of elts with overflow: auto and padding is + // inconsistent across browsers. This is used to ensure the + // scrollable area is big enough. + d.heightForcer = elt("div", null, null, "position: absolute; height: " + scrollerGap + "px; width: 1px;"); + // Will contain the gutters, if any. + d.gutters = elt("div", null, "CodeMirror-gutters"); + d.lineGutter = null; + // Actual scrollable element. + d.scroller = elt("div", [d.sizer, d.heightForcer, d.gutters], "CodeMirror-scroll"); + d.scroller.setAttribute("tabIndex", "-1"); + // The element in which the editor lives. + d.wrapper = elt("div", [d.scrollbarFiller, d.gutterFiller, d.scroller], "CodeMirror"); + + // Work around IE7 z-index bug (not perfect, hence IE7 not really being supported) + if (ie && ie_version < 8) { d.gutters.style.zIndex = -1; d.scroller.style.paddingRight = 0; } + if (!webkit && !(gecko && mobile)) { d.scroller.draggable = true; } + + if (place) { + if (place.appendChild) { place.appendChild(d.wrapper); } + else { place(d.wrapper); } + } + + // Current rendered range (may be bigger than the view window). + d.viewFrom = d.viewTo = doc.first; + d.reportedViewFrom = d.reportedViewTo = doc.first; + // Information about the rendered lines. + d.view = []; + d.renderedView = null; + // Holds info about a single rendered line when it was rendered + // for measurement, while not in view. + d.externalMeasured = null; + // Empty space (in pixels) above the view + d.viewOffset = 0; + d.lastWrapHeight = d.lastWrapWidth = 0; + d.updateLineNumbers = null; + + d.nativeBarWidth = d.barHeight = d.barWidth = 0; + d.scrollbarsClipped = false; + + // Used to only resize the line number gutter when necessary (when + // the amount of lines crosses a boundary that makes its width change) + d.lineNumWidth = d.lineNumInnerWidth = d.lineNumChars = null; + // Set to true when a non-horizontal-scrolling line widget is + // added. As an optimization, line widget aligning is skipped when + // this is false. + d.alignWidgets = false; + + d.cachedCharWidth = d.cachedTextHeight = d.cachedPaddingH = null; + + // Tracks the maximum line length so that the horizontal scrollbar + // can be kept static when scrolling. + d.maxLine = null; + d.maxLineLength = 0; + d.maxLineChanged = false; + + // Used for measuring wheel scrolling granularity + d.wheelDX = d.wheelDY = d.wheelStartX = d.wheelStartY = null; + + // True when shift is held down. + d.shift = false; + + // Used to track whether anything happened since the context menu + // was opened. + d.selForContextMenu = null; + + d.activeTouch = null; + + d.gutterSpecs = getGutters(options.gutters, options.lineNumbers); + renderGutters(d); + + input.init(d); + } + + // Since the delta values reported on mouse wheel events are + // unstandardized between browsers and even browser versions, and + // generally horribly unpredictable, this code starts by measuring + // the scroll effect that the first few mouse wheel events have, + // and, from that, detects the way it can convert deltas to pixel + // offsets afterwards. + // + // The reason we want to know the amount a wheel event will scroll + // is that it gives us a chance to update the display before the + // actual scrolling happens, reducing flickering. + + var wheelSamples = 0, wheelPixelsPerUnit = null; + // Fill in a browser-detected starting value on browsers where we + // know one. These don't have to be accurate -- the result of them + // being wrong would just be a slight flicker on the first wheel + // scroll (if it is large enough). + if (ie) { wheelPixelsPerUnit = -.53; } + else if (gecko) { wheelPixelsPerUnit = 15; } + else if (chrome) { wheelPixelsPerUnit = -.7; } + else if (safari) { wheelPixelsPerUnit = -1/3; } + + function wheelEventDelta(e) { + var dx = e.wheelDeltaX, dy = e.wheelDeltaY; + if (dx == null && e.detail && e.axis == e.HORIZONTAL_AXIS) { dx = e.detail; } + if (dy == null && e.detail && e.axis == e.VERTICAL_AXIS) { dy = e.detail; } + else if (dy == null) { dy = e.wheelDelta; } + return {x: dx, y: dy} + } + function wheelEventPixels(e) { + var delta = wheelEventDelta(e); + delta.x *= wheelPixelsPerUnit; + delta.y *= wheelPixelsPerUnit; + return delta + } + + function onScrollWheel(cm, e) { + var delta = wheelEventDelta(e), dx = delta.x, dy = delta.y; + + var display = cm.display, scroll = display.scroller; + // Quit if there's nothing to scroll here + var canScrollX = scroll.scrollWidth > scroll.clientWidth; + var canScrollY = scroll.scrollHeight > scroll.clientHeight; + if (!(dx && canScrollX || dy && canScrollY)) { return } + + // Webkit browsers on OS X abort momentum scrolls when the target + // of the scroll event is removed from the scrollable element. + // This hack (see related code in patchDisplay) makes sure the + // element is kept around. + if (dy && mac && webkit) { + outer: for (var cur = e.target, view = display.view; cur != scroll; cur = cur.parentNode) { + for (var i = 0; i < view.length; i++) { + if (view[i].node == cur) { + cm.display.currentWheelTarget = cur; + break outer + } + } + } + } -function lineNumberFor(options, i) { - return String(options.lineNumberFormatter(i + options.firstLineNumber)) -} + // On some browsers, horizontal scrolling will cause redraws to + // happen before the gutter has been realigned, causing it to + // wriggle around in a most unseemly way. When we have an + // estimated pixels/delta value, we just handle horizontal + // scrolling entirely here. It'll be slightly off from native, but + // better than glitching out. + if (dx && !gecko && !presto && wheelPixelsPerUnit != null) { + if (dy && canScrollY) + { updateScrollTop(cm, Math.max(0, scroll.scrollTop + dy * wheelPixelsPerUnit)); } + setScrollLeft(cm, Math.max(0, scroll.scrollLeft + dx * wheelPixelsPerUnit)); + // Only prevent default scrolling if vertical scrolling is + // actually possible. Otherwise, it causes vertical scroll + // jitter on OSX trackpads when deltaX is small and deltaY + // is large (issue #3579) + if (!dy || (dy && canScrollY)) + { e_preventDefault(e); } + display.wheelStartX = null; // Abort measurement, if in progress + return + } -// A Pos instance represents a position within the text. -function Pos(line, ch, sticky) { - if ( sticky === void 0 ) sticky = null; + // 'Project' the visible viewport to cover the area that is being + // scrolled into view (if we know enough to estimate it). + if (dy && wheelPixelsPerUnit != null) { + var pixels = dy * wheelPixelsPerUnit; + var top = cm.doc.scrollTop, bot = top + display.wrapper.clientHeight; + if (pixels < 0) { top = Math.max(0, top + pixels - 50); } + else { bot = Math.min(cm.doc.height, bot + pixels + 50); } + updateDisplaySimple(cm, {top: top, bottom: bot}); + } + + if (wheelSamples < 20) { + if (display.wheelStartX == null) { + display.wheelStartX = scroll.scrollLeft; display.wheelStartY = scroll.scrollTop; + display.wheelDX = dx; display.wheelDY = dy; + setTimeout(function () { + if (display.wheelStartX == null) { return } + var movedX = scroll.scrollLeft - display.wheelStartX; + var movedY = scroll.scrollTop - display.wheelStartY; + var sample = (movedY && display.wheelDY && movedY / display.wheelDY) || + (movedX && display.wheelDX && movedX / display.wheelDX); + display.wheelStartX = display.wheelStartY = null; + if (!sample) { return } + wheelPixelsPerUnit = (wheelPixelsPerUnit * wheelSamples + sample) / (wheelSamples + 1); + ++wheelSamples; + }, 200); + } else { + display.wheelDX += dx; display.wheelDY += dy; + } + } + } - if (!(this instanceof Pos)) { return new Pos(line, ch, sticky) } - this.line = line; - this.ch = ch; - this.sticky = sticky; -} + // Selection objects are immutable. A new one is created every time + // the selection changes. A selection is one or more non-overlapping + // (and non-touching) ranges, sorted, and an integer that indicates + // which one is the primary selection (the one that's scrolled into + // view, that getCursor returns, etc). + var Selection = function(ranges, primIndex) { + this.ranges = ranges; + this.primIndex = primIndex; + }; -// Compare two positions, return 0 if they are the same, a negative -// number when a is less, and a positive number otherwise. -function cmp(a, b) { return a.line - b.line || a.ch - b.ch } + Selection.prototype.primary = function () { return this.ranges[this.primIndex] }; -function equalCursorPos(a, b) { return a.sticky == b.sticky && cmp(a, b) == 0 } + Selection.prototype.equals = function (other) { + var this$1 = this; -function copyPos(x) {return Pos(x.line, x.ch)} -function maxPos(a, b) { return cmp(a, b) < 0 ? b : a } -function minPos(a, b) { return cmp(a, b) < 0 ? a : b } + if (other == this) { return true } + if (other.primIndex != this.primIndex || other.ranges.length != this.ranges.length) { return false } + for (var i = 0; i < this.ranges.length; i++) { + var here = this$1.ranges[i], there = other.ranges[i]; + if (!equalCursorPos(here.anchor, there.anchor) || !equalCursorPos(here.head, there.head)) { return false } + } + return true + }; -// Most of the external API clips given positions to make sure they -// actually exist within the document. -function clipLine(doc, n) {return Math.max(doc.first, Math.min(n, doc.first + doc.size - 1))} -function clipPos(doc, pos) { - if (pos.line < doc.first) { return Pos(doc.first, 0) } - var last = doc.first + doc.size - 1; - if (pos.line > last) { return Pos(last, getLine(doc, last).text.length) } - return clipToLen(pos, getLine(doc, pos.line).text.length) -} -function clipToLen(pos, linelen) { - var ch = pos.ch; - if (ch == null || ch > linelen) { return Pos(pos.line, linelen) } - else if (ch < 0) { return Pos(pos.line, 0) } - else { return pos } -} -function clipPosArray(doc, array) { - var out = []; - for (var i = 0; i < array.length; i++) { out[i] = clipPos(doc, array[i]); } - return out -} + Selection.prototype.deepCopy = function () { + var this$1 = this; -// Optimize some code when these features are not used. -var sawReadOnlySpans = false; -var sawCollapsedSpans = false; + var out = []; + for (var i = 0; i < this.ranges.length; i++) + { out[i] = new Range(copyPos(this$1.ranges[i].anchor), copyPos(this$1.ranges[i].head)); } + return new Selection(out, this.primIndex) + }; -function seeReadOnlySpans() { - sawReadOnlySpans = true; -} + Selection.prototype.somethingSelected = function () { + var this$1 = this; -function seeCollapsedSpans() { - sawCollapsedSpans = true; -} + for (var i = 0; i < this.ranges.length; i++) + { if (!this$1.ranges[i].empty()) { return true } } + return false + }; -// TEXTMARKER SPANS + Selection.prototype.contains = function (pos, end) { + var this$1 = this; -function MarkedSpan(marker, from, to) { - this.marker = marker; - this.from = from; this.to = to; -} + if (!end) { end = pos; } + for (var i = 0; i < this.ranges.length; i++) { + var range = this$1.ranges[i]; + if (cmp(end, range.from()) >= 0 && cmp(pos, range.to()) <= 0) + { return i } + } + return -1 + }; -// Search an array of spans for a span matching the given marker. -function getMarkedSpanFor(spans, marker) { - if (spans) { for (var i = 0; i < spans.length; ++i) { - var span = spans[i]; - if (span.marker == marker) { return span } - } } -} -// Remove a span from an array, returning undefined if no spans are -// left (we don't store arrays for lines without spans). -function removeMarkedSpan(spans, span) { - var r; - for (var i = 0; i < spans.length; ++i) - { if (spans[i] != span) { (r || (r = [])).push(spans[i]); } } - return r -} -// Add a span to a line. -function addMarkedSpan(line, span) { - line.markedSpans = line.markedSpans ? line.markedSpans.concat([span]) : [span]; - span.marker.attachLine(line); -} + var Range = function(anchor, head) { + this.anchor = anchor; this.head = head; + }; -// Used for the algorithm that adjusts markers for a change in the -// document. These functions cut an array of spans at a given -// character position, returning an array of remaining chunks (or -// undefined if nothing remains). -function markedSpansBefore(old, startCh, isInsert) { - var nw; - if (old) { for (var i = 0; i < old.length; ++i) { - var span = old[i], marker = span.marker; - var startsBefore = span.from == null || (marker.inclusiveLeft ? span.from <= startCh : span.from < startCh); - if (startsBefore || span.from == startCh && marker.type == "bookmark" && (!isInsert || !span.marker.insertLeft)) { - var endsAfter = span.to == null || (marker.inclusiveRight ? span.to >= startCh : span.to > startCh);(nw || (nw = [])).push(new MarkedSpan(marker, span.from, endsAfter ? null : span.to)); - } - } } - return nw -} -function markedSpansAfter(old, endCh, isInsert) { - var nw; - if (old) { for (var i = 0; i < old.length; ++i) { - var span = old[i], marker = span.marker; - var endsAfter = span.to == null || (marker.inclusiveRight ? span.to >= endCh : span.to > endCh); - if (endsAfter || span.from == endCh && marker.type == "bookmark" && (!isInsert || span.marker.insertLeft)) { - var startsBefore = span.from == null || (marker.inclusiveLeft ? span.from <= endCh : span.from < endCh);(nw || (nw = [])).push(new MarkedSpan(marker, startsBefore ? null : span.from - endCh, - span.to == null ? null : span.to - endCh)); - } - } } - return nw -} + Range.prototype.from = function () { return minPos(this.anchor, this.head) }; + Range.prototype.to = function () { return maxPos(this.anchor, this.head) }; + Range.prototype.empty = function () { return this.head.line == this.anchor.line && this.head.ch == this.anchor.ch }; -// Given a change object, compute the new set of marker spans that -// cover the line in which the change took place. Removes spans -// entirely within the change, reconnects spans belonging to the -// same marker that appear on both sides of the change, and cuts off -// spans partially within the change. Returns an array of span -// arrays with one element for each line in (after) the change. -function stretchSpansOverChange(doc, change) { - if (change.full) { return null } - var oldFirst = isLine(doc, change.from.line) && getLine(doc, change.from.line).markedSpans; - var oldLast = isLine(doc, change.to.line) && getLine(doc, change.to.line).markedSpans; - if (!oldFirst && !oldLast) { return null } - - var startCh = change.from.ch, endCh = change.to.ch, isInsert = cmp(change.from, change.to) == 0; - // Get the spans that 'stick out' on both sides - var first = markedSpansBefore(oldFirst, startCh, isInsert); - var last = markedSpansAfter(oldLast, endCh, isInsert); - - // Next, merge those two ends - var sameLine = change.text.length == 1, offset = lst(change.text).length + (sameLine ? startCh : 0); - if (first) { - // Fix up .to properties of first - for (var i = 0; i < first.length; ++i) { - var span = first[i]; - if (span.to == null) { - var found = getMarkedSpanFor(last, span.marker); - if (!found) { span.to = startCh; } - else if (sameLine) { span.to = found.to == null ? null : found.to + offset; } - } - } - } - if (last) { - // Fix up .from in last (or move them into first in case of sameLine) - for (var i$1 = 0; i$1 < last.length; ++i$1) { - var span$1 = last[i$1]; - if (span$1.to != null) { span$1.to += offset; } - if (span$1.from == null) { - var found$1 = getMarkedSpanFor(first, span$1.marker); - if (!found$1) { - span$1.from = offset; - if (sameLine) { (first || (first = [])).push(span$1); } - } - } else { - span$1.from += offset; - if (sameLine) { (first || (first = [])).push(span$1); } + // Take an unsorted, potentially overlapping set of ranges, and + // build a selection out of it. 'Consumes' ranges array (modifying + // it). + function normalizeSelection(cm, ranges, primIndex) { + var mayTouch = cm && cm.options.selectionsMayTouch; + var prim = ranges[primIndex]; + ranges.sort(function (a, b) { return cmp(a.from(), b.from()); }); + primIndex = indexOf(ranges, prim); + for (var i = 1; i < ranges.length; i++) { + var cur = ranges[i], prev = ranges[i - 1]; + var diff = cmp(prev.to(), cur.from()); + if (mayTouch && !cur.empty() ? diff > 0 : diff >= 0) { + var from = minPos(prev.from(), cur.from()), to = maxPos(prev.to(), cur.to()); + var inv = prev.empty() ? cur.from() == cur.head : prev.from() == prev.head; + if (i <= primIndex) { --primIndex; } + ranges.splice(--i, 2, new Range(inv ? to : from, inv ? from : to)); } } + return new Selection(ranges, primIndex) } - // Make sure we didn't create any zero-length spans - if (first) { first = clearEmptySpans(first); } - if (last && last != first) { last = clearEmptySpans(last); } - var newMarkers = [first]; - if (!sameLine) { - // Fill gap with whole-line-spans - var gap = change.text.length - 2, gapMarkers; - if (gap > 0 && first) - { for (var i$2 = 0; i$2 < first.length; ++i$2) - { if (first[i$2].to == null) - { (gapMarkers || (gapMarkers = [])).push(new MarkedSpan(first[i$2].marker, null, null)); } } } - for (var i$3 = 0; i$3 < gap; ++i$3) - { newMarkers.push(gapMarkers); } - newMarkers.push(last); + function simpleSelection(anchor, head) { + return new Selection([new Range(anchor, head || anchor)], 0) } - return newMarkers -} -// Remove spans that are empty and don't have a clearWhenEmpty -// option of false. -function clearEmptySpans(spans) { - for (var i = 0; i < spans.length; ++i) { - var span = spans[i]; - if (span.from != null && span.from == span.to && span.marker.clearWhenEmpty !== false) - { spans.splice(i--, 1); } + // Compute the position of the end of a change (its 'to' property + // refers to the pre-change end). + function changeEnd(change) { + if (!change.text) { return change.to } + return Pos(change.from.line + change.text.length - 1, + lst(change.text).length + (change.text.length == 1 ? change.from.ch : 0)) } - if (!spans.length) { return null } - return spans -} -// Used to 'clip' out readOnly ranges when making a change. -function removeReadOnlyRanges(doc, from, to) { - var markers = null; - doc.iter(from.line, to.line + 1, function (line) { - if (line.markedSpans) { for (var i = 0; i < line.markedSpans.length; ++i) { - var mark = line.markedSpans[i].marker; - if (mark.readOnly && (!markers || indexOf(markers, mark) == -1)) - { (markers || (markers = [])).push(mark); } - } } - }); - if (!markers) { return null } - var parts = [{from: from, to: to}]; - for (var i = 0; i < markers.length; ++i) { - var mk = markers[i], m = mk.find(0); - for (var j = 0; j < parts.length; ++j) { - var p = parts[j]; - if (cmp(p.to, m.from) < 0 || cmp(p.from, m.to) > 0) { continue } - var newParts = [j, 1], dfrom = cmp(p.from, m.from), dto = cmp(p.to, m.to); - if (dfrom < 0 || !mk.inclusiveLeft && !dfrom) - { newParts.push({from: p.from, to: m.from}); } - if (dto > 0 || !mk.inclusiveRight && !dto) - { newParts.push({from: m.to, to: p.to}); } - parts.splice.apply(parts, newParts); - j += newParts.length - 3; - } - } - return parts -} - -// Connect or disconnect spans from a line. -function detachMarkedSpans(line) { - var spans = line.markedSpans; - if (!spans) { return } - for (var i = 0; i < spans.length; ++i) - { spans[i].marker.detachLine(line); } - line.markedSpans = null; -} -function attachMarkedSpans(line, spans) { - if (!spans) { return } - for (var i = 0; i < spans.length; ++i) - { spans[i].marker.attachLine(line); } - line.markedSpans = spans; -} - -// Helpers used when computing which overlapping collapsed span -// counts as the larger one. -function extraLeft(marker) { return marker.inclusiveLeft ? -1 : 0 } -function extraRight(marker) { return marker.inclusiveRight ? 1 : 0 } - -// Returns a number indicating which of two overlapping collapsed -// spans is larger (and thus includes the other). Falls back to -// comparing ids when the spans cover exactly the same range. -function compareCollapsedMarkers(a, b) { - var lenDiff = a.lines.length - b.lines.length; - if (lenDiff != 0) { return lenDiff } - var aPos = a.find(), bPos = b.find(); - var fromCmp = cmp(aPos.from, bPos.from) || extraLeft(a) - extraLeft(b); - if (fromCmp) { return -fromCmp } - var toCmp = cmp(aPos.to, bPos.to) || extraRight(a) - extraRight(b); - if (toCmp) { return toCmp } - return b.id - a.id -} + // Adjust a position to refer to the post-change position of the + // same text, or the end of the change if the change covers it. + function adjustForChange(pos, change) { + if (cmp(pos, change.from) < 0) { return pos } + if (cmp(pos, change.to) <= 0) { return changeEnd(change) } -// Find out whether a line ends or starts in a collapsed span. If -// so, return the marker for that span. -function collapsedSpanAtSide(line, start) { - var sps = sawCollapsedSpans && line.markedSpans, found; - if (sps) { for (var sp = (void 0), i = 0; i < sps.length; ++i) { - sp = sps[i]; - if (sp.marker.collapsed && (start ? sp.from : sp.to) == null && - (!found || compareCollapsedMarkers(found, sp.marker) < 0)) - { found = sp.marker; } - } } - return found -} -function collapsedSpanAtStart(line) { return collapsedSpanAtSide(line, true) } -function collapsedSpanAtEnd(line) { return collapsedSpanAtSide(line, false) } - -// Test whether there exists a collapsed span that partially -// overlaps (covers the start or end, but not both) of a new span. -// Such overlap is not allowed. -function conflictingCollapsedRange(doc, lineNo$$1, from, to, marker) { - var line = getLine(doc, lineNo$$1); - var sps = sawCollapsedSpans && line.markedSpans; - if (sps) { for (var i = 0; i < sps.length; ++i) { - var sp = sps[i]; - if (!sp.marker.collapsed) { continue } - var found = sp.marker.find(0); - var fromCmp = cmp(found.from, from) || extraLeft(sp.marker) - extraLeft(marker); - var toCmp = cmp(found.to, to) || extraRight(sp.marker) - extraRight(marker); - if (fromCmp >= 0 && toCmp <= 0 || fromCmp <= 0 && toCmp >= 0) { continue } - if (fromCmp <= 0 && (sp.marker.inclusiveRight && marker.inclusiveLeft ? cmp(found.to, from) >= 0 : cmp(found.to, from) > 0) || - fromCmp >= 0 && (sp.marker.inclusiveRight && marker.inclusiveLeft ? cmp(found.from, to) <= 0 : cmp(found.from, to) < 0)) - { return true } - } } -} + var line = pos.line + change.text.length - (change.to.line - change.from.line) - 1, ch = pos.ch; + if (pos.line == change.to.line) { ch += changeEnd(change).ch - change.to.ch; } + return Pos(line, ch) + } -// A visual line is a line as drawn on the screen. Folding, for -// example, can cause multiple logical lines to appear on the same -// visual line. This finds the start of the visual line that the -// given line is part of (usually that is the line itself). -function visualLine(line) { - var merged; - while (merged = collapsedSpanAtStart(line)) - { line = merged.find(-1, true).line; } - return line -} + function computeSelAfterChange(doc, change) { + var out = []; + for (var i = 0; i < doc.sel.ranges.length; i++) { + var range = doc.sel.ranges[i]; + out.push(new Range(adjustForChange(range.anchor, change), + adjustForChange(range.head, change))); + } + return normalizeSelection(doc.cm, out, doc.sel.primIndex) + } -function visualLineEnd(line) { - var merged; - while (merged = collapsedSpanAtEnd(line)) - { line = merged.find(1, true).line; } - return line -} + function offsetPos(pos, old, nw) { + if (pos.line == old.line) + { return Pos(nw.line, pos.ch - old.ch + nw.ch) } + else + { return Pos(nw.line + (pos.line - old.line), pos.ch) } + } -// Returns an array of logical lines that continue the visual line -// started by the argument, or undefined if there are no such lines. -function visualLineContinued(line) { - var merged, lines; - while (merged = collapsedSpanAtEnd(line)) { - line = merged.find(1, true).line - ;(lines || (lines = [])).push(line); + // Used by replaceSelections to allow moving the selection to the + // start or around the replaced test. Hint may be "start" or "around". + function computeReplacedSel(doc, changes, hint) { + var out = []; + var oldPrev = Pos(doc.first, 0), newPrev = oldPrev; + for (var i = 0; i < changes.length; i++) { + var change = changes[i]; + var from = offsetPos(change.from, oldPrev, newPrev); + var to = offsetPos(changeEnd(change), oldPrev, newPrev); + oldPrev = change.to; + newPrev = to; + if (hint == "around") { + var range = doc.sel.ranges[i], inv = cmp(range.head, range.anchor) < 0; + out[i] = new Range(inv ? to : from, inv ? from : to); + } else { + out[i] = new Range(from, from); + } + } + return new Selection(out, doc.sel.primIndex) } - return lines -} -// Get the line number of the start of the visual line that the -// given line number is part of. -function visualLineNo(doc, lineN) { - var line = getLine(doc, lineN), vis = visualLine(line); - if (line == vis) { return lineN } - return lineNo(vis) -} + // Used to get the editor into a consistent state again when options change. -// Get the line number of the start of the next visual line after -// the given line. -function visualLineEndNo(doc, lineN) { - if (lineN > doc.lastLine()) { return lineN } - var line = getLine(doc, lineN), merged; - if (!lineIsHidden(doc, line)) { return lineN } - while (merged = collapsedSpanAtEnd(line)) - { line = merged.find(1, true).line; } - return lineNo(line) + 1 -} + function loadMode(cm) { + cm.doc.mode = getMode(cm.options, cm.doc.modeOption); + resetModeState(cm); + } -// Compute whether a line is hidden. Lines count as hidden when they -// are part of a visual line that starts with another line, or when -// they are entirely covered by collapsed, non-widget span. -function lineIsHidden(doc, line) { - var sps = sawCollapsedSpans && line.markedSpans; - if (sps) { for (var sp = (void 0), i = 0; i < sps.length; ++i) { - sp = sps[i]; - if (!sp.marker.collapsed) { continue } - if (sp.from == null) { return true } - if (sp.marker.widgetNode) { continue } - if (sp.from == 0 && sp.marker.inclusiveLeft && lineIsHiddenInner(doc, line, sp)) - { return true } - } } -} -function lineIsHiddenInner(doc, line, span) { - if (span.to == null) { - var end = span.marker.find(1, true); - return lineIsHiddenInner(doc, end.line, getMarkedSpanFor(end.line.markedSpans, span.marker)) - } - if (span.marker.inclusiveRight && span.to == line.text.length) - { return true } - for (var sp = (void 0), i = 0; i < line.markedSpans.length; ++i) { - sp = line.markedSpans[i]; - if (sp.marker.collapsed && !sp.marker.widgetNode && sp.from == span.to && - (sp.to == null || sp.to != span.from) && - (sp.marker.inclusiveLeft || span.marker.inclusiveRight) && - lineIsHiddenInner(doc, line, sp)) { return true } + function resetModeState(cm) { + cm.doc.iter(function (line) { + if (line.stateAfter) { line.stateAfter = null; } + if (line.styles) { line.styles = null; } + }); + cm.doc.modeFrontier = cm.doc.highlightFrontier = cm.doc.first; + startWorker(cm, 100); + cm.state.modeGen++; + if (cm.curOp) { regChange(cm); } } -} -// Find the height above the given line. -function heightAtLine(lineObj) { - lineObj = visualLine(lineObj); + // DOCUMENT DATA STRUCTURE - var h = 0, chunk = lineObj.parent; - for (var i = 0; i < chunk.lines.length; ++i) { - var line = chunk.lines[i]; - if (line == lineObj) { break } - else { h += line.height; } - } - for (var p = chunk.parent; p; chunk = p, p = chunk.parent) { - for (var i$1 = 0; i$1 < p.children.length; ++i$1) { - var cur = p.children[i$1]; - if (cur == chunk) { break } - else { h += cur.height; } - } + // By default, updates that start and end at the beginning of a line + // are treated specially, in order to make the association of line + // widgets and marker elements with the text behave more intuitive. + function isWholeLineUpdate(doc, change) { + return change.from.ch == 0 && change.to.ch == 0 && lst(change.text) == "" && + (!doc.cm || doc.cm.options.wholeLineUpdateBefore) } - return h -} - -// Compute the character length of a line, taking into account -// collapsed ranges (see markText) that might hide parts, and join -// other lines onto it. -function lineLength(line) { - if (line.height == 0) { return 0 } - var len = line.text.length, merged, cur = line; - while (merged = collapsedSpanAtStart(cur)) { - var found = merged.find(0, true); - cur = found.from.line; - len += found.from.ch - found.to.ch; - } - cur = line; - while (merged = collapsedSpanAtEnd(cur)) { - var found$1 = merged.find(0, true); - len -= cur.text.length - found$1.from.ch; - cur = found$1.to.line; - len += cur.text.length - found$1.to.ch; - } - return len -} -// Find the longest line in the document. -function findMaxLine(cm) { - var d = cm.display, doc = cm.doc; - d.maxLine = getLine(doc, doc.first); - d.maxLineLength = lineLength(d.maxLine); - d.maxLineChanged = true; - doc.iter(function (line) { - var len = lineLength(line); - if (len > d.maxLineLength) { - d.maxLineLength = len; - d.maxLine = line; + // Perform a change on the document data structure. + function updateDoc(doc, change, markedSpans, estimateHeight$$1) { + function spansFor(n) {return markedSpans ? markedSpans[n] : null} + function update(line, text, spans) { + updateLine(line, text, spans, estimateHeight$$1); + signalLater(line, "change", line, change); + } + function linesFor(start, end) { + var result = []; + for (var i = start; i < end; ++i) + { result.push(new Line(text[i], spansFor(i), estimateHeight$$1)); } + return result + } + + var from = change.from, to = change.to, text = change.text; + var firstLine = getLine(doc, from.line), lastLine = getLine(doc, to.line); + var lastText = lst(text), lastSpans = spansFor(text.length - 1), nlines = to.line - from.line; + + // Adjust the line structure + if (change.full) { + doc.insert(0, linesFor(0, text.length)); + doc.remove(text.length, doc.size - text.length); + } else if (isWholeLineUpdate(doc, change)) { + // This is a whole-line replace. Treated specially to make + // sure line objects move the way they are supposed to. + var added = linesFor(0, text.length - 1); + update(lastLine, lastLine.text, lastSpans); + if (nlines) { doc.remove(from.line, nlines); } + if (added.length) { doc.insert(from.line, added); } + } else if (firstLine == lastLine) { + if (text.length == 1) { + update(firstLine, firstLine.text.slice(0, from.ch) + lastText + firstLine.text.slice(to.ch), lastSpans); + } else { + var added$1 = linesFor(1, text.length - 1); + added$1.push(new Line(lastText + firstLine.text.slice(to.ch), lastSpans, estimateHeight$$1)); + update(firstLine, firstLine.text.slice(0, from.ch) + text[0], spansFor(0)); + doc.insert(from.line + 1, added$1); + } + } else if (text.length == 1) { + update(firstLine, firstLine.text.slice(0, from.ch) + text[0] + lastLine.text.slice(to.ch), spansFor(0)); + doc.remove(from.line + 1, nlines); + } else { + update(firstLine, firstLine.text.slice(0, from.ch) + text[0], spansFor(0)); + update(lastLine, lastText + lastLine.text.slice(to.ch), lastSpans); + var added$2 = linesFor(1, text.length - 1); + if (nlines > 1) { doc.remove(from.line + 1, nlines - 1); } + doc.insert(from.line + 1, added$2); } - }); -} -// BIDI HELPERS + signalLater(doc, "change", doc, change); + } -function iterateBidiSections(order, from, to, f) { - if (!order) { return f(from, to, "ltr", 0) } - var found = false; - for (var i = 0; i < order.length; ++i) { - var part = order[i]; - if (part.from < to && part.to > from || from == to && part.to == from) { - f(Math.max(part.from, from), Math.min(part.to, to), part.level == 1 ? "rtl" : "ltr", i); - found = true; + // Call f for all linked documents. + function linkedDocs(doc, f, sharedHistOnly) { + function propagate(doc, skip, sharedHist) { + if (doc.linked) { for (var i = 0; i < doc.linked.length; ++i) { + var rel = doc.linked[i]; + if (rel.doc == skip) { continue } + var shared = sharedHist && rel.sharedHist; + if (sharedHistOnly && !shared) { continue } + f(rel.doc, shared); + propagate(rel.doc, doc, shared); + } } } + propagate(doc, null, true); } - if (!found) { f(from, to, "ltr"); } -} -var bidiOther = null; -function getBidiPartAt(order, ch, sticky) { - var found; - bidiOther = null; - for (var i = 0; i < order.length; ++i) { - var cur = order[i]; - if (cur.from < ch && cur.to > ch) { return i } - if (cur.to == ch) { - if (cur.from != cur.to && sticky == "before") { found = i; } - else { bidiOther = i; } - } - if (cur.from == ch) { - if (cur.from != cur.to && sticky != "before") { found = i; } - else { bidiOther = i; } - } + // Attach a document to an editor. + function attachDoc(cm, doc) { + if (doc.cm) { throw new Error("This document is already in use.") } + cm.doc = doc; + doc.cm = cm; + estimateLineHeights(cm); + loadMode(cm); + setDirectionClass(cm); + if (!cm.options.lineWrapping) { findMaxLine(cm); } + cm.options.mode = doc.modeOption; + regChange(cm); } - return found != null ? found : bidiOther -} -// Bidirectional ordering algorithm -// See http://unicode.org/reports/tr9/tr9-13.html for the algorithm -// that this (partially) implements. - -// One-char codes used for character types: -// L (L): Left-to-Right -// R (R): Right-to-Left -// r (AL): Right-to-Left Arabic -// 1 (EN): European Number -// + (ES): European Number Separator -// % (ET): European Number Terminator -// n (AN): Arabic Number -// , (CS): Common Number Separator -// m (NSM): Non-Spacing Mark -// b (BN): Boundary Neutral -// s (B): Paragraph Separator -// t (S): Segment Separator -// w (WS): Whitespace -// N (ON): Other Neutrals - -// Returns null if characters are ordered as they appear -// (left-to-right), or an array of sections ({from, to, level} -// objects) in the order in which they occur visually. -var bidiOrdering = (function() { - // Character types for codepoints 0 to 0xff - var lowTypes = "bbbbbbbbbtstwsbbbbbbbbbbbbbbssstwNN%%%NNNNNN,N,N1111111111NNNNNNNLLLLLLLLLLLLLLLLLLLLLLLLLLNNNNNNLLLLLLLLLLLLLLLLLLLLLLLLLLNNNNbbbbbbsbbbbbbbbbbbbbbbbbbbbbbbbbb,N%%%%NNNNLNNNNN%%11NLNNN1LNNNNNLLLLLLLLLLLLLLLLLLLLLLLNLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLN"; - // Character types for codepoints 0x600 to 0x6f9 - var arabicTypes = "nnnnnnNNr%%r,rNNmmmmmmmmmmmrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrmmmmmmmmmmmmmmmmmmmmmnnnnnnnnnn%nnrrrmrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrmmmmmmmnNmmmmmmrrmmNmmmmrr1111111111"; - function charType(code) { - if (code <= 0xf7) { return lowTypes.charAt(code) } - else if (0x590 <= code && code <= 0x5f4) { return "R" } - else if (0x600 <= code && code <= 0x6f9) { return arabicTypes.charAt(code - 0x600) } - else if (0x6ee <= code && code <= 0x8ac) { return "r" } - else if (0x2000 <= code && code <= 0x200b) { return "w" } - else if (code == 0x200c) { return "b" } - else { return "L" } - } - - var bidiRE = /[\u0590-\u05f4\u0600-\u06ff\u0700-\u08ac]/; - var isNeutral = /[stwN]/, isStrong = /[LRr]/, countsAsLeft = /[Lb1n]/, countsAsNum = /[1n]/; - - function BidiSpan(level, from, to) { - this.level = level; - this.from = from; this.to = to; + function setDirectionClass(cm) { + (cm.doc.direction == "rtl" ? addClass : rmClass)(cm.display.lineDiv, "CodeMirror-rtl"); + } + + function directionChanged(cm) { + runInOp(cm, function () { + setDirectionClass(cm); + regChange(cm); + }); } - return function(str, direction) { - var outerType = direction == "ltr" ? "L" : "R"; - - if (str.length == 0 || direction == "ltr" && !bidiRE.test(str)) { return false } - var len = str.length, types = []; - for (var i = 0; i < len; ++i) - { types.push(charType(str.charCodeAt(i))); } - - // W1. Examine each non-spacing mark (NSM) in the level run, and - // change the type of the NSM to the type of the previous - // character. If the NSM is at the start of the level run, it will - // get the type of sor. - for (var i$1 = 0, prev = outerType; i$1 < len; ++i$1) { - var type = types[i$1]; - if (type == "m") { types[i$1] = prev; } - else { prev = type; } - } - - // W2. Search backwards from each instance of a European number - // until the first strong type (R, L, AL, or sor) is found. If an - // AL is found, change the type of the European number to Arabic - // number. - // W3. Change all ALs to R. - for (var i$2 = 0, cur = outerType; i$2 < len; ++i$2) { - var type$1 = types[i$2]; - if (type$1 == "1" && cur == "r") { types[i$2] = "n"; } - else if (isStrong.test(type$1)) { cur = type$1; if (type$1 == "r") { types[i$2] = "R"; } } - } - - // W4. A single European separator between two European numbers - // changes to a European number. A single common separator between - // two numbers of the same type changes to that type. - for (var i$3 = 1, prev$1 = types[0]; i$3 < len - 1; ++i$3) { - var type$2 = types[i$3]; - if (type$2 == "+" && prev$1 == "1" && types[i$3+1] == "1") { types[i$3] = "1"; } - else if (type$2 == "," && prev$1 == types[i$3+1] && - (prev$1 == "1" || prev$1 == "n")) { types[i$3] = prev$1; } - prev$1 = type$2; - } - - // W5. A sequence of European terminators adjacent to European - // numbers changes to all European numbers. - // W6. Otherwise, separators and terminators change to Other - // Neutral. - for (var i$4 = 0; i$4 < len; ++i$4) { - var type$3 = types[i$4]; - if (type$3 == ",") { types[i$4] = "N"; } - else if (type$3 == "%") { - var end = (void 0); - for (end = i$4 + 1; end < len && types[end] == "%"; ++end) {} - var replace = (i$4 && types[i$4-1] == "!") || (end < len && types[end] == "1") ? "1" : "N"; - for (var j = i$4; j < end; ++j) { types[j] = replace; } - i$4 = end - 1; - } - } - - // W7. Search backwards from each instance of a European number - // until the first strong type (R, L, or sor) is found. If an L is - // found, then change the type of the European number to L. - for (var i$5 = 0, cur$1 = outerType; i$5 < len; ++i$5) { - var type$4 = types[i$5]; - if (cur$1 == "L" && type$4 == "1") { types[i$5] = "L"; } - else if (isStrong.test(type$4)) { cur$1 = type$4; } - } - - // N1. A sequence of neutrals takes the direction of the - // surrounding strong text if the text on both sides has the same - // direction. European and Arabic numbers act as if they were R in - // terms of their influence on neutrals. Start-of-level-run (sor) - // and end-of-level-run (eor) are used at level run boundaries. - // N2. Any remaining neutrals take the embedding direction. - for (var i$6 = 0; i$6 < len; ++i$6) { - if (isNeutral.test(types[i$6])) { - var end$1 = (void 0); - for (end$1 = i$6 + 1; end$1 < len && isNeutral.test(types[end$1]); ++end$1) {} - var before = (i$6 ? types[i$6-1] : outerType) == "L"; - var after = (end$1 < len ? types[end$1] : outerType) == "L"; - var replace$1 = before == after ? (before ? "L" : "R") : outerType; - for (var j$1 = i$6; j$1 < end$1; ++j$1) { types[j$1] = replace$1; } - i$6 = end$1 - 1; - } - } - - // Here we depart from the documented algorithm, in order to avoid - // building up an actual levels array. Since there are only three - // levels (0, 1, 2) in an implementation that doesn't take - // explicit embedding into account, we can build up the order on - // the fly, without following the level-based algorithm. - var order = [], m; - for (var i$7 = 0; i$7 < len;) { - if (countsAsLeft.test(types[i$7])) { - var start = i$7; - for (++i$7; i$7 < len && countsAsLeft.test(types[i$7]); ++i$7) {} - order.push(new BidiSpan(0, start, i$7)); + function History(startGen) { + // Arrays of change events and selections. Doing something adds an + // event to done and clears undo. Undoing moves events from done + // to undone, redoing moves them in the other direction. + this.done = []; this.undone = []; + this.undoDepth = Infinity; + // Used to track when changes can be merged into a single undo + // event + this.lastModTime = this.lastSelTime = 0; + this.lastOp = this.lastSelOp = null; + this.lastOrigin = this.lastSelOrigin = null; + // Used by the isClean() method + this.generation = this.maxGeneration = startGen || 1; + } + + // Create a history change event from an updateDoc-style change + // object. + function historyChangeFromChange(doc, change) { + var histChange = {from: copyPos(change.from), to: changeEnd(change), text: getBetween(doc, change.from, change.to)}; + attachLocalSpans(doc, histChange, change.from.line, change.to.line + 1); + linkedDocs(doc, function (doc) { return attachLocalSpans(doc, histChange, change.from.line, change.to.line + 1); }, true); + return histChange + } + + // Pop all selection events off the end of a history array. Stop at + // a change event. + function clearSelectionEvents(array) { + while (array.length) { + var last = lst(array); + if (last.ranges) { array.pop(); } + else { break } + } + } + + // Find the top change event in the history. Pop off selection + // events that are in the way. + function lastChangeEvent(hist, force) { + if (force) { + clearSelectionEvents(hist.done); + return lst(hist.done) + } else if (hist.done.length && !lst(hist.done).ranges) { + return lst(hist.done) + } else if (hist.done.length > 1 && !hist.done[hist.done.length - 2].ranges) { + hist.done.pop(); + return lst(hist.done) + } + } + + // Register a change in the history. Merges changes that are within + // a single operation, or are close together with an origin that + // allows merging (starting with "+") into a single event. + function addChangeToHistory(doc, change, selAfter, opId) { + var hist = doc.history; + hist.undone.length = 0; + var time = +new Date, cur; + var last; + + if ((hist.lastOp == opId || + hist.lastOrigin == change.origin && change.origin && + ((change.origin.charAt(0) == "+" && hist.lastModTime > time - (doc.cm ? doc.cm.options.historyEventDelay : 500)) || + change.origin.charAt(0) == "*")) && + (cur = lastChangeEvent(hist, hist.lastOp == opId))) { + // Merge this change into the last event + last = lst(cur.changes); + if (cmp(change.from, change.to) == 0 && cmp(change.from, last.to) == 0) { + // Optimized case for simple insertion -- don't want to add + // new changesets for every character typed + last.to = changeEnd(change); } else { - var pos = i$7, at = order.length; - for (++i$7; i$7 < len && types[i$7] != "L"; ++i$7) {} - for (var j$2 = pos; j$2 < i$7;) { - if (countsAsNum.test(types[j$2])) { - if (pos < j$2) { order.splice(at, 0, new BidiSpan(1, pos, j$2)); } - var nstart = j$2; - for (++j$2; j$2 < i$7 && countsAsNum.test(types[j$2]); ++j$2) {} - order.splice(at, 0, new BidiSpan(2, nstart, j$2)); - pos = j$2; - } else { ++j$2; } - } - if (pos < i$7) { order.splice(at, 0, new BidiSpan(1, pos, i$7)); } - } - } - if (direction == "ltr") { - if (order[0].level == 1 && (m = str.match(/^\s+/))) { - order[0].from = m[0].length; - order.unshift(new BidiSpan(0, 0, m[0].length)); + // Add new sub-event + cur.changes.push(historyChangeFromChange(doc, change)); } - if (lst(order).level == 1 && (m = str.match(/\s+$/))) { - lst(order).to -= m[0].length; - order.push(new BidiSpan(0, len - m[0].length, len)); - } - } + } else { + // Can not be merged, start a new event. + var before = lst(hist.done); + if (!before || !before.ranges) + { pushSelectionToHistory(doc.sel, hist.done); } + cur = {changes: [historyChangeFromChange(doc, change)], + generation: hist.generation}; + hist.done.push(cur); + while (hist.done.length > hist.undoDepth) { + hist.done.shift(); + if (!hist.done[0].ranges) { hist.done.shift(); } + } + } + hist.done.push(selAfter); + hist.generation = ++hist.maxGeneration; + hist.lastModTime = hist.lastSelTime = time; + hist.lastOp = hist.lastSelOp = opId; + hist.lastOrigin = hist.lastSelOrigin = change.origin; + + if (!last) { signal(doc, "historyAdded"); } + } + + function selectionEventCanBeMerged(doc, origin, prev, sel) { + var ch = origin.charAt(0); + return ch == "*" || + ch == "+" && + prev.ranges.length == sel.ranges.length && + prev.somethingSelected() == sel.somethingSelected() && + new Date - doc.history.lastSelTime <= (doc.cm ? doc.cm.options.historyEventDelay : 500) + } + + // Called whenever the selection changes, sets the new selection as + // the pending selection in the history, and pushes the old pending + // selection into the 'done' array when it was significantly + // different (in number of selected ranges, emptiness, or time). + function addSelectionToHistory(doc, sel, opId, options) { + var hist = doc.history, origin = options && options.origin; + + // A new event is started when the previous origin does not match + // the current, or the origins don't allow matching. Origins + // starting with * are always merged, those starting with + are + // merged when similar and close together in time. + if (opId == hist.lastSelOp || + (origin && hist.lastSelOrigin == origin && + (hist.lastModTime == hist.lastSelTime && hist.lastOrigin == origin || + selectionEventCanBeMerged(doc, origin, lst(hist.done), sel)))) + { hist.done[hist.done.length - 1] = sel; } + else + { pushSelectionToHistory(sel, hist.done); } - return direction == "rtl" ? order.reverse() : order + hist.lastSelTime = +new Date; + hist.lastSelOrigin = origin; + hist.lastSelOp = opId; + if (options && options.clearRedo !== false) + { clearSelectionEvents(hist.undone); } } -})(); - -// Get the bidi ordering for the given line (and cache it). Returns -// false for lines that are fully left-to-right, and an array of -// BidiSpan objects otherwise. -function getOrder(line, direction) { - var order = line.order; - if (order == null) { order = line.order = bidiOrdering(line.text, direction); } - return order -} - -// EVENT HANDLING -// Lightweight event framework. on/off also work on DOM nodes, -// registering native DOM handlers. + function pushSelectionToHistory(sel, dest) { + var top = lst(dest); + if (!(top && top.ranges && top.equals(sel))) + { dest.push(sel); } + } -var noHandlers = []; + // Used to store marked span information in the history. + function attachLocalSpans(doc, change, from, to) { + var existing = change["spans_" + doc.id], n = 0; + doc.iter(Math.max(doc.first, from), Math.min(doc.first + doc.size, to), function (line) { + if (line.markedSpans) + { (existing || (existing = change["spans_" + doc.id] = {}))[n] = line.markedSpans; } + ++n; + }); + } -var on = function(emitter, type, f) { - if (emitter.addEventListener) { - emitter.addEventListener(type, f, false); - } else if (emitter.attachEvent) { - emitter.attachEvent("on" + type, f); - } else { - var map$$1 = emitter._handlers || (emitter._handlers = {}); - map$$1[type] = (map$$1[type] || noHandlers).concat(f); + // When un/re-doing restores text containing marked spans, those + // that have been explicitly cleared should not be restored. + function removeClearedSpans(spans) { + if (!spans) { return null } + var out; + for (var i = 0; i < spans.length; ++i) { + if (spans[i].marker.explicitlyCleared) { if (!out) { out = spans.slice(0, i); } } + else if (out) { out.push(spans[i]); } + } + return !out ? spans : out.length ? out : null + } + + // Retrieve and filter the old marked spans stored in a change event. + function getOldSpans(doc, change) { + var found = change["spans_" + doc.id]; + if (!found) { return null } + var nw = []; + for (var i = 0; i < change.text.length; ++i) + { nw.push(removeClearedSpans(found[i])); } + return nw + } + + // Used for un/re-doing changes from the history. Combines the + // result of computing the existing spans with the set of spans that + // existed in the history (so that deleting around a span and then + // undoing brings back the span). + function mergeOldSpans(doc, change) { + var old = getOldSpans(doc, change); + var stretched = stretchSpansOverChange(doc, change); + if (!old) { return stretched } + if (!stretched) { return old } + + for (var i = 0; i < old.length; ++i) { + var oldCur = old[i], stretchCur = stretched[i]; + if (oldCur && stretchCur) { + spans: for (var j = 0; j < stretchCur.length; ++j) { + var span = stretchCur[j]; + for (var k = 0; k < oldCur.length; ++k) + { if (oldCur[k].marker == span.marker) { continue spans } } + oldCur.push(span); + } + } else if (stretchCur) { + old[i] = stretchCur; + } + } + return old + } + + // Used both to provide a JSON-safe object in .getHistory, and, when + // detaching a document, to split the history in two + function copyHistoryArray(events, newGroup, instantiateSel) { + var copy = []; + for (var i = 0; i < events.length; ++i) { + var event = events[i]; + if (event.ranges) { + copy.push(instantiateSel ? Selection.prototype.deepCopy.call(event) : event); + continue + } + var changes = event.changes, newChanges = []; + copy.push({changes: newChanges}); + for (var j = 0; j < changes.length; ++j) { + var change = changes[j], m = (void 0); + newChanges.push({from: change.from, to: change.to, text: change.text}); + if (newGroup) { for (var prop in change) { if (m = prop.match(/^spans_(\d+)$/)) { + if (indexOf(newGroup, Number(m[1])) > -1) { + lst(newChanges)[prop] = change[prop]; + delete change[prop]; + } + } } } + } + } + return copy } -}; -function getHandlers(emitter, type) { - return emitter._handlers && emitter._handlers[type] || noHandlers -} + // The 'scroll' parameter given to many of these indicated whether + // the new cursor position should be scrolled into view after + // modifying the selection. -function off(emitter, type, f) { - if (emitter.removeEventListener) { - emitter.removeEventListener(type, f, false); - } else if (emitter.detachEvent) { - emitter.detachEvent("on" + type, f); - } else { - var map$$1 = emitter._handlers, arr = map$$1 && map$$1[type]; - if (arr) { - var index = indexOf(arr, f); - if (index > -1) - { map$$1[type] = arr.slice(0, index).concat(arr.slice(index + 1)); } + // If shift is held or the extend flag is set, extends a range to + // include a given position (and optionally a second position). + // Otherwise, simply returns the range between the given positions. + // Used for cursor motion and such. + function extendRange(range, head, other, extend) { + if (extend) { + var anchor = range.anchor; + if (other) { + var posBefore = cmp(head, anchor) < 0; + if (posBefore != (cmp(other, anchor) < 0)) { + anchor = head; + head = other; + } else if (posBefore != (cmp(head, other) < 0)) { + head = other; + } + } + return new Range(anchor, head) + } else { + return new Range(other || head, head) } } -} -function signal(emitter, type /*, values...*/) { - var handlers = getHandlers(emitter, type); - if (!handlers.length) { return } - var args = Array.prototype.slice.call(arguments, 2); - for (var i = 0; i < handlers.length; ++i) { handlers[i].apply(null, args); } -} + // Extend the primary selection range, discard the rest. + function extendSelection(doc, head, other, options, extend) { + if (extend == null) { extend = doc.cm && (doc.cm.display.shift || doc.extend); } + setSelection(doc, new Selection([extendRange(doc.sel.primary(), head, other, extend)], 0), options); + } -// The DOM events that CodeMirror handles can be overridden by -// registering a (non-DOM) handler on the editor for the event name, -// and preventDefault-ing the event in that handler. -function signalDOMEvent(cm, e, override) { - if (typeof e == "string") - { e = {type: e, preventDefault: function() { this.defaultPrevented = true; }}; } - signal(cm, override || e.type, cm, e); - return e_defaultPrevented(e) || e.codemirrorIgnore -} + // Extend all selections (pos is an array of selections with length + // equal the number of selections) + function extendSelections(doc, heads, options) { + var out = []; + var extend = doc.cm && (doc.cm.display.shift || doc.extend); + for (var i = 0; i < doc.sel.ranges.length; i++) + { out[i] = extendRange(doc.sel.ranges[i], heads[i], null, extend); } + var newSel = normalizeSelection(doc.cm, out, doc.sel.primIndex); + setSelection(doc, newSel, options); + } -function signalCursorActivity(cm) { - var arr = cm._handlers && cm._handlers.cursorActivity; - if (!arr) { return } - var set = cm.curOp.cursorActivityHandlers || (cm.curOp.cursorActivityHandlers = []); - for (var i = 0; i < arr.length; ++i) { if (indexOf(set, arr[i]) == -1) - { set.push(arr[i]); } } -} + // Updates a single range in the selection. + function replaceOneSelection(doc, i, range, options) { + var ranges = doc.sel.ranges.slice(0); + ranges[i] = range; + setSelection(doc, normalizeSelection(doc.cm, ranges, doc.sel.primIndex), options); + } -function hasHandler(emitter, type) { - return getHandlers(emitter, type).length > 0 -} + // Reset the selection to a single range. + function setSimpleSelection(doc, anchor, head, options) { + setSelection(doc, simpleSelection(anchor, head), options); + } -// Add on and off methods to a constructor's prototype, to make -// registering events on such objects more convenient. -function eventMixin(ctor) { - ctor.prototype.on = function(type, f) {on(this, type, f);}; - ctor.prototype.off = function(type, f) {off(this, type, f);}; -} + // Give beforeSelectionChange handlers a change to influence a + // selection update. + function filterSelectionChange(doc, sel, options) { + var obj = { + ranges: sel.ranges, + update: function(ranges) { + var this$1 = this; + + this.ranges = []; + for (var i = 0; i < ranges.length; i++) + { this$1.ranges[i] = new Range(clipPos(doc, ranges[i].anchor), + clipPos(doc, ranges[i].head)); } + }, + origin: options && options.origin + }; + signal(doc, "beforeSelectionChange", doc, obj); + if (doc.cm) { signal(doc.cm, "beforeSelectionChange", doc.cm, obj); } + if (obj.ranges != sel.ranges) { return normalizeSelection(doc.cm, obj.ranges, obj.ranges.length - 1) } + else { return sel } + } -// Due to the fact that we still support jurassic IE versions, some -// compatibility wrappers are needed. + function setSelectionReplaceHistory(doc, sel, options) { + var done = doc.history.done, last = lst(done); + if (last && last.ranges) { + done[done.length - 1] = sel; + setSelectionNoUndo(doc, sel, options); + } else { + setSelection(doc, sel, options); + } + } -function e_preventDefault(e) { - if (e.preventDefault) { e.preventDefault(); } - else { e.returnValue = false; } -} -function e_stopPropagation(e) { - if (e.stopPropagation) { e.stopPropagation(); } - else { e.cancelBubble = true; } -} -function e_defaultPrevented(e) { - return e.defaultPrevented != null ? e.defaultPrevented : e.returnValue == false -} -function e_stop(e) {e_preventDefault(e); e_stopPropagation(e);} - -function e_target(e) {return e.target || e.srcElement} -function e_button(e) { - var b = e.which; - if (b == null) { - if (e.button & 1) { b = 1; } - else if (e.button & 2) { b = 3; } - else if (e.button & 4) { b = 2; } - } - if (mac && e.ctrlKey && b == 1) { b = 3; } - return b -} + // Set a new selection. + function setSelection(doc, sel, options) { + setSelectionNoUndo(doc, sel, options); + addSelectionToHistory(doc, doc.sel, doc.cm ? doc.cm.curOp.id : NaN, options); + } -// Detect drag-and-drop -var dragAndDrop = function() { - // There is *some* kind of drag-and-drop support in IE6-8, but I - // couldn't get it to work yet. - if (ie && ie_version < 9) { return false } - var div = elt('div'); - return "draggable" in div || "dragDrop" in div -}(); + function setSelectionNoUndo(doc, sel, options) { + if (hasHandler(doc, "beforeSelectionChange") || doc.cm && hasHandler(doc.cm, "beforeSelectionChange")) + { sel = filterSelectionChange(doc, sel, options); } -var zwspSupported; -function zeroWidthElement(measure) { - if (zwspSupported == null) { - var test = elt("span", "\u200b"); - removeChildrenAndAdd(measure, elt("span", [test, document.createTextNode("x")])); - if (measure.firstChild.offsetHeight != 0) - { zwspSupported = test.offsetWidth <= 1 && test.offsetHeight > 2 && !(ie && ie_version < 8); } - } - var node = zwspSupported ? elt("span", "\u200b") : - elt("span", "\u00a0", null, "display: inline-block; width: 1px; margin-right: -1px"); - node.setAttribute("cm-text", ""); - return node -} + var bias = options && options.bias || + (cmp(sel.primary().head, doc.sel.primary().head) < 0 ? -1 : 1); + setSelectionInner(doc, skipAtomicInSelection(doc, sel, bias, true)); -// Feature-detect IE's crummy client rect reporting for bidi text -var badBidiRects; -function hasBadBidiRects(measure) { - if (badBidiRects != null) { return badBidiRects } - var txt = removeChildrenAndAdd(measure, document.createTextNode("A\u062eA")); - var r0 = range(txt, 0, 1).getBoundingClientRect(); - var r1 = range(txt, 1, 2).getBoundingClientRect(); - removeChildren(measure); - if (!r0 || r0.left == r0.right) { return false } // Safari returns null in some cases (#2780) - return badBidiRects = (r1.right - r0.right < 3) -} + if (!(options && options.scroll === false) && doc.cm) + { ensureCursorVisible(doc.cm); } + } -// See if "".split is the broken IE version, if so, provide an -// alternative way to split lines. -var splitLinesAuto = "\n\nb".split(/\n/).length != 3 ? function (string) { - var pos = 0, result = [], l = string.length; - while (pos <= l) { - var nl = string.indexOf("\n", pos); - if (nl == -1) { nl = string.length; } - var line = string.slice(pos, string.charAt(nl - 1) == "\r" ? nl - 1 : nl); - var rt = line.indexOf("\r"); - if (rt != -1) { - result.push(line.slice(0, rt)); - pos += rt + 1; - } else { - result.push(line); - pos = nl + 1; - } - } - return result -} : function (string) { return string.split(/\r\n?|\n/); }; - -var hasSelection = window.getSelection ? function (te) { - try { return te.selectionStart != te.selectionEnd } - catch(e) { return false } -} : function (te) { - var range$$1; - try {range$$1 = te.ownerDocument.selection.createRange();} - catch(e) {} - if (!range$$1 || range$$1.parentElement() != te) { return false } - return range$$1.compareEndPoints("StartToEnd", range$$1) != 0 -}; + function setSelectionInner(doc, sel) { + if (sel.equals(doc.sel)) { return } -var hasCopyEvent = (function () { - var e = elt("div"); - if ("oncopy" in e) { return true } - e.setAttribute("oncopy", "return;"); - return typeof e.oncopy == "function" -})(); + doc.sel = sel; -var badZoomedRects = null; -function hasBadZoomedRects(measure) { - if (badZoomedRects != null) { return badZoomedRects } - var node = removeChildrenAndAdd(measure, elt("span", "x")); - var normal = node.getBoundingClientRect(); - var fromRange = range(node, 0, 1).getBoundingClientRect(); - return badZoomedRects = Math.abs(normal.left - fromRange.left) > 1 -} + if (doc.cm) { + doc.cm.curOp.updateInput = 1; + doc.cm.curOp.selectionChanged = true; + signalCursorActivity(doc.cm); + } + signalLater(doc, "cursorActivity", doc); + } -// Known modes, by name and by MIME -var modes = {}; -var mimeModes = {}; - -// Extra arguments are stored as the mode's dependencies, which is -// used by (legacy) mechanisms like loadmode.js to automatically -// load a mode. (Preferred mechanism is the require/define calls.) -function defineMode(name, mode) { - if (arguments.length > 2) - { mode.dependencies = Array.prototype.slice.call(arguments, 2); } - modes[name] = mode; -} + // Verify that the selection does not partially select any atomic + // marked ranges. + function reCheckSelection(doc) { + setSelectionInner(doc, skipAtomicInSelection(doc, doc.sel, null, false)); + } -function defineMIME(mime, spec) { - mimeModes[mime] = spec; -} + // Return a selection that does not partially select any atomic + // ranges. + function skipAtomicInSelection(doc, sel, bias, mayClear) { + var out; + for (var i = 0; i < sel.ranges.length; i++) { + var range = sel.ranges[i]; + var old = sel.ranges.length == doc.sel.ranges.length && doc.sel.ranges[i]; + var newAnchor = skipAtomic(doc, range.anchor, old && old.anchor, bias, mayClear); + var newHead = skipAtomic(doc, range.head, old && old.head, bias, mayClear); + if (out || newAnchor != range.anchor || newHead != range.head) { + if (!out) { out = sel.ranges.slice(0, i); } + out[i] = new Range(newAnchor, newHead); + } + } + return out ? normalizeSelection(doc.cm, out, sel.primIndex) : sel + } -// Given a MIME type, a {name, ...options} config object, or a name -// string, return a mode config object. -function resolveMode(spec) { - if (typeof spec == "string" && mimeModes.hasOwnProperty(spec)) { - spec = mimeModes[spec]; - } else if (spec && typeof spec.name == "string" && mimeModes.hasOwnProperty(spec.name)) { - var found = mimeModes[spec.name]; - if (typeof found == "string") { found = {name: found}; } - spec = createObj(found, spec); - spec.name = found.name; - } else if (typeof spec == "string" && /^[\w\-]+\/[\w\-]+\+xml$/.test(spec)) { - return resolveMode("application/xml") - } else if (typeof spec == "string" && /^[\w\-]+\/[\w\-]+\+json$/.test(spec)) { - return resolveMode("application/json") - } - if (typeof spec == "string") { return {name: spec} } - else { return spec || {name: "null"} } -} + function skipAtomicInner(doc, pos, oldPos, dir, mayClear) { + var line = getLine(doc, pos.line); + if (line.markedSpans) { for (var i = 0; i < line.markedSpans.length; ++i) { + var sp = line.markedSpans[i], m = sp.marker; + + // Determine if we should prevent the cursor being placed to the left/right of an atomic marker + // Historically this was determined using the inclusiveLeft/Right option, but the new way to control it + // is with selectLeft/Right + var preventCursorLeft = ("selectLeft" in m) ? !m.selectLeft : m.inclusiveLeft; + var preventCursorRight = ("selectRight" in m) ? !m.selectRight : m.inclusiveRight; + + if ((sp.from == null || (preventCursorLeft ? sp.from <= pos.ch : sp.from < pos.ch)) && + (sp.to == null || (preventCursorRight ? sp.to >= pos.ch : sp.to > pos.ch))) { + if (mayClear) { + signal(m, "beforeCursorEnter"); + if (m.explicitlyCleared) { + if (!line.markedSpans) { break } + else {--i; continue} + } + } + if (!m.atomic) { continue } -// Given a mode spec (anything that resolveMode accepts), find and -// initialize an actual mode object. -function getMode(options, spec) { - spec = resolveMode(spec); - var mfactory = modes[spec.name]; - if (!mfactory) { return getMode(options, "text/plain") } - var modeObj = mfactory(options, spec); - if (modeExtensions.hasOwnProperty(spec.name)) { - var exts = modeExtensions[spec.name]; - for (var prop in exts) { - if (!exts.hasOwnProperty(prop)) { continue } - if (modeObj.hasOwnProperty(prop)) { modeObj["_" + prop] = modeObj[prop]; } - modeObj[prop] = exts[prop]; - } - } - modeObj.name = spec.name; - if (spec.helperType) { modeObj.helperType = spec.helperType; } - if (spec.modeProps) { for (var prop$1 in spec.modeProps) - { modeObj[prop$1] = spec.modeProps[prop$1]; } } - - return modeObj -} + if (oldPos) { + var near = m.find(dir < 0 ? 1 : -1), diff = (void 0); + if (dir < 0 ? preventCursorRight : preventCursorLeft) + { near = movePos(doc, near, -dir, near && near.line == pos.line ? line : null); } + if (near && near.line == pos.line && (diff = cmp(near, oldPos)) && (dir < 0 ? diff < 0 : diff > 0)) + { return skipAtomicInner(doc, near, pos, dir, mayClear) } + } -// This can be used to attach properties to mode objects from -// outside the actual mode definition. -var modeExtensions = {}; -function extendMode(mode, properties) { - var exts = modeExtensions.hasOwnProperty(mode) ? modeExtensions[mode] : (modeExtensions[mode] = {}); - copyObj(properties, exts); -} + var far = m.find(dir < 0 ? -1 : 1); + if (dir < 0 ? preventCursorLeft : preventCursorRight) + { far = movePos(doc, far, dir, far.line == pos.line ? line : null); } + return far ? skipAtomicInner(doc, far, pos, dir, mayClear) : null + } + } } + return pos + } -function copyState(mode, state) { - if (state === true) { return state } - if (mode.copyState) { return mode.copyState(state) } - var nstate = {}; - for (var n in state) { - var val = state[n]; - if (val instanceof Array) { val = val.concat([]); } - nstate[n] = val; + // Ensure a given position is not inside an atomic range. + function skipAtomic(doc, pos, oldPos, bias, mayClear) { + var dir = bias || 1; + var found = skipAtomicInner(doc, pos, oldPos, dir, mayClear) || + (!mayClear && skipAtomicInner(doc, pos, oldPos, dir, true)) || + skipAtomicInner(doc, pos, oldPos, -dir, mayClear) || + (!mayClear && skipAtomicInner(doc, pos, oldPos, -dir, true)); + if (!found) { + doc.cantEdit = true; + return Pos(doc.first, 0) + } + return found } - return nstate -} -// Given a mode and a state (for that mode), find the inner mode and -// state at the position that the state refers to. -function innerMode(mode, state) { - var info; - while (mode.innerMode) { - info = mode.innerMode(state); - if (!info || info.mode == mode) { break } - state = info.state; - mode = info.mode; - } - return info || {mode: mode, state: state} -} + function movePos(doc, pos, dir, line) { + if (dir < 0 && pos.ch == 0) { + if (pos.line > doc.first) { return clipPos(doc, Pos(pos.line - 1)) } + else { return null } + } else if (dir > 0 && pos.ch == (line || getLine(doc, pos.line)).text.length) { + if (pos.line < doc.first + doc.size - 1) { return Pos(pos.line + 1, 0) } + else { return null } + } else { + return new Pos(pos.line, pos.ch + dir) + } + } -function startState(mode, a1, a2) { - return mode.startState ? mode.startState(a1, a2) : true -} + function selectAll(cm) { + cm.setSelection(Pos(cm.firstLine(), 0), Pos(cm.lastLine()), sel_dontScroll); + } -// STRING STREAM + // UPDATING -// Fed to the mode parsers, provides helper functions to make -// parsers more succinct. + // Allow "beforeChange" event handlers to influence a change + function filterChange(doc, change, update) { + var obj = { + canceled: false, + from: change.from, + to: change.to, + text: change.text, + origin: change.origin, + cancel: function () { return obj.canceled = true; } + }; + if (update) { obj.update = function (from, to, text, origin) { + if (from) { obj.from = clipPos(doc, from); } + if (to) { obj.to = clipPos(doc, to); } + if (text) { obj.text = text; } + if (origin !== undefined) { obj.origin = origin; } + }; } + signal(doc, "beforeChange", doc, obj); + if (doc.cm) { signal(doc.cm, "beforeChange", doc.cm, obj); } -var StringStream = function(string, tabSize, lineOracle) { - this.pos = this.start = 0; - this.string = string; - this.tabSize = tabSize || 8; - this.lastColumnPos = this.lastColumnValue = 0; - this.lineStart = 0; - this.lineOracle = lineOracle; -}; + if (obj.canceled) { + if (doc.cm) { doc.cm.curOp.updateInput = 2; } + return null + } + return {from: obj.from, to: obj.to, text: obj.text, origin: obj.origin} + } -StringStream.prototype.eol = function () {return this.pos >= this.string.length}; -StringStream.prototype.sol = function () {return this.pos == this.lineStart}; -StringStream.prototype.peek = function () {return this.string.charAt(this.pos) || undefined}; -StringStream.prototype.next = function () { - if (this.pos < this.string.length) - { return this.string.charAt(this.pos++) } -}; -StringStream.prototype.eat = function (match) { - var ch = this.string.charAt(this.pos); - var ok; - if (typeof match == "string") { ok = ch == match; } - else { ok = ch && (match.test ? match.test(ch) : match(ch)); } - if (ok) {++this.pos; return ch} -}; -StringStream.prototype.eatWhile = function (match) { - var start = this.pos; - while (this.eat(match)){} - return this.pos > start -}; -StringStream.prototype.eatSpace = function () { - var this$1 = this; + // Apply a change to a document, and add it to the document's + // history, and propagating it to all linked documents. + function makeChange(doc, change, ignoreReadOnly) { + if (doc.cm) { + if (!doc.cm.curOp) { return operation(doc.cm, makeChange)(doc, change, ignoreReadOnly) } + if (doc.cm.state.suppressEdits) { return } + } - var start = this.pos; - while (/[\s\u00a0]/.test(this.string.charAt(this.pos))) { ++this$1.pos; } - return this.pos > start -}; -StringStream.prototype.skipToEnd = function () {this.pos = this.string.length;}; -StringStream.prototype.skipTo = function (ch) { - var found = this.string.indexOf(ch, this.pos); - if (found > -1) {this.pos = found; return true} -}; -StringStream.prototype.backUp = function (n) {this.pos -= n;}; -StringStream.prototype.column = function () { - if (this.lastColumnPos < this.start) { - this.lastColumnValue = countColumn(this.string, this.start, this.tabSize, this.lastColumnPos, this.lastColumnValue); - this.lastColumnPos = this.start; - } - return this.lastColumnValue - (this.lineStart ? countColumn(this.string, this.lineStart, this.tabSize) : 0) -}; -StringStream.prototype.indentation = function () { - return countColumn(this.string, null, this.tabSize) - - (this.lineStart ? countColumn(this.string, this.lineStart, this.tabSize) : 0) -}; -StringStream.prototype.match = function (pattern, consume, caseInsensitive) { - if (typeof pattern == "string") { - var cased = function (str) { return caseInsensitive ? str.toLowerCase() : str; }; - var substr = this.string.substr(this.pos, pattern.length); - if (cased(substr) == cased(pattern)) { - if (consume !== false) { this.pos += pattern.length; } - return true + if (hasHandler(doc, "beforeChange") || doc.cm && hasHandler(doc.cm, "beforeChange")) { + change = filterChange(doc, change, true); + if (!change) { return } + } + + // Possibly split or suppress the update based on the presence + // of read-only spans in its range. + var split = sawReadOnlySpans && !ignoreReadOnly && removeReadOnlyRanges(doc, change.from, change.to); + if (split) { + for (var i = split.length - 1; i >= 0; --i) + { makeChangeInner(doc, {from: split[i].from, to: split[i].to, text: i ? [""] : change.text, origin: change.origin}); } + } else { + makeChangeInner(doc, change); } - } else { - var match = this.string.slice(this.pos).match(pattern); - if (match && match.index > 0) { return null } - if (match && consume !== false) { this.pos += match[0].length; } - return match } -}; -StringStream.prototype.current = function (){return this.string.slice(this.start, this.pos)}; -StringStream.prototype.hideFirstChars = function (n, inner) { - this.lineStart += n; - try { return inner() } - finally { this.lineStart -= n; } -}; -StringStream.prototype.lookAhead = function (n) { - var oracle = this.lineOracle; - return oracle && oracle.lookAhead(n) -}; -StringStream.prototype.baseToken = function () { - var oracle = this.lineOracle; - return oracle && oracle.baseToken(this.pos) -}; -var SavedContext = function(state, lookAhead) { - this.state = state; - this.lookAhead = lookAhead; -}; + function makeChangeInner(doc, change) { + if (change.text.length == 1 && change.text[0] == "" && cmp(change.from, change.to) == 0) { return } + var selAfter = computeSelAfterChange(doc, change); + addChangeToHistory(doc, change, selAfter, doc.cm ? doc.cm.curOp.id : NaN); -var Context = function(doc, state, line, lookAhead) { - this.state = state; - this.doc = doc; - this.line = line; - this.maxLookAhead = lookAhead || 0; - this.baseTokens = null; - this.baseTokenPos = 1; -}; + makeChangeSingleDoc(doc, change, selAfter, stretchSpansOverChange(doc, change)); + var rebased = []; -Context.prototype.lookAhead = function (n) { - var line = this.doc.getLine(this.line + n); - if (line != null && n > this.maxLookAhead) { this.maxLookAhead = n; } - return line -}; + linkedDocs(doc, function (doc, sharedHist) { + if (!sharedHist && indexOf(rebased, doc.history) == -1) { + rebaseHist(doc.history, change); + rebased.push(doc.history); + } + makeChangeSingleDoc(doc, change, null, stretchSpansOverChange(doc, change)); + }); + } -Context.prototype.baseToken = function (n) { - var this$1 = this; + // Revert a change stored in a document's history. + function makeChangeFromHistory(doc, type, allowSelectionOnly) { + var suppress = doc.cm && doc.cm.state.suppressEdits; + if (suppress && !allowSelectionOnly) { return } - if (!this.baseTokens) { return null } - while (this.baseTokens[this.baseTokenPos] <= n) - { this$1.baseTokenPos += 2; } - var type = this.baseTokens[this.baseTokenPos + 1]; - return {type: type && type.replace(/( |^)overlay .*/, ""), - size: this.baseTokens[this.baseTokenPos] - n} -}; + var hist = doc.history, event, selAfter = doc.sel; + var source = type == "undo" ? hist.done : hist.undone, dest = type == "undo" ? hist.undone : hist.done; -Context.prototype.nextLine = function () { - this.line++; - if (this.maxLookAhead > 0) { this.maxLookAhead--; } -}; + // Verify that there is a useable event (so that ctrl-z won't + // needlessly clear selection events) + var i = 0; + for (; i < source.length; i++) { + event = source[i]; + if (allowSelectionOnly ? event.ranges && !event.equals(doc.sel) : !event.ranges) + { break } + } + if (i == source.length) { return } + hist.lastOrigin = hist.lastSelOrigin = null; -Context.fromSaved = function (doc, saved, line) { - if (saved instanceof SavedContext) - { return new Context(doc, copyState(doc.mode, saved.state), line, saved.lookAhead) } - else - { return new Context(doc, copyState(doc.mode, saved), line) } -}; + for (;;) { + event = source.pop(); + if (event.ranges) { + pushSelectionToHistory(event, dest); + if (allowSelectionOnly && !event.equals(doc.sel)) { + setSelection(doc, event, {clearRedo: false}); + return + } + selAfter = event; + } else if (suppress) { + source.push(event); + return + } else { break } + } -Context.prototype.save = function (copy) { - var state = copy !== false ? copyState(this.doc.mode, this.state) : this.state; - return this.maxLookAhead > 0 ? new SavedContext(state, this.maxLookAhead) : state -}; + // Build up a reverse change object to add to the opposite history + // stack (redo when undoing, and vice versa). + var antiChanges = []; + pushSelectionToHistory(selAfter, dest); + dest.push({changes: antiChanges, generation: hist.generation}); + hist.generation = event.generation || ++hist.maxGeneration; + var filter = hasHandler(doc, "beforeChange") || doc.cm && hasHandler(doc.cm, "beforeChange"); -// Compute a style array (an array starting with a mode generation -// -- for invalidation -- followed by pairs of end positions and -// style strings), which is used to highlight the tokens on the -// line. -function highlightLine(cm, line, context, forceToEnd) { - // A styles array always starts with a number identifying the - // mode/overlays that it is based on (for easy invalidation). - var st = [cm.state.modeGen], lineClasses = {}; - // Compute the base array of styles - runMode(cm, line.text, cm.doc.mode, context, function (end, style) { return st.push(end, style); }, - lineClasses, forceToEnd); - var state = context.state; - - // Run overlays, adjust style array. - var loop = function ( o ) { - context.baseTokens = st; - var overlay = cm.state.overlays[o], i = 1, at = 0; - context.state = true; - runMode(cm, line.text, overlay.mode, context, function (end, style) { - var start = i; - // Ensure there's a token end at the current position, and that i points at it - while (at < end) { - var i_end = st[i]; - if (i_end > end) - { st.splice(i, 1, end, st[i+1], i_end); } - i += 2; - at = Math.min(end, i_end); - } - if (!style) { return } - if (overlay.opaque) { - st.splice(start, i - start, end, "overlay " + style); - i = start + 2; - } else { - for (; start < i; start += 2) { - var cur = st[start+1]; - st[start+1] = (cur ? cur + " " : "") + "overlay " + style; - } + var loop = function ( i ) { + var change = event.changes[i]; + change.origin = type; + if (filter && !filterChange(doc, change, false)) { + source.length = 0; + return {} } - }, lineClasses); - context.state = state; - context.baseTokens = null; - context.baseTokenPos = 1; - }; - for (var o = 0; o < cm.state.overlays.length; ++o) loop( o ); + antiChanges.push(historyChangeFromChange(doc, change)); - return {styles: st, classes: lineClasses.bgClass || lineClasses.textClass ? lineClasses : null} -} + var after = i ? computeSelAfterChange(doc, change) : lst(source); + makeChangeSingleDoc(doc, change, after, mergeOldSpans(doc, change)); + if (!i && doc.cm) { doc.cm.scrollIntoView({from: change.from, to: changeEnd(change)}); } + var rebased = []; -function getLineStyles(cm, line, updateFrontier) { - if (!line.styles || line.styles[0] != cm.state.modeGen) { - var context = getContextBefore(cm, lineNo(line)); - var resetState = line.text.length > cm.options.maxHighlightLength && copyState(cm.doc.mode, context.state); - var result = highlightLine(cm, line, context); - if (resetState) { context.state = resetState; } - line.stateAfter = context.save(!resetState); - line.styles = result.styles; - if (result.classes) { line.styleClasses = result.classes; } - else if (line.styleClasses) { line.styleClasses = null; } - if (updateFrontier === cm.doc.highlightFrontier) - { cm.doc.modeFrontier = Math.max(cm.doc.modeFrontier, ++cm.doc.highlightFrontier); } - } - return line.styles -} + // Propagate to the linked documents + linkedDocs(doc, function (doc, sharedHist) { + if (!sharedHist && indexOf(rebased, doc.history) == -1) { + rebaseHist(doc.history, change); + rebased.push(doc.history); + } + makeChangeSingleDoc(doc, change, null, mergeOldSpans(doc, change)); + }); + }; -function getContextBefore(cm, n, precise) { - var doc = cm.doc, display = cm.display; - if (!doc.mode.startState) { return new Context(doc, true, n) } - var start = findStartLine(cm, n, precise); - var saved = start > doc.first && getLine(doc, start - 1).stateAfter; - var context = saved ? Context.fromSaved(doc, saved, start) : new Context(doc, startState(doc.mode), start); - - doc.iter(start, n, function (line) { - processLine(cm, line.text, context); - var pos = context.line; - line.stateAfter = pos == n - 1 || pos % 5 == 0 || pos >= display.viewFrom && pos < display.viewTo ? context.save() : null; - context.nextLine(); - }); - if (precise) { doc.modeFrontier = context.line; } - return context -} + for (var i$1 = event.changes.length - 1; i$1 >= 0; --i$1) { + var returned = loop( i$1 ); -// Lightweight form of highlight -- proceed over this line and -// update state, but don't save a style array. Used for lines that -// aren't currently visible. -function processLine(cm, text, context, startAt) { - var mode = cm.doc.mode; - var stream = new StringStream(text, cm.options.tabSize, context); - stream.start = stream.pos = startAt || 0; - if (text == "") { callBlankLine(mode, context.state); } - while (!stream.eol()) { - readToken(mode, stream, context.state); - stream.start = stream.pos; + if ( returned ) return returned.v; + } } -} -function callBlankLine(mode, state) { - if (mode.blankLine) { return mode.blankLine(state) } - if (!mode.innerMode) { return } - var inner = innerMode(mode, state); - if (inner.mode.blankLine) { return inner.mode.blankLine(inner.state) } -} - -function readToken(mode, stream, state, inner) { - for (var i = 0; i < 10; i++) { - if (inner) { inner[0] = innerMode(mode, state).mode; } - var style = mode.token(stream, state); - if (stream.pos > stream.start) { return style } + // Sub-views need their line numbers shifted when text is added + // above or below them in the parent document. + function shiftDoc(doc, distance) { + if (distance == 0) { return } + doc.first += distance; + doc.sel = new Selection(map(doc.sel.ranges, function (range) { return new Range( + Pos(range.anchor.line + distance, range.anchor.ch), + Pos(range.head.line + distance, range.head.ch) + ); }), doc.sel.primIndex); + if (doc.cm) { + regChange(doc.cm, doc.first, doc.first - distance, distance); + for (var d = doc.cm.display, l = d.viewFrom; l < d.viewTo; l++) + { regLineChange(doc.cm, l, "gutter"); } + } } - throw new Error("Mode " + mode.name + " failed to advance stream.") -} - -var Token = function(stream, type, state) { - this.start = stream.start; this.end = stream.pos; - this.string = stream.current(); - this.type = type || null; - this.state = state; -}; - -// Utility for getTokenAt and getLineTokens -function takeToken(cm, pos, precise, asArray) { - var doc = cm.doc, mode = doc.mode, style; - pos = clipPos(doc, pos); - var line = getLine(doc, pos.line), context = getContextBefore(cm, pos.line, precise); - var stream = new StringStream(line.text, cm.options.tabSize, context), tokens; - if (asArray) { tokens = []; } - while ((asArray || stream.pos < pos.ch) && !stream.eol()) { - stream.start = stream.pos; - style = readToken(mode, stream, context.state); - if (asArray) { tokens.push(new Token(stream, style, copyState(doc.mode, context.state))); } - } - return asArray ? tokens : new Token(stream, style, context.state) -} -function extractLineClasses(type, output) { - if (type) { for (;;) { - var lineClass = type.match(/(?:^|\s+)line-(background-)?(\S+)/); - if (!lineClass) { break } - type = type.slice(0, lineClass.index) + type.slice(lineClass.index + lineClass[0].length); - var prop = lineClass[1] ? "bgClass" : "textClass"; - if (output[prop] == null) - { output[prop] = lineClass[2]; } - else if (!(new RegExp("(?:^|\s)" + lineClass[2] + "(?:$|\s)")).test(output[prop])) - { output[prop] += " " + lineClass[2]; } - } } - return type -} + // More lower-level change function, handling only a single document + // (not linked ones). + function makeChangeSingleDoc(doc, change, selAfter, spans) { + if (doc.cm && !doc.cm.curOp) + { return operation(doc.cm, makeChangeSingleDoc)(doc, change, selAfter, spans) } -// Run the given mode's parser over a line, calling f for each token. -function runMode(cm, text, mode, context, f, lineClasses, forceToEnd) { - var flattenSpans = mode.flattenSpans; - if (flattenSpans == null) { flattenSpans = cm.options.flattenSpans; } - var curStart = 0, curStyle = null; - var stream = new StringStream(text, cm.options.tabSize, context), style; - var inner = cm.options.addModeClass && [null]; - if (text == "") { extractLineClasses(callBlankLine(mode, context.state), lineClasses); } - while (!stream.eol()) { - if (stream.pos > cm.options.maxHighlightLength) { - flattenSpans = false; - if (forceToEnd) { processLine(cm, text, context, stream.pos); } - stream.pos = text.length; - style = null; - } else { - style = extractLineClasses(readToken(mode, stream, context.state, inner), lineClasses); + if (change.to.line < doc.first) { + shiftDoc(doc, change.text.length - 1 - (change.to.line - change.from.line)); + return } - if (inner) { - var mName = inner[0].name; - if (mName) { style = "m-" + (style ? mName + " " + style : mName); } + if (change.from.line > doc.lastLine()) { return } + + // Clip the change to the size of this doc + if (change.from.line < doc.first) { + var shift = change.text.length - 1 - (doc.first - change.from.line); + shiftDoc(doc, shift); + change = {from: Pos(doc.first, 0), to: Pos(change.to.line + shift, change.to.ch), + text: [lst(change.text)], origin: change.origin}; } - if (!flattenSpans || curStyle != style) { - while (curStart < stream.start) { - curStart = Math.min(stream.start, curStart + 5000); - f(curStart, curStyle); - } - curStyle = style; + var last = doc.lastLine(); + if (change.to.line > last) { + change = {from: change.from, to: Pos(last, getLine(doc, last).text.length), + text: [change.text[0]], origin: change.origin}; } - stream.start = stream.pos; - } - while (curStart < stream.pos) { - // Webkit seems to refuse to render text nodes longer than 57444 - // characters, and returns inaccurate measurements in nodes - // starting around 5000 chars. - var pos = Math.min(stream.pos, curStart + 5000); - f(pos, curStyle); - curStart = pos; - } -} -// Finds the line to start with when starting a parse. Tries to -// find a line with a stateAfter, so that it can start with a -// valid state. If that fails, it returns the line with the -// smallest indentation, which tends to need the least context to -// parse correctly. -function findStartLine(cm, n, precise) { - var minindent, minline, doc = cm.doc; - var lim = precise ? -1 : n - (cm.doc.mode.innerMode ? 1000 : 100); - for (var search = n; search > lim; --search) { - if (search <= doc.first) { return doc.first } - var line = getLine(doc, search - 1), after = line.stateAfter; - if (after && (!precise || search + (after instanceof SavedContext ? after.lookAhead : 0) <= doc.modeFrontier)) - { return search } - var indented = countColumn(line.text, null, cm.options.tabSize); - if (minline == null || minindent > indented) { - minline = search - 1; - minindent = indented; - } - } - return minline -} + change.removed = getBetween(doc, change.from, change.to); -function retreatFrontier(doc, n) { - doc.modeFrontier = Math.min(doc.modeFrontier, n); - if (doc.highlightFrontier < n - 10) { return } - var start = doc.first; - for (var line = n - 1; line > start; line--) { - var saved = getLine(doc, line).stateAfter; - // change is on 3 - // state on line 1 looked ahead 2 -- so saw 3 - // test 1 + 2 < 3 should cover this - if (saved && (!(saved instanceof SavedContext) || line + saved.lookAhead < n)) { - start = line + 1; - break - } - } - doc.highlightFrontier = Math.min(doc.highlightFrontier, start); -} + if (!selAfter) { selAfter = computeSelAfterChange(doc, change); } + if (doc.cm) { makeChangeSingleDocInEditor(doc.cm, change, spans); } + else { updateDoc(doc, change, spans); } + setSelectionNoUndo(doc, selAfter, sel_dontScroll); -// LINE DATA STRUCTURE + if (doc.cantEdit && skipAtomic(doc, Pos(doc.firstLine(), 0))) + { doc.cantEdit = false; } + } -// Line objects. These hold state related to a line, including -// highlighting info (the styles array). -var Line = function(text, markedSpans, estimateHeight) { - this.text = text; - attachMarkedSpans(this, markedSpans); - this.height = estimateHeight ? estimateHeight(this) : 1; -}; + // Handle the interaction of a change to a document with the editor + // that this document is part of. + function makeChangeSingleDocInEditor(cm, change, spans) { + var doc = cm.doc, display = cm.display, from = change.from, to = change.to; -Line.prototype.lineNo = function () { return lineNo(this) }; -eventMixin(Line); - -// Change the content (text, markers) of a line. Automatically -// invalidates cached information and tries to re-estimate the -// line's height. -function updateLine(line, text, markedSpans, estimateHeight) { - line.text = text; - if (line.stateAfter) { line.stateAfter = null; } - if (line.styles) { line.styles = null; } - if (line.order != null) { line.order = null; } - detachMarkedSpans(line); - attachMarkedSpans(line, markedSpans); - var estHeight = estimateHeight ? estimateHeight(line) : 1; - if (estHeight != line.height) { updateLineHeight(line, estHeight); } -} + var recomputeMaxLength = false, checkWidthStart = from.line; + if (!cm.options.lineWrapping) { + checkWidthStart = lineNo(visualLine(getLine(doc, from.line))); + doc.iter(checkWidthStart, to.line + 1, function (line) { + if (line == display.maxLine) { + recomputeMaxLength = true; + return true + } + }); + } -// Detach a line from the document tree and its markers. -function cleanUpLine(line) { - line.parent = null; - detachMarkedSpans(line); -} + if (doc.sel.contains(change.from, change.to) > -1) + { signalCursorActivity(cm); } -// Convert a style as returned by a mode (either null, or a string -// containing one or more styles) to a CSS style. This is cached, -// and also looks for line-wide styles. -var styleToClassCache = {}; -var styleToClassCacheWithMode = {}; -function interpretTokenStyle(style, options) { - if (!style || /^\s*$/.test(style)) { return null } - var cache = options.addModeClass ? styleToClassCacheWithMode : styleToClassCache; - return cache[style] || - (cache[style] = style.replace(/\S+/g, "cm-$&")) -} + updateDoc(doc, change, spans, estimateHeight(cm)); -// Render the DOM representation of the text of a line. Also builds -// up a 'line map', which points at the DOM nodes that represent -// specific stretches of text, and is used by the measuring code. -// The returned object contains the DOM node, this map, and -// information about line-wide styles that were set by the mode. -function buildLineContent(cm, lineView) { - // The padding-right forces the element to have a 'border', which - // is needed on Webkit to be able to get line-level bounding - // rectangles for it (in measureChar). - var content = eltP("span", null, null, webkit ? "padding-right: .1px" : null); - var builder = {pre: eltP("pre", [content], "CodeMirror-line"), content: content, - col: 0, pos: 0, cm: cm, - trailingSpace: false, - splitSpaces: (ie || webkit) && cm.getOption("lineWrapping")}; - lineView.measure = {}; - - // Iterate over the logical lines that make up this visual line. - for (var i = 0; i <= (lineView.rest ? lineView.rest.length : 0); i++) { - var line = i ? lineView.rest[i - 1] : lineView.line, order = (void 0); - builder.pos = 0; - builder.addToken = buildToken; - // Optionally wire in some hacks into the token-rendering - // algorithm, to deal with browser quirks. - if (hasBadBidiRects(cm.display.measure) && (order = getOrder(line, cm.doc.direction))) - { builder.addToken = buildTokenBadBidi(builder.addToken, order); } - builder.map = []; - var allowFrontierUpdate = lineView != cm.display.externalMeasured && lineNo(line); - insertLineContent(line, builder, getLineStyles(cm, line, allowFrontierUpdate)); - if (line.styleClasses) { - if (line.styleClasses.bgClass) - { builder.bgClass = joinClasses(line.styleClasses.bgClass, builder.bgClass || ""); } - if (line.styleClasses.textClass) - { builder.textClass = joinClasses(line.styleClasses.textClass, builder.textClass || ""); } - } - - // Ensure at least a single node is present, for measuring. - if (builder.map.length == 0) - { builder.map.push(0, 0, builder.content.appendChild(zeroWidthElement(cm.display.measure))); } - - // Store the map and a cache object for the current logical line - if (i == 0) { - lineView.measure.map = builder.map; - lineView.measure.cache = {}; - } else { - (lineView.measure.maps || (lineView.measure.maps = [])).push(builder.map) - ;(lineView.measure.caches || (lineView.measure.caches = [])).push({}); + if (!cm.options.lineWrapping) { + doc.iter(checkWidthStart, from.line + change.text.length, function (line) { + var len = lineLength(line); + if (len > display.maxLineLength) { + display.maxLine = line; + display.maxLineLength = len; + display.maxLineChanged = true; + recomputeMaxLength = false; + } + }); + if (recomputeMaxLength) { cm.curOp.updateMaxLine = true; } } - } - // See issue #2901 - if (webkit) { - var last = builder.content.lastChild; - if (/\bcm-tab\b/.test(last.className) || (last.querySelector && last.querySelector(".cm-tab"))) - { builder.content.className = "cm-tab-wrap-hack"; } - } + retreatFrontier(doc, from.line); + startWorker(cm, 400); - signal(cm, "renderLine", cm, lineView.line, builder.pre); - if (builder.pre.className) - { builder.textClass = joinClasses(builder.pre.className, builder.textClass || ""); } + var lendiff = change.text.length - (to.line - from.line) - 1; + // Remember that these lines changed, for updating the display + if (change.full) + { regChange(cm); } + else if (from.line == to.line && change.text.length == 1 && !isWholeLineUpdate(cm.doc, change)) + { regLineChange(cm, from.line, "text"); } + else + { regChange(cm, from.line, to.line + 1, lendiff); } - return builder -} + var changesHandler = hasHandler(cm, "changes"), changeHandler = hasHandler(cm, "change"); + if (changeHandler || changesHandler) { + var obj = { + from: from, to: to, + text: change.text, + removed: change.removed, + origin: change.origin + }; + if (changeHandler) { signalLater(cm, "change", cm, obj); } + if (changesHandler) { (cm.curOp.changeObjs || (cm.curOp.changeObjs = [])).push(obj); } + } + cm.display.selForContextMenu = null; + } -function defaultSpecialCharPlaceholder(ch) { - var token = elt("span", "\u2022", "cm-invalidchar"); - token.title = "\\u" + ch.charCodeAt(0).toString(16); - token.setAttribute("aria-label", token.title); - return token -} + function replaceRange(doc, code, from, to, origin) { + var assign; -// Build up the DOM representation for a single token, and add it to -// the line map. Takes care to render special characters separately. -function buildToken(builder, text, style, startStyle, endStyle, title, css) { - if (!text) { return } - var displayText = builder.splitSpaces ? splitSpaces(text, builder.trailingSpace) : text; - var special = builder.cm.state.specialChars, mustWrap = false; - var content; - if (!special.test(text)) { - builder.col += text.length; - content = document.createTextNode(displayText); - builder.map.push(builder.pos, builder.pos + text.length, content); - if (ie && ie_version < 9) { mustWrap = true; } - builder.pos += text.length; - } else { - content = document.createDocumentFragment(); - var pos = 0; - while (true) { - special.lastIndex = pos; - var m = special.exec(text); - var skipped = m ? m.index - pos : text.length - pos; - if (skipped) { - var txt = document.createTextNode(displayText.slice(pos, pos + skipped)); - if (ie && ie_version < 9) { content.appendChild(elt("span", [txt])); } - else { content.appendChild(txt); } - builder.map.push(builder.pos, builder.pos + skipped, txt); - builder.col += skipped; - builder.pos += skipped; - } - if (!m) { break } - pos += skipped + 1; - var txt$1 = (void 0); - if (m[0] == "\t") { - var tabSize = builder.cm.options.tabSize, tabWidth = tabSize - builder.col % tabSize; - txt$1 = content.appendChild(elt("span", spaceStr(tabWidth), "cm-tab")); - txt$1.setAttribute("role", "presentation"); - txt$1.setAttribute("cm-text", "\t"); - builder.col += tabWidth; - } else if (m[0] == "\r" || m[0] == "\n") { - txt$1 = content.appendChild(elt("span", m[0] == "\r" ? "\u240d" : "\u2424", "cm-invalidchar")); - txt$1.setAttribute("cm-text", m[0]); - builder.col += 1; - } else { - txt$1 = builder.cm.options.specialCharPlaceholder(m[0]); - txt$1.setAttribute("cm-text", m[0]); - if (ie && ie_version < 9) { content.appendChild(elt("span", [txt$1])); } - else { content.appendChild(txt$1); } - builder.col += 1; - } - builder.map.push(builder.pos, builder.pos + 1, txt$1); - builder.pos++; - } - } - builder.trailingSpace = displayText.charCodeAt(text.length - 1) == 32; - if (style || startStyle || endStyle || mustWrap || css) { - var fullStyle = style || ""; - if (startStyle) { fullStyle += startStyle; } - if (endStyle) { fullStyle += endStyle; } - var token = elt("span", [content], fullStyle, css); - if (title) { token.title = title; } - return builder.content.appendChild(token) - } - builder.content.appendChild(content); -} + if (!to) { to = from; } + if (cmp(to, from) < 0) { (assign = [to, from], from = assign[0], to = assign[1]); } + if (typeof code == "string") { code = doc.splitLines(code); } + makeChange(doc, {from: from, to: to, text: code, origin: origin}); + } -function splitSpaces(text, trailingBefore) { - if (text.length > 1 && !/ /.test(text)) { return text } - var spaceBefore = trailingBefore, result = ""; - for (var i = 0; i < text.length; i++) { - var ch = text.charAt(i); - if (ch == " " && spaceBefore && (i == text.length - 1 || text.charCodeAt(i + 1) == 32)) - { ch = "\u00a0"; } - result += ch; - spaceBefore = ch == " "; - } - return result -} + // Rebasing/resetting history to deal with externally-sourced changes -// Work around nonsense dimensions being reported for stretches of -// right-to-left text. -function buildTokenBadBidi(inner, order) { - return function (builder, text, style, startStyle, endStyle, title, css) { - style = style ? style + " cm-force-border" : "cm-force-border"; - var start = builder.pos, end = start + text.length; - for (;;) { - // Find the part that overlaps with the start of this text - var part = (void 0); - for (var i = 0; i < order.length; i++) { - part = order[i]; - if (part.to > start && part.from <= start) { break } - } - if (part.to >= end) { return inner(builder, text, style, startStyle, endStyle, title, css) } - inner(builder, text.slice(0, part.to - start), style, startStyle, null, title, css); - startStyle = null; - text = text.slice(part.to - start); - start = part.to; + function rebaseHistSelSingle(pos, from, to, diff) { + if (to < pos.line) { + pos.line += diff; + } else if (from < pos.line) { + pos.line = from; + pos.ch = 0; } } -} - -function buildCollapsedSpan(builder, size, marker, ignoreWidget) { - var widget = !ignoreWidget && marker.widgetNode; - if (widget) { builder.map.push(builder.pos, builder.pos + size, widget); } - if (!ignoreWidget && builder.cm.display.input.needsContentAttribute) { - if (!widget) - { widget = builder.content.appendChild(document.createElement("span")); } - widget.setAttribute("cm-marker", marker.id); - } - if (widget) { - builder.cm.display.input.setUneditable(widget); - builder.content.appendChild(widget); - } - builder.pos += size; - builder.trailingSpace = false; -} -// Outputs a number of spans to make up a line, taking highlighting -// and marked text into account. -function insertLineContent(line, builder, styles) { - var spans = line.markedSpans, allText = line.text, at = 0; - if (!spans) { - for (var i$1 = 1; i$1 < styles.length; i$1+=2) - { builder.addToken(builder, allText.slice(at, at = styles[i$1]), interpretTokenStyle(styles[i$1+1], builder.cm.options)); } - return - } - - var len = allText.length, pos = 0, i = 1, text = "", style, css; - var nextChange = 0, spanStyle, spanEndStyle, spanStartStyle, title, collapsed; - for (;;) { - if (nextChange == pos) { // Update current marker set - spanStyle = spanEndStyle = spanStartStyle = title = css = ""; - collapsed = null; nextChange = Infinity; - var foundBookmarks = [], endStyles = (void 0); - for (var j = 0; j < spans.length; ++j) { - var sp = spans[j], m = sp.marker; - if (m.type == "bookmark" && sp.from == pos && m.widgetNode) { - foundBookmarks.push(m); - } else if (sp.from <= pos && (sp.to == null || sp.to > pos || m.collapsed && sp.to == pos && sp.from == pos)) { - if (sp.to != null && sp.to != pos && nextChange > sp.to) { - nextChange = sp.to; - spanEndStyle = ""; - } - if (m.className) { spanStyle += " " + m.className; } - if (m.css) { css = (css ? css + ";" : "") + m.css; } - if (m.startStyle && sp.from == pos) { spanStartStyle += " " + m.startStyle; } - if (m.endStyle && sp.to == nextChange) { (endStyles || (endStyles = [])).push(m.endStyle, sp.to); } - if (m.title && !title) { title = m.title; } - if (m.collapsed && (!collapsed || compareCollapsedMarkers(collapsed.marker, m) < 0)) - { collapsed = sp; } - } else if (sp.from > pos && nextChange > sp.from) { - nextChange = sp.from; + // Tries to rebase an array of history events given a change in the + // document. If the change touches the same lines as the event, the + // event, and everything 'behind' it, is discarded. If the change is + // before the event, the event's positions are updated. Uses a + // copy-on-write scheme for the positions, to avoid having to + // reallocate them all on every rebase, but also avoid problems with + // shared position objects being unsafely updated. + function rebaseHistArray(array, from, to, diff) { + for (var i = 0; i < array.length; ++i) { + var sub = array[i], ok = true; + if (sub.ranges) { + if (!sub.copied) { sub = array[i] = sub.deepCopy(); sub.copied = true; } + for (var j = 0; j < sub.ranges.length; j++) { + rebaseHistSelSingle(sub.ranges[j].anchor, from, to, diff); + rebaseHistSelSingle(sub.ranges[j].head, from, to, diff); + } + continue + } + for (var j$1 = 0; j$1 < sub.changes.length; ++j$1) { + var cur = sub.changes[j$1]; + if (to < cur.from.line) { + cur.from = Pos(cur.from.line + diff, cur.from.ch); + cur.to = Pos(cur.to.line + diff, cur.to.ch); + } else if (from <= cur.to.line) { + ok = false; + break } } - if (endStyles) { for (var j$1 = 0; j$1 < endStyles.length; j$1 += 2) - { if (endStyles[j$1 + 1] == nextChange) { spanEndStyle += " " + endStyles[j$1]; } } } - - if (!collapsed || collapsed.from == pos) { for (var j$2 = 0; j$2 < foundBookmarks.length; ++j$2) - { buildCollapsedSpan(builder, 0, foundBookmarks[j$2]); } } - if (collapsed && (collapsed.from || 0) == pos) { - buildCollapsedSpan(builder, (collapsed.to == null ? len + 1 : collapsed.to) - pos, - collapsed.marker, collapsed.from == null); - if (collapsed.to == null) { return } - if (collapsed.to == pos) { collapsed = false; } - } - } - if (pos >= len) { break } - - var upto = Math.min(len, nextChange); - while (true) { - if (text) { - var end = pos + text.length; - if (!collapsed) { - var tokenText = end > upto ? text.slice(0, upto - pos) : text; - builder.addToken(builder, tokenText, style ? style + spanStyle : spanStyle, - spanStartStyle, pos + tokenText.length == nextChange ? spanEndStyle : "", title, css); - } - if (end >= upto) {text = text.slice(upto - pos); pos = upto; break} - pos = end; - spanStartStyle = ""; + if (!ok) { + array.splice(0, i + 1); + i = 0; } - text = allText.slice(at, at = styles[i++]); - style = interpretTokenStyle(styles[i++], builder.cm.options); } } -} - -// These objects are used to represent the visible (currently drawn) -// part of the document. A LineView may correspond to multiple -// logical lines, if those are connected by collapsed ranges. -function LineView(doc, line, lineN) { - // The starting line - this.line = line; - // Continuing lines, if any - this.rest = visualLineContinued(line); - // Number of logical lines in this visual line - this.size = this.rest ? lineNo(lst(this.rest)) - lineN + 1 : 1; - this.node = this.text = null; - this.hidden = lineIsHidden(doc, line); -} - -// Create a range of LineView objects for the given lines. -function buildViewArray(cm, from, to) { - var array = [], nextPos; - for (var pos = from; pos < to; pos = nextPos) { - var view = new LineView(cm.doc, getLine(cm.doc, pos), pos); - nextPos = pos + view.size; - array.push(view); + function rebaseHist(hist, change) { + var from = change.from.line, to = change.to.line, diff = change.text.length - (to - from) - 1; + rebaseHistArray(hist.done, from, to, diff); + rebaseHistArray(hist.undone, from, to, diff); } - return array -} -var operationGroup = null; - -function pushOperation(op) { - if (operationGroup) { - operationGroup.ops.push(op); - } else { - op.ownsGroup = operationGroup = { - ops: [op], - delayedCallbacks: [] - }; + // Utility for applying a change to a line by handle or number, + // returning the number and optionally registering the line as + // changed. + function changeLine(doc, handle, changeType, op) { + var no = handle, line = handle; + if (typeof handle == "number") { line = getLine(doc, clipLine(doc, handle)); } + else { no = lineNo(handle); } + if (no == null) { return null } + if (op(line, no) && doc.cm) { regLineChange(doc.cm, no, changeType); } + return line } -} -function fireCallbacksForOps(group) { - // Calls delayed callbacks and cursorActivity handlers until no - // new ones appear - var callbacks = group.delayedCallbacks, i = 0; - do { - for (; i < callbacks.length; i++) - { callbacks[i].call(null); } - for (var j = 0; j < group.ops.length; j++) { - var op = group.ops[j]; - if (op.cursorActivityHandlers) - { while (op.cursorActivityCalled < op.cursorActivityHandlers.length) - { op.cursorActivityHandlers[op.cursorActivityCalled++].call(null, op.cm); } } - } - } while (i < callbacks.length) -} - -function finishOperation(op, endCb) { - var group = op.ownsGroup; - if (!group) { return } + // The document is represented as a BTree consisting of leaves, with + // chunk of lines in them, and branches, with up to ten leaves or + // other branch nodes below them. The top node is always a branch + // node, and is the document object itself (meaning it has + // additional methods and properties). + // + // All nodes have parent links. The tree is used both to go from + // line numbers to line objects, and to go from objects to numbers. + // It also indexes by height, and is used to convert between height + // and line object, and to find the total height of the document. + // + // See also http://marijnhaverbeke.nl/blog/codemirror-line-tree.html - try { fireCallbacksForOps(group); } - finally { - operationGroup = null; - endCb(group); - } -} + function LeafChunk(lines) { + var this$1 = this; -var orphanDelayedCallbacks = null; - -// Often, we want to signal events at a point where we are in the -// middle of some work, but don't want the handler to start calling -// other methods on the editor, which might be in an inconsistent -// state or simply not expect any other events to happen. -// signalLater looks whether there are any handlers, and schedules -// them to be executed when the last operation ends, or, if no -// operation is active, when a timeout fires. -function signalLater(emitter, type /*, values...*/) { - var arr = getHandlers(emitter, type); - if (!arr.length) { return } - var args = Array.prototype.slice.call(arguments, 2), list; - if (operationGroup) { - list = operationGroup.delayedCallbacks; - } else if (orphanDelayedCallbacks) { - list = orphanDelayedCallbacks; - } else { - list = orphanDelayedCallbacks = []; - setTimeout(fireOrphanDelayed, 0); + this.lines = lines; + this.parent = null; + var height = 0; + for (var i = 0; i < lines.length; ++i) { + lines[i].parent = this$1; + height += lines[i].height; + } + this.height = height; } - var loop = function ( i ) { - list.push(function () { return arr[i].apply(null, args); }); - }; - for (var i = 0; i < arr.length; ++i) - loop( i ); -} + LeafChunk.prototype = { + chunkSize: function() { return this.lines.length }, -function fireOrphanDelayed() { - var delayed = orphanDelayedCallbacks; - orphanDelayedCallbacks = null; - for (var i = 0; i < delayed.length; ++i) { delayed[i](); } -} + // Remove the n lines at offset 'at'. + removeInner: function(at, n) { + var this$1 = this; -// When an aspect of a line changes, a string is added to -// lineView.changes. This updates the relevant part of the line's -// DOM structure. -function updateLineForChanges(cm, lineView, lineN, dims) { - for (var j = 0; j < lineView.changes.length; j++) { - var type = lineView.changes[j]; - if (type == "text") { updateLineText(cm, lineView); } - else if (type == "gutter") { updateLineGutter(cm, lineView, lineN, dims); } - else if (type == "class") { updateLineClasses(cm, lineView); } - else if (type == "widget") { updateLineWidgets(cm, lineView, dims); } - } - lineView.changes = null; -} + for (var i = at, e = at + n; i < e; ++i) { + var line = this$1.lines[i]; + this$1.height -= line.height; + cleanUpLine(line); + signalLater(line, "delete"); + } + this.lines.splice(at, n); + }, -// Lines with gutter elements, widgets or a background class need to -// be wrapped, and have the extra elements added to the wrapper div -function ensureLineWrapped(lineView) { - if (lineView.node == lineView.text) { - lineView.node = elt("div", null, null, "position: relative"); - if (lineView.text.parentNode) - { lineView.text.parentNode.replaceChild(lineView.node, lineView.text); } - lineView.node.appendChild(lineView.text); - if (ie && ie_version < 8) { lineView.node.style.zIndex = 2; } - } - return lineView.node -} + // Helper used to collapse a small branch into a single leaf. + collapse: function(lines) { + lines.push.apply(lines, this.lines); + }, -function updateLineBackground(cm, lineView) { - var cls = lineView.bgClass ? lineView.bgClass + " " + (lineView.line.bgClass || "") : lineView.line.bgClass; - if (cls) { cls += " CodeMirror-linebackground"; } - if (lineView.background) { - if (cls) { lineView.background.className = cls; } - else { lineView.background.parentNode.removeChild(lineView.background); lineView.background = null; } - } else if (cls) { - var wrap = ensureLineWrapped(lineView); - lineView.background = wrap.insertBefore(elt("div", null, cls), wrap.firstChild); - cm.display.input.setUneditable(lineView.background); - } -} + // Insert the given array of lines at offset 'at', count them as + // having the given height. + insertInner: function(at, lines, height) { + var this$1 = this; -// Wrapper around buildLineContent which will reuse the structure -// in display.externalMeasured when possible. -function getLineContent(cm, lineView) { - var ext = cm.display.externalMeasured; - if (ext && ext.line == lineView.line) { - cm.display.externalMeasured = null; - lineView.measure = ext.measure; - return ext.built - } - return buildLineContent(cm, lineView) -} + this.height += height; + this.lines = this.lines.slice(0, at).concat(lines).concat(this.lines.slice(at)); + for (var i = 0; i < lines.length; ++i) { lines[i].parent = this$1; } + }, -// Redraw the line's text. Interacts with the background and text -// classes because the mode may output tokens that influence these -// classes. -function updateLineText(cm, lineView) { - var cls = lineView.text.className; - var built = getLineContent(cm, lineView); - if (lineView.text == lineView.node) { lineView.node = built.pre; } - lineView.text.parentNode.replaceChild(built.pre, lineView.text); - lineView.text = built.pre; - if (built.bgClass != lineView.bgClass || built.textClass != lineView.textClass) { - lineView.bgClass = built.bgClass; - lineView.textClass = built.textClass; - updateLineClasses(cm, lineView); - } else if (cls) { - lineView.text.className = cls; - } -} + // Used to iterate over a part of the tree. + iterN: function(at, n, op) { + var this$1 = this; -function updateLineClasses(cm, lineView) { - updateLineBackground(cm, lineView); - if (lineView.line.wrapClass) - { ensureLineWrapped(lineView).className = lineView.line.wrapClass; } - else if (lineView.node != lineView.text) - { lineView.node.className = ""; } - var textClass = lineView.textClass ? lineView.textClass + " " + (lineView.line.textClass || "") : lineView.line.textClass; - lineView.text.className = textClass || ""; -} + for (var e = at + n; at < e; ++at) + { if (op(this$1.lines[at])) { return true } } + } + }; -function updateLineGutter(cm, lineView, lineN, dims) { - if (lineView.gutter) { - lineView.node.removeChild(lineView.gutter); - lineView.gutter = null; - } - if (lineView.gutterBackground) { - lineView.node.removeChild(lineView.gutterBackground); - lineView.gutterBackground = null; - } - if (lineView.line.gutterClass) { - var wrap = ensureLineWrapped(lineView); - lineView.gutterBackground = elt("div", null, "CodeMirror-gutter-background " + lineView.line.gutterClass, - ("left: " + (cm.options.fixedGutter ? dims.fixedPos : -dims.gutterTotalWidth) + "px; width: " + (dims.gutterTotalWidth) + "px")); - cm.display.input.setUneditable(lineView.gutterBackground); - wrap.insertBefore(lineView.gutterBackground, lineView.text); - } - var markers = lineView.line.gutterMarkers; - if (cm.options.lineNumbers || markers) { - var wrap$1 = ensureLineWrapped(lineView); - var gutterWrap = lineView.gutter = elt("div", null, "CodeMirror-gutter-wrapper", ("left: " + (cm.options.fixedGutter ? dims.fixedPos : -dims.gutterTotalWidth) + "px")); - cm.display.input.setUneditable(gutterWrap); - wrap$1.insertBefore(gutterWrap, lineView.text); - if (lineView.line.gutterClass) - { gutterWrap.className += " " + lineView.line.gutterClass; } - if (cm.options.lineNumbers && (!markers || !markers["CodeMirror-linenumbers"])) - { lineView.lineNumber = gutterWrap.appendChild( - elt("div", lineNumberFor(cm.options, lineN), - "CodeMirror-linenumber CodeMirror-gutter-elt", - ("left: " + (dims.gutterLeft["CodeMirror-linenumbers"]) + "px; width: " + (cm.display.lineNumInnerWidth) + "px"))); } - if (markers) { for (var k = 0; k < cm.options.gutters.length; ++k) { - var id = cm.options.gutters[k], found = markers.hasOwnProperty(id) && markers[id]; - if (found) - { gutterWrap.appendChild(elt("div", [found], "CodeMirror-gutter-elt", - ("left: " + (dims.gutterLeft[id]) + "px; width: " + (dims.gutterWidth[id]) + "px"))); } - } } - } -} + function BranchChunk(children) { + var this$1 = this; -function updateLineWidgets(cm, lineView, dims) { - if (lineView.alignable) { lineView.alignable = null; } - for (var node = lineView.node.firstChild, next = (void 0); node; node = next) { - next = node.nextSibling; - if (node.className == "CodeMirror-linewidget") - { lineView.node.removeChild(node); } + this.children = children; + var size = 0, height = 0; + for (var i = 0; i < children.length; ++i) { + var ch = children[i]; + size += ch.chunkSize(); height += ch.height; + ch.parent = this$1; + } + this.size = size; + this.height = height; + this.parent = null; } - insertLineWidgets(cm, lineView, dims); -} -// Build a line's DOM representation from scratch -function buildLineElement(cm, lineView, lineN, dims) { - var built = getLineContent(cm, lineView); - lineView.text = lineView.node = built.pre; - if (built.bgClass) { lineView.bgClass = built.bgClass; } - if (built.textClass) { lineView.textClass = built.textClass; } - - updateLineClasses(cm, lineView); - updateLineGutter(cm, lineView, lineN, dims); - insertLineWidgets(cm, lineView, dims); - return lineView.node -} + BranchChunk.prototype = { + chunkSize: function() { return this.size }, -// A lineView may contain multiple logical lines (when merged by -// collapsed spans). The widgets for all of them need to be drawn. -function insertLineWidgets(cm, lineView, dims) { - insertLineWidgetsFor(cm, lineView.line, lineView, dims, true); - if (lineView.rest) { for (var i = 0; i < lineView.rest.length; i++) - { insertLineWidgetsFor(cm, lineView.rest[i], lineView, dims, false); } } -} + removeInner: function(at, n) { + var this$1 = this; -function insertLineWidgetsFor(cm, line, lineView, dims, allowAbove) { - if (!line.widgets) { return } - var wrap = ensureLineWrapped(lineView); - for (var i = 0, ws = line.widgets; i < ws.length; ++i) { - var widget = ws[i], node = elt("div", [widget.node], "CodeMirror-linewidget"); - if (!widget.handleMouseEvents) { node.setAttribute("cm-ignore-events", "true"); } - positionLineWidget(widget, node, lineView, dims); - cm.display.input.setUneditable(node); - if (allowAbove && widget.above) - { wrap.insertBefore(node, lineView.gutter || lineView.text); } - else - { wrap.appendChild(node); } - signalLater(widget, "redraw"); - } -} + this.size -= n; + for (var i = 0; i < this.children.length; ++i) { + var child = this$1.children[i], sz = child.chunkSize(); + if (at < sz) { + var rm = Math.min(n, sz - at), oldHeight = child.height; + child.removeInner(at, rm); + this$1.height -= oldHeight - child.height; + if (sz == rm) { this$1.children.splice(i--, 1); child.parent = null; } + if ((n -= rm) == 0) { break } + at = 0; + } else { at -= sz; } + } + // If the result is smaller than 25 lines, ensure that it is a + // single leaf node. + if (this.size - n < 25 && + (this.children.length > 1 || !(this.children[0] instanceof LeafChunk))) { + var lines = []; + this.collapse(lines); + this.children = [new LeafChunk(lines)]; + this.children[0].parent = this; + } + }, + + collapse: function(lines) { + var this$1 = this; -function positionLineWidget(widget, node, lineView, dims) { - if (widget.noHScroll) { - (lineView.alignable || (lineView.alignable = [])).push(node); - var width = dims.wrapperWidth; - node.style.left = dims.fixedPos + "px"; - if (!widget.coverGutter) { - width -= dims.gutterTotalWidth; - node.style.paddingLeft = dims.gutterTotalWidth + "px"; - } - node.style.width = width + "px"; - } - if (widget.coverGutter) { - node.style.zIndex = 5; - node.style.position = "relative"; - if (!widget.noHScroll) { node.style.marginLeft = -dims.gutterTotalWidth + "px"; } - } -} + for (var i = 0; i < this.children.length; ++i) { this$1.children[i].collapse(lines); } + }, -function widgetHeight(widget) { - if (widget.height != null) { return widget.height } - var cm = widget.doc.cm; - if (!cm) { return 0 } - if (!contains(document.body, widget.node)) { - var parentStyle = "position: relative;"; - if (widget.coverGutter) - { parentStyle += "margin-left: -" + cm.display.gutters.offsetWidth + "px;"; } - if (widget.noHScroll) - { parentStyle += "width: " + cm.display.wrapper.clientWidth + "px;"; } - removeChildrenAndAdd(cm.display.measure, elt("div", [widget.node], null, parentStyle)); - } - return widget.height = widget.node.parentNode.offsetHeight -} + insertInner: function(at, lines, height) { + var this$1 = this; -// Return true when the given mouse event happened in a widget -function eventInWidget(display, e) { - for (var n = e_target(e); n != display.wrapper; n = n.parentNode) { - if (!n || (n.nodeType == 1 && n.getAttribute("cm-ignore-events") == "true") || - (n.parentNode == display.sizer && n != display.mover)) - { return true } - } -} + this.size += lines.length; + this.height += height; + for (var i = 0; i < this.children.length; ++i) { + var child = this$1.children[i], sz = child.chunkSize(); + if (at <= sz) { + child.insertInner(at, lines, height); + if (child.lines && child.lines.length > 50) { + // To avoid memory thrashing when child.lines is huge (e.g. first view of a large file), it's never spliced. + // Instead, small slices are taken. They're taken in order because sequential memory accesses are fastest. + var remaining = child.lines.length % 25 + 25; + for (var pos = remaining; pos < child.lines.length;) { + var leaf = new LeafChunk(child.lines.slice(pos, pos += 25)); + child.height -= leaf.height; + this$1.children.splice(++i, 0, leaf); + leaf.parent = this$1; + } + child.lines = child.lines.slice(0, remaining); + this$1.maybeSpill(); + } + break + } + at -= sz; + } + }, -// POSITION MEASUREMENT - -function paddingTop(display) {return display.lineSpace.offsetTop} -function paddingVert(display) {return display.mover.offsetHeight - display.lineSpace.offsetHeight} -function paddingH(display) { - if (display.cachedPaddingH) { return display.cachedPaddingH } - var e = removeChildrenAndAdd(display.measure, elt("pre", "x")); - var style = window.getComputedStyle ? window.getComputedStyle(e) : e.currentStyle; - var data = {left: parseInt(style.paddingLeft), right: parseInt(style.paddingRight)}; - if (!isNaN(data.left) && !isNaN(data.right)) { display.cachedPaddingH = data; } - return data -} + // When a node has grown, check whether it should be split. + maybeSpill: function() { + if (this.children.length <= 10) { return } + var me = this; + do { + var spilled = me.children.splice(me.children.length - 5, 5); + var sibling = new BranchChunk(spilled); + if (!me.parent) { // Become the parent node + var copy = new BranchChunk(me.children); + copy.parent = me; + me.children = [copy, sibling]; + me = copy; + } else { + me.size -= sibling.size; + me.height -= sibling.height; + var myIndex = indexOf(me.parent.children, me); + me.parent.children.splice(myIndex + 1, 0, sibling); + } + sibling.parent = me.parent; + } while (me.children.length > 10) + me.parent.maybeSpill(); + }, -function scrollGap(cm) { return scrollerGap - cm.display.nativeBarWidth } -function displayWidth(cm) { - return cm.display.scroller.clientWidth - scrollGap(cm) - cm.display.barWidth -} -function displayHeight(cm) { - return cm.display.scroller.clientHeight - scrollGap(cm) - cm.display.barHeight -} + iterN: function(at, n, op) { + var this$1 = this; -// Ensure the lineView.wrapping.heights array is populated. This is -// an array of bottom offsets for the lines that make up a drawn -// line. When lineWrapping is on, there might be more than one -// height. -function ensureLineHeights(cm, lineView, rect) { - var wrapping = cm.options.lineWrapping; - var curWidth = wrapping && displayWidth(cm); - if (!lineView.measure.heights || wrapping && lineView.measure.width != curWidth) { - var heights = lineView.measure.heights = []; - if (wrapping) { - lineView.measure.width = curWidth; - var rects = lineView.text.firstChild.getClientRects(); - for (var i = 0; i < rects.length - 1; i++) { - var cur = rects[i], next = rects[i + 1]; - if (Math.abs(cur.bottom - next.bottom) > 2) - { heights.push((cur.bottom + next.top) / 2 - rect.top); } - } - } - heights.push(rect.bottom - rect.top); - } -} + for (var i = 0; i < this.children.length; ++i) { + var child = this$1.children[i], sz = child.chunkSize(); + if (at < sz) { + var used = Math.min(n, sz - at); + if (child.iterN(at, used, op)) { return true } + if ((n -= used) == 0) { break } + at = 0; + } else { at -= sz; } + } + } + }; -// Find a line map (mapping character offsets to text nodes) and a -// measurement cache for the given line number. (A line view might -// contain multiple lines when collapsed ranges are present.) -function mapFromLineView(lineView, line, lineN) { - if (lineView.line == line) - { return {map: lineView.measure.map, cache: lineView.measure.cache} } - for (var i = 0; i < lineView.rest.length; i++) - { if (lineView.rest[i] == line) - { return {map: lineView.measure.maps[i], cache: lineView.measure.caches[i]} } } - for (var i$1 = 0; i$1 < lineView.rest.length; i$1++) - { if (lineNo(lineView.rest[i$1]) > lineN) - { return {map: lineView.measure.maps[i$1], cache: lineView.measure.caches[i$1], before: true} } } -} + // Line widgets are block elements displayed above or below a line. -// Render a line into the hidden node display.externalMeasured. Used -// when measurement is needed for a line that's not in the viewport. -function updateExternalMeasurement(cm, line) { - line = visualLine(line); - var lineN = lineNo(line); - var view = cm.display.externalMeasured = new LineView(cm.doc, line, lineN); - view.lineN = lineN; - var built = view.built = buildLineContent(cm, view); - view.text = built.pre; - removeChildrenAndAdd(cm.display.lineMeasure, built.pre); - return view -} + var LineWidget = function(doc, node, options) { + var this$1 = this; -// Get a {top, bottom, left, right} box (in line-local coordinates) -// for a given character. -function measureChar(cm, line, ch, bias) { - return measureCharPrepared(cm, prepareMeasureForLine(cm, line), ch, bias) -} + if (options) { for (var opt in options) { if (options.hasOwnProperty(opt)) + { this$1[opt] = options[opt]; } } } + this.doc = doc; + this.node = node; + }; -// Find a line view that corresponds to the given line number. -function findViewForLine(cm, lineN) { - if (lineN >= cm.display.viewFrom && lineN < cm.display.viewTo) - { return cm.display.view[findViewIndex(cm, lineN)] } - var ext = cm.display.externalMeasured; - if (ext && lineN >= ext.lineN && lineN < ext.lineN + ext.size) - { return ext } -} + LineWidget.prototype.clear = function () { + var this$1 = this; -// Measurement can be split in two steps, the set-up work that -// applies to the whole line, and the measurement of the actual -// character. Functions like coordsChar, that need to do a lot of -// measurements in a row, can thus ensure that the set-up work is -// only done once. -function prepareMeasureForLine(cm, line) { - var lineN = lineNo(line); - var view = findViewForLine(cm, lineN); - if (view && !view.text) { - view = null; - } else if (view && view.changes) { - updateLineForChanges(cm, view, lineN, getDimensions(cm)); - cm.curOp.forceUpdate = true; - } - if (!view) - { view = updateExternalMeasurement(cm, line); } - - var info = mapFromLineView(view, line, lineN); - return { - line: line, view: view, rect: null, - map: info.map, cache: info.cache, before: info.before, - hasHeights: false - } -} + var cm = this.doc.cm, ws = this.line.widgets, line = this.line, no = lineNo(line); + if (no == null || !ws) { return } + for (var i = 0; i < ws.length; ++i) { if (ws[i] == this$1) { ws.splice(i--, 1); } } + if (!ws.length) { line.widgets = null; } + var height = widgetHeight(this); + updateLineHeight(line, Math.max(0, line.height - height)); + if (cm) { + runInOp(cm, function () { + adjustScrollWhenAboveVisible(cm, line, -height); + regLineChange(cm, no, "widget"); + }); + signalLater(cm, "lineWidgetCleared", cm, this, no); + } + }; -// Given a prepared measurement object, measures the position of an -// actual character (or fetches it from the cache). -function measureCharPrepared(cm, prepared, ch, bias, varHeight) { - if (prepared.before) { ch = -1; } - var key = ch + (bias || ""), found; - if (prepared.cache.hasOwnProperty(key)) { - found = prepared.cache[key]; - } else { - if (!prepared.rect) - { prepared.rect = prepared.view.text.getBoundingClientRect(); } - if (!prepared.hasHeights) { - ensureLineHeights(cm, prepared.view, prepared.rect); - prepared.hasHeights = true; - } - found = measureCharInner(cm, prepared, ch, bias); - if (!found.bogus) { prepared.cache[key] = found; } - } - return {left: found.left, right: found.right, - top: varHeight ? found.rtop : found.top, - bottom: varHeight ? found.rbottom : found.bottom} -} + LineWidget.prototype.changed = function () { + var this$1 = this; -var nullRect = {left: 0, right: 0, top: 0, bottom: 0}; - -function nodeAndOffsetInLineMap(map$$1, ch, bias) { - var node, start, end, collapse, mStart, mEnd; - // First, search the line map for the text node corresponding to, - // or closest to, the target character. - for (var i = 0; i < map$$1.length; i += 3) { - mStart = map$$1[i]; - mEnd = map$$1[i + 1]; - if (ch < mStart) { - start = 0; end = 1; - collapse = "left"; - } else if (ch < mEnd) { - start = ch - mStart; - end = start + 1; - } else if (i == map$$1.length - 3 || ch == mEnd && map$$1[i + 3] > ch) { - end = mEnd - mStart; - start = end - 1; - if (ch >= mEnd) { collapse = "right"; } - } - if (start != null) { - node = map$$1[i + 2]; - if (mStart == mEnd && bias == (node.insertLeft ? "left" : "right")) - { collapse = bias; } - if (bias == "left" && start == 0) - { while (i && map$$1[i - 2] == map$$1[i - 3] && map$$1[i - 1].insertLeft) { - node = map$$1[(i -= 3) + 2]; - collapse = "left"; - } } - if (bias == "right" && start == mEnd - mStart) - { while (i < map$$1.length - 3 && map$$1[i + 3] == map$$1[i + 4] && !map$$1[i + 5].insertLeft) { - node = map$$1[(i += 3) + 2]; - collapse = "right"; - } } - break + var oldH = this.height, cm = this.doc.cm, line = this.line; + this.height = null; + var diff = widgetHeight(this) - oldH; + if (!diff) { return } + if (!lineIsHidden(this.doc, line)) { updateLineHeight(line, line.height + diff); } + if (cm) { + runInOp(cm, function () { + cm.curOp.forceUpdate = true; + adjustScrollWhenAboveVisible(cm, line, diff); + signalLater(cm, "lineWidgetChanged", cm, this$1, lineNo(line)); + }); } - } - return {node: node, start: start, end: end, collapse: collapse, coverStart: mStart, coverEnd: mEnd} -} - -function getUsefulRect(rects, bias) { - var rect = nullRect; - if (bias == "left") { for (var i = 0; i < rects.length; i++) { - if ((rect = rects[i]).left != rect.right) { break } - } } else { for (var i$1 = rects.length - 1; i$1 >= 0; i$1--) { - if ((rect = rects[i$1]).left != rect.right) { break } - } } - return rect -} + }; + eventMixin(LineWidget); -function measureCharInner(cm, prepared, ch, bias) { - var place = nodeAndOffsetInLineMap(prepared.map, ch, bias); - var node = place.node, start = place.start, end = place.end, collapse = place.collapse; - - var rect; - if (node.nodeType == 3) { // If it is a text node, use a range to retrieve the coordinates. - for (var i$1 = 0; i$1 < 4; i$1++) { // Retry a maximum of 4 times when nonsense rectangles are returned - while (start && isExtendingChar(prepared.line.text.charAt(place.coverStart + start))) { --start; } - while (place.coverStart + end < place.coverEnd && isExtendingChar(prepared.line.text.charAt(place.coverStart + end))) { ++end; } - if (ie && ie_version < 9 && start == 0 && end == place.coverEnd - place.coverStart) - { rect = node.parentNode.getBoundingClientRect(); } - else - { rect = getUsefulRect(range(node, start, end).getClientRects(), bias); } - if (rect.left || rect.right || start == 0) { break } - end = start; - start = start - 1; - collapse = "right"; - } - if (ie && ie_version < 11) { rect = maybeUpdateRectForZooming(cm.display.measure, rect); } - } else { // If it is a widget, simply get the box for the whole widget. - if (start > 0) { collapse = bias = "right"; } - var rects; - if (cm.options.lineWrapping && (rects = node.getClientRects()).length > 1) - { rect = rects[bias == "right" ? rects.length - 1 : 0]; } - else - { rect = node.getBoundingClientRect(); } + function adjustScrollWhenAboveVisible(cm, line, diff) { + if (heightAtLine(line) < ((cm.curOp && cm.curOp.scrollTop) || cm.doc.scrollTop)) + { addToScrollTop(cm, diff); } } - if (ie && ie_version < 9 && !start && (!rect || !rect.left && !rect.right)) { - var rSpan = node.parentNode.getClientRects()[0]; - if (rSpan) - { rect = {left: rSpan.left, right: rSpan.left + charWidth(cm.display), top: rSpan.top, bottom: rSpan.bottom}; } - else - { rect = nullRect; } - } - - var rtop = rect.top - prepared.rect.top, rbot = rect.bottom - prepared.rect.top; - var mid = (rtop + rbot) / 2; - var heights = prepared.view.measure.heights; - var i = 0; - for (; i < heights.length - 1; i++) - { if (mid < heights[i]) { break } } - var top = i ? heights[i - 1] : 0, bot = heights[i]; - var result = {left: (collapse == "right" ? rect.right : rect.left) - prepared.rect.left, - right: (collapse == "left" ? rect.left : rect.right) - prepared.rect.left, - top: top, bottom: bot}; - if (!rect.left && !rect.right) { result.bogus = true; } - if (!cm.options.singleCursorHeightPerLine) { result.rtop = rtop; result.rbottom = rbot; } - - return result -} - -// Work around problem with bounding client rects on ranges being -// returned incorrectly when zoomed on IE10 and below. -function maybeUpdateRectForZooming(measure, rect) { - if (!window.screen || screen.logicalXDPI == null || - screen.logicalXDPI == screen.deviceXDPI || !hasBadZoomedRects(measure)) - { return rect } - var scaleX = screen.logicalXDPI / screen.deviceXDPI; - var scaleY = screen.logicalYDPI / screen.deviceYDPI; - return {left: rect.left * scaleX, right: rect.right * scaleX, - top: rect.top * scaleY, bottom: rect.bottom * scaleY} -} -function clearLineMeasurementCacheFor(lineView) { - if (lineView.measure) { - lineView.measure.cache = {}; - lineView.measure.heights = null; - if (lineView.rest) { for (var i = 0; i < lineView.rest.length; i++) - { lineView.measure.caches[i] = {}; } } + function addLineWidget(doc, handle, node, options) { + var widget = new LineWidget(doc, node, options); + var cm = doc.cm; + if (cm && widget.noHScroll) { cm.display.alignWidgets = true; } + changeLine(doc, handle, "widget", function (line) { + var widgets = line.widgets || (line.widgets = []); + if (widget.insertAt == null) { widgets.push(widget); } + else { widgets.splice(Math.min(widgets.length - 1, Math.max(0, widget.insertAt)), 0, widget); } + widget.line = line; + if (cm && !lineIsHidden(doc, line)) { + var aboveVisible = heightAtLine(line) < doc.scrollTop; + updateLineHeight(line, line.height + widgetHeight(widget)); + if (aboveVisible) { addToScrollTop(cm, widget.height); } + cm.curOp.forceUpdate = true; + } + return true + }); + if (cm) { signalLater(cm, "lineWidgetAdded", cm, widget, typeof handle == "number" ? handle : lineNo(handle)); } + return widget } -} -function clearLineMeasurementCache(cm) { - cm.display.externalMeasure = null; - removeChildren(cm.display.lineMeasure); - for (var i = 0; i < cm.display.view.length; i++) - { clearLineMeasurementCacheFor(cm.display.view[i]); } -} - -function clearCaches(cm) { - clearLineMeasurementCache(cm); - cm.display.cachedCharWidth = cm.display.cachedTextHeight = cm.display.cachedPaddingH = null; - if (!cm.options.lineWrapping) { cm.display.maxLineChanged = true; } - cm.display.lineNumChars = null; -} + // TEXTMARKERS -function pageScrollX() { - // Work around https://bugs.chromium.org/p/chromium/issues/detail?id=489206 - // which causes page_Offset and bounding client rects to use - // different reference viewports and invalidate our calculations. - if (chrome && android) { return -(document.body.getBoundingClientRect().left - parseInt(getComputedStyle(document.body).marginLeft)) } - return window.pageXOffset || (document.documentElement || document.body).scrollLeft -} -function pageScrollY() { - if (chrome && android) { return -(document.body.getBoundingClientRect().top - parseInt(getComputedStyle(document.body).marginTop)) } - return window.pageYOffset || (document.documentElement || document.body).scrollTop -} + // Created with markText and setBookmark methods. A TextMarker is a + // handle that can be used to clear or find a marked position in the + // document. Line objects hold arrays (markedSpans) containing + // {from, to, marker} object pointing to such marker objects, and + // indicating that such a marker is present on that line. Multiple + // lines may point to the same marker when it spans across lines. + // The spans will have null for their from/to properties when the + // marker continues beyond the start/end of the line. Markers have + // links back to the lines they currently touch. -function widgetTopHeight(lineObj) { - var height = 0; - if (lineObj.widgets) { for (var i = 0; i < lineObj.widgets.length; ++i) { if (lineObj.widgets[i].above) - { height += widgetHeight(lineObj.widgets[i]); } } } - return height -} + // Collapsed markers have unique ids, in order to be able to order + // them, which is needed for uniquely determining an outer marker + // when they overlap (they may nest, but not partially overlap). + var nextMarkerId = 0; -// Converts a {top, bottom, left, right} box from line-local -// coordinates into another coordinate system. Context may be one of -// "line", "div" (display.lineDiv), "local"./null (editor), "window", -// or "page". -function intoCoordSystem(cm, lineObj, rect, context, includeWidgets) { - if (!includeWidgets) { - var height = widgetTopHeight(lineObj); - rect.top += height; rect.bottom += height; - } - if (context == "line") { return rect } - if (!context) { context = "local"; } - var yOff = heightAtLine(lineObj); - if (context == "local") { yOff += paddingTop(cm.display); } - else { yOff -= cm.display.viewOffset; } - if (context == "page" || context == "window") { - var lOff = cm.display.lineSpace.getBoundingClientRect(); - yOff += lOff.top + (context == "window" ? 0 : pageScrollY()); - var xOff = lOff.left + (context == "window" ? 0 : pageScrollX()); - rect.left += xOff; rect.right += xOff; - } - rect.top += yOff; rect.bottom += yOff; - return rect -} + var TextMarker = function(doc, type) { + this.lines = []; + this.type = type; + this.doc = doc; + this.id = ++nextMarkerId; + }; -// Coverts a box from "div" coords to another coordinate system. -// Context may be "window", "page", "div", or "local"./null. -function fromCoordSystem(cm, coords, context) { - if (context == "div") { return coords } - var left = coords.left, top = coords.top; - // First move into "page" coordinate system - if (context == "page") { - left -= pageScrollX(); - top -= pageScrollY(); - } else if (context == "local" || !context) { - var localBox = cm.display.sizer.getBoundingClientRect(); - left += localBox.left; - top += localBox.top; - } - - var lineSpaceBox = cm.display.lineSpace.getBoundingClientRect(); - return {left: left - lineSpaceBox.left, top: top - lineSpaceBox.top} -} + // Clear the marker. + TextMarker.prototype.clear = function () { + var this$1 = this; -function charCoords(cm, pos, context, lineObj, bias) { - if (!lineObj) { lineObj = getLine(cm.doc, pos.line); } - return intoCoordSystem(cm, lineObj, measureChar(cm, lineObj, pos.ch, bias), context) -} + if (this.explicitlyCleared) { return } + var cm = this.doc.cm, withOp = cm && !cm.curOp; + if (withOp) { startOperation(cm); } + if (hasHandler(this, "clear")) { + var found = this.find(); + if (found) { signalLater(this, "clear", found.from, found.to); } + } + var min = null, max = null; + for (var i = 0; i < this.lines.length; ++i) { + var line = this$1.lines[i]; + var span = getMarkedSpanFor(line.markedSpans, this$1); + if (cm && !this$1.collapsed) { regLineChange(cm, lineNo(line), "text"); } + else if (cm) { + if (span.to != null) { max = lineNo(line); } + if (span.from != null) { min = lineNo(line); } + } + line.markedSpans = removeMarkedSpan(line.markedSpans, span); + if (span.from == null && this$1.collapsed && !lineIsHidden(this$1.doc, line) && cm) + { updateLineHeight(line, textHeight(cm.display)); } + } + if (cm && this.collapsed && !cm.options.lineWrapping) { for (var i$1 = 0; i$1 < this.lines.length; ++i$1) { + var visual = visualLine(this$1.lines[i$1]), len = lineLength(visual); + if (len > cm.display.maxLineLength) { + cm.display.maxLine = visual; + cm.display.maxLineLength = len; + cm.display.maxLineChanged = true; + } + } } -// Returns a box for a given cursor position, which may have an -// 'other' property containing the position of the secondary cursor -// on a bidi boundary. -// A cursor Pos(line, char, "before") is on the same visual line as `char - 1` -// and after `char - 1` in writing order of `char - 1` -// A cursor Pos(line, char, "after") is on the same visual line as `char` -// and before `char` in writing order of `char` -// Examples (upper-case letters are RTL, lower-case are LTR): -// Pos(0, 1, ...) -// before after -// ab a|b a|b -// aB a|B aB| -// Ab |Ab A|b -// AB B|A B|A -// Every position after the last character on a line is considered to stick -// to the last character on the line. -function cursorCoords(cm, pos, context, lineObj, preparedMeasure, varHeight) { - lineObj = lineObj || getLine(cm.doc, pos.line); - if (!preparedMeasure) { preparedMeasure = prepareMeasureForLine(cm, lineObj); } - function get(ch, right) { - var m = measureCharPrepared(cm, preparedMeasure, ch, right ? "right" : "left", varHeight); - if (right) { m.left = m.right; } else { m.right = m.left; } - return intoCoordSystem(cm, lineObj, m, context) - } - var order = getOrder(lineObj, cm.doc.direction), ch = pos.ch, sticky = pos.sticky; - if (ch >= lineObj.text.length) { - ch = lineObj.text.length; - sticky = "before"; - } else if (ch <= 0) { - ch = 0; - sticky = "after"; - } - if (!order) { return get(sticky == "before" ? ch - 1 : ch, sticky == "before") } - - function getBidi(ch, partPos, invert) { - var part = order[partPos], right = part.level == 1; - return get(invert ? ch - 1 : ch, right != invert) - } - var partPos = getBidiPartAt(order, ch, sticky); - var other = bidiOther; - var val = getBidi(ch, partPos, sticky == "before"); - if (other != null) { val.other = getBidi(ch, other, sticky != "before"); } - return val -} + if (min != null && cm && this.collapsed) { regChange(cm, min, max + 1); } + this.lines.length = 0; + this.explicitlyCleared = true; + if (this.atomic && this.doc.cantEdit) { + this.doc.cantEdit = false; + if (cm) { reCheckSelection(cm.doc); } + } + if (cm) { signalLater(cm, "markerCleared", cm, this, min, max); } + if (withOp) { endOperation(cm); } + if (this.parent) { this.parent.clear(); } + }; -// Used to cheaply estimate the coordinates for a position. Used for -// intermediate scroll updates. -function estimateCoords(cm, pos) { - var left = 0; - pos = clipPos(cm.doc, pos); - if (!cm.options.lineWrapping) { left = charWidth(cm.display) * pos.ch; } - var lineObj = getLine(cm.doc, pos.line); - var top = heightAtLine(lineObj) + paddingTop(cm.display); - return {left: left, right: left, top: top, bottom: top + lineObj.height} -} + // Find the position of the marker in the document. Returns a {from, + // to} object by default. Side can be passed to get a specific side + // -- 0 (both), -1 (left), or 1 (right). When lineObj is true, the + // Pos objects returned contain a line object, rather than a line + // number (used to prevent looking up the same line twice). + TextMarker.prototype.find = function (side, lineObj) { + var this$1 = this; -// Positions returned by coordsChar contain some extra information. -// xRel is the relative x position of the input coordinates compared -// to the found position (so xRel > 0 means the coordinates are to -// the right of the character position, for example). When outside -// is true, that means the coordinates lie outside the line's -// vertical range. -function PosWithInfo(line, ch, sticky, outside, xRel) { - var pos = Pos(line, ch, sticky); - pos.xRel = xRel; - if (outside) { pos.outside = true; } - return pos -} + if (side == null && this.type == "bookmark") { side = 1; } + var from, to; + for (var i = 0; i < this.lines.length; ++i) { + var line = this$1.lines[i]; + var span = getMarkedSpanFor(line.markedSpans, this$1); + if (span.from != null) { + from = Pos(lineObj ? line : lineNo(line), span.from); + if (side == -1) { return from } + } + if (span.to != null) { + to = Pos(lineObj ? line : lineNo(line), span.to); + if (side == 1) { return to } + } + } + return from && {from: from, to: to} + }; -// Compute the character position closest to the given coordinates. -// Input must be lineSpace-local ("div" coordinate system). -function coordsChar(cm, x, y) { - var doc = cm.doc; - y += cm.display.viewOffset; - if (y < 0) { return PosWithInfo(doc.first, 0, null, true, -1) } - var lineN = lineAtHeight(doc, y), last = doc.first + doc.size - 1; - if (lineN > last) - { return PosWithInfo(doc.first + doc.size - 1, getLine(doc, last).text.length, null, true, 1) } - if (x < 0) { x = 0; } - - var lineObj = getLine(doc, lineN); - for (;;) { - var found = coordsCharInner(cm, lineObj, lineN, x, y); - var merged = collapsedSpanAtEnd(lineObj); - var mergedPos = merged && merged.find(0, true); - if (merged && (found.ch > mergedPos.from.ch || found.ch == mergedPos.from.ch && found.xRel > 0)) - { lineN = lineNo(lineObj = mergedPos.to.line); } - else - { return found } - } -} + // Signals that the marker's widget changed, and surrounding layout + // should be recomputed. + TextMarker.prototype.changed = function () { + var this$1 = this; -function wrappedLineExtent(cm, lineObj, preparedMeasure, y) { - y -= widgetTopHeight(lineObj); - var end = lineObj.text.length; - var begin = findFirst(function (ch) { return measureCharPrepared(cm, preparedMeasure, ch - 1).bottom <= y; }, end, 0); - end = findFirst(function (ch) { return measureCharPrepared(cm, preparedMeasure, ch).top > y; }, begin, end); - return {begin: begin, end: end} -} + var pos = this.find(-1, true), widget = this, cm = this.doc.cm; + if (!pos || !cm) { return } + runInOp(cm, function () { + var line = pos.line, lineN = lineNo(pos.line); + var view = findViewForLine(cm, lineN); + if (view) { + clearLineMeasurementCacheFor(view); + cm.curOp.selectionChanged = cm.curOp.forceUpdate = true; + } + cm.curOp.updateMaxLine = true; + if (!lineIsHidden(widget.doc, line) && widget.height != null) { + var oldHeight = widget.height; + widget.height = null; + var dHeight = widgetHeight(widget) - oldHeight; + if (dHeight) + { updateLineHeight(line, line.height + dHeight); } + } + signalLater(cm, "markerChanged", cm, this$1); + }); + }; -function wrappedLineExtentChar(cm, lineObj, preparedMeasure, target) { - if (!preparedMeasure) { preparedMeasure = prepareMeasureForLine(cm, lineObj); } - var targetTop = intoCoordSystem(cm, lineObj, measureCharPrepared(cm, preparedMeasure, target), "line").top; - return wrappedLineExtent(cm, lineObj, preparedMeasure, targetTop) -} + TextMarker.prototype.attachLine = function (line) { + if (!this.lines.length && this.doc.cm) { + var op = this.doc.cm.curOp; + if (!op.maybeHiddenMarkers || indexOf(op.maybeHiddenMarkers, this) == -1) + { (op.maybeUnhiddenMarkers || (op.maybeUnhiddenMarkers = [])).push(this); } + } + this.lines.push(line); + }; + + TextMarker.prototype.detachLine = function (line) { + this.lines.splice(indexOf(this.lines, line), 1); + if (!this.lines.length && this.doc.cm) { + var op = this.doc.cm.curOp + ;(op.maybeHiddenMarkers || (op.maybeHiddenMarkers = [])).push(this); + } + }; + eventMixin(TextMarker); + + // Create a marker, wire it up to the right lines, and + function markText(doc, from, to, options, type) { + // Shared markers (across linked documents) are handled separately + // (markTextShared will call out to this again, once per + // document). + if (options && options.shared) { return markTextShared(doc, from, to, options, type) } + // Ensure we are in an operation. + if (doc.cm && !doc.cm.curOp) { return operation(doc.cm, markText)(doc, from, to, options, type) } + + var marker = new TextMarker(doc, type), diff = cmp(from, to); + if (options) { copyObj(options, marker, false); } + // Don't connect empty markers unless clearWhenEmpty is false + if (diff > 0 || diff == 0 && marker.clearWhenEmpty !== false) + { return marker } + if (marker.replacedWith) { + // Showing up as a widget implies collapsed (widget replaces text) + marker.collapsed = true; + marker.widgetNode = eltP("span", [marker.replacedWith], "CodeMirror-widget"); + if (!options.handleMouseEvents) { marker.widgetNode.setAttribute("cm-ignore-events", "true"); } + if (options.insertLeft) { marker.widgetNode.insertLeft = true; } + } + if (marker.collapsed) { + if (conflictingCollapsedRange(doc, from.line, from, to, marker) || + from.line != to.line && conflictingCollapsedRange(doc, to.line, from, to, marker)) + { throw new Error("Inserting collapsed marker partially overlapping an existing one") } + seeCollapsedSpans(); + } + + if (marker.addToHistory) + { addChangeToHistory(doc, {from: from, to: to, origin: "markText"}, doc.sel, NaN); } + + var curLine = from.line, cm = doc.cm, updateMaxLine; + doc.iter(curLine, to.line + 1, function (line) { + if (cm && marker.collapsed && !cm.options.lineWrapping && visualLine(line) == cm.display.maxLine) + { updateMaxLine = true; } + if (marker.collapsed && curLine != from.line) { updateLineHeight(line, 0); } + addMarkedSpan(line, new MarkedSpan(marker, + curLine == from.line ? from.ch : null, + curLine == to.line ? to.ch : null)); + ++curLine; + }); + // lineIsHidden depends on the presence of the spans, so needs a second pass + if (marker.collapsed) { doc.iter(from.line, to.line + 1, function (line) { + if (lineIsHidden(doc, line)) { updateLineHeight(line, 0); } + }); } + + if (marker.clearOnEnter) { on(marker, "beforeCursorEnter", function () { return marker.clear(); }); } + + if (marker.readOnly) { + seeReadOnlySpans(); + if (doc.history.done.length || doc.history.undone.length) + { doc.clearHistory(); } + } + if (marker.collapsed) { + marker.id = ++nextMarkerId; + marker.atomic = true; + } + if (cm) { + // Sync editor state + if (updateMaxLine) { cm.curOp.updateMaxLine = true; } + if (marker.collapsed) + { regChange(cm, from.line, to.line + 1); } + else if (marker.className || marker.startStyle || marker.endStyle || marker.css || + marker.attributes || marker.title) + { for (var i = from.line; i <= to.line; i++) { regLineChange(cm, i, "text"); } } + if (marker.atomic) { reCheckSelection(cm.doc); } + signalLater(cm, "markerAdded", cm, marker); + } + return marker + } + + // SHARED TEXTMARKERS + + // A shared marker spans multiple linked documents. It is + // implemented as a meta-marker-object controlling multiple normal + // markers. + var SharedTextMarker = function(markers, primary) { + var this$1 = this; -// Returns true if the given side of a box is after the given -// coordinates, in top-to-bottom, left-to-right order. -function boxIsAfter(box, x, y, left) { - return box.bottom <= y ? false : box.top > y ? true : (left ? box.left : box.right) > x -} + this.markers = markers; + this.primary = primary; + for (var i = 0; i < markers.length; ++i) + { markers[i].parent = this$1; } + }; -function coordsCharInner(cm, lineObj, lineNo$$1, x, y) { - // Move y into line-local coordinate space - y -= heightAtLine(lineObj); - var preparedMeasure = prepareMeasureForLine(cm, lineObj); - // When directly calling `measureCharPrepared`, we have to adjust - // for the widgets at this line. - var widgetHeight$$1 = widgetTopHeight(lineObj); - var begin = 0, end = lineObj.text.length, ltr = true; - - var order = getOrder(lineObj, cm.doc.direction); - // If the line isn't plain left-to-right text, first figure out - // which bidi section the coordinates fall into. - if (order) { - var part = (cm.options.lineWrapping ? coordsBidiPartWrapped : coordsBidiPart) - (cm, lineObj, lineNo$$1, preparedMeasure, order, x, y); - ltr = part.level != 1; - // The awkward -1 offsets are needed because findFirst (called - // on these below) will treat its first bound as inclusive, - // second as exclusive, but we want to actually address the - // characters in the part's range - begin = ltr ? part.from : part.to - 1; - end = ltr ? part.to : part.from - 1; - } - - // A binary search to find the first character whose bounding box - // starts after the coordinates. If we run across any whose box wrap - // the coordinates, store that. - var chAround = null, boxAround = null; - var ch = findFirst(function (ch) { - var box = measureCharPrepared(cm, preparedMeasure, ch); - box.top += widgetHeight$$1; box.bottom += widgetHeight$$1; - if (!boxIsAfter(box, x, y, false)) { return false } - if (box.top <= y && box.left <= x) { - chAround = ch; - boxAround = box; - } - return true - }, begin, end); - - var baseX, sticky, outside = false; - // If a box around the coordinates was found, use that - if (boxAround) { - // Distinguish coordinates nearer to the left or right side of the box - var atLeft = x - boxAround.left < boxAround.right - x, atStart = atLeft == ltr; - ch = chAround + (atStart ? 0 : 1); - sticky = atStart ? "after" : "before"; - baseX = atLeft ? boxAround.left : boxAround.right; - } else { - // (Adjust for extended bound, if necessary.) - if (!ltr && (ch == end || ch == begin)) { ch++; } - // To determine which side to associate with, get the box to the - // left of the character and compare it's vertical position to the - // coordinates - sticky = ch == 0 ? "after" : ch == lineObj.text.length ? "before" : - (measureCharPrepared(cm, preparedMeasure, ch - (ltr ? 1 : 0)).bottom + widgetHeight$$1 <= y) == ltr ? - "after" : "before"; - // Now get accurate coordinates for this place, in order to get a - // base X position - var coords = cursorCoords(cm, Pos(lineNo$$1, ch, sticky), "line", lineObj, preparedMeasure); - baseX = coords.left; - outside = y < coords.top || y >= coords.bottom; - } - - ch = skipExtendingChars(lineObj.text, ch, 1); - return PosWithInfo(lineNo$$1, ch, sticky, outside, x - baseX) -} + SharedTextMarker.prototype.clear = function () { + var this$1 = this; -function coordsBidiPart(cm, lineObj, lineNo$$1, preparedMeasure, order, x, y) { - // Bidi parts are sorted left-to-right, and in a non-line-wrapping - // situation, we can take this ordering to correspond to the visual - // ordering. This finds the first part whose end is after the given - // coordinates. - var index = findFirst(function (i) { - var part = order[i], ltr = part.level != 1; - return boxIsAfter(cursorCoords(cm, Pos(lineNo$$1, ltr ? part.to : part.from, ltr ? "before" : "after"), - "line", lineObj, preparedMeasure), x, y, true) - }, 0, order.length - 1); - var part = order[index]; - // If this isn't the first part, the part's start is also after - // the coordinates, and the coordinates aren't on the same line as - // that start, move one part back. - if (index > 0) { - var ltr = part.level != 1; - var start = cursorCoords(cm, Pos(lineNo$$1, ltr ? part.from : part.to, ltr ? "after" : "before"), - "line", lineObj, preparedMeasure); - if (boxIsAfter(start, x, y, true) && start.top > y) - { part = order[index - 1]; } - } - return part -} + if (this.explicitlyCleared) { return } + this.explicitlyCleared = true; + for (var i = 0; i < this.markers.length; ++i) + { this$1.markers[i].clear(); } + signalLater(this, "clear"); + }; + + SharedTextMarker.prototype.find = function (side, lineObj) { + return this.primary.find(side, lineObj) + }; + eventMixin(SharedTextMarker); + + function markTextShared(doc, from, to, options, type) { + options = copyObj(options); + options.shared = false; + var markers = [markText(doc, from, to, options, type)], primary = markers[0]; + var widget = options.widgetNode; + linkedDocs(doc, function (doc) { + if (widget) { options.widgetNode = widget.cloneNode(true); } + markers.push(markText(doc, clipPos(doc, from), clipPos(doc, to), options, type)); + for (var i = 0; i < doc.linked.length; ++i) + { if (doc.linked[i].isParent) { return } } + primary = lst(markers); + }); + return new SharedTextMarker(markers, primary) + } -function coordsBidiPartWrapped(cm, lineObj, _lineNo, preparedMeasure, order, x, y) { - // In a wrapped line, rtl text on wrapping boundaries can do things - // that don't correspond to the ordering in our `order` array at - // all, so a binary search doesn't work, and we want to return a - // part that only spans one line so that the binary search in - // coordsCharInner is safe. As such, we first find the extent of the - // wrapped line, and then do a flat search in which we discard any - // spans that aren't on the line. - var ref = wrappedLineExtent(cm, lineObj, preparedMeasure, y); - var begin = ref.begin; - var end = ref.end; - if (/\s/.test(lineObj.text.charAt(end - 1))) { end--; } - var part = null, closestDist = null; - for (var i = 0; i < order.length; i++) { - var p = order[i]; - if (p.from >= end || p.to <= begin) { continue } - var ltr = p.level != 1; - var endX = measureCharPrepared(cm, preparedMeasure, ltr ? Math.min(end, p.to) - 1 : Math.max(begin, p.from)).right; - // Weigh against spans ending before this, so that they are only - // picked if nothing ends after - var dist = endX < x ? x - endX + 1e9 : endX - x; - if (!part || closestDist > dist) { - part = p; - closestDist = dist; - } - } - if (!part) { part = order[order.length - 1]; } - // Clip the part to the wrapped line. - if (part.from < begin) { part = {from: begin, to: part.to, level: part.level}; } - if (part.to > end) { part = {from: part.from, to: end, level: part.level}; } - return part -} + function findSharedMarkers(doc) { + return doc.findMarks(Pos(doc.first, 0), doc.clipPos(Pos(doc.lastLine())), function (m) { return m.parent; }) + } -var measureText; -// Compute the default text height. -function textHeight(display) { - if (display.cachedTextHeight != null) { return display.cachedTextHeight } - if (measureText == null) { - measureText = elt("pre"); - // Measure a bunch of lines, for browsers that compute - // fractional heights. - for (var i = 0; i < 49; ++i) { - measureText.appendChild(document.createTextNode("x")); - measureText.appendChild(elt("br")); + function copySharedMarkers(doc, markers) { + for (var i = 0; i < markers.length; i++) { + var marker = markers[i], pos = marker.find(); + var mFrom = doc.clipPos(pos.from), mTo = doc.clipPos(pos.to); + if (cmp(mFrom, mTo)) { + var subMark = markText(doc, mFrom, mTo, marker.primary, marker.primary.type); + marker.markers.push(subMark); + subMark.parent = marker; + } } - measureText.appendChild(document.createTextNode("x")); } - removeChildrenAndAdd(display.measure, measureText); - var height = measureText.offsetHeight / 50; - if (height > 3) { display.cachedTextHeight = height; } - removeChildren(display.measure); - return height || 1 -} - -// Compute the default character width. -function charWidth(display) { - if (display.cachedCharWidth != null) { return display.cachedCharWidth } - var anchor = elt("span", "xxxxxxxxxx"); - var pre = elt("pre", [anchor]); - removeChildrenAndAdd(display.measure, pre); - var rect = anchor.getBoundingClientRect(), width = (rect.right - rect.left) / 10; - if (width > 2) { display.cachedCharWidth = width; } - return width || 10 -} - -// Do a bulk-read of the DOM positions and sizes needed to draw the -// view, so that we don't interleave reading and writing to the DOM. -function getDimensions(cm) { - var d = cm.display, left = {}, width = {}; - var gutterLeft = d.gutters.clientLeft; - for (var n = d.gutters.firstChild, i = 0; n; n = n.nextSibling, ++i) { - left[cm.options.gutters[i]] = n.offsetLeft + n.clientLeft + gutterLeft; - width[cm.options.gutters[i]] = n.clientWidth; - } - return {fixedPos: compensateForHScroll(d), - gutterTotalWidth: d.gutters.offsetWidth, - gutterLeft: left, - gutterWidth: width, - wrapperWidth: d.wrapper.clientWidth} -} - -// Computes display.scroller.scrollLeft + display.gutters.offsetWidth, -// but using getBoundingClientRect to get a sub-pixel-accurate -// result. -function compensateForHScroll(display) { - return display.scroller.getBoundingClientRect().left - display.sizer.getBoundingClientRect().left -} - -// Returns a function that estimates the height of a line, to use as -// first approximation until the line becomes visible (and is thus -// properly measurable). -function estimateHeight(cm) { - var th = textHeight(cm.display), wrapping = cm.options.lineWrapping; - var perLine = wrapping && Math.max(5, cm.display.scroller.clientWidth / charWidth(cm.display) - 3); - return function (line) { - if (lineIsHidden(cm.doc, line)) { return 0 } - - var widgetsHeight = 0; - if (line.widgets) { for (var i = 0; i < line.widgets.length; i++) { - if (line.widgets[i].height) { widgetsHeight += line.widgets[i].height; } - } } - if (wrapping) - { return widgetsHeight + (Math.ceil(line.text.length / perLine) || 1) * th } - else - { return widgetsHeight + th } - } -} + function detachSharedMarkers(markers) { + var loop = function ( i ) { + var marker = markers[i], linked = [marker.primary.doc]; + linkedDocs(marker.primary.doc, function (d) { return linked.push(d); }); + for (var j = 0; j < marker.markers.length; j++) { + var subMarker = marker.markers[j]; + if (indexOf(linked, subMarker.doc) == -1) { + subMarker.parent = null; + marker.markers.splice(j--, 1); + } + } + }; -function estimateLineHeights(cm) { - var doc = cm.doc, est = estimateHeight(cm); - doc.iter(function (line) { - var estHeight = est(line); - if (estHeight != line.height) { updateLineHeight(line, estHeight); } - }); -} + for (var i = 0; i < markers.length; i++) loop( i ); + } + + var nextDocId = 0; + var Doc = function(text, mode, firstLine, lineSep, direction) { + if (!(this instanceof Doc)) { return new Doc(text, mode, firstLine, lineSep, direction) } + if (firstLine == null) { firstLine = 0; } + + BranchChunk.call(this, [new LeafChunk([new Line("", null)])]); + this.first = firstLine; + this.scrollTop = this.scrollLeft = 0; + this.cantEdit = false; + this.cleanGeneration = 1; + this.modeFrontier = this.highlightFrontier = firstLine; + var start = Pos(firstLine, 0); + this.sel = simpleSelection(start); + this.history = new History(null); + this.id = ++nextDocId; + this.modeOption = mode; + this.lineSep = lineSep; + this.direction = (direction == "rtl") ? "rtl" : "ltr"; + this.extend = false; + + if (typeof text == "string") { text = this.splitLines(text); } + updateDoc(this, {from: start, to: start, text: text}); + setSelection(this, simpleSelection(start), sel_dontScroll); + }; + + Doc.prototype = createObj(BranchChunk.prototype, { + constructor: Doc, + // Iterate over the document. Supports two forms -- with only one + // argument, it calls that for each line in the document. With + // three, it iterates over the range given by the first two (with + // the second being non-inclusive). + iter: function(from, to, op) { + if (op) { this.iterN(from - this.first, to - from, op); } + else { this.iterN(this.first, this.first + this.size, from); } + }, + + // Non-public interface for adding and removing lines. + insert: function(at, lines) { + var height = 0; + for (var i = 0; i < lines.length; ++i) { height += lines[i].height; } + this.insertInner(at - this.first, lines, height); + }, + remove: function(at, n) { this.removeInner(at - this.first, n); }, + + // From here, the methods are part of the public interface. Most + // are also available from CodeMirror (editor) instances. + + getValue: function(lineSep) { + var lines = getLines(this, this.first, this.first + this.size); + if (lineSep === false) { return lines } + return lines.join(lineSep || this.lineSeparator()) + }, + setValue: docMethodOp(function(code) { + var top = Pos(this.first, 0), last = this.first + this.size - 1; + makeChange(this, {from: top, to: Pos(last, getLine(this, last).text.length), + text: this.splitLines(code), origin: "setValue", full: true}, true); + if (this.cm) { scrollToCoords(this.cm, 0, 0); } + setSelection(this, simpleSelection(top), sel_dontScroll); + }), + replaceRange: function(code, from, to, origin) { + from = clipPos(this, from); + to = to ? clipPos(this, to) : from; + replaceRange(this, code, from, to, origin); + }, + getRange: function(from, to, lineSep) { + var lines = getBetween(this, clipPos(this, from), clipPos(this, to)); + if (lineSep === false) { return lines } + return lines.join(lineSep || this.lineSeparator()) + }, -// Given a mouse event, find the corresponding position. If liberal -// is false, it checks whether a gutter or scrollbar was clicked, -// and returns null if it was. forRect is used by rectangular -// selections, and tries to estimate a character position even for -// coordinates beyond the right of the text. -function posFromMouse(cm, e, liberal, forRect) { - var display = cm.display; - if (!liberal && e_target(e).getAttribute("cm-not-content") == "true") { return null } - - var x, y, space = display.lineSpace.getBoundingClientRect(); - // Fails unpredictably on IE[67] when mouse is dragged around quickly. - try { x = e.clientX - space.left; y = e.clientY - space.top; } - catch (e) { return null } - var coords = coordsChar(cm, x, y), line; - if (forRect && coords.xRel == 1 && (line = getLine(cm.doc, coords.line).text).length == coords.ch) { - var colDiff = countColumn(line, line.length, cm.options.tabSize) - line.length; - coords = Pos(coords.line, Math.max(0, Math.round((x - paddingH(cm.display).left) / charWidth(cm.display)) - colDiff)); - } - return coords -} + getLine: function(line) {var l = this.getLineHandle(line); return l && l.text}, -// Find the view element corresponding to a given line. Return null -// when the line isn't visible. -function findViewIndex(cm, n) { - if (n >= cm.display.viewTo) { return null } - n -= cm.display.viewFrom; - if (n < 0) { return null } - var view = cm.display.view; - for (var i = 0; i < view.length; i++) { - n -= view[i].size; - if (n < 0) { return i } - } -} + getLineHandle: function(line) {if (isLine(this, line)) { return getLine(this, line) }}, + getLineNumber: function(line) {return lineNo(line)}, -function updateSelection(cm) { - cm.display.input.showSelection(cm.display.input.prepareSelection()); -} + getLineHandleVisualStart: function(line) { + if (typeof line == "number") { line = getLine(this, line); } + return visualLine(line) + }, -function prepareSelection(cm, primary) { - if ( primary === void 0 ) primary = true; + lineCount: function() {return this.size}, + firstLine: function() {return this.first}, + lastLine: function() {return this.first + this.size - 1}, - var doc = cm.doc, result = {}; - var curFragment = result.cursors = document.createDocumentFragment(); - var selFragment = result.selection = document.createDocumentFragment(); + clipPos: function(pos) {return clipPos(this, pos)}, - for (var i = 0; i < doc.sel.ranges.length; i++) { - if (!primary && i == doc.sel.primIndex) { continue } - var range$$1 = doc.sel.ranges[i]; - if (range$$1.from().line >= cm.display.viewTo || range$$1.to().line < cm.display.viewFrom) { continue } - var collapsed = range$$1.empty(); - if (collapsed || cm.options.showCursorWhenSelecting) - { drawSelectionCursor(cm, range$$1.head, curFragment); } - if (!collapsed) - { drawSelectionRange(cm, range$$1, selFragment); } - } - return result -} + getCursor: function(start) { + var range$$1 = this.sel.primary(), pos; + if (start == null || start == "head") { pos = range$$1.head; } + else if (start == "anchor") { pos = range$$1.anchor; } + else if (start == "end" || start == "to" || start === false) { pos = range$$1.to(); } + else { pos = range$$1.from(); } + return pos + }, + listSelections: function() { return this.sel.ranges }, + somethingSelected: function() {return this.sel.somethingSelected()}, -// Draws a cursor for the given range -function drawSelectionCursor(cm, head, output) { - var pos = cursorCoords(cm, head, "div", null, null, !cm.options.singleCursorHeightPerLine); + setCursor: docMethodOp(function(line, ch, options) { + setSimpleSelection(this, clipPos(this, typeof line == "number" ? Pos(line, ch || 0) : line), null, options); + }), + setSelection: docMethodOp(function(anchor, head, options) { + setSimpleSelection(this, clipPos(this, anchor), clipPos(this, head || anchor), options); + }), + extendSelection: docMethodOp(function(head, other, options) { + extendSelection(this, clipPos(this, head), other && clipPos(this, other), options); + }), + extendSelections: docMethodOp(function(heads, options) { + extendSelections(this, clipPosArray(this, heads), options); + }), + extendSelectionsBy: docMethodOp(function(f, options) { + var heads = map(this.sel.ranges, f); + extendSelections(this, clipPosArray(this, heads), options); + }), + setSelections: docMethodOp(function(ranges, primary, options) { + var this$1 = this; - var cursor = output.appendChild(elt("div", "\u00a0", "CodeMirror-cursor")); - cursor.style.left = pos.left + "px"; - cursor.style.top = pos.top + "px"; - cursor.style.height = Math.max(0, pos.bottom - pos.top) * cm.options.cursorHeight + "px"; + if (!ranges.length) { return } + var out = []; + for (var i = 0; i < ranges.length; i++) + { out[i] = new Range(clipPos(this$1, ranges[i].anchor), + clipPos(this$1, ranges[i].head)); } + if (primary == null) { primary = Math.min(ranges.length - 1, this.sel.primIndex); } + setSelection(this, normalizeSelection(this.cm, out, primary), options); + }), + addSelection: docMethodOp(function(anchor, head, options) { + var ranges = this.sel.ranges.slice(0); + ranges.push(new Range(clipPos(this, anchor), clipPos(this, head || anchor))); + setSelection(this, normalizeSelection(this.cm, ranges, ranges.length - 1), options); + }), - if (pos.other) { - // Secondary cursor, shown when on a 'jump' in bi-directional text - var otherCursor = output.appendChild(elt("div", "\u00a0", "CodeMirror-cursor CodeMirror-secondarycursor")); - otherCursor.style.display = ""; - otherCursor.style.left = pos.other.left + "px"; - otherCursor.style.top = pos.other.top + "px"; - otherCursor.style.height = (pos.other.bottom - pos.other.top) * .85 + "px"; - } -} + getSelection: function(lineSep) { + var this$1 = this; -function cmpCoords(a, b) { return a.top - b.top || a.left - b.left } - -// Draws the given range as a highlighted selection -function drawSelectionRange(cm, range$$1, output) { - var display = cm.display, doc = cm.doc; - var fragment = document.createDocumentFragment(); - var padding = paddingH(cm.display), leftSide = padding.left; - var rightSide = Math.max(display.sizerWidth, displayWidth(cm) - display.sizer.offsetLeft) - padding.right; - var docLTR = doc.direction == "ltr"; - - function add(left, top, width, bottom) { - if (top < 0) { top = 0; } - top = Math.round(top); - bottom = Math.round(bottom); - fragment.appendChild(elt("div", null, "CodeMirror-selected", ("position: absolute; left: " + left + "px;\n top: " + top + "px; width: " + (width == null ? rightSide - left : width) + "px;\n height: " + (bottom - top) + "px"))); - } - - function drawForLine(line, fromArg, toArg) { - var lineObj = getLine(doc, line); - var lineLen = lineObj.text.length; - var start, end; - function coords(ch, bias) { - return charCoords(cm, Pos(line, ch), "div", lineObj, bias) - } - - function wrapX(pos, dir, side) { - var extent = wrappedLineExtentChar(cm, lineObj, null, pos); - var prop = (dir == "ltr") == (side == "after") ? "left" : "right"; - var ch = side == "after" ? extent.begin : extent.end - (/\s/.test(lineObj.text.charAt(extent.end - 1)) ? 2 : 1); - return coords(ch, prop)[prop] - } - - var order = getOrder(lineObj, doc.direction); - iterateBidiSections(order, fromArg || 0, toArg == null ? lineLen : toArg, function (from, to, dir, i) { - var ltr = dir == "ltr"; - var fromPos = coords(from, ltr ? "left" : "right"); - var toPos = coords(to - 1, ltr ? "right" : "left"); - - var openStart = fromArg == null && from == 0, openEnd = toArg == null && to == lineLen; - var first = i == 0, last = !order || i == order.length - 1; - if (toPos.top - fromPos.top <= 3) { // Single line - var openLeft = (docLTR ? openStart : openEnd) && first; - var openRight = (docLTR ? openEnd : openStart) && last; - var left = openLeft ? leftSide : (ltr ? fromPos : toPos).left; - var right = openRight ? rightSide : (ltr ? toPos : fromPos).right; - add(left, fromPos.top, right - left, fromPos.bottom); - } else { // Multiple lines - var topLeft, topRight, botLeft, botRight; - if (ltr) { - topLeft = docLTR && openStart && first ? leftSide : fromPos.left; - topRight = docLTR ? rightSide : wrapX(from, dir, "before"); - botLeft = docLTR ? leftSide : wrapX(to, dir, "after"); - botRight = docLTR && openEnd && last ? rightSide : toPos.right; - } else { - topLeft = !docLTR ? leftSide : wrapX(from, dir, "before"); - topRight = !docLTR && openStart && first ? rightSide : fromPos.right; - botLeft = !docLTR && openEnd && last ? leftSide : toPos.left; - botRight = !docLTR ? rightSide : wrapX(to, dir, "after"); - } - add(topLeft, fromPos.top, topRight - topLeft, fromPos.bottom); - if (fromPos.bottom < toPos.top) { add(leftSide, fromPos.bottom, null, toPos.top); } - add(botLeft, toPos.top, botRight - botLeft, toPos.bottom); + var ranges = this.sel.ranges, lines; + for (var i = 0; i < ranges.length; i++) { + var sel = getBetween(this$1, ranges[i].from(), ranges[i].to()); + lines = lines ? lines.concat(sel) : sel; } + if (lineSep === false) { return lines } + else { return lines.join(lineSep || this.lineSeparator()) } + }, + getSelections: function(lineSep) { + var this$1 = this; - if (!start || cmpCoords(fromPos, start) < 0) { start = fromPos; } - if (cmpCoords(toPos, start) < 0) { start = toPos; } - if (!end || cmpCoords(fromPos, end) < 0) { end = fromPos; } - if (cmpCoords(toPos, end) < 0) { end = toPos; } - }); - return {start: start, end: end} - } + var parts = [], ranges = this.sel.ranges; + for (var i = 0; i < ranges.length; i++) { + var sel = getBetween(this$1, ranges[i].from(), ranges[i].to()); + if (lineSep !== false) { sel = sel.join(lineSep || this$1.lineSeparator()); } + parts[i] = sel; + } + return parts + }, + replaceSelection: function(code, collapse, origin) { + var dup = []; + for (var i = 0; i < this.sel.ranges.length; i++) + { dup[i] = code; } + this.replaceSelections(dup, collapse, origin || "+input"); + }, + replaceSelections: docMethodOp(function(code, collapse, origin) { + var this$1 = this; - var sFrom = range$$1.from(), sTo = range$$1.to(); - if (sFrom.line == sTo.line) { - drawForLine(sFrom.line, sFrom.ch, sTo.ch); - } else { - var fromLine = getLine(doc, sFrom.line), toLine = getLine(doc, sTo.line); - var singleVLine = visualLine(fromLine) == visualLine(toLine); - var leftEnd = drawForLine(sFrom.line, sFrom.ch, singleVLine ? fromLine.text.length + 1 : null).end; - var rightStart = drawForLine(sTo.line, singleVLine ? 0 : null, sTo.ch).start; - if (singleVLine) { - if (leftEnd.top < rightStart.top - 2) { - add(leftEnd.right, leftEnd.top, null, leftEnd.bottom); - add(leftSide, rightStart.top, rightStart.left, rightStart.bottom); - } else { - add(leftEnd.right, leftEnd.top, rightStart.left - leftEnd.right, leftEnd.bottom); + var changes = [], sel = this.sel; + for (var i = 0; i < sel.ranges.length; i++) { + var range$$1 = sel.ranges[i]; + changes[i] = {from: range$$1.from(), to: range$$1.to(), text: this$1.splitLines(code[i]), origin: origin}; } - } - if (leftEnd.bottom < rightStart.top) - { add(leftSide, leftEnd.bottom, null, rightStart.top); } - } + var newSel = collapse && collapse != "end" && computeReplacedSel(this, changes, collapse); + for (var i$1 = changes.length - 1; i$1 >= 0; i$1--) + { makeChange(this$1, changes[i$1]); } + if (newSel) { setSelectionReplaceHistory(this, newSel); } + else if (this.cm) { ensureCursorVisible(this.cm); } + }), + undo: docMethodOp(function() {makeChangeFromHistory(this, "undo");}), + redo: docMethodOp(function() {makeChangeFromHistory(this, "redo");}), + undoSelection: docMethodOp(function() {makeChangeFromHistory(this, "undo", true);}), + redoSelection: docMethodOp(function() {makeChangeFromHistory(this, "redo", true);}), - output.appendChild(fragment); -} + setExtending: function(val) {this.extend = val;}, + getExtending: function() {return this.extend}, -// Cursor-blinking -function restartBlink(cm) { - if (!cm.state.focused) { return } - var display = cm.display; - clearInterval(display.blinker); - var on = true; - display.cursorDiv.style.visibility = ""; - if (cm.options.cursorBlinkRate > 0) - { display.blinker = setInterval(function () { return display.cursorDiv.style.visibility = (on = !on) ? "" : "hidden"; }, - cm.options.cursorBlinkRate); } - else if (cm.options.cursorBlinkRate < 0) - { display.cursorDiv.style.visibility = "hidden"; } -} + historySize: function() { + var hist = this.history, done = 0, undone = 0; + for (var i = 0; i < hist.done.length; i++) { if (!hist.done[i].ranges) { ++done; } } + for (var i$1 = 0; i$1 < hist.undone.length; i$1++) { if (!hist.undone[i$1].ranges) { ++undone; } } + return {undo: done, redo: undone} + }, + clearHistory: function() {this.history = new History(this.history.maxGeneration);}, -function ensureFocus(cm) { - if (!cm.state.focused) { cm.display.input.focus(); onFocus(cm); } -} + markClean: function() { + this.cleanGeneration = this.changeGeneration(true); + }, + changeGeneration: function(forceSplit) { + if (forceSplit) + { this.history.lastOp = this.history.lastSelOp = this.history.lastOrigin = null; } + return this.history.generation + }, + isClean: function (gen) { + return this.history.generation == (gen || this.cleanGeneration) + }, -function delayBlurEvent(cm) { - cm.state.delayingBlurEvent = true; - setTimeout(function () { if (cm.state.delayingBlurEvent) { - cm.state.delayingBlurEvent = false; - onBlur(cm); - } }, 100); -} + getHistory: function() { + return {done: copyHistoryArray(this.history.done), + undone: copyHistoryArray(this.history.undone)} + }, + setHistory: function(histData) { + var hist = this.history = new History(this.history.maxGeneration); + hist.done = copyHistoryArray(histData.done.slice(0), null, true); + hist.undone = copyHistoryArray(histData.undone.slice(0), null, true); + }, -function onFocus(cm, e) { - if (cm.state.delayingBlurEvent) { cm.state.delayingBlurEvent = false; } - - if (cm.options.readOnly == "nocursor") { return } - if (!cm.state.focused) { - signal(cm, "focus", cm, e); - cm.state.focused = true; - addClass(cm.display.wrapper, "CodeMirror-focused"); - // This test prevents this from firing when a context - // menu is closed (since the input reset would kill the - // select-all detection hack) - if (!cm.curOp && cm.display.selForContextMenu != cm.doc.sel) { - cm.display.input.reset(); - if (webkit) { setTimeout(function () { return cm.display.input.reset(true); }, 20); } // Issue #1730 - } - cm.display.input.receivedFocus(); - } - restartBlink(cm); -} -function onBlur(cm, e) { - if (cm.state.delayingBlurEvent) { return } - - if (cm.state.focused) { - signal(cm, "blur", cm, e); - cm.state.focused = false; - rmClass(cm.display.wrapper, "CodeMirror-focused"); - } - clearInterval(cm.display.blinker); - setTimeout(function () { if (!cm.state.focused) { cm.display.shift = false; } }, 150); -} + setGutterMarker: docMethodOp(function(line, gutterID, value) { + return changeLine(this, line, "gutter", function (line) { + var markers = line.gutterMarkers || (line.gutterMarkers = {}); + markers[gutterID] = value; + if (!value && isEmpty(markers)) { line.gutterMarkers = null; } + return true + }) + }), -// Read the actual heights of the rendered lines, and update their -// stored heights to match. -function updateHeightsInViewport(cm) { - var display = cm.display; - var prevBottom = display.lineDiv.offsetTop; - for (var i = 0; i < display.view.length; i++) { - var cur = display.view[i], height = (void 0); - if (cur.hidden) { continue } - if (ie && ie_version < 8) { - var bot = cur.node.offsetTop + cur.node.offsetHeight; - height = bot - prevBottom; - prevBottom = bot; - } else { - var box = cur.node.getBoundingClientRect(); - height = box.bottom - box.top; - } - var diff = cur.line.height - height; - if (height < 2) { height = textHeight(display); } - if (diff > .005 || diff < -.005) { - updateLineHeight(cur.line, height); - updateWidgetHeight(cur.line); - if (cur.rest) { for (var j = 0; j < cur.rest.length; j++) - { updateWidgetHeight(cur.rest[j]); } } - } - } -} + clearGutter: docMethodOp(function(gutterID) { + var this$1 = this; -// Read and store the height of line widgets associated with the -// given line. -function updateWidgetHeight(line) { - if (line.widgets) { for (var i = 0; i < line.widgets.length; ++i) - { line.widgets[i].height = line.widgets[i].node.parentNode.offsetHeight; } } -} + this.iter(function (line) { + if (line.gutterMarkers && line.gutterMarkers[gutterID]) { + changeLine(this$1, line, "gutter", function () { + line.gutterMarkers[gutterID] = null; + if (isEmpty(line.gutterMarkers)) { line.gutterMarkers = null; } + return true + }); + } + }); + }), -// Compute the lines that are visible in a given viewport (defaults -// the the current scroll position). viewport may contain top, -// height, and ensure (see op.scrollToPos) properties. -function visibleLines(display, doc, viewport) { - var top = viewport && viewport.top != null ? Math.max(0, viewport.top) : display.scroller.scrollTop; - top = Math.floor(top - paddingTop(display)); - var bottom = viewport && viewport.bottom != null ? viewport.bottom : top + display.wrapper.clientHeight; - - var from = lineAtHeight(doc, top), to = lineAtHeight(doc, bottom); - // Ensure is a {from: {line, ch}, to: {line, ch}} object, and - // forces those lines into the viewport (if possible). - if (viewport && viewport.ensure) { - var ensureFrom = viewport.ensure.from.line, ensureTo = viewport.ensure.to.line; - if (ensureFrom < from) { - from = ensureFrom; - to = lineAtHeight(doc, heightAtLine(getLine(doc, ensureFrom)) + display.wrapper.clientHeight); - } else if (Math.min(ensureTo, doc.lastLine()) >= to) { - from = lineAtHeight(doc, heightAtLine(getLine(doc, ensureTo)) - display.wrapper.clientHeight); - to = ensureTo; - } - } - return {from: from, to: Math.max(to, from + 1)} -} + lineInfo: function(line) { + var n; + if (typeof line == "number") { + if (!isLine(this, line)) { return null } + n = line; + line = getLine(this, line); + if (!line) { return null } + } else { + n = lineNo(line); + if (n == null) { return null } + } + return {line: n, handle: line, text: line.text, gutterMarkers: line.gutterMarkers, + textClass: line.textClass, bgClass: line.bgClass, wrapClass: line.wrapClass, + widgets: line.widgets} + }, + + addLineClass: docMethodOp(function(handle, where, cls) { + return changeLine(this, handle, where == "gutter" ? "gutter" : "class", function (line) { + var prop = where == "text" ? "textClass" + : where == "background" ? "bgClass" + : where == "gutter" ? "gutterClass" : "wrapClass"; + if (!line[prop]) { line[prop] = cls; } + else if (classTest(cls).test(line[prop])) { return false } + else { line[prop] += " " + cls; } + return true + }) + }), + removeLineClass: docMethodOp(function(handle, where, cls) { + return changeLine(this, handle, where == "gutter" ? "gutter" : "class", function (line) { + var prop = where == "text" ? "textClass" + : where == "background" ? "bgClass" + : where == "gutter" ? "gutterClass" : "wrapClass"; + var cur = line[prop]; + if (!cur) { return false } + else if (cls == null) { line[prop] = null; } + else { + var found = cur.match(classTest(cls)); + if (!found) { return false } + var end = found.index + found[0].length; + line[prop] = cur.slice(0, found.index) + (!found.index || end == cur.length ? "" : " ") + cur.slice(end) || null; + } + return true + }) + }), -// Re-align line numbers and gutter marks to compensate for -// horizontal scrolling. -function alignHorizontally(cm) { - var display = cm.display, view = display.view; - if (!display.alignWidgets && (!display.gutters.firstChild || !cm.options.fixedGutter)) { return } - var comp = compensateForHScroll(display) - display.scroller.scrollLeft + cm.doc.scrollLeft; - var gutterW = display.gutters.offsetWidth, left = comp + "px"; - for (var i = 0; i < view.length; i++) { if (!view[i].hidden) { - if (cm.options.fixedGutter) { - if (view[i].gutter) - { view[i].gutter.style.left = left; } - if (view[i].gutterBackground) - { view[i].gutterBackground.style.left = left; } - } - var align = view[i].alignable; - if (align) { for (var j = 0; j < align.length; j++) - { align[j].style.left = left; } } - } } - if (cm.options.fixedGutter) - { display.gutters.style.left = (comp + gutterW) + "px"; } -} + addLineWidget: docMethodOp(function(handle, node, options) { + return addLineWidget(this, handle, node, options) + }), + removeLineWidget: function(widget) { widget.clear(); }, + + markText: function(from, to, options) { + return markText(this, clipPos(this, from), clipPos(this, to), options, options && options.type || "range") + }, + setBookmark: function(pos, options) { + var realOpts = {replacedWith: options && (options.nodeType == null ? options.widget : options), + insertLeft: options && options.insertLeft, + clearWhenEmpty: false, shared: options && options.shared, + handleMouseEvents: options && options.handleMouseEvents}; + pos = clipPos(this, pos); + return markText(this, pos, pos, realOpts, "bookmark") + }, + findMarksAt: function(pos) { + pos = clipPos(this, pos); + var markers = [], spans = getLine(this, pos.line).markedSpans; + if (spans) { for (var i = 0; i < spans.length; ++i) { + var span = spans[i]; + if ((span.from == null || span.from <= pos.ch) && + (span.to == null || span.to >= pos.ch)) + { markers.push(span.marker.parent || span.marker); } + } } + return markers + }, + findMarks: function(from, to, filter) { + from = clipPos(this, from); to = clipPos(this, to); + var found = [], lineNo$$1 = from.line; + this.iter(from.line, to.line + 1, function (line) { + var spans = line.markedSpans; + if (spans) { for (var i = 0; i < spans.length; i++) { + var span = spans[i]; + if (!(span.to != null && lineNo$$1 == from.line && from.ch >= span.to || + span.from == null && lineNo$$1 != from.line || + span.from != null && lineNo$$1 == to.line && span.from >= to.ch) && + (!filter || filter(span.marker))) + { found.push(span.marker.parent || span.marker); } + } } + ++lineNo$$1; + }); + return found + }, + getAllMarks: function() { + var markers = []; + this.iter(function (line) { + var sps = line.markedSpans; + if (sps) { for (var i = 0; i < sps.length; ++i) + { if (sps[i].from != null) { markers.push(sps[i].marker); } } } + }); + return markers + }, -// Used to ensure that the line number gutter is still the right -// size for the current document size. Returns true when an update -// is needed. -function maybeUpdateLineNumberWidth(cm) { - if (!cm.options.lineNumbers) { return false } - var doc = cm.doc, last = lineNumberFor(cm.options, doc.first + doc.size - 1), display = cm.display; - if (last.length != display.lineNumChars) { - var test = display.measure.appendChild(elt("div", [elt("div", last)], - "CodeMirror-linenumber CodeMirror-gutter-elt")); - var innerW = test.firstChild.offsetWidth, padding = test.offsetWidth - innerW; - display.lineGutter.style.width = ""; - display.lineNumInnerWidth = Math.max(innerW, display.lineGutter.offsetWidth - padding) + 1; - display.lineNumWidth = display.lineNumInnerWidth + padding; - display.lineNumChars = display.lineNumInnerWidth ? last.length : -1; - display.lineGutter.style.width = display.lineNumWidth + "px"; - updateGutterSpace(cm); - return true - } - return false -} + posFromIndex: function(off) { + var ch, lineNo$$1 = this.first, sepSize = this.lineSeparator().length; + this.iter(function (line) { + var sz = line.text.length + sepSize; + if (sz > off) { ch = off; return true } + off -= sz; + ++lineNo$$1; + }); + return clipPos(this, Pos(lineNo$$1, ch)) + }, + indexFromPos: function (coords) { + coords = clipPos(this, coords); + var index = coords.ch; + if (coords.line < this.first || coords.ch < 0) { return 0 } + var sepSize = this.lineSeparator().length; + this.iter(this.first, coords.line, function (line) { // iter aborts when callback returns a truthy value + index += line.text.length + sepSize; + }); + return index + }, + + copy: function(copyHistory) { + var doc = new Doc(getLines(this, this.first, this.first + this.size), + this.modeOption, this.first, this.lineSep, this.direction); + doc.scrollTop = this.scrollTop; doc.scrollLeft = this.scrollLeft; + doc.sel = this.sel; + doc.extend = false; + if (copyHistory) { + doc.history.undoDepth = this.history.undoDepth; + doc.setHistory(this.getHistory()); + } + return doc + }, + + linkedDoc: function(options) { + if (!options) { options = {}; } + var from = this.first, to = this.first + this.size; + if (options.from != null && options.from > from) { from = options.from; } + if (options.to != null && options.to < to) { to = options.to; } + var copy = new Doc(getLines(this, from, to), options.mode || this.modeOption, from, this.lineSep, this.direction); + if (options.sharedHist) { copy.history = this.history + ; }(this.linked || (this.linked = [])).push({doc: copy, sharedHist: options.sharedHist}); + copy.linked = [{doc: this, isParent: true, sharedHist: options.sharedHist}]; + copySharedMarkers(copy, findSharedMarkers(this)); + return copy + }, + unlinkDoc: function(other) { + var this$1 = this; -// SCROLLING THINGS INTO VIEW + if (other instanceof CodeMirror) { other = other.doc; } + if (this.linked) { for (var i = 0; i < this.linked.length; ++i) { + var link = this$1.linked[i]; + if (link.doc != other) { continue } + this$1.linked.splice(i, 1); + other.unlinkDoc(this$1); + detachSharedMarkers(findSharedMarkers(this$1)); + break + } } + // If the histories were shared, split them again + if (other.history == this.history) { + var splitIds = [other.id]; + linkedDocs(other, function (doc) { return splitIds.push(doc.id); }, true); + other.history = new History(null); + other.history.done = copyHistoryArray(this.history.done, splitIds); + other.history.undone = copyHistoryArray(this.history.undone, splitIds); + } + }, + iterLinkedDocs: function(f) {linkedDocs(this, f);}, -// If an editor sits on the top or bottom of the window, partially -// scrolled out of view, this ensures that the cursor is visible. -function maybeScrollWindow(cm, rect) { - if (signalDOMEvent(cm, "scrollCursorIntoView")) { return } + getMode: function() {return this.mode}, + getEditor: function() {return this.cm}, - var display = cm.display, box = display.sizer.getBoundingClientRect(), doScroll = null; - if (rect.top + box.top < 0) { doScroll = true; } - else if (rect.bottom + box.top > (window.innerHeight || document.documentElement.clientHeight)) { doScroll = false; } - if (doScroll != null && !phantom) { - var scrollNode = elt("div", "\u200b", null, ("position: absolute;\n top: " + (rect.top - display.viewOffset - paddingTop(cm.display)) + "px;\n height: " + (rect.bottom - rect.top + scrollGap(cm) + display.barHeight) + "px;\n left: " + (rect.left) + "px; width: " + (Math.max(2, rect.right - rect.left)) + "px;")); - cm.display.lineSpace.appendChild(scrollNode); - scrollNode.scrollIntoView(doScroll); - cm.display.lineSpace.removeChild(scrollNode); - } -} + splitLines: function(str) { + if (this.lineSep) { return str.split(this.lineSep) } + return splitLinesAuto(str) + }, + lineSeparator: function() { return this.lineSep || "\n" }, -// Scroll a given position into view (immediately), verifying that -// it actually became visible (as line heights are accurately -// measured, the position of something may 'drift' during drawing). -function scrollPosIntoView(cm, pos, end, margin) { - if (margin == null) { margin = 0; } - var rect; - if (!cm.options.lineWrapping && pos == end) { - // Set pos and end to the cursor positions around the character pos sticks to - // If pos.sticky == "before", that is around pos.ch - 1, otherwise around pos.ch - // If pos == Pos(_, 0, "before"), pos and end are unchanged - pos = pos.ch ? Pos(pos.line, pos.sticky == "before" ? pos.ch - 1 : pos.ch, "after") : pos; - end = pos.sticky == "before" ? Pos(pos.line, pos.ch + 1, "before") : pos; - } - for (var limit = 0; limit < 5; limit++) { - var changed = false; - var coords = cursorCoords(cm, pos); - var endCoords = !end || end == pos ? coords : cursorCoords(cm, end); - rect = {left: Math.min(coords.left, endCoords.left), - top: Math.min(coords.top, endCoords.top) - margin, - right: Math.max(coords.left, endCoords.left), - bottom: Math.max(coords.bottom, endCoords.bottom) + margin}; - var scrollPos = calculateScrollPos(cm, rect); - var startTop = cm.doc.scrollTop, startLeft = cm.doc.scrollLeft; - if (scrollPos.scrollTop != null) { - updateScrollTop(cm, scrollPos.scrollTop); - if (Math.abs(cm.doc.scrollTop - startTop) > 1) { changed = true; } - } - if (scrollPos.scrollLeft != null) { - setScrollLeft(cm, scrollPos.scrollLeft); - if (Math.abs(cm.doc.scrollLeft - startLeft) > 1) { changed = true; } - } - if (!changed) { break } - } - return rect -} + setDirection: docMethodOp(function (dir) { + if (dir != "rtl") { dir = "ltr"; } + if (dir == this.direction) { return } + this.direction = dir; + this.iter(function (line) { return line.order = null; }); + if (this.cm) { directionChanged(this.cm); } + }) + }); -// Scroll a given set of coordinates into view (immediately). -function scrollIntoView(cm, rect) { - var scrollPos = calculateScrollPos(cm, rect); - if (scrollPos.scrollTop != null) { updateScrollTop(cm, scrollPos.scrollTop); } - if (scrollPos.scrollLeft != null) { setScrollLeft(cm, scrollPos.scrollLeft); } -} + // Public alias. + Doc.prototype.eachLine = Doc.prototype.iter; -// Calculate a new scroll position needed to scroll the given -// rectangle into view. Returns an object with scrollTop and -// scrollLeft properties. When these are undefined, the -// vertical/horizontal position does not need to be adjusted. -function calculateScrollPos(cm, rect) { - var display = cm.display, snapMargin = textHeight(cm.display); - if (rect.top < 0) { rect.top = 0; } - var screentop = cm.curOp && cm.curOp.scrollTop != null ? cm.curOp.scrollTop : display.scroller.scrollTop; - var screen = displayHeight(cm), result = {}; - if (rect.bottom - rect.top > screen) { rect.bottom = rect.top + screen; } - var docBottom = cm.doc.height + paddingVert(display); - var atTop = rect.top < snapMargin, atBottom = rect.bottom > docBottom - snapMargin; - if (rect.top < screentop) { - result.scrollTop = atTop ? 0 : rect.top; - } else if (rect.bottom > screentop + screen) { - var newTop = Math.min(rect.top, (atBottom ? docBottom : rect.bottom) - screen); - if (newTop != screentop) { result.scrollTop = newTop; } - } - - var screenleft = cm.curOp && cm.curOp.scrollLeft != null ? cm.curOp.scrollLeft : display.scroller.scrollLeft; - var screenw = displayWidth(cm) - (cm.options.fixedGutter ? display.gutters.offsetWidth : 0); - var tooWide = rect.right - rect.left > screenw; - if (tooWide) { rect.right = rect.left + screenw; } - if (rect.left < 10) - { result.scrollLeft = 0; } - else if (rect.left < screenleft) - { result.scrollLeft = Math.max(0, rect.left - (tooWide ? 0 : 10)); } - else if (rect.right > screenw + screenleft - 3) - { result.scrollLeft = rect.right + (tooWide ? 0 : 10) - screenw; } - return result -} + // Kludge to work around strange IE behavior where it'll sometimes + // re-fire a series of drag-related events right after the drop (#1551) + var lastDrop = 0; -// Store a relative adjustment to the scroll position in the current -// operation (to be applied when the operation finishes). -function addToScrollTop(cm, top) { - if (top == null) { return } - resolveScrollToPos(cm); - cm.curOp.scrollTop = (cm.curOp.scrollTop == null ? cm.doc.scrollTop : cm.curOp.scrollTop) + top; -} + function onDrop(e) { + var cm = this; + clearDragCursor(cm); + if (signalDOMEvent(cm, e) || eventInWidget(cm.display, e)) + { return } + e_preventDefault(e); + if (ie) { lastDrop = +new Date; } + var pos = posFromMouse(cm, e, true), files = e.dataTransfer.files; + if (!pos || cm.isReadOnly()) { return } + // Might be a file drop, in which case we simply extract the text + // and insert it. + if (files && files.length && window.FileReader && window.File) { + var n = files.length, text = Array(n), read = 0; + var loadFile = function (file, i) { + if (cm.options.allowDropFileTypes && + indexOf(cm.options.allowDropFileTypes, file.type) == -1) + { return } + + var reader = new FileReader; + reader.onload = operation(cm, function () { + var content = reader.result; + if (/[\x00-\x08\x0e-\x1f]{2}/.test(content)) { content = ""; } + text[i] = content; + if (++read == n) { + pos = clipPos(cm.doc, pos); + var change = {from: pos, to: pos, + text: cm.doc.splitLines(text.join(cm.doc.lineSeparator())), + origin: "paste"}; + makeChange(cm.doc, change); + setSelectionReplaceHistory(cm.doc, simpleSelection(pos, changeEnd(change))); + } + }); + reader.readAsText(file); + }; + for (var i = 0; i < n; ++i) { loadFile(files[i], i); } + } else { // Normal drop + // Don't do a replace if the drop happened inside of the selected text. + if (cm.state.draggingText && cm.doc.sel.contains(pos) > -1) { + cm.state.draggingText(e); + // Ensure the editor is re-focused + setTimeout(function () { return cm.display.input.focus(); }, 20); + return + } + try { + var text$1 = e.dataTransfer.getData("Text"); + if (text$1) { + var selected; + if (cm.state.draggingText && !cm.state.draggingText.copy) + { selected = cm.listSelections(); } + setSelectionNoUndo(cm.doc, simpleSelection(pos, pos)); + if (selected) { for (var i$1 = 0; i$1 < selected.length; ++i$1) + { replaceRange(cm.doc, "", selected[i$1].anchor, selected[i$1].head, "drag"); } } + cm.replaceSelection(text$1, "around", "paste"); + cm.display.input.focus(); + } + } + catch(e){} + } + } -// Make sure that at the end of the operation the current cursor is -// shown. -function ensureCursorVisible(cm) { - resolveScrollToPos(cm); - var cur = cm.getCursor(); - cm.curOp.scrollToPos = {from: cur, to: cur, margin: cm.options.cursorScrollMargin}; -} + function onDragStart(cm, e) { + if (ie && (!cm.state.draggingText || +new Date - lastDrop < 100)) { e_stop(e); return } + if (signalDOMEvent(cm, e) || eventInWidget(cm.display, e)) { return } -function scrollToCoords(cm, x, y) { - if (x != null || y != null) { resolveScrollToPos(cm); } - if (x != null) { cm.curOp.scrollLeft = x; } - if (y != null) { cm.curOp.scrollTop = y; } -} + e.dataTransfer.setData("Text", cm.getSelection()); + e.dataTransfer.effectAllowed = "copyMove"; -function scrollToRange(cm, range$$1) { - resolveScrollToPos(cm); - cm.curOp.scrollToPos = range$$1; -} + // Use dummy image instead of default browsers image. + // Recent Safari (~6.0.2) have a tendency to segfault when this happens, so we don't do it there. + if (e.dataTransfer.setDragImage && !safari) { + var img = elt("img", null, null, "position: fixed; left: 0; top: 0;"); + img.src = "data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw=="; + if (presto) { + img.width = img.height = 1; + cm.display.wrapper.appendChild(img); + // Force a relayout, or Opera won't use our image for some obscure reason + img._top = img.offsetTop; + } + e.dataTransfer.setDragImage(img, 0, 0); + if (presto) { img.parentNode.removeChild(img); } + } + } -// When an operation has its scrollToPos property set, and another -// scroll action is applied before the end of the operation, this -// 'simulates' scrolling that position into view in a cheap way, so -// that the effect of intermediate scroll commands is not ignored. -function resolveScrollToPos(cm) { - var range$$1 = cm.curOp.scrollToPos; - if (range$$1) { - cm.curOp.scrollToPos = null; - var from = estimateCoords(cm, range$$1.from), to = estimateCoords(cm, range$$1.to); - scrollToCoordsRange(cm, from, to, range$$1.margin); + function onDragOver(cm, e) { + var pos = posFromMouse(cm, e); + if (!pos) { return } + var frag = document.createDocumentFragment(); + drawSelectionCursor(cm, pos, frag); + if (!cm.display.dragCursor) { + cm.display.dragCursor = elt("div", null, "CodeMirror-cursors CodeMirror-dragcursors"); + cm.display.lineSpace.insertBefore(cm.display.dragCursor, cm.display.cursorDiv); + } + removeChildrenAndAdd(cm.display.dragCursor, frag); } -} -function scrollToCoordsRange(cm, from, to, margin) { - var sPos = calculateScrollPos(cm, { - left: Math.min(from.left, to.left), - top: Math.min(from.top, to.top) - margin, - right: Math.max(from.right, to.right), - bottom: Math.max(from.bottom, to.bottom) + margin - }); - scrollToCoords(cm, sPos.scrollLeft, sPos.scrollTop); -} + function clearDragCursor(cm) { + if (cm.display.dragCursor) { + cm.display.lineSpace.removeChild(cm.display.dragCursor); + cm.display.dragCursor = null; + } + } -// Sync the scrollable area and scrollbars, ensure the viewport -// covers the visible area. -function updateScrollTop(cm, val) { - if (Math.abs(cm.doc.scrollTop - val) < 2) { return } - if (!gecko) { updateDisplaySimple(cm, {top: val}); } - setScrollTop(cm, val, true); - if (gecko) { updateDisplaySimple(cm); } - startWorker(cm, 100); -} + // These must be handled carefully, because naively registering a + // handler for each editor will cause the editors to never be + // garbage collected. -function setScrollTop(cm, val, forceScroll) { - val = Math.min(cm.display.scroller.scrollHeight - cm.display.scroller.clientHeight, val); - if (cm.display.scroller.scrollTop == val && !forceScroll) { return } - cm.doc.scrollTop = val; - cm.display.scrollbars.setScrollTop(val); - if (cm.display.scroller.scrollTop != val) { cm.display.scroller.scrollTop = val; } -} + function forEachCodeMirror(f) { + if (!document.getElementsByClassName) { return } + var byClass = document.getElementsByClassName("CodeMirror"), editors = []; + for (var i = 0; i < byClass.length; i++) { + var cm = byClass[i].CodeMirror; + if (cm) { editors.push(cm); } + } + if (editors.length) { editors[0].operation(function () { + for (var i = 0; i < editors.length; i++) { f(editors[i]); } + }); } + } -// Sync scroller and scrollbar, ensure the gutter elements are -// aligned. -function setScrollLeft(cm, val, isScroller, forceScroll) { - val = Math.min(val, cm.display.scroller.scrollWidth - cm.display.scroller.clientWidth); - if ((isScroller ? val == cm.doc.scrollLeft : Math.abs(cm.doc.scrollLeft - val) < 2) && !forceScroll) { return } - cm.doc.scrollLeft = val; - alignHorizontally(cm); - if (cm.display.scroller.scrollLeft != val) { cm.display.scroller.scrollLeft = val; } - cm.display.scrollbars.setScrollLeft(val); -} + var globalsRegistered = false; + function ensureGlobalHandlers() { + if (globalsRegistered) { return } + registerGlobalHandlers(); + globalsRegistered = true; + } + function registerGlobalHandlers() { + // When the window resizes, we need to refresh active editors. + var resizeTimer; + on(window, "resize", function () { + if (resizeTimer == null) { resizeTimer = setTimeout(function () { + resizeTimer = null; + forEachCodeMirror(onResize); + }, 100); } + }); + // When the window loses focus, we want to show the editor as blurred + on(window, "blur", function () { return forEachCodeMirror(onBlur); }); + } + // Called when the window resizes + function onResize(cm) { + var d = cm.display; + // Might be a text scaling operation, clear size caches. + d.cachedCharWidth = d.cachedTextHeight = d.cachedPaddingH = null; + d.scrollbarsClipped = false; + cm.setSize(); + } + + var keyNames = { + 3: "Pause", 8: "Backspace", 9: "Tab", 13: "Enter", 16: "Shift", 17: "Ctrl", 18: "Alt", + 19: "Pause", 20: "CapsLock", 27: "Esc", 32: "Space", 33: "PageUp", 34: "PageDown", 35: "End", + 36: "Home", 37: "Left", 38: "Up", 39: "Right", 40: "Down", 44: "PrintScrn", 45: "Insert", + 46: "Delete", 59: ";", 61: "=", 91: "Mod", 92: "Mod", 93: "Mod", + 106: "*", 107: "=", 109: "-", 110: ".", 111: "/", 145: "ScrollLock", + 173: "-", 186: ";", 187: "=", 188: ",", 189: "-", 190: ".", 191: "/", 192: "`", 219: "[", 220: "\\", + 221: "]", 222: "'", 63232: "Up", 63233: "Down", 63234: "Left", 63235: "Right", 63272: "Delete", + 63273: "Home", 63275: "End", 63276: "PageUp", 63277: "PageDown", 63302: "Insert" + }; + + // Number keys + for (var i = 0; i < 10; i++) { keyNames[i + 48] = keyNames[i + 96] = String(i); } + // Alphabetic keys + for (var i$1 = 65; i$1 <= 90; i$1++) { keyNames[i$1] = String.fromCharCode(i$1); } + // Function keys + for (var i$2 = 1; i$2 <= 12; i$2++) { keyNames[i$2 + 111] = keyNames[i$2 + 63235] = "F" + i$2; } + + var keyMap = {}; + + keyMap.basic = { + "Left": "goCharLeft", "Right": "goCharRight", "Up": "goLineUp", "Down": "goLineDown", + "End": "goLineEnd", "Home": "goLineStartSmart", "PageUp": "goPageUp", "PageDown": "goPageDown", + "Delete": "delCharAfter", "Backspace": "delCharBefore", "Shift-Backspace": "delCharBefore", + "Tab": "defaultTab", "Shift-Tab": "indentAuto", + "Enter": "newlineAndIndent", "Insert": "toggleOverwrite", + "Esc": "singleSelection" + }; + // Note that the save and find-related commands aren't defined by + // default. User code or addons can define them. Unknown commands + // are simply ignored. + keyMap.pcDefault = { + "Ctrl-A": "selectAll", "Ctrl-D": "deleteLine", "Ctrl-Z": "undo", "Shift-Ctrl-Z": "redo", "Ctrl-Y": "redo", + "Ctrl-Home": "goDocStart", "Ctrl-End": "goDocEnd", "Ctrl-Up": "goLineUp", "Ctrl-Down": "goLineDown", + "Ctrl-Left": "goGroupLeft", "Ctrl-Right": "goGroupRight", "Alt-Left": "goLineStart", "Alt-Right": "goLineEnd", + "Ctrl-Backspace": "delGroupBefore", "Ctrl-Delete": "delGroupAfter", "Ctrl-S": "save", "Ctrl-F": "find", + "Ctrl-G": "findNext", "Shift-Ctrl-G": "findPrev", "Shift-Ctrl-F": "replace", "Shift-Ctrl-R": "replaceAll", + "Ctrl-[": "indentLess", "Ctrl-]": "indentMore", + "Ctrl-U": "undoSelection", "Shift-Ctrl-U": "redoSelection", "Alt-U": "redoSelection", + "fallthrough": "basic" + }; + // Very basic readline/emacs-style bindings, which are standard on Mac. + keyMap.emacsy = { + "Ctrl-F": "goCharRight", "Ctrl-B": "goCharLeft", "Ctrl-P": "goLineUp", "Ctrl-N": "goLineDown", + "Alt-F": "goWordRight", "Alt-B": "goWordLeft", "Ctrl-A": "goLineStart", "Ctrl-E": "goLineEnd", + "Ctrl-V": "goPageDown", "Shift-Ctrl-V": "goPageUp", "Ctrl-D": "delCharAfter", "Ctrl-H": "delCharBefore", + "Alt-D": "delWordAfter", "Alt-Backspace": "delWordBefore", "Ctrl-K": "killLine", "Ctrl-T": "transposeChars", + "Ctrl-O": "openLine" + }; + keyMap.macDefault = { + "Cmd-A": "selectAll", "Cmd-D": "deleteLine", "Cmd-Z": "undo", "Shift-Cmd-Z": "redo", "Cmd-Y": "redo", + "Cmd-Home": "goDocStart", "Cmd-Up": "goDocStart", "Cmd-End": "goDocEnd", "Cmd-Down": "goDocEnd", "Alt-Left": "goGroupLeft", + "Alt-Right": "goGroupRight", "Cmd-Left": "goLineLeft", "Cmd-Right": "goLineRight", "Alt-Backspace": "delGroupBefore", + "Ctrl-Alt-Backspace": "delGroupAfter", "Alt-Delete": "delGroupAfter", "Cmd-S": "save", "Cmd-F": "find", + "Cmd-G": "findNext", "Shift-Cmd-G": "findPrev", "Cmd-Alt-F": "replace", "Shift-Cmd-Alt-F": "replaceAll", + "Cmd-[": "indentLess", "Cmd-]": "indentMore", "Cmd-Backspace": "delWrappedLineLeft", "Cmd-Delete": "delWrappedLineRight", + "Cmd-U": "undoSelection", "Shift-Cmd-U": "redoSelection", "Ctrl-Up": "goDocStart", "Ctrl-Down": "goDocEnd", + "fallthrough": ["basic", "emacsy"] + }; + keyMap["default"] = mac ? keyMap.macDefault : keyMap.pcDefault; + + // KEYMAP DISPATCH + + function normalizeKeyName(name) { + var parts = name.split(/-(?!$)/); + name = parts[parts.length - 1]; + var alt, ctrl, shift, cmd; + for (var i = 0; i < parts.length - 1; i++) { + var mod = parts[i]; + if (/^(cmd|meta|m)$/i.test(mod)) { cmd = true; } + else if (/^a(lt)?$/i.test(mod)) { alt = true; } + else if (/^(c|ctrl|control)$/i.test(mod)) { ctrl = true; } + else if (/^s(hift)?$/i.test(mod)) { shift = true; } + else { throw new Error("Unrecognized modifier name: " + mod) } + } + if (alt) { name = "Alt-" + name; } + if (ctrl) { name = "Ctrl-" + name; } + if (cmd) { name = "Cmd-" + name; } + if (shift) { name = "Shift-" + name; } + return name + } + + // This is a kludge to keep keymaps mostly working as raw objects + // (backwards compatibility) while at the same time support features + // like normalization and multi-stroke key bindings. It compiles a + // new normalized keymap, and then updates the old object to reflect + // this. + function normalizeKeyMap(keymap) { + var copy = {}; + for (var keyname in keymap) { if (keymap.hasOwnProperty(keyname)) { + var value = keymap[keyname]; + if (/^(name|fallthrough|(de|at)tach)$/.test(keyname)) { continue } + if (value == "...") { delete keymap[keyname]; continue } + + var keys = map(keyname.split(" "), normalizeKeyName); + for (var i = 0; i < keys.length; i++) { + var val = (void 0), name = (void 0); + if (i == keys.length - 1) { + name = keys.join(" "); + val = value; + } else { + name = keys.slice(0, i + 1).join(" "); + val = "..."; + } + var prev = copy[name]; + if (!prev) { copy[name] = val; } + else if (prev != val) { throw new Error("Inconsistent bindings for " + name) } + } + delete keymap[keyname]; + } } + for (var prop in copy) { keymap[prop] = copy[prop]; } + return keymap + } -// SCROLLBARS + function lookupKey(key, map$$1, handle, context) { + map$$1 = getKeyMap(map$$1); + var found = map$$1.call ? map$$1.call(key, context) : map$$1[key]; + if (found === false) { return "nothing" } + if (found === "...") { return "multi" } + if (found != null && handle(found)) { return "handled" } -// Prepare DOM reads needed to update the scrollbars. Done in one -// shot to minimize update/measure roundtrips. -function measureForScrollbars(cm) { - var d = cm.display, gutterW = d.gutters.offsetWidth; - var docH = Math.round(cm.doc.height + paddingVert(cm.display)); - return { - clientHeight: d.scroller.clientHeight, - viewHeight: d.wrapper.clientHeight, - scrollWidth: d.scroller.scrollWidth, clientWidth: d.scroller.clientWidth, - viewWidth: d.wrapper.clientWidth, - barLeft: cm.options.fixedGutter ? gutterW : 0, - docHeight: docH, - scrollHeight: docH + scrollGap(cm) + d.barHeight, - nativeBarWidth: d.nativeBarWidth, - gutterWidth: gutterW + if (map$$1.fallthrough) { + if (Object.prototype.toString.call(map$$1.fallthrough) != "[object Array]") + { return lookupKey(key, map$$1.fallthrough, handle, context) } + for (var i = 0; i < map$$1.fallthrough.length; i++) { + var result = lookupKey(key, map$$1.fallthrough[i], handle, context); + if (result) { return result } + } + } } -} -var NativeScrollbars = function(place, scroll, cm) { - this.cm = cm; - var vert = this.vert = elt("div", [elt("div", null, null, "min-width: 1px")], "CodeMirror-vscrollbar"); - var horiz = this.horiz = elt("div", [elt("div", null, null, "height: 100%; min-height: 1px")], "CodeMirror-hscrollbar"); - place(vert); place(horiz); + // Modifier key presses don't count as 'real' key presses for the + // purpose of keymap fallthrough. + function isModifierKey(value) { + var name = typeof value == "string" ? value : keyNames[value.keyCode]; + return name == "Ctrl" || name == "Alt" || name == "Shift" || name == "Mod" + } - on(vert, "scroll", function () { - if (vert.clientHeight) { scroll(vert.scrollTop, "vertical"); } - }); - on(horiz, "scroll", function () { - if (horiz.clientWidth) { scroll(horiz.scrollLeft, "horizontal"); } - }); + function addModifierNames(name, event, noShift) { + var base = name; + if (event.altKey && base != "Alt") { name = "Alt-" + name; } + if ((flipCtrlCmd ? event.metaKey : event.ctrlKey) && base != "Ctrl") { name = "Ctrl-" + name; } + if ((flipCtrlCmd ? event.ctrlKey : event.metaKey) && base != "Cmd") { name = "Cmd-" + name; } + if (!noShift && event.shiftKey && base != "Shift") { name = "Shift-" + name; } + return name + } - this.checkedZeroWidth = false; - // Need to set a minimum width to see the scrollbar on IE7 (but must not set it on IE8). - if (ie && ie_version < 8) { this.horiz.style.minHeight = this.vert.style.minWidth = "18px"; } -}; + // Look up the name of a key as indicated by an event object. + function keyName(event, noShift) { + if (presto && event.keyCode == 34 && event["char"]) { return false } + var name = keyNames[event.keyCode]; + if (name == null || event.altGraphKey) { return false } + // Ctrl-ScrollLock has keyCode 3, same as Ctrl-Pause, + // so we'll use event.code when available (Chrome 48+, FF 38+, Safari 10.1+) + if (event.keyCode == 3 && event.code) { name = event.code; } + return addModifierNames(name, event, noShift) + } -NativeScrollbars.prototype.update = function (measure) { - var needsH = measure.scrollWidth > measure.clientWidth + 1; - var needsV = measure.scrollHeight > measure.clientHeight + 1; - var sWidth = measure.nativeBarWidth; - - if (needsV) { - this.vert.style.display = "block"; - this.vert.style.bottom = needsH ? sWidth + "px" : "0"; - var totalHeight = measure.viewHeight - (needsH ? sWidth : 0); - // A bug in IE8 can cause this value to be negative, so guard it. - this.vert.firstChild.style.height = - Math.max(0, measure.scrollHeight - measure.clientHeight + totalHeight) + "px"; - } else { - this.vert.style.display = ""; - this.vert.firstChild.style.height = "0"; + function getKeyMap(val) { + return typeof val == "string" ? keyMap[val] : val } - if (needsH) { - this.horiz.style.display = "block"; - this.horiz.style.right = needsV ? sWidth + "px" : "0"; - this.horiz.style.left = measure.barLeft + "px"; - var totalWidth = measure.viewWidth - measure.barLeft - (needsV ? sWidth : 0); - this.horiz.firstChild.style.width = - Math.max(0, measure.scrollWidth - measure.clientWidth + totalWidth) + "px"; - } else { - this.horiz.style.display = ""; - this.horiz.firstChild.style.width = "0"; + // Helper for deleting text near the selection(s), used to implement + // backspace, delete, and similar functionality. + function deleteNearSelection(cm, compute) { + var ranges = cm.doc.sel.ranges, kill = []; + // Build up a set of ranges to kill first, merging overlapping + // ranges. + for (var i = 0; i < ranges.length; i++) { + var toKill = compute(ranges[i]); + while (kill.length && cmp(toKill.from, lst(kill).to) <= 0) { + var replaced = kill.pop(); + if (cmp(replaced.from, toKill.from) < 0) { + toKill.from = replaced.from; + break + } + } + kill.push(toKill); + } + // Next, remove those actual ranges. + runInOp(cm, function () { + for (var i = kill.length - 1; i >= 0; i--) + { replaceRange(cm.doc, "", kill[i].from, kill[i].to, "+delete"); } + ensureCursorVisible(cm); + }); } - if (!this.checkedZeroWidth && measure.clientHeight > 0) { - if (sWidth == 0) { this.zeroWidthHack(); } - this.checkedZeroWidth = true; + function moveCharLogically(line, ch, dir) { + var target = skipExtendingChars(line.text, ch + dir, dir); + return target < 0 || target > line.text.length ? null : target } - return {right: needsV ? sWidth : 0, bottom: needsH ? sWidth : 0} -}; + function moveLogically(line, start, dir) { + var ch = moveCharLogically(line, start.ch, dir); + return ch == null ? null : new Pos(start.line, ch, dir < 0 ? "after" : "before") + } -NativeScrollbars.prototype.setScrollLeft = function (pos) { - if (this.horiz.scrollLeft != pos) { this.horiz.scrollLeft = pos; } - if (this.disableHoriz) { this.enableZeroWidthBar(this.horiz, this.disableHoriz, "horiz"); } -}; + function endOfLine(visually, cm, lineObj, lineNo, dir) { + if (visually) { + var order = getOrder(lineObj, cm.doc.direction); + if (order) { + var part = dir < 0 ? lst(order) : order[0]; + var moveInStorageOrder = (dir < 0) == (part.level == 1); + var sticky = moveInStorageOrder ? "after" : "before"; + var ch; + // With a wrapped rtl chunk (possibly spanning multiple bidi parts), + // it could be that the last bidi part is not on the last visual line, + // since visual lines contain content order-consecutive chunks. + // Thus, in rtl, we are looking for the first (content-order) character + // in the rtl chunk that is on the last line (that is, the same line + // as the last (content-order) character). + if (part.level > 0 || cm.doc.direction == "rtl") { + var prep = prepareMeasureForLine(cm, lineObj); + ch = dir < 0 ? lineObj.text.length - 1 : 0; + var targetTop = measureCharPrepared(cm, prep, ch).top; + ch = findFirst(function (ch) { return measureCharPrepared(cm, prep, ch).top == targetTop; }, (dir < 0) == (part.level == 1) ? part.from : part.to - 1, ch); + if (sticky == "before") { ch = moveCharLogically(lineObj, ch, 1); } + } else { ch = dir < 0 ? part.to : part.from; } + return new Pos(lineNo, ch, sticky) + } + } + return new Pos(lineNo, dir < 0 ? lineObj.text.length : 0, dir < 0 ? "before" : "after") + } + + function moveVisually(cm, line, start, dir) { + var bidi = getOrder(line, cm.doc.direction); + if (!bidi) { return moveLogically(line, start, dir) } + if (start.ch >= line.text.length) { + start.ch = line.text.length; + start.sticky = "before"; + } else if (start.ch <= 0) { + start.ch = 0; + start.sticky = "after"; + } + var partPos = getBidiPartAt(bidi, start.ch, start.sticky), part = bidi[partPos]; + if (cm.doc.direction == "ltr" && part.level % 2 == 0 && (dir > 0 ? part.to > start.ch : part.from < start.ch)) { + // Case 1: We move within an ltr part in an ltr editor. Even with wrapped lines, + // nothing interesting happens. + return moveLogically(line, start, dir) + } + + var mv = function (pos, dir) { return moveCharLogically(line, pos instanceof Pos ? pos.ch : pos, dir); }; + var prep; + var getWrappedLineExtent = function (ch) { + if (!cm.options.lineWrapping) { return {begin: 0, end: line.text.length} } + prep = prep || prepareMeasureForLine(cm, line); + return wrappedLineExtentChar(cm, line, prep, ch) + }; + var wrappedLineExtent = getWrappedLineExtent(start.sticky == "before" ? mv(start, -1) : start.ch); -NativeScrollbars.prototype.setScrollTop = function (pos) { - if (this.vert.scrollTop != pos) { this.vert.scrollTop = pos; } - if (this.disableVert) { this.enableZeroWidthBar(this.vert, this.disableVert, "vert"); } -}; + if (cm.doc.direction == "rtl" || part.level == 1) { + var moveInStorageOrder = (part.level == 1) == (dir < 0); + var ch = mv(start, moveInStorageOrder ? 1 : -1); + if (ch != null && (!moveInStorageOrder ? ch >= part.from && ch >= wrappedLineExtent.begin : ch <= part.to && ch <= wrappedLineExtent.end)) { + // Case 2: We move within an rtl part or in an rtl editor on the same visual line + var sticky = moveInStorageOrder ? "before" : "after"; + return new Pos(start.line, ch, sticky) + } + } -NativeScrollbars.prototype.zeroWidthHack = function () { - var w = mac && !mac_geMountainLion ? "12px" : "18px"; - this.horiz.style.height = this.vert.style.width = w; - this.horiz.style.pointerEvents = this.vert.style.pointerEvents = "none"; - this.disableHoriz = new Delayed; - this.disableVert = new Delayed; -}; + // Case 3: Could not move within this bidi part in this visual line, so leave + // the current bidi part -NativeScrollbars.prototype.enableZeroWidthBar = function (bar, delay, type) { - bar.style.pointerEvents = "auto"; - function maybeDisable() { - // To find out whether the scrollbar is still visible, we - // check whether the element under the pixel in the bottom - // right corner of the scrollbar box is the scrollbar box - // itself (when the bar is still visible) or its filler child - // (when the bar is hidden). If it is still visible, we keep - // it enabled, if it's hidden, we disable pointer events. - var box = bar.getBoundingClientRect(); - var elt$$1 = type == "vert" ? document.elementFromPoint(box.right - 1, (box.top + box.bottom) / 2) - : document.elementFromPoint((box.right + box.left) / 2, box.bottom - 1); - if (elt$$1 != bar) { bar.style.pointerEvents = "none"; } - else { delay.set(1000, maybeDisable); } - } - delay.set(1000, maybeDisable); -}; + var searchInVisualLine = function (partPos, dir, wrappedLineExtent) { + var getRes = function (ch, moveInStorageOrder) { return moveInStorageOrder + ? new Pos(start.line, mv(ch, 1), "before") + : new Pos(start.line, ch, "after"); }; -NativeScrollbars.prototype.clear = function () { - var parent = this.horiz.parentNode; - parent.removeChild(this.horiz); - parent.removeChild(this.vert); -}; + for (; partPos >= 0 && partPos < bidi.length; partPos += dir) { + var part = bidi[partPos]; + var moveInStorageOrder = (dir > 0) == (part.level != 1); + var ch = moveInStorageOrder ? wrappedLineExtent.begin : mv(wrappedLineExtent.end, -1); + if (part.from <= ch && ch < part.to) { return getRes(ch, moveInStorageOrder) } + ch = moveInStorageOrder ? part.from : mv(part.to, -1); + if (wrappedLineExtent.begin <= ch && ch < wrappedLineExtent.end) { return getRes(ch, moveInStorageOrder) } + } + }; -var NullScrollbars = function () {}; + // Case 3a: Look for other bidi parts on the same visual line + var res = searchInVisualLine(partPos + dir, dir, wrappedLineExtent); + if (res) { return res } -NullScrollbars.prototype.update = function () { return {bottom: 0, right: 0} }; -NullScrollbars.prototype.setScrollLeft = function () {}; -NullScrollbars.prototype.setScrollTop = function () {}; -NullScrollbars.prototype.clear = function () {}; + // Case 3b: Look for other bidi parts on the next visual line + var nextCh = dir > 0 ? wrappedLineExtent.end : mv(wrappedLineExtent.begin, -1); + if (nextCh != null && !(dir > 0 && nextCh == line.text.length)) { + res = searchInVisualLine(dir > 0 ? 0 : bidi.length - 1, dir, getWrappedLineExtent(nextCh)); + if (res) { return res } + } -function updateScrollbars(cm, measure) { - if (!measure) { measure = measureForScrollbars(cm); } - var startWidth = cm.display.barWidth, startHeight = cm.display.barHeight; - updateScrollbarsInner(cm, measure); - for (var i = 0; i < 4 && startWidth != cm.display.barWidth || startHeight != cm.display.barHeight; i++) { - if (startWidth != cm.display.barWidth && cm.options.lineWrapping) - { updateHeightsInViewport(cm); } - updateScrollbarsInner(cm, measureForScrollbars(cm)); - startWidth = cm.display.barWidth; startHeight = cm.display.barHeight; + // Case 4: Nowhere to move + return null } -} - -// Re-synchronize the fake scrollbars with the actual size of the -// content. -function updateScrollbarsInner(cm, measure) { - var d = cm.display; - var sizes = d.scrollbars.update(measure); - - d.sizer.style.paddingRight = (d.barWidth = sizes.right) + "px"; - d.sizer.style.paddingBottom = (d.barHeight = sizes.bottom) + "px"; - d.heightForcer.style.borderBottom = sizes.bottom + "px solid transparent"; - - if (sizes.right && sizes.bottom) { - d.scrollbarFiller.style.display = "block"; - d.scrollbarFiller.style.height = sizes.bottom + "px"; - d.scrollbarFiller.style.width = sizes.right + "px"; - } else { d.scrollbarFiller.style.display = ""; } - if (sizes.bottom && cm.options.coverGutterNextToScrollbar && cm.options.fixedGutter) { - d.gutterFiller.style.display = "block"; - d.gutterFiller.style.height = sizes.bottom + "px"; - d.gutterFiller.style.width = measure.gutterWidth + "px"; - } else { d.gutterFiller.style.display = ""; } -} -var scrollbarModel = {"native": NativeScrollbars, "null": NullScrollbars}; + // Commands are parameter-less actions that can be performed on an + // editor, mostly used for keybindings. + var commands = { + selectAll: selectAll, + singleSelection: function (cm) { return cm.setSelection(cm.getCursor("anchor"), cm.getCursor("head"), sel_dontScroll); }, + killLine: function (cm) { return deleteNearSelection(cm, function (range) { + if (range.empty()) { + var len = getLine(cm.doc, range.head.line).text.length; + if (range.head.ch == len && range.head.line < cm.lastLine()) + { return {from: range.head, to: Pos(range.head.line + 1, 0)} } + else + { return {from: range.head, to: Pos(range.head.line, len)} } + } else { + return {from: range.from(), to: range.to()} + } + }); }, + deleteLine: function (cm) { return deleteNearSelection(cm, function (range) { return ({ + from: Pos(range.from().line, 0), + to: clipPos(cm.doc, Pos(range.to().line + 1, 0)) + }); }); }, + delLineLeft: function (cm) { return deleteNearSelection(cm, function (range) { return ({ + from: Pos(range.from().line, 0), to: range.from() + }); }); }, + delWrappedLineLeft: function (cm) { return deleteNearSelection(cm, function (range) { + var top = cm.charCoords(range.head, "div").top + 5; + var leftPos = cm.coordsChar({left: 0, top: top}, "div"); + return {from: leftPos, to: range.from()} + }); }, + delWrappedLineRight: function (cm) { return deleteNearSelection(cm, function (range) { + var top = cm.charCoords(range.head, "div").top + 5; + var rightPos = cm.coordsChar({left: cm.display.lineDiv.offsetWidth + 100, top: top}, "div"); + return {from: range.from(), to: rightPos } + }); }, + undo: function (cm) { return cm.undo(); }, + redo: function (cm) { return cm.redo(); }, + undoSelection: function (cm) { return cm.undoSelection(); }, + redoSelection: function (cm) { return cm.redoSelection(); }, + goDocStart: function (cm) { return cm.extendSelection(Pos(cm.firstLine(), 0)); }, + goDocEnd: function (cm) { return cm.extendSelection(Pos(cm.lastLine())); }, + goLineStart: function (cm) { return cm.extendSelectionsBy(function (range) { return lineStart(cm, range.head.line); }, + {origin: "+move", bias: 1} + ); }, + goLineStartSmart: function (cm) { return cm.extendSelectionsBy(function (range) { return lineStartSmart(cm, range.head); }, + {origin: "+move", bias: 1} + ); }, + goLineEnd: function (cm) { return cm.extendSelectionsBy(function (range) { return lineEnd(cm, range.head.line); }, + {origin: "+move", bias: -1} + ); }, + goLineRight: function (cm) { return cm.extendSelectionsBy(function (range) { + var top = cm.cursorCoords(range.head, "div").top + 5; + return cm.coordsChar({left: cm.display.lineDiv.offsetWidth + 100, top: top}, "div") + }, sel_move); }, + goLineLeft: function (cm) { return cm.extendSelectionsBy(function (range) { + var top = cm.cursorCoords(range.head, "div").top + 5; + return cm.coordsChar({left: 0, top: top}, "div") + }, sel_move); }, + goLineLeftSmart: function (cm) { return cm.extendSelectionsBy(function (range) { + var top = cm.cursorCoords(range.head, "div").top + 5; + var pos = cm.coordsChar({left: 0, top: top}, "div"); + if (pos.ch < cm.getLine(pos.line).search(/\S/)) { return lineStartSmart(cm, range.head) } + return pos + }, sel_move); }, + goLineUp: function (cm) { return cm.moveV(-1, "line"); }, + goLineDown: function (cm) { return cm.moveV(1, "line"); }, + goPageUp: function (cm) { return cm.moveV(-1, "page"); }, + goPageDown: function (cm) { return cm.moveV(1, "page"); }, + goCharLeft: function (cm) { return cm.moveH(-1, "char"); }, + goCharRight: function (cm) { return cm.moveH(1, "char"); }, + goColumnLeft: function (cm) { return cm.moveH(-1, "column"); }, + goColumnRight: function (cm) { return cm.moveH(1, "column"); }, + goWordLeft: function (cm) { return cm.moveH(-1, "word"); }, + goGroupRight: function (cm) { return cm.moveH(1, "group"); }, + goGroupLeft: function (cm) { return cm.moveH(-1, "group"); }, + goWordRight: function (cm) { return cm.moveH(1, "word"); }, + delCharBefore: function (cm) { return cm.deleteH(-1, "char"); }, + delCharAfter: function (cm) { return cm.deleteH(1, "char"); }, + delWordBefore: function (cm) { return cm.deleteH(-1, "word"); }, + delWordAfter: function (cm) { return cm.deleteH(1, "word"); }, + delGroupBefore: function (cm) { return cm.deleteH(-1, "group"); }, + delGroupAfter: function (cm) { return cm.deleteH(1, "group"); }, + indentAuto: function (cm) { return cm.indentSelection("smart"); }, + indentMore: function (cm) { return cm.indentSelection("add"); }, + indentLess: function (cm) { return cm.indentSelection("subtract"); }, + insertTab: function (cm) { return cm.replaceSelection("\t"); }, + insertSoftTab: function (cm) { + var spaces = [], ranges = cm.listSelections(), tabSize = cm.options.tabSize; + for (var i = 0; i < ranges.length; i++) { + var pos = ranges[i].from(); + var col = countColumn(cm.getLine(pos.line), pos.ch, tabSize); + spaces.push(spaceStr(tabSize - col % tabSize)); + } + cm.replaceSelections(spaces); + }, + defaultTab: function (cm) { + if (cm.somethingSelected()) { cm.indentSelection("add"); } + else { cm.execCommand("insertTab"); } + }, + // Swap the two chars left and right of each selection's head. + // Move cursor behind the two swapped characters afterwards. + // + // Doesn't consider line feeds a character. + // Doesn't scan more than one line above to find a character. + // Doesn't do anything on an empty line. + // Doesn't do anything with non-empty selections. + transposeChars: function (cm) { return runInOp(cm, function () { + var ranges = cm.listSelections(), newSel = []; + for (var i = 0; i < ranges.length; i++) { + if (!ranges[i].empty()) { continue } + var cur = ranges[i].head, line = getLine(cm.doc, cur.line).text; + if (line) { + if (cur.ch == line.length) { cur = new Pos(cur.line, cur.ch - 1); } + if (cur.ch > 0) { + cur = new Pos(cur.line, cur.ch + 1); + cm.replaceRange(line.charAt(cur.ch - 1) + line.charAt(cur.ch - 2), + Pos(cur.line, cur.ch - 2), cur, "+transpose"); + } else if (cur.line > cm.doc.first) { + var prev = getLine(cm.doc, cur.line - 1).text; + if (prev) { + cur = new Pos(cur.line, 1); + cm.replaceRange(line.charAt(0) + cm.doc.lineSeparator() + + prev.charAt(prev.length - 1), + Pos(cur.line - 1, prev.length - 1), cur, "+transpose"); + } + } + } + newSel.push(new Range(cur, cur)); + } + cm.setSelections(newSel); + }); }, + newlineAndIndent: function (cm) { return runInOp(cm, function () { + var sels = cm.listSelections(); + for (var i = sels.length - 1; i >= 0; i--) + { cm.replaceRange(cm.doc.lineSeparator(), sels[i].anchor, sels[i].head, "+input"); } + sels = cm.listSelections(); + for (var i$1 = 0; i$1 < sels.length; i$1++) + { cm.indentLine(sels[i$1].from().line, null, true); } + ensureCursorVisible(cm); + }); }, + openLine: function (cm) { return cm.replaceSelection("\n", "start"); }, + toggleOverwrite: function (cm) { return cm.toggleOverwrite(); } + }; + + + function lineStart(cm, lineN) { + var line = getLine(cm.doc, lineN); + var visual = visualLine(line); + if (visual != line) { lineN = lineNo(visual); } + return endOfLine(true, cm, visual, lineN, 1) + } + function lineEnd(cm, lineN) { + var line = getLine(cm.doc, lineN); + var visual = visualLineEnd(line); + if (visual != line) { lineN = lineNo(visual); } + return endOfLine(true, cm, line, lineN, -1) + } + function lineStartSmart(cm, pos) { + var start = lineStart(cm, pos.line); + var line = getLine(cm.doc, start.line); + var order = getOrder(line, cm.doc.direction); + if (!order || order[0].level == 0) { + var firstNonWS = Math.max(0, line.text.search(/\S/)); + var inWS = pos.line == start.line && pos.ch <= firstNonWS && pos.ch; + return Pos(start.line, inWS ? 0 : firstNonWS, start.sticky) + } + return start + } + + // Run a handler that was bound to a key. + function doHandleBinding(cm, bound, dropShift) { + if (typeof bound == "string") { + bound = commands[bound]; + if (!bound) { return false } + } + // Ensure previous input has been read, so that the handler sees a + // consistent view of the document + cm.display.input.ensurePolled(); + var prevShift = cm.display.shift, done = false; + try { + if (cm.isReadOnly()) { cm.state.suppressEdits = true; } + if (dropShift) { cm.display.shift = false; } + done = bound(cm) != Pass; + } finally { + cm.display.shift = prevShift; + cm.state.suppressEdits = false; + } + return done + } -function initScrollbars(cm) { - if (cm.display.scrollbars) { - cm.display.scrollbars.clear(); - if (cm.display.scrollbars.addClass) - { rmClass(cm.display.wrapper, cm.display.scrollbars.addClass); } + function lookupKeyForEditor(cm, name, handle) { + for (var i = 0; i < cm.state.keyMaps.length; i++) { + var result = lookupKey(name, cm.state.keyMaps[i], handle, cm); + if (result) { return result } + } + return (cm.options.extraKeys && lookupKey(name, cm.options.extraKeys, handle, cm)) + || lookupKey(name, cm.options.keyMap, handle, cm) } - cm.display.scrollbars = new scrollbarModel[cm.options.scrollbarStyle](function (node) { - cm.display.wrapper.insertBefore(node, cm.display.scrollbarFiller); - // Prevent clicks in the scrollbars from killing focus - on(node, "mousedown", function () { - if (cm.state.focused) { setTimeout(function () { return cm.display.input.focus(); }, 0); } - }); - node.setAttribute("cm-not-content", "true"); - }, function (pos, axis) { - if (axis == "horizontal") { setScrollLeft(cm, pos); } - else { updateScrollTop(cm, pos); } - }, cm); - if (cm.display.scrollbars.addClass) - { addClass(cm.display.wrapper, cm.display.scrollbars.addClass); } -} + // Note that, despite the name, this function is also used to check + // for bound mouse clicks. -// Operations are used to wrap a series of changes to the editor -// state in such a way that each change won't have to update the -// cursor and display (which would be awkward, slow, and -// error-prone). Instead, display updates are batched and then all -// combined and executed at once. - -var nextOpId = 0; -// Start a new operation. -function startOperation(cm) { - cm.curOp = { - cm: cm, - viewChanged: false, // Flag that indicates that lines might need to be redrawn - startHeight: cm.doc.height, // Used to detect need to update scrollbar - forceUpdate: false, // Used to force a redraw - updateInput: null, // Whether to reset the input textarea - typing: false, // Whether this reset should be careful to leave existing text (for compositing) - changeObjs: null, // Accumulated changes, for firing change events - cursorActivityHandlers: null, // Set of handlers to fire cursorActivity on - cursorActivityCalled: 0, // Tracks which cursorActivity handlers have been called already - selectionChanged: false, // Whether the selection needs to be redrawn - updateMaxLine: false, // Set when the widest line needs to be determined anew - scrollLeft: null, scrollTop: null, // Intermediate scroll position, not pushed to DOM yet - scrollToPos: null, // Used to scroll to a specific position - focus: false, - id: ++nextOpId // Unique ID - }; - pushOperation(cm.curOp); -} + var stopSeq = new Delayed; -// Finish an operation, updating the display and signalling delayed events -function endOperation(cm) { - var op = cm.curOp; - finishOperation(op, function (group) { - for (var i = 0; i < group.ops.length; i++) - { group.ops[i].cm.curOp = null; } - endOperations(group); - }); -} + function dispatchKey(cm, name, e, handle) { + var seq = cm.state.keySeq; + if (seq) { + if (isModifierKey(name)) { return "handled" } + if (/\'$/.test(name)) + { cm.state.keySeq = null; } + else + { stopSeq.set(50, function () { + if (cm.state.keySeq == seq) { + cm.state.keySeq = null; + cm.display.input.reset(); + } + }); } + if (dispatchKeyInner(cm, seq + " " + name, e, handle)) { return true } + } + return dispatchKeyInner(cm, name, e, handle) + } -// The DOM updates done when an operation finishes are batched so -// that the minimum number of relayouts are required. -function endOperations(group) { - var ops = group.ops; - for (var i = 0; i < ops.length; i++) // Read DOM - { endOperation_R1(ops[i]); } - for (var i$1 = 0; i$1 < ops.length; i$1++) // Write DOM (maybe) - { endOperation_W1(ops[i$1]); } - for (var i$2 = 0; i$2 < ops.length; i$2++) // Read DOM - { endOperation_R2(ops[i$2]); } - for (var i$3 = 0; i$3 < ops.length; i$3++) // Write DOM (maybe) - { endOperation_W2(ops[i$3]); } - for (var i$4 = 0; i$4 < ops.length; i$4++) // Read DOM - { endOperation_finish(ops[i$4]); } -} + function dispatchKeyInner(cm, name, e, handle) { + var result = lookupKeyForEditor(cm, name, handle); -function endOperation_R1(op) { - var cm = op.cm, display = cm.display; - maybeClipScrollbars(cm); - if (op.updateMaxLine) { findMaxLine(cm); } - - op.mustUpdate = op.viewChanged || op.forceUpdate || op.scrollTop != null || - op.scrollToPos && (op.scrollToPos.from.line < display.viewFrom || - op.scrollToPos.to.line >= display.viewTo) || - display.maxLineChanged && cm.options.lineWrapping; - op.update = op.mustUpdate && - new DisplayUpdate(cm, op.mustUpdate && {top: op.scrollTop, ensure: op.scrollToPos}, op.forceUpdate); -} + if (result == "multi") + { cm.state.keySeq = name; } + if (result == "handled") + { signalLater(cm, "keyHandled", cm, name, e); } -function endOperation_W1(op) { - op.updatedDisplay = op.mustUpdate && updateDisplayIfNeeded(op.cm, op.update); -} + if (result == "handled" || result == "multi") { + e_preventDefault(e); + restartBlink(cm); + } -function endOperation_R2(op) { - var cm = op.cm, display = cm.display; - if (op.updatedDisplay) { updateHeightsInViewport(cm); } + return !!result + } - op.barMeasure = measureForScrollbars(cm); + // Handle a key from the keydown event. + function handleKeyBinding(cm, e) { + var name = keyName(e, true); + if (!name) { return false } - // If the max line changed since it was last measured, measure it, - // and ensure the document's width matches it. - // updateDisplay_W2 will use these properties to do the actual resizing - if (display.maxLineChanged && !cm.options.lineWrapping) { - op.adjustWidthTo = measureChar(cm, display.maxLine, display.maxLine.text.length).left + 3; - cm.display.sizerWidth = op.adjustWidthTo; - op.barMeasure.scrollWidth = - Math.max(display.scroller.clientWidth, display.sizer.offsetLeft + op.adjustWidthTo + scrollGap(cm) + cm.display.barWidth); - op.maxScrollLeft = Math.max(0, display.sizer.offsetLeft + op.adjustWidthTo - displayWidth(cm)); + if (e.shiftKey && !cm.state.keySeq) { + // First try to resolve full name (including 'Shift-'). Failing + // that, see if there is a cursor-motion command (starting with + // 'go') bound to the keyname without 'Shift-'. + return dispatchKey(cm, "Shift-" + name, e, function (b) { return doHandleBinding(cm, b, true); }) + || dispatchKey(cm, name, e, function (b) { + if (typeof b == "string" ? /^go[A-Z]/.test(b) : b.motion) + { return doHandleBinding(cm, b) } + }) + } else { + return dispatchKey(cm, name, e, function (b) { return doHandleBinding(cm, b); }) + } } - if (op.updatedDisplay || op.selectionChanged) - { op.preparedSelection = display.input.prepareSelection(); } -} + // Handle a key from the keypress event + function handleCharBinding(cm, e, ch) { + return dispatchKey(cm, "'" + ch + "'", e, function (b) { return doHandleBinding(cm, b, true); }) + } -function endOperation_W2(op) { - var cm = op.cm; + var lastStoppedKey = null; + function onKeyDown(e) { + var cm = this; + cm.curOp.focus = activeElt(); + if (signalDOMEvent(cm, e)) { return } + // IE does strange things with escape. + if (ie && ie_version < 11 && e.keyCode == 27) { e.returnValue = false; } + var code = e.keyCode; + cm.display.shift = code == 16 || e.shiftKey; + var handled = handleKeyBinding(cm, e); + if (presto) { + lastStoppedKey = handled ? code : null; + // Opera has no cut event... we try to at least catch the key combo + if (!handled && code == 88 && !hasCopyEvent && (mac ? e.metaKey : e.ctrlKey)) + { cm.replaceSelection("", null, "cut"); } + } - if (op.adjustWidthTo != null) { - cm.display.sizer.style.minWidth = op.adjustWidthTo + "px"; - if (op.maxScrollLeft < cm.doc.scrollLeft) - { setScrollLeft(cm, Math.min(cm.display.scroller.scrollLeft, op.maxScrollLeft), true); } - cm.display.maxLineChanged = false; + // Turn mouse into crosshair when Alt is held on Mac. + if (code == 18 && !/\bCodeMirror-crosshair\b/.test(cm.display.lineDiv.className)) + { showCrossHair(cm); } } - var takeFocus = op.focus && op.focus == activeElt(); - if (op.preparedSelection) - { cm.display.input.showSelection(op.preparedSelection, takeFocus); } - if (op.updatedDisplay || op.startHeight != cm.doc.height) - { updateScrollbars(cm, op.barMeasure); } - if (op.updatedDisplay) - { setDocumentHeight(cm, op.barMeasure); } + function showCrossHair(cm) { + var lineDiv = cm.display.lineDiv; + addClass(lineDiv, "CodeMirror-crosshair"); + + function up(e) { + if (e.keyCode == 18 || !e.altKey) { + rmClass(lineDiv, "CodeMirror-crosshair"); + off(document, "keyup", up); + off(document, "mouseover", up); + } + } + on(document, "keyup", up); + on(document, "mouseover", up); + } - if (op.selectionChanged) { restartBlink(cm); } + function onKeyUp(e) { + if (e.keyCode == 16) { this.doc.sel.shift = false; } + signalDOMEvent(this, e); + } - if (cm.state.focused && op.updateInput) - { cm.display.input.reset(op.typing); } - if (takeFocus) { ensureFocus(op.cm); } -} + function onKeyPress(e) { + var cm = this; + if (eventInWidget(cm.display, e) || signalDOMEvent(cm, e) || e.ctrlKey && !e.altKey || mac && e.metaKey) { return } + var keyCode = e.keyCode, charCode = e.charCode; + if (presto && keyCode == lastStoppedKey) {lastStoppedKey = null; e_preventDefault(e); return} + if ((presto && (!e.which || e.which < 10)) && handleKeyBinding(cm, e)) { return } + var ch = String.fromCharCode(charCode == null ? keyCode : charCode); + // Some browsers fire keypress events for backspace + if (ch == "\x08") { return } + if (handleCharBinding(cm, e, ch)) { return } + cm.display.input.onKeyPress(e); + } + + var DOUBLECLICK_DELAY = 400; + + var PastClick = function(time, pos, button) { + this.time = time; + this.pos = pos; + this.button = button; + }; + + PastClick.prototype.compare = function (time, pos, button) { + return this.time + DOUBLECLICK_DELAY > time && + cmp(pos, this.pos) == 0 && button == this.button + }; + + var lastClick, lastDoubleClick; + function clickRepeat(pos, button) { + var now = +new Date; + if (lastDoubleClick && lastDoubleClick.compare(now, pos, button)) { + lastClick = lastDoubleClick = null; + return "triple" + } else if (lastClick && lastClick.compare(now, pos, button)) { + lastDoubleClick = new PastClick(now, pos, button); + lastClick = null; + return "double" + } else { + lastClick = new PastClick(now, pos, button); + lastDoubleClick = null; + return "single" + } + } + + // A mouse down can be a single click, double click, triple click, + // start of selection drag, start of text drag, new cursor + // (ctrl-click), rectangle drag (alt-drag), or xwin + // middle-click-paste. Or it might be a click on something we should + // not interfere with, such as a scrollbar or widget. + function onMouseDown(e) { + var cm = this, display = cm.display; + if (signalDOMEvent(cm, e) || display.activeTouch && display.input.supportsTouch()) { return } + display.input.ensurePolled(); + display.shift = e.shiftKey; + + if (eventInWidget(display, e)) { + if (!webkit) { + // Briefly turn off draggability, to allow widgets to do + // normal dragging things. + display.scroller.draggable = false; + setTimeout(function () { return display.scroller.draggable = true; }, 100); + } + return + } + if (clickInGutter(cm, e)) { return } + var pos = posFromMouse(cm, e), button = e_button(e), repeat = pos ? clickRepeat(pos, button) : "single"; + window.focus(); -function endOperation_finish(op) { - var cm = op.cm, display = cm.display, doc = cm.doc; + // #3261: make sure, that we're not starting a second selection + if (button == 1 && cm.state.selectingText) + { cm.state.selectingText(e); } - if (op.updatedDisplay) { postUpdateDisplay(cm, op.update); } + if (pos && handleMappedButton(cm, button, pos, repeat, e)) { return } - // Abort mouse wheel delta measurement, when scrolling explicitly - if (display.wheelStartX != null && (op.scrollTop != null || op.scrollLeft != null || op.scrollToPos)) - { display.wheelStartX = display.wheelStartY = null; } + if (button == 1) { + if (pos) { leftButtonDown(cm, pos, repeat, e); } + else if (e_target(e) == display.scroller) { e_preventDefault(e); } + } else if (button == 2) { + if (pos) { extendSelection(cm.doc, pos); } + setTimeout(function () { return display.input.focus(); }, 20); + } else if (button == 3) { + if (captureRightClick) { cm.display.input.onContextMenu(e); } + else { delayBlurEvent(cm); } + } + } - // Propagate the scroll position to the actual DOM scroller - if (op.scrollTop != null) { setScrollTop(cm, op.scrollTop, op.forceScroll); } + function handleMappedButton(cm, button, pos, repeat, event) { + var name = "Click"; + if (repeat == "double") { name = "Double" + name; } + else if (repeat == "triple") { name = "Triple" + name; } + name = (button == 1 ? "Left" : button == 2 ? "Middle" : "Right") + name; - if (op.scrollLeft != null) { setScrollLeft(cm, op.scrollLeft, true, true); } - // If we need to scroll a specific position into view, do so. - if (op.scrollToPos) { - var rect = scrollPosIntoView(cm, clipPos(doc, op.scrollToPos.from), - clipPos(doc, op.scrollToPos.to), op.scrollToPos.margin); - maybeScrollWindow(cm, rect); + return dispatchKey(cm, addModifierNames(name, event), event, function (bound) { + if (typeof bound == "string") { bound = commands[bound]; } + if (!bound) { return false } + var done = false; + try { + if (cm.isReadOnly()) { cm.state.suppressEdits = true; } + done = bound(cm, pos) != Pass; + } finally { + cm.state.suppressEdits = false; + } + return done + }) } - // Fire events for markers that are hidden/unidden by editing or - // undoing - var hidden = op.maybeHiddenMarkers, unhidden = op.maybeUnhiddenMarkers; - if (hidden) { for (var i = 0; i < hidden.length; ++i) - { if (!hidden[i].lines.length) { signal(hidden[i], "hide"); } } } - if (unhidden) { for (var i$1 = 0; i$1 < unhidden.length; ++i$1) - { if (unhidden[i$1].lines.length) { signal(unhidden[i$1], "unhide"); } } } + function configureMouse(cm, repeat, event) { + var option = cm.getOption("configureMouse"); + var value = option ? option(cm, repeat, event) : {}; + if (value.unit == null) { + var rect = chromeOS ? event.shiftKey && event.metaKey : event.altKey; + value.unit = rect ? "rectangle" : repeat == "single" ? "char" : repeat == "double" ? "word" : "line"; + } + if (value.extend == null || cm.doc.extend) { value.extend = cm.doc.extend || event.shiftKey; } + if (value.addNew == null) { value.addNew = mac ? event.metaKey : event.ctrlKey; } + if (value.moveOnDrag == null) { value.moveOnDrag = !(mac ? event.altKey : event.ctrlKey); } + return value + } - if (display.wrapper.offsetHeight) - { doc.scrollTop = cm.display.scroller.scrollTop; } + function leftButtonDown(cm, pos, repeat, event) { + if (ie) { setTimeout(bind(ensureFocus, cm), 0); } + else { cm.curOp.focus = activeElt(); } - // Fire change events, and delayed event handlers - if (op.changeObjs) - { signal(cm, "changes", cm, op.changeObjs); } - if (op.update) - { op.update.finish(); } -} + var behavior = configureMouse(cm, repeat, event); -// Run the given function in an operation -function runInOp(cm, f) { - if (cm.curOp) { return f() } - startOperation(cm); - try { return f() } - finally { endOperation(cm); } -} -// Wraps a function in an operation. Returns the wrapped function. -function operation(cm, f) { - return function() { - if (cm.curOp) { return f.apply(cm, arguments) } - startOperation(cm); - try { return f.apply(cm, arguments) } - finally { endOperation(cm); } - } -} -// Used to add methods to editor and doc instances, wrapping them in -// operations. -function methodOp(f) { - return function() { - if (this.curOp) { return f.apply(this, arguments) } - startOperation(this); - try { return f.apply(this, arguments) } - finally { endOperation(this); } + var sel = cm.doc.sel, contained; + if (cm.options.dragDrop && dragAndDrop && !cm.isReadOnly() && + repeat == "single" && (contained = sel.contains(pos)) > -1 && + (cmp((contained = sel.ranges[contained]).from(), pos) < 0 || pos.xRel > 0) && + (cmp(contained.to(), pos) > 0 || pos.xRel < 0)) + { leftButtonStartDrag(cm, event, pos, behavior); } + else + { leftButtonSelect(cm, event, pos, behavior); } + } + + // Start a text drag. When it ends, see if any dragging actually + // happen, and treat as a click if it didn't. + function leftButtonStartDrag(cm, event, pos, behavior) { + var display = cm.display, moved = false; + var dragEnd = operation(cm, function (e) { + if (webkit) { display.scroller.draggable = false; } + cm.state.draggingText = false; + off(display.wrapper.ownerDocument, "mouseup", dragEnd); + off(display.wrapper.ownerDocument, "mousemove", mouseMove); + off(display.scroller, "dragstart", dragStart); + off(display.scroller, "drop", dragEnd); + if (!moved) { + e_preventDefault(e); + if (!behavior.addNew) + { extendSelection(cm.doc, pos, null, null, behavior.extend); } + // Work around unexplainable focus problem in IE9 (#2127) and Chrome (#3081) + if (webkit || ie && ie_version == 9) + { setTimeout(function () {display.wrapper.ownerDocument.body.focus(); display.input.focus();}, 20); } + else + { display.input.focus(); } + } + }); + var mouseMove = function(e2) { + moved = moved || Math.abs(event.clientX - e2.clientX) + Math.abs(event.clientY - e2.clientY) >= 10; + }; + var dragStart = function () { return moved = true; }; + // Let the drag handler handle this. + if (webkit) { display.scroller.draggable = true; } + cm.state.draggingText = dragEnd; + dragEnd.copy = !behavior.moveOnDrag; + // IE's approach to draggable + if (display.scroller.dragDrop) { display.scroller.dragDrop(); } + on(display.wrapper.ownerDocument, "mouseup", dragEnd); + on(display.wrapper.ownerDocument, "mousemove", mouseMove); + on(display.scroller, "dragstart", dragStart); + on(display.scroller, "drop", dragEnd); + + delayBlurEvent(cm); + setTimeout(function () { return display.input.focus(); }, 20); } -} -function docMethodOp(f) { - return function() { - var cm = this.cm; - if (!cm || cm.curOp) { return f.apply(this, arguments) } - startOperation(cm); - try { return f.apply(this, arguments) } - finally { endOperation(cm); } + + function rangeForUnit(cm, pos, unit) { + if (unit == "char") { return new Range(pos, pos) } + if (unit == "word") { return cm.findWordAt(pos) } + if (unit == "line") { return new Range(Pos(pos.line, 0), clipPos(cm.doc, Pos(pos.line + 1, 0))) } + var result = unit(cm, pos); + return new Range(result.from, result.to) } -} -// Updates the display.view data structure for a given change to the -// document. From and to are in pre-change coordinates. Lendiff is -// the amount of lines added or subtracted by the change. This is -// used for changes that span multiple lines, or change the way -// lines are divided into visual lines. regLineChange (below) -// registers single-line changes. -function regChange(cm, from, to, lendiff) { - if (from == null) { from = cm.doc.first; } - if (to == null) { to = cm.doc.first + cm.doc.size; } - if (!lendiff) { lendiff = 0; } - - var display = cm.display; - if (lendiff && to < display.viewTo && - (display.updateLineNumbers == null || display.updateLineNumbers > from)) - { display.updateLineNumbers = from; } - - cm.curOp.viewChanged = true; - - if (from >= display.viewTo) { // Change after - if (sawCollapsedSpans && visualLineNo(cm.doc, from) < display.viewTo) - { resetView(cm); } - } else if (to <= display.viewFrom) { // Change before - if (sawCollapsedSpans && visualLineEndNo(cm.doc, to + lendiff) > display.viewFrom) { - resetView(cm); - } else { - display.viewFrom += lendiff; - display.viewTo += lendiff; - } - } else if (from <= display.viewFrom && to >= display.viewTo) { // Full overlap - resetView(cm); - } else if (from <= display.viewFrom) { // Top overlap - var cut = viewCuttingPoint(cm, to, to + lendiff, 1); - if (cut) { - display.view = display.view.slice(cut.index); - display.viewFrom = cut.lineN; - display.viewTo += lendiff; + // Normal selection, as opposed to text dragging. + function leftButtonSelect(cm, event, start, behavior) { + var display = cm.display, doc = cm.doc; + e_preventDefault(event); + + var ourRange, ourIndex, startSel = doc.sel, ranges = startSel.ranges; + if (behavior.addNew && !behavior.extend) { + ourIndex = doc.sel.contains(start); + if (ourIndex > -1) + { ourRange = ranges[ourIndex]; } + else + { ourRange = new Range(start, start); } } else { - resetView(cm); + ourRange = doc.sel.primary(); + ourIndex = doc.sel.primIndex; } - } else if (to >= display.viewTo) { // Bottom overlap - var cut$1 = viewCuttingPoint(cm, from, from, -1); - if (cut$1) { - display.view = display.view.slice(0, cut$1.index); - display.viewTo = cut$1.lineN; + + if (behavior.unit == "rectangle") { + if (!behavior.addNew) { ourRange = new Range(start, start); } + start = posFromMouse(cm, event, true, true); + ourIndex = -1; } else { - resetView(cm); + var range$$1 = rangeForUnit(cm, start, behavior.unit); + if (behavior.extend) + { ourRange = extendRange(ourRange, range$$1.anchor, range$$1.head, behavior.extend); } + else + { ourRange = range$$1; } + } + + if (!behavior.addNew) { + ourIndex = 0; + setSelection(doc, new Selection([ourRange], 0), sel_mouse); + startSel = doc.sel; + } else if (ourIndex == -1) { + ourIndex = ranges.length; + setSelection(doc, normalizeSelection(cm, ranges.concat([ourRange]), ourIndex), + {scroll: false, origin: "*mouse"}); + } else if (ranges.length > 1 && ranges[ourIndex].empty() && behavior.unit == "char" && !behavior.extend) { + setSelection(doc, normalizeSelection(cm, ranges.slice(0, ourIndex).concat(ranges.slice(ourIndex + 1)), 0), + {scroll: false, origin: "*mouse"}); + startSel = doc.sel; + } else { + replaceOneSelection(doc, ourIndex, ourRange, sel_mouse); + } + + var lastPos = start; + function extendTo(pos) { + if (cmp(lastPos, pos) == 0) { return } + lastPos = pos; + + if (behavior.unit == "rectangle") { + var ranges = [], tabSize = cm.options.tabSize; + var startCol = countColumn(getLine(doc, start.line).text, start.ch, tabSize); + var posCol = countColumn(getLine(doc, pos.line).text, pos.ch, tabSize); + var left = Math.min(startCol, posCol), right = Math.max(startCol, posCol); + for (var line = Math.min(start.line, pos.line), end = Math.min(cm.lastLine(), Math.max(start.line, pos.line)); + line <= end; line++) { + var text = getLine(doc, line).text, leftPos = findColumn(text, left, tabSize); + if (left == right) + { ranges.push(new Range(Pos(line, leftPos), Pos(line, leftPos))); } + else if (text.length > leftPos) + { ranges.push(new Range(Pos(line, leftPos), Pos(line, findColumn(text, right, tabSize)))); } + } + if (!ranges.length) { ranges.push(new Range(start, start)); } + setSelection(doc, normalizeSelection(cm, startSel.ranges.slice(0, ourIndex).concat(ranges), ourIndex), + {origin: "*mouse", scroll: false}); + cm.scrollIntoView(pos); + } else { + var oldRange = ourRange; + var range$$1 = rangeForUnit(cm, pos, behavior.unit); + var anchor = oldRange.anchor, head; + if (cmp(range$$1.anchor, anchor) > 0) { + head = range$$1.head; + anchor = minPos(oldRange.from(), range$$1.anchor); + } else { + head = range$$1.anchor; + anchor = maxPos(oldRange.to(), range$$1.head); + } + var ranges$1 = startSel.ranges.slice(0); + ranges$1[ourIndex] = bidiSimplify(cm, new Range(clipPos(doc, anchor), head)); + setSelection(doc, normalizeSelection(cm, ranges$1, ourIndex), sel_mouse); + } + } + + var editorSize = display.wrapper.getBoundingClientRect(); + // Used to ensure timeout re-tries don't fire when another extend + // happened in the meantime (clearTimeout isn't reliable -- at + // least on Chrome, the timeouts still happen even when cleared, + // if the clear happens after their scheduled firing time). + var counter = 0; + + function extend(e) { + var curCount = ++counter; + var cur = posFromMouse(cm, e, true, behavior.unit == "rectangle"); + if (!cur) { return } + if (cmp(cur, lastPos) != 0) { + cm.curOp.focus = activeElt(); + extendTo(cur); + var visible = visibleLines(display, doc); + if (cur.line >= visible.to || cur.line < visible.from) + { setTimeout(operation(cm, function () {if (counter == curCount) { extend(e); }}), 150); } + } else { + var outside = e.clientY < editorSize.top ? -20 : e.clientY > editorSize.bottom ? 20 : 0; + if (outside) { setTimeout(operation(cm, function () { + if (counter != curCount) { return } + display.scroller.scrollTop += outside; + extend(e); + }), 50); } + } + } + + function done(e) { + cm.state.selectingText = false; + counter = Infinity; + // If e is null or undefined we interpret this as someone trying + // to explicitly cancel the selection rather than the user + // letting go of the mouse button. + if (e) { + e_preventDefault(e); + display.input.focus(); + } + off(display.wrapper.ownerDocument, "mousemove", move); + off(display.wrapper.ownerDocument, "mouseup", up); + doc.history.lastSelOrigin = null; } - } else { // Gap in the middle - var cutTop = viewCuttingPoint(cm, from, from, -1); - var cutBot = viewCuttingPoint(cm, to, to + lendiff, 1); - if (cutTop && cutBot) { - display.view = display.view.slice(0, cutTop.index) - .concat(buildViewArray(cm, cutTop.lineN, cutBot.lineN)) - .concat(display.view.slice(cutBot.index)); - display.viewTo += lendiff; + + var move = operation(cm, function (e) { + if (e.buttons === 0 || !e_button(e)) { done(e); } + else { extend(e); } + }); + var up = operation(cm, done); + cm.state.selectingText = up; + on(display.wrapper.ownerDocument, "mousemove", move); + on(display.wrapper.ownerDocument, "mouseup", up); + } + + // Used when mouse-selecting to adjust the anchor to the proper side + // of a bidi jump depending on the visual position of the head. + function bidiSimplify(cm, range$$1) { + var anchor = range$$1.anchor; + var head = range$$1.head; + var anchorLine = getLine(cm.doc, anchor.line); + if (cmp(anchor, head) == 0 && anchor.sticky == head.sticky) { return range$$1 } + var order = getOrder(anchorLine); + if (!order) { return range$$1 } + var index = getBidiPartAt(order, anchor.ch, anchor.sticky), part = order[index]; + if (part.from != anchor.ch && part.to != anchor.ch) { return range$$1 } + var boundary = index + ((part.from == anchor.ch) == (part.level != 1) ? 0 : 1); + if (boundary == 0 || boundary == order.length) { return range$$1 } + + // Compute the relative visual position of the head compared to the + // anchor (<0 is to the left, >0 to the right) + var leftSide; + if (head.line != anchor.line) { + leftSide = (head.line - anchor.line) * (cm.doc.direction == "ltr" ? 1 : -1) > 0; } else { - resetView(cm); + var headIndex = getBidiPartAt(order, head.ch, head.sticky); + var dir = headIndex - index || (head.ch - anchor.ch) * (part.level == 1 ? -1 : 1); + if (headIndex == boundary - 1 || headIndex == boundary) + { leftSide = dir < 0; } + else + { leftSide = dir > 0; } } - } - var ext = display.externalMeasured; - if (ext) { - if (to < ext.lineN) - { ext.lineN += lendiff; } - else if (from < ext.lineN + ext.size) - { display.externalMeasured = null; } + var usePart = order[boundary + (leftSide ? -1 : 0)]; + var from = leftSide == (usePart.level == 1); + var ch = from ? usePart.from : usePart.to, sticky = from ? "after" : "before"; + return anchor.ch == ch && anchor.sticky == sticky ? range$$1 : new Range(new Pos(anchor.line, ch, sticky), head) } -} -// Register a change to a single line. Type must be one of "text", -// "gutter", "class", "widget" -function regLineChange(cm, line, type) { - cm.curOp.viewChanged = true; - var display = cm.display, ext = cm.display.externalMeasured; - if (ext && line >= ext.lineN && line < ext.lineN + ext.size) - { display.externalMeasured = null; } - - if (line < display.viewFrom || line >= display.viewTo) { return } - var lineView = display.view[findViewIndex(cm, line)]; - if (lineView.node == null) { return } - var arr = lineView.changes || (lineView.changes = []); - if (indexOf(arr, type) == -1) { arr.push(type); } -} - -// Clear the view. -function resetView(cm) { - cm.display.viewFrom = cm.display.viewTo = cm.doc.first; - cm.display.view = []; - cm.display.viewOffset = 0; -} -function viewCuttingPoint(cm, oldN, newN, dir) { - var index = findViewIndex(cm, oldN), diff, view = cm.display.view; - if (!sawCollapsedSpans || newN == cm.doc.first + cm.doc.size) - { return {index: index, lineN: newN} } - var n = cm.display.viewFrom; - for (var i = 0; i < index; i++) - { n += view[i].size; } - if (n != oldN) { - if (dir > 0) { - if (index == view.length - 1) { return null } - diff = (n + view[index].size) - oldN; - index++; + // Determines whether an event happened in the gutter, and fires the + // handlers for the corresponding event. + function gutterEvent(cm, e, type, prevent) { + var mX, mY; + if (e.touches) { + mX = e.touches[0].clientX; + mY = e.touches[0].clientY; } else { - diff = n - oldN; + try { mX = e.clientX; mY = e.clientY; } + catch(e) { return false } + } + if (mX >= Math.floor(cm.display.gutters.getBoundingClientRect().right)) { return false } + if (prevent) { e_preventDefault(e); } + + var display = cm.display; + var lineBox = display.lineDiv.getBoundingClientRect(); + + if (mY > lineBox.bottom || !hasHandler(cm, type)) { return e_defaultPrevented(e) } + mY -= lineBox.top - display.viewOffset; + + for (var i = 0; i < cm.display.gutterSpecs.length; ++i) { + var g = display.gutters.childNodes[i]; + if (g && g.getBoundingClientRect().right >= mX) { + var line = lineAtHeight(cm.doc, mY); + var gutter = cm.display.gutterSpecs[i]; + signal(cm, type, cm, line, gutter.className, e); + return e_defaultPrevented(e) + } } - oldN += diff; newN += diff; } - while (visualLineNo(cm.doc, newN) != newN) { - if (index == (dir < 0 ? 0 : view.length - 1)) { return null } - newN += dir * view[index - (dir < 0 ? 1 : 0)].size; - index += dir; + + function clickInGutter(cm, e) { + return gutterEvent(cm, e, "gutterClick", true) } - return {index: index, lineN: newN} -} -// Force the view to cover a given range, adding empty view element -// or clipping off existing ones as needed. -function adjustView(cm, from, to) { - var display = cm.display, view = display.view; - if (view.length == 0 || from >= display.viewTo || to <= display.viewFrom) { - display.view = buildViewArray(cm, from, to); - display.viewFrom = from; - } else { - if (display.viewFrom > from) - { display.view = buildViewArray(cm, from, display.viewFrom).concat(display.view); } - else if (display.viewFrom < from) - { display.view = display.view.slice(findViewIndex(cm, from)); } - display.viewFrom = from; - if (display.viewTo < to) - { display.view = display.view.concat(buildViewArray(cm, display.viewTo, to)); } - else if (display.viewTo > to) - { display.view = display.view.slice(0, findViewIndex(cm, to)); } - } - display.viewTo = to; -} + // CONTEXT MENU HANDLING -// Count the number of lines in the view whose DOM representation is -// out of date (or nonexistent). -function countDirtyView(cm) { - var view = cm.display.view, dirty = 0; - for (var i = 0; i < view.length; i++) { - var lineView = view[i]; - if (!lineView.hidden && (!lineView.node || lineView.changes)) { ++dirty; } + // To make the context menu work, we need to briefly unhide the + // textarea (making it as unobtrusive as possible) to let the + // right-click take effect on it. + function onContextMenu(cm, e) { + if (eventInWidget(cm.display, e) || contextMenuInGutter(cm, e)) { return } + if (signalDOMEvent(cm, e, "contextmenu")) { return } + if (!captureRightClick) { cm.display.input.onContextMenu(e); } } - return dirty -} - -// HIGHLIGHT WORKER - -function startWorker(cm, time) { - if (cm.doc.highlightFrontier < cm.display.viewTo) - { cm.state.highlight.set(time, bind(highlightWorker, cm)); } -} - -function highlightWorker(cm) { - var doc = cm.doc; - if (doc.highlightFrontier >= cm.display.viewTo) { return } - var end = +new Date + cm.options.workTime; - var context = getContextBefore(cm, doc.highlightFrontier); - var changedLines = []; - - doc.iter(context.line, Math.min(doc.first + doc.size, cm.display.viewTo + 500), function (line) { - if (context.line >= cm.display.viewFrom) { // Visible - var oldStyles = line.styles; - var resetState = line.text.length > cm.options.maxHighlightLength ? copyState(doc.mode, context.state) : null; - var highlighted = highlightLine(cm, line, context, true); - if (resetState) { context.state = resetState; } - line.styles = highlighted.styles; - var oldCls = line.styleClasses, newCls = highlighted.classes; - if (newCls) { line.styleClasses = newCls; } - else if (oldCls) { line.styleClasses = null; } - var ischange = !oldStyles || oldStyles.length != line.styles.length || - oldCls != newCls && (!oldCls || !newCls || oldCls.bgClass != newCls.bgClass || oldCls.textClass != newCls.textClass); - for (var i = 0; !ischange && i < oldStyles.length; ++i) { ischange = oldStyles[i] != line.styles[i]; } - if (ischange) { changedLines.push(context.line); } - line.stateAfter = context.save(); - context.nextLine(); - } else { - if (line.text.length <= cm.options.maxHighlightLength) - { processLine(cm, line.text, context); } - line.stateAfter = context.line % 5 == 0 ? context.save() : null; - context.nextLine(); - } - if (+new Date > end) { - startWorker(cm, cm.options.workDelay); - return true - } - }); - doc.highlightFrontier = context.line; - doc.modeFrontier = Math.max(doc.modeFrontier, context.line); - if (changedLines.length) { runInOp(cm, function () { - for (var i = 0; i < changedLines.length; i++) - { regLineChange(cm, changedLines[i], "text"); } - }); } -} - -// DISPLAY DRAWING - -var DisplayUpdate = function(cm, viewport, force) { - var display = cm.display; - - this.viewport = viewport; - // Store some values that we'll need later (but don't want to force a relayout for) - this.visible = visibleLines(display, cm.doc, viewport); - this.editorIsHidden = !display.wrapper.offsetWidth; - this.wrapperHeight = display.wrapper.clientHeight; - this.wrapperWidth = display.wrapper.clientWidth; - this.oldDisplayWidth = displayWidth(cm); - this.force = force; - this.dims = getDimensions(cm); - this.events = []; -}; -DisplayUpdate.prototype.signal = function (emitter, type) { - if (hasHandler(emitter, type)) - { this.events.push(arguments); } -}; -DisplayUpdate.prototype.finish = function () { - var this$1 = this; - - for (var i = 0; i < this.events.length; i++) - { signal.apply(null, this$1.events[i]); } -}; - -function maybeClipScrollbars(cm) { - var display = cm.display; - if (!display.scrollbarsClipped && display.scroller.offsetWidth) { - display.nativeBarWidth = display.scroller.offsetWidth - display.scroller.clientWidth; - display.heightForcer.style.height = scrollGap(cm) + "px"; - display.sizer.style.marginBottom = -display.nativeBarWidth + "px"; - display.sizer.style.borderRightWidth = scrollGap(cm) + "px"; - display.scrollbarsClipped = true; - } -} - -function selectionSnapshot(cm) { - if (cm.hasFocus()) { return null } - var active = activeElt(); - if (!active || !contains(cm.display.lineDiv, active)) { return null } - var result = {activeElt: active}; - if (window.getSelection) { - var sel = window.getSelection(); - if (sel.anchorNode && sel.extend && contains(cm.display.lineDiv, sel.anchorNode)) { - result.anchorNode = sel.anchorNode; - result.anchorOffset = sel.anchorOffset; - result.focusNode = sel.focusNode; - result.focusOffset = sel.focusOffset; - } - } - return result -} - -function restoreSelection(snapshot) { - if (!snapshot || !snapshot.activeElt || snapshot.activeElt == activeElt()) { return } - snapshot.activeElt.focus(); - if (snapshot.anchorNode && contains(document.body, snapshot.anchorNode) && contains(document.body, snapshot.focusNode)) { - var sel = window.getSelection(), range$$1 = document.createRange(); - range$$1.setEnd(snapshot.anchorNode, snapshot.anchorOffset); - range$$1.collapse(false); - sel.removeAllRanges(); - sel.addRange(range$$1); - sel.extend(snapshot.focusNode, snapshot.focusOffset); + function contextMenuInGutter(cm, e) { + if (!hasHandler(cm, "gutterContextMenu")) { return false } + return gutterEvent(cm, e, "gutterContextMenu", false) } -} -// Does the actual updating of the line display. Bails out -// (returning false) when there is nothing to be done and forced is -// false. -function updateDisplayIfNeeded(cm, update) { - var display = cm.display, doc = cm.doc; - - if (update.editorIsHidden) { - resetView(cm); - return false + function themeChanged(cm) { + cm.display.wrapper.className = cm.display.wrapper.className.replace(/\s*cm-s-\S+/g, "") + + cm.options.theme.replace(/(^|\s)\s*/g, " cm-s-"); + clearCaches(cm); } - // Bail out if the visible area is already rendered and nothing changed. - if (!update.force && - update.visible.from >= display.viewFrom && update.visible.to <= display.viewTo && - (display.updateLineNumbers == null || display.updateLineNumbers >= display.viewTo) && - display.renderedView == display.view && countDirtyView(cm) == 0) - { return false } - - if (maybeUpdateLineNumberWidth(cm)) { - resetView(cm); - update.dims = getDimensions(cm); - } - - // Compute a suitable new viewport (from & to) - var end = doc.first + doc.size; - var from = Math.max(update.visible.from - cm.options.viewportMargin, doc.first); - var to = Math.min(end, update.visible.to + cm.options.viewportMargin); - if (display.viewFrom < from && from - display.viewFrom < 20) { from = Math.max(doc.first, display.viewFrom); } - if (display.viewTo > to && display.viewTo - to < 20) { to = Math.min(end, display.viewTo); } - if (sawCollapsedSpans) { - from = visualLineNo(cm.doc, from); - to = visualLineEndNo(cm.doc, to); - } - - var different = from != display.viewFrom || to != display.viewTo || - display.lastWrapHeight != update.wrapperHeight || display.lastWrapWidth != update.wrapperWidth; - adjustView(cm, from, to); - - display.viewOffset = heightAtLine(getLine(cm.doc, display.viewFrom)); - // Position the mover div to align with the current scroll position - cm.display.mover.style.top = display.viewOffset + "px"; - - var toUpdate = countDirtyView(cm); - if (!different && toUpdate == 0 && !update.force && display.renderedView == display.view && - (display.updateLineNumbers == null || display.updateLineNumbers >= display.viewTo)) - { return false } - - // For big changes, we hide the enclosing element during the - // update, since that speeds up the operations on most browsers. - var selSnapshot = selectionSnapshot(cm); - if (toUpdate > 4) { display.lineDiv.style.display = "none"; } - patchDisplay(cm, display.updateLineNumbers, update.dims); - if (toUpdate > 4) { display.lineDiv.style.display = ""; } - display.renderedView = display.view; - // There might have been a widget with a focused element that got - // hidden or updated, if so re-focus it. - restoreSelection(selSnapshot); - - // Prevent selection and cursors from interfering with the scroll - // width and height. - removeChildren(display.cursorDiv); - removeChildren(display.selectionDiv); - display.gutters.style.height = display.sizer.style.minHeight = 0; - - if (different) { - display.lastWrapHeight = update.wrapperHeight; - display.lastWrapWidth = update.wrapperWidth; - startWorker(cm, 400); - } + var Init = {toString: function(){return "CodeMirror.Init"}}; - display.updateLineNumbers = null; + var defaults = {}; + var optionHandlers = {}; - return true -} + function defineOptions(CodeMirror) { + var optionHandlers = CodeMirror.optionHandlers; -function postUpdateDisplay(cm, update) { - var viewport = update.viewport; - - for (var first = true;; first = false) { - if (!first || !cm.options.lineWrapping || update.oldDisplayWidth == displayWidth(cm)) { - // Clip forced viewport to actual scrollable area. - if (viewport && viewport.top != null) - { viewport = {top: Math.min(cm.doc.height + paddingVert(cm.display) - displayHeight(cm), viewport.top)}; } - // Updated line heights might result in the drawn area not - // actually covering the viewport. Keep looping until it does. - update.visible = visibleLines(cm.display, cm.doc, viewport); - if (update.visible.from >= cm.display.viewFrom && update.visible.to <= cm.display.viewTo) - { break } + function option(name, deflt, handle, notOnInit) { + CodeMirror.defaults[name] = deflt; + if (handle) { optionHandlers[name] = + notOnInit ? function (cm, val, old) {if (old != Init) { handle(cm, val, old); }} : handle; } } - if (!updateDisplayIfNeeded(cm, update)) { break } - updateHeightsInViewport(cm); - var barMeasure = measureForScrollbars(cm); - updateSelection(cm); - updateScrollbars(cm, barMeasure); - setDocumentHeight(cm, barMeasure); - update.force = false; - } - update.signal(cm, "update", cm); - if (cm.display.viewFrom != cm.display.reportedViewFrom || cm.display.viewTo != cm.display.reportedViewTo) { - update.signal(cm, "viewportChange", cm, cm.display.viewFrom, cm.display.viewTo); - cm.display.reportedViewFrom = cm.display.viewFrom; cm.display.reportedViewTo = cm.display.viewTo; - } -} - -function updateDisplaySimple(cm, viewport) { - var update = new DisplayUpdate(cm, viewport); - if (updateDisplayIfNeeded(cm, update)) { - updateHeightsInViewport(cm); - postUpdateDisplay(cm, update); - var barMeasure = measureForScrollbars(cm); - updateSelection(cm); - updateScrollbars(cm, barMeasure); - setDocumentHeight(cm, barMeasure); - update.finish(); - } -} + CodeMirror.defineOption = option; -// Sync the actual display DOM structure with display.view, removing -// nodes for lines that are no longer in view, and creating the ones -// that are not there yet, and updating the ones that are out of -// date. -function patchDisplay(cm, updateNumbersFrom, dims) { - var display = cm.display, lineNumbers = cm.options.lineNumbers; - var container = display.lineDiv, cur = container.firstChild; - - function rm(node) { - var next = node.nextSibling; - // Works around a throw-scroll bug in OS X Webkit - if (webkit && mac && cm.display.currentWheelTarget == node) - { node.style.display = "none"; } - else - { node.parentNode.removeChild(node); } - return next - } - - var view = display.view, lineN = display.viewFrom; - // Loop over the elements in the view, syncing cur (the DOM nodes - // in display.lineDiv) with the view as we go. - for (var i = 0; i < view.length; i++) { - var lineView = view[i]; - if (lineView.hidden) { - } else if (!lineView.node || lineView.node.parentNode != container) { // Not drawn yet - var node = buildLineElement(cm, lineView, lineN, dims); - container.insertBefore(node, cur); - } else { // Already drawn - while (cur != lineView.node) { cur = rm(cur); } - var updateNumber = lineNumbers && updateNumbersFrom != null && - updateNumbersFrom <= lineN && lineView.lineNumber; - if (lineView.changes) { - if (indexOf(lineView.changes, "gutter") > -1) { updateNumber = false; } - updateLineForChanges(cm, lineView, lineN, dims); - } - if (updateNumber) { - removeChildren(lineView.lineNumber); - lineView.lineNumber.appendChild(document.createTextNode(lineNumberFor(cm.options, lineN))); - } - cur = lineView.node.nextSibling; - } - lineN += lineView.size; - } - while (cur) { cur = rm(cur); } -} + // Passed to option handlers when there is no old value. + CodeMirror.Init = Init; -function updateGutterSpace(cm) { - var width = cm.display.gutters.offsetWidth; - cm.display.sizer.style.marginLeft = width + "px"; -} + // These two are, on init, called from the constructor because they + // have to be initialized before the editor can start at all. + option("value", "", function (cm, val) { return cm.setValue(val); }, true); + option("mode", null, function (cm, val) { + cm.doc.modeOption = val; + loadMode(cm); + }, true); -function setDocumentHeight(cm, measure) { - cm.display.sizer.style.minHeight = measure.docHeight + "px"; - cm.display.heightForcer.style.top = measure.docHeight + "px"; - cm.display.gutters.style.height = (measure.docHeight + cm.display.barHeight + scrollGap(cm)) + "px"; -} + option("indentUnit", 2, loadMode, true); + option("indentWithTabs", false); + option("smartIndent", true); + option("tabSize", 4, function (cm) { + resetModeState(cm); + clearCaches(cm); + regChange(cm); + }, true); -// Rebuild the gutter elements, ensure the margin to the left of the -// code matches their width. -function updateGutters(cm) { - var gutters = cm.display.gutters, specs = cm.options.gutters; - removeChildren(gutters); - var i = 0; - for (; i < specs.length; ++i) { - var gutterClass = specs[i]; - var gElt = gutters.appendChild(elt("div", null, "CodeMirror-gutter " + gutterClass)); - if (gutterClass == "CodeMirror-linenumbers") { - cm.display.lineGutter = gElt; - gElt.style.width = (cm.display.lineNumWidth || 1) + "px"; - } - } - gutters.style.display = i ? "" : "none"; - updateGutterSpace(cm); -} + option("lineSeparator", null, function (cm, val) { + cm.doc.lineSep = val; + if (!val) { return } + var newBreaks = [], lineNo = cm.doc.first; + cm.doc.iter(function (line) { + for (var pos = 0;;) { + var found = line.text.indexOf(val, pos); + if (found == -1) { break } + pos = found + val.length; + newBreaks.push(Pos(lineNo, found)); + } + lineNo++; + }); + for (var i = newBreaks.length - 1; i >= 0; i--) + { replaceRange(cm.doc, val, newBreaks[i], Pos(newBreaks[i].line, newBreaks[i].ch + val.length)); } + }); + option("specialChars", /[\u0000-\u001f\u007f-\u009f\u00ad\u061c\u200b-\u200f\u2028\u2029\ufeff\ufff9-\ufffc]/g, function (cm, val, old) { + cm.state.specialChars = new RegExp(val.source + (val.test("\t") ? "" : "|\t"), "g"); + if (old != Init) { cm.refresh(); } + }); + option("specialCharPlaceholder", defaultSpecialCharPlaceholder, function (cm) { return cm.refresh(); }, true); + option("electricChars", true); + option("inputStyle", mobile ? "contenteditable" : "textarea", function () { + throw new Error("inputStyle can not (yet) be changed in a running editor") // FIXME + }, true); + option("spellcheck", false, function (cm, val) { return cm.getInputField().spellcheck = val; }, true); + option("autocorrect", false, function (cm, val) { return cm.getInputField().autocorrect = val; }, true); + option("autocapitalize", false, function (cm, val) { return cm.getInputField().autocapitalize = val; }, true); + option("rtlMoveVisually", !windows); + option("wholeLineUpdateBefore", true); + + option("theme", "default", function (cm) { + themeChanged(cm); + updateGutters(cm); + }, true); + option("keyMap", "default", function (cm, val, old) { + var next = getKeyMap(val); + var prev = old != Init && getKeyMap(old); + if (prev && prev.detach) { prev.detach(cm, next); } + if (next.attach) { next.attach(cm, prev || null); } + }); + option("extraKeys", null); + option("configureMouse", null); + + option("lineWrapping", false, wrappingChanged, true); + option("gutters", [], function (cm, val) { + cm.display.gutterSpecs = getGutters(val, cm.options.lineNumbers); + updateGutters(cm); + }, true); + option("fixedGutter", true, function (cm, val) { + cm.display.gutters.style.left = val ? compensateForHScroll(cm.display) + "px" : "0"; + cm.refresh(); + }, true); + option("coverGutterNextToScrollbar", false, function (cm) { return updateScrollbars(cm); }, true); + option("scrollbarStyle", "native", function (cm) { + initScrollbars(cm); + updateScrollbars(cm); + cm.display.scrollbars.setScrollTop(cm.doc.scrollTop); + cm.display.scrollbars.setScrollLeft(cm.doc.scrollLeft); + }, true); + option("lineNumbers", false, function (cm, val) { + cm.display.gutterSpecs = getGutters(cm.options.gutters, val); + updateGutters(cm); + }, true); + option("firstLineNumber", 1, updateGutters, true); + option("lineNumberFormatter", function (integer) { return integer; }, updateGutters, true); + option("showCursorWhenSelecting", false, updateSelection, true); + + option("resetSelectionOnContextMenu", true); + option("lineWiseCopyCut", true); + option("pasteLinesPerSelection", true); + option("selectionsMayTouch", false); + + option("readOnly", false, function (cm, val) { + if (val == "nocursor") { + onBlur(cm); + cm.display.input.blur(); + } + cm.display.input.readOnlyChanged(val); + }); + option("disableInput", false, function (cm, val) {if (!val) { cm.display.input.reset(); }}, true); + option("dragDrop", true, dragDropChanged); + option("allowDropFileTypes", null); + + option("cursorBlinkRate", 530); + option("cursorScrollMargin", 0); + option("cursorHeight", 1, updateSelection, true); + option("singleCursorHeightPerLine", true, updateSelection, true); + option("workTime", 100); + option("workDelay", 100); + option("flattenSpans", true, resetModeState, true); + option("addModeClass", false, resetModeState, true); + option("pollInterval", 100); + option("undoDepth", 200, function (cm, val) { return cm.doc.history.undoDepth = val; }); + option("historyEventDelay", 1250); + option("viewportMargin", 10, function (cm) { return cm.refresh(); }, true); + option("maxHighlightLength", 10000, resetModeState, true); + option("moveInputWithCursor", true, function (cm, val) { + if (!val) { cm.display.input.resetPosition(); } + }); -// Make sure the gutters options contains the element -// "CodeMirror-linenumbers" when the lineNumbers option is true. -function setGuttersForLineNumbers(options) { - var found = indexOf(options.gutters, "CodeMirror-linenumbers"); - if (found == -1 && options.lineNumbers) { - options.gutters = options.gutters.concat(["CodeMirror-linenumbers"]); - } else if (found > -1 && !options.lineNumbers) { - options.gutters = options.gutters.slice(0); - options.gutters.splice(found, 1); + option("tabindex", null, function (cm, val) { return cm.display.input.getField().tabIndex = val || ""; }); + option("autofocus", null); + option("direction", "ltr", function (cm, val) { return cm.doc.setDirection(val); }, true); + option("phrases", null); } -} - -// Since the delta values reported on mouse wheel events are -// unstandardized between browsers and even browser versions, and -// generally horribly unpredictable, this code starts by measuring -// the scroll effect that the first few mouse wheel events have, -// and, from that, detects the way it can convert deltas to pixel -// offsets afterwards. -// -// The reason we want to know the amount a wheel event will scroll -// is that it gives us a chance to update the display before the -// actual scrolling happens, reducing flickering. - -var wheelSamples = 0; -var wheelPixelsPerUnit = null; -// Fill in a browser-detected starting value on browsers where we -// know one. These don't have to be accurate -- the result of them -// being wrong would just be a slight flicker on the first wheel -// scroll (if it is large enough). -if (ie) { wheelPixelsPerUnit = -.53; } -else if (gecko) { wheelPixelsPerUnit = 15; } -else if (chrome) { wheelPixelsPerUnit = -.7; } -else if (safari) { wheelPixelsPerUnit = -1/3; } - -function wheelEventDelta(e) { - var dx = e.wheelDeltaX, dy = e.wheelDeltaY; - if (dx == null && e.detail && e.axis == e.HORIZONTAL_AXIS) { dx = e.detail; } - if (dy == null && e.detail && e.axis == e.VERTICAL_AXIS) { dy = e.detail; } - else if (dy == null) { dy = e.wheelDelta; } - return {x: dx, y: dy} -} -function wheelEventPixels(e) { - var delta = wheelEventDelta(e); - delta.x *= wheelPixelsPerUnit; - delta.y *= wheelPixelsPerUnit; - return delta -} -function onScrollWheel(cm, e) { - var delta = wheelEventDelta(e), dx = delta.x, dy = delta.y; - - var display = cm.display, scroll = display.scroller; - // Quit if there's nothing to scroll here - var canScrollX = scroll.scrollWidth > scroll.clientWidth; - var canScrollY = scroll.scrollHeight > scroll.clientHeight; - if (!(dx && canScrollX || dy && canScrollY)) { return } - - // Webkit browsers on OS X abort momentum scrolls when the target - // of the scroll event is removed from the scrollable element. - // This hack (see related code in patchDisplay) makes sure the - // element is kept around. - if (dy && mac && webkit) { - outer: for (var cur = e.target, view = display.view; cur != scroll; cur = cur.parentNode) { - for (var i = 0; i < view.length; i++) { - if (view[i].node == cur) { - cm.display.currentWheelTarget = cur; - break outer - } - } - } - } - - // On some browsers, horizontal scrolling will cause redraws to - // happen before the gutter has been realigned, causing it to - // wriggle around in a most unseemly way. When we have an - // estimated pixels/delta value, we just handle horizontal - // scrolling entirely here. It'll be slightly off from native, but - // better than glitching out. - if (dx && !gecko && !presto && wheelPixelsPerUnit != null) { - if (dy && canScrollY) - { updateScrollTop(cm, Math.max(0, scroll.scrollTop + dy * wheelPixelsPerUnit)); } - setScrollLeft(cm, Math.max(0, scroll.scrollLeft + dx * wheelPixelsPerUnit)); - // Only prevent default scrolling if vertical scrolling is - // actually possible. Otherwise, it causes vertical scroll - // jitter on OSX trackpads when deltaX is small and deltaY - // is large (issue #3579) - if (!dy || (dy && canScrollY)) - { e_preventDefault(e); } - display.wheelStartX = null; // Abort measurement, if in progress - return - } - - // 'Project' the visible viewport to cover the area that is being - // scrolled into view (if we know enough to estimate it). - if (dy && wheelPixelsPerUnit != null) { - var pixels = dy * wheelPixelsPerUnit; - var top = cm.doc.scrollTop, bot = top + display.wrapper.clientHeight; - if (pixels < 0) { top = Math.max(0, top + pixels - 50); } - else { bot = Math.min(cm.doc.height, bot + pixels + 50); } - updateDisplaySimple(cm, {top: top, bottom: bot}); - } - - if (wheelSamples < 20) { - if (display.wheelStartX == null) { - display.wheelStartX = scroll.scrollLeft; display.wheelStartY = scroll.scrollTop; - display.wheelDX = dx; display.wheelDY = dy; - setTimeout(function () { - if (display.wheelStartX == null) { return } - var movedX = scroll.scrollLeft - display.wheelStartX; - var movedY = scroll.scrollTop - display.wheelStartY; - var sample = (movedY && display.wheelDY && movedY / display.wheelDY) || - (movedX && display.wheelDX && movedX / display.wheelDX); - display.wheelStartX = display.wheelStartY = null; - if (!sample) { return } - wheelPixelsPerUnit = (wheelPixelsPerUnit * wheelSamples + sample) / (wheelSamples + 1); - ++wheelSamples; - }, 200); - } else { - display.wheelDX += dx; display.wheelDY += dy; + function dragDropChanged(cm, value, old) { + var wasOn = old && old != Init; + if (!value != !wasOn) { + var funcs = cm.display.dragFunctions; + var toggle = value ? on : off; + toggle(cm.display.scroller, "dragstart", funcs.start); + toggle(cm.display.scroller, "dragenter", funcs.enter); + toggle(cm.display.scroller, "dragover", funcs.over); + toggle(cm.display.scroller, "dragleave", funcs.leave); + toggle(cm.display.scroller, "drop", funcs.drop); } } -} - -// Selection objects are immutable. A new one is created every time -// the selection changes. A selection is one or more non-overlapping -// (and non-touching) ranges, sorted, and an integer that indicates -// which one is the primary selection (the one that's scrolled into -// view, that getCursor returns, etc). -var Selection = function(ranges, primIndex) { - this.ranges = ranges; - this.primIndex = primIndex; -}; - -Selection.prototype.primary = function () { return this.ranges[this.primIndex] }; -Selection.prototype.equals = function (other) { - var this$1 = this; - - if (other == this) { return true } - if (other.primIndex != this.primIndex || other.ranges.length != this.ranges.length) { return false } - for (var i = 0; i < this.ranges.length; i++) { - var here = this$1.ranges[i], there = other.ranges[i]; - if (!equalCursorPos(here.anchor, there.anchor) || !equalCursorPos(here.head, there.head)) { return false } + function wrappingChanged(cm) { + if (cm.options.lineWrapping) { + addClass(cm.display.wrapper, "CodeMirror-wrap"); + cm.display.sizer.style.minWidth = ""; + cm.display.sizerWidth = null; + } else { + rmClass(cm.display.wrapper, "CodeMirror-wrap"); + findMaxLine(cm); + } + estimateLineHeights(cm); + regChange(cm); + clearCaches(cm); + setTimeout(function () { return updateScrollbars(cm); }, 100); } - return true -}; - -Selection.prototype.deepCopy = function () { - var this$1 = this; - var out = []; - for (var i = 0; i < this.ranges.length; i++) - { out[i] = new Range(copyPos(this$1.ranges[i].anchor), copyPos(this$1.ranges[i].head)); } - return new Selection(out, this.primIndex) -}; + // A CodeMirror instance represents an editor. This is the object + // that user code is usually dealing with. -Selection.prototype.somethingSelected = function () { + function CodeMirror(place, options) { var this$1 = this; - for (var i = 0; i < this.ranges.length; i++) - { if (!this$1.ranges[i].empty()) { return true } } - return false -}; - -Selection.prototype.contains = function (pos, end) { - var this$1 = this; + if (!(this instanceof CodeMirror)) { return new CodeMirror(place, options) } + + this.options = options = options ? copyObj(options) : {}; + // Determine effective options based on given values and defaults. + copyObj(defaults, options, false); + + var doc = options.value; + if (typeof doc == "string") { doc = new Doc(doc, options.mode, null, options.lineSeparator, options.direction); } + else if (options.mode) { doc.modeOption = options.mode; } + this.doc = doc; + + var input = new CodeMirror.inputStyles[options.inputStyle](this); + var display = this.display = new Display(place, doc, input, options); + display.wrapper.CodeMirror = this; + themeChanged(this); + if (options.lineWrapping) + { this.display.wrapper.className += " CodeMirror-wrap"; } + initScrollbars(this); + + this.state = { + keyMaps: [], // stores maps added by addKeyMap + overlays: [], // highlighting overlays, as added by addOverlay + modeGen: 0, // bumped when mode/overlay changes, used to invalidate highlighting info + overwrite: false, + delayingBlurEvent: false, + focused: false, + suppressEdits: false, // used to disable editing during key handlers when in readOnly mode + pasteIncoming: -1, cutIncoming: -1, // help recognize paste/cut edits in input.poll + selectingText: false, + draggingText: false, + highlight: new Delayed(), // stores highlight worker timeout + keySeq: null, // Unfinished key sequence + specialChars: null + }; - if (!end) { end = pos; } - for (var i = 0; i < this.ranges.length; i++) { - var range = this$1.ranges[i]; - if (cmp(end, range.from()) >= 0 && cmp(pos, range.to()) <= 0) - { return i } - } - return -1 -}; + if (options.autofocus && !mobile) { display.input.focus(); } -var Range = function(anchor, head) { - this.anchor = anchor; this.head = head; -}; + // Override magic textarea content restore that IE sometimes does + // on our hidden textarea on reload + if (ie && ie_version < 11) { setTimeout(function () { return this$1.display.input.reset(true); }, 20); } -Range.prototype.from = function () { return minPos(this.anchor, this.head) }; -Range.prototype.to = function () { return maxPos(this.anchor, this.head) }; -Range.prototype.empty = function () { return this.head.line == this.anchor.line && this.head.ch == this.anchor.ch }; - -// Take an unsorted, potentially overlapping set of ranges, and -// build a selection out of it. 'Consumes' ranges array (modifying -// it). -function normalizeSelection(ranges, primIndex) { - var prim = ranges[primIndex]; - ranges.sort(function (a, b) { return cmp(a.from(), b.from()); }); - primIndex = indexOf(ranges, prim); - for (var i = 1; i < ranges.length; i++) { - var cur = ranges[i], prev = ranges[i - 1]; - if (cmp(prev.to(), cur.from()) >= 0) { - var from = minPos(prev.from(), cur.from()), to = maxPos(prev.to(), cur.to()); - var inv = prev.empty() ? cur.from() == cur.head : prev.from() == prev.head; - if (i <= primIndex) { --primIndex; } - ranges.splice(--i, 2, new Range(inv ? to : from, inv ? from : to)); - } - } - return new Selection(ranges, primIndex) -} + registerEventHandlers(this); + ensureGlobalHandlers(); -function simpleSelection(anchor, head) { - return new Selection([new Range(anchor, head || anchor)], 0) -} + startOperation(this); + this.curOp.forceUpdate = true; + attachDoc(this, doc); -// Compute the position of the end of a change (its 'to' property -// refers to the pre-change end). -function changeEnd(change) { - if (!change.text) { return change.to } - return Pos(change.from.line + change.text.length - 1, - lst(change.text).length + (change.text.length == 1 ? change.from.ch : 0)) -} + if ((options.autofocus && !mobile) || this.hasFocus()) + { setTimeout(bind(onFocus, this), 20); } + else + { onBlur(this); } + + for (var opt in optionHandlers) { if (optionHandlers.hasOwnProperty(opt)) + { optionHandlers[opt](this$1, options[opt], Init); } } + maybeUpdateLineNumberWidth(this); + if (options.finishInit) { options.finishInit(this); } + for (var i = 0; i < initHooks.length; ++i) { initHooks[i](this$1); } + endOperation(this); + // Suppress optimizelegibility in Webkit, since it breaks text + // measuring on line wrapping boundaries. + if (webkit && options.lineWrapping && + getComputedStyle(display.lineDiv).textRendering == "optimizelegibility") + { display.lineDiv.style.textRendering = "auto"; } + } + + // The default configuration options. + CodeMirror.defaults = defaults; + // Functions to run when options are changed. + CodeMirror.optionHandlers = optionHandlers; + + // Attach the necessary event handlers when initializing the editor + function registerEventHandlers(cm) { + var d = cm.display; + on(d.scroller, "mousedown", operation(cm, onMouseDown)); + // Older IE's will not fire a second mousedown for a double click + if (ie && ie_version < 11) + { on(d.scroller, "dblclick", operation(cm, function (e) { + if (signalDOMEvent(cm, e)) { return } + var pos = posFromMouse(cm, e); + if (!pos || clickInGutter(cm, e) || eventInWidget(cm.display, e)) { return } + e_preventDefault(e); + var word = cm.findWordAt(pos); + extendSelection(cm.doc, word.anchor, word.head); + })); } + else + { on(d.scroller, "dblclick", function (e) { return signalDOMEvent(cm, e) || e_preventDefault(e); }); } + // Some browsers fire contextmenu *after* opening the menu, at + // which point we can't mess with it anymore. Context menu is + // handled in onMouseDown for these browsers. + on(d.scroller, "contextmenu", function (e) { return onContextMenu(cm, e); }); + + // Used to suppress mouse event handling when a touch happens + var touchFinished, prevTouch = {end: 0}; + function finishTouch() { + if (d.activeTouch) { + touchFinished = setTimeout(function () { return d.activeTouch = null; }, 1000); + prevTouch = d.activeTouch; + prevTouch.end = +new Date; + } + } + function isMouseLikeTouchEvent(e) { + if (e.touches.length != 1) { return false } + var touch = e.touches[0]; + return touch.radiusX <= 1 && touch.radiusY <= 1 + } + function farAway(touch, other) { + if (other.left == null) { return true } + var dx = other.left - touch.left, dy = other.top - touch.top; + return dx * dx + dy * dy > 20 * 20 + } + on(d.scroller, "touchstart", function (e) { + if (!signalDOMEvent(cm, e) && !isMouseLikeTouchEvent(e) && !clickInGutter(cm, e)) { + d.input.ensurePolled(); + clearTimeout(touchFinished); + var now = +new Date; + d.activeTouch = {start: now, moved: false, + prev: now - prevTouch.end <= 300 ? prevTouch : null}; + if (e.touches.length == 1) { + d.activeTouch.left = e.touches[0].pageX; + d.activeTouch.top = e.touches[0].pageY; + } + } + }); + on(d.scroller, "touchmove", function () { + if (d.activeTouch) { d.activeTouch.moved = true; } + }); + on(d.scroller, "touchend", function (e) { + var touch = d.activeTouch; + if (touch && !eventInWidget(d, e) && touch.left != null && + !touch.moved && new Date - touch.start < 300) { + var pos = cm.coordsChar(d.activeTouch, "page"), range; + if (!touch.prev || farAway(touch, touch.prev)) // Single tap + { range = new Range(pos, pos); } + else if (!touch.prev.prev || farAway(touch, touch.prev.prev)) // Double tap + { range = cm.findWordAt(pos); } + else // Triple tap + { range = new Range(Pos(pos.line, 0), clipPos(cm.doc, Pos(pos.line + 1, 0))); } + cm.setSelection(range.anchor, range.head); + cm.focus(); + e_preventDefault(e); + } + finishTouch(); + }); + on(d.scroller, "touchcancel", finishTouch); -// Adjust a position to refer to the post-change position of the -// same text, or the end of the change if the change covers it. -function adjustForChange(pos, change) { - if (cmp(pos, change.from) < 0) { return pos } - if (cmp(pos, change.to) <= 0) { return changeEnd(change) } + // Sync scrolling between fake scrollbars and real scrollable + // area, ensure viewport is updated when scrolling. + on(d.scroller, "scroll", function () { + if (d.scroller.clientHeight) { + updateScrollTop(cm, d.scroller.scrollTop); + setScrollLeft(cm, d.scroller.scrollLeft, true); + signal(cm, "scroll", cm); + } + }); - var line = pos.line + change.text.length - (change.to.line - change.from.line) - 1, ch = pos.ch; - if (pos.line == change.to.line) { ch += changeEnd(change).ch - change.to.ch; } - return Pos(line, ch) -} + // Listen to wheel events in order to try and update the viewport on time. + on(d.scroller, "mousewheel", function (e) { return onScrollWheel(cm, e); }); + on(d.scroller, "DOMMouseScroll", function (e) { return onScrollWheel(cm, e); }); -function computeSelAfterChange(doc, change) { - var out = []; - for (var i = 0; i < doc.sel.ranges.length; i++) { - var range = doc.sel.ranges[i]; - out.push(new Range(adjustForChange(range.anchor, change), - adjustForChange(range.head, change))); - } - return normalizeSelection(out, doc.sel.primIndex) -} + // Prevent wrapper from ever scrolling + on(d.wrapper, "scroll", function () { return d.wrapper.scrollTop = d.wrapper.scrollLeft = 0; }); -function offsetPos(pos, old, nw) { - if (pos.line == old.line) - { return Pos(nw.line, pos.ch - old.ch + nw.ch) } - else - { return Pos(nw.line + (pos.line - old.line), pos.ch) } -} + d.dragFunctions = { + enter: function (e) {if (!signalDOMEvent(cm, e)) { e_stop(e); }}, + over: function (e) {if (!signalDOMEvent(cm, e)) { onDragOver(cm, e); e_stop(e); }}, + start: function (e) { return onDragStart(cm, e); }, + drop: operation(cm, onDrop), + leave: function (e) {if (!signalDOMEvent(cm, e)) { clearDragCursor(cm); }} + }; -// Used by replaceSelections to allow moving the selection to the -// start or around the replaced test. Hint may be "start" or "around". -function computeReplacedSel(doc, changes, hint) { - var out = []; - var oldPrev = Pos(doc.first, 0), newPrev = oldPrev; - for (var i = 0; i < changes.length; i++) { - var change = changes[i]; - var from = offsetPos(change.from, oldPrev, newPrev); - var to = offsetPos(changeEnd(change), oldPrev, newPrev); - oldPrev = change.to; - newPrev = to; - if (hint == "around") { - var range = doc.sel.ranges[i], inv = cmp(range.head, range.anchor) < 0; - out[i] = new Range(inv ? to : from, inv ? from : to); + var inp = d.input.getField(); + on(inp, "keyup", function (e) { return onKeyUp.call(cm, e); }); + on(inp, "keydown", operation(cm, onKeyDown)); + on(inp, "keypress", operation(cm, onKeyPress)); + on(inp, "focus", function (e) { return onFocus(cm, e); }); + on(inp, "blur", function (e) { return onBlur(cm, e); }); + } + + var initHooks = []; + CodeMirror.defineInitHook = function (f) { return initHooks.push(f); }; + + // Indent the given line. The how parameter can be "smart", + // "add"/null, "subtract", or "prev". When aggressive is false + // (typically set to true for forced single-line indents), empty + // lines are not indented, and places where the mode returns Pass + // are left alone. + function indentLine(cm, n, how, aggressive) { + var doc = cm.doc, state; + if (how == null) { how = "add"; } + if (how == "smart") { + // Fall back to "prev" when the mode doesn't have an indentation + // method. + if (!doc.mode.indent) { how = "prev"; } + else { state = getContextBefore(cm, n).state; } + } + + var tabSize = cm.options.tabSize; + var line = getLine(doc, n), curSpace = countColumn(line.text, null, tabSize); + if (line.stateAfter) { line.stateAfter = null; } + var curSpaceString = line.text.match(/^\s*/)[0], indentation; + if (!aggressive && !/\S/.test(line.text)) { + indentation = 0; + how = "not"; + } else if (how == "smart") { + indentation = doc.mode.indent(state, line.text.slice(curSpaceString.length), line.text); + if (indentation == Pass || indentation > 150) { + if (!aggressive) { return } + how = "prev"; + } + } + if (how == "prev") { + if (n > doc.first) { indentation = countColumn(getLine(doc, n-1).text, null, tabSize); } + else { indentation = 0; } + } else if (how == "add") { + indentation = curSpace + cm.options.indentUnit; + } else if (how == "subtract") { + indentation = curSpace - cm.options.indentUnit; + } else if (typeof how == "number") { + indentation = curSpace + how; + } + indentation = Math.max(0, indentation); + + var indentString = "", pos = 0; + if (cm.options.indentWithTabs) + { for (var i = Math.floor(indentation / tabSize); i; --i) {pos += tabSize; indentString += "\t";} } + if (pos < indentation) { indentString += spaceStr(indentation - pos); } + + if (indentString != curSpaceString) { + replaceRange(doc, indentString, Pos(n, 0), Pos(n, curSpaceString.length), "+input"); + line.stateAfter = null; + return true } else { - out[i] = new Range(from, from); + // Ensure that, if the cursor was in the whitespace at the start + // of the line, it is moved to the end of that space. + for (var i$1 = 0; i$1 < doc.sel.ranges.length; i$1++) { + var range = doc.sel.ranges[i$1]; + if (range.head.line == n && range.head.ch < curSpaceString.length) { + var pos$1 = Pos(n, curSpaceString.length); + replaceOneSelection(doc, i$1, new Range(pos$1, pos$1)); + break + } + } } } - return new Selection(out, doc.sel.primIndex) -} -// Used to get the editor into a consistent state again when options change. + // This will be set to a {lineWise: bool, text: [string]} object, so + // that, when pasting, we know what kind of selections the copied + // text was made out of. + var lastCopied = null; -function loadMode(cm) { - cm.doc.mode = getMode(cm.options, cm.doc.modeOption); - resetModeState(cm); -} + function setLastCopied(newLastCopied) { + lastCopied = newLastCopied; + } -function resetModeState(cm) { - cm.doc.iter(function (line) { - if (line.stateAfter) { line.stateAfter = null; } - if (line.styles) { line.styles = null; } - }); - cm.doc.modeFrontier = cm.doc.highlightFrontier = cm.doc.first; - startWorker(cm, 100); - cm.state.modeGen++; - if (cm.curOp) { regChange(cm); } -} + function applyTextInput(cm, inserted, deleted, sel, origin) { + var doc = cm.doc; + cm.display.shift = false; + if (!sel) { sel = doc.sel; } -// DOCUMENT DATA STRUCTURE + var recent = +new Date - 200; + var paste = origin == "paste" || cm.state.pasteIncoming > recent; + var textLines = splitLinesAuto(inserted), multiPaste = null; + // When pasting N lines into N selections, insert one line per selection + if (paste && sel.ranges.length > 1) { + if (lastCopied && lastCopied.text.join("\n") == inserted) { + if (sel.ranges.length % lastCopied.text.length == 0) { + multiPaste = []; + for (var i = 0; i < lastCopied.text.length; i++) + { multiPaste.push(doc.splitLines(lastCopied.text[i])); } + } + } else if (textLines.length == sel.ranges.length && cm.options.pasteLinesPerSelection) { + multiPaste = map(textLines, function (l) { return [l]; }); + } + } -// By default, updates that start and end at the beginning of a line -// are treated specially, in order to make the association of line -// widgets and marker elements with the text behave more intuitive. -function isWholeLineUpdate(doc, change) { - return change.from.ch == 0 && change.to.ch == 0 && lst(change.text) == "" && - (!doc.cm || doc.cm.options.wholeLineUpdateBefore) -} + var updateInput = cm.curOp.updateInput; + // Normal behavior is to insert the new text into every selection + for (var i$1 = sel.ranges.length - 1; i$1 >= 0; i$1--) { + var range$$1 = sel.ranges[i$1]; + var from = range$$1.from(), to = range$$1.to(); + if (range$$1.empty()) { + if (deleted && deleted > 0) // Handle deletion + { from = Pos(from.line, from.ch - deleted); } + else if (cm.state.overwrite && !paste) // Handle overwrite + { to = Pos(to.line, Math.min(getLine(doc, to.line).text.length, to.ch + lst(textLines).length)); } + else if (paste && lastCopied && lastCopied.lineWise && lastCopied.text.join("\n") == inserted) + { from = to = Pos(from.line, 0); } + } + var changeEvent = {from: from, to: to, text: multiPaste ? multiPaste[i$1 % multiPaste.length] : textLines, + origin: origin || (paste ? "paste" : cm.state.cutIncoming > recent ? "cut" : "+input")}; + makeChange(cm.doc, changeEvent); + signalLater(cm, "inputRead", cm, changeEvent); + } + if (inserted && !paste) + { triggerElectric(cm, inserted); } -// Perform a change on the document data structure. -function updateDoc(doc, change, markedSpans, estimateHeight$$1) { - function spansFor(n) {return markedSpans ? markedSpans[n] : null} - function update(line, text, spans) { - updateLine(line, text, spans, estimateHeight$$1); - signalLater(line, "change", line, change); - } - function linesFor(start, end) { - var result = []; - for (var i = start; i < end; ++i) - { result.push(new Line(text[i], spansFor(i), estimateHeight$$1)); } - return result + ensureCursorVisible(cm); + if (cm.curOp.updateInput < 2) { cm.curOp.updateInput = updateInput; } + cm.curOp.typing = true; + cm.state.pasteIncoming = cm.state.cutIncoming = -1; } - var from = change.from, to = change.to, text = change.text; - var firstLine = getLine(doc, from.line), lastLine = getLine(doc, to.line); - var lastText = lst(text), lastSpans = spansFor(text.length - 1), nlines = to.line - from.line; - - // Adjust the line structure - if (change.full) { - doc.insert(0, linesFor(0, text.length)); - doc.remove(text.length, doc.size - text.length); - } else if (isWholeLineUpdate(doc, change)) { - // This is a whole-line replace. Treated specially to make - // sure line objects move the way they are supposed to. - var added = linesFor(0, text.length - 1); - update(lastLine, lastLine.text, lastSpans); - if (nlines) { doc.remove(from.line, nlines); } - if (added.length) { doc.insert(from.line, added); } - } else if (firstLine == lastLine) { - if (text.length == 1) { - update(firstLine, firstLine.text.slice(0, from.ch) + lastText + firstLine.text.slice(to.ch), lastSpans); - } else { - var added$1 = linesFor(1, text.length - 1); - added$1.push(new Line(lastText + firstLine.text.slice(to.ch), lastSpans, estimateHeight$$1)); - update(firstLine, firstLine.text.slice(0, from.ch) + text[0], spansFor(0)); - doc.insert(from.line + 1, added$1); + function handlePaste(e, cm) { + var pasted = e.clipboardData && e.clipboardData.getData("Text"); + if (pasted) { + e.preventDefault(); + if (!cm.isReadOnly() && !cm.options.disableInput) + { runInOp(cm, function () { return applyTextInput(cm, pasted, 0, null, "paste"); }); } + return true } - } else if (text.length == 1) { - update(firstLine, firstLine.text.slice(0, from.ch) + text[0] + lastLine.text.slice(to.ch), spansFor(0)); - doc.remove(from.line + 1, nlines); - } else { - update(firstLine, firstLine.text.slice(0, from.ch) + text[0], spansFor(0)); - update(lastLine, lastText + lastLine.text.slice(to.ch), lastSpans); - var added$2 = linesFor(1, text.length - 1); - if (nlines > 1) { doc.remove(from.line + 1, nlines - 1); } - doc.insert(from.line + 1, added$2); - } - - signalLater(doc, "change", doc, change); -} - -// Call f for all linked documents. -function linkedDocs(doc, f, sharedHistOnly) { - function propagate(doc, skip, sharedHist) { - if (doc.linked) { for (var i = 0; i < doc.linked.length; ++i) { - var rel = doc.linked[i]; - if (rel.doc == skip) { continue } - var shared = sharedHist && rel.sharedHist; - if (sharedHistOnly && !shared) { continue } - f(rel.doc, shared); - propagate(rel.doc, doc, shared); - } } } - propagate(doc, null, true); -} -// Attach a document to an editor. -function attachDoc(cm, doc) { - if (doc.cm) { throw new Error("This document is already in use.") } - cm.doc = doc; - doc.cm = cm; - estimateLineHeights(cm); - loadMode(cm); - setDirectionClass(cm); - if (!cm.options.lineWrapping) { findMaxLine(cm); } - cm.options.mode = doc.modeOption; - regChange(cm); -} + function triggerElectric(cm, inserted) { + // When an 'electric' character is inserted, immediately trigger a reindent + if (!cm.options.electricChars || !cm.options.smartIndent) { return } + var sel = cm.doc.sel; -function setDirectionClass(cm) { - (cm.doc.direction == "rtl" ? addClass : rmClass)(cm.display.lineDiv, "CodeMirror-rtl"); -} + for (var i = sel.ranges.length - 1; i >= 0; i--) { + var range$$1 = sel.ranges[i]; + if (range$$1.head.ch > 100 || (i && sel.ranges[i - 1].head.line == range$$1.head.line)) { continue } + var mode = cm.getModeAt(range$$1.head); + var indented = false; + if (mode.electricChars) { + for (var j = 0; j < mode.electricChars.length; j++) + { if (inserted.indexOf(mode.electricChars.charAt(j)) > -1) { + indented = indentLine(cm, range$$1.head.line, "smart"); + break + } } + } else if (mode.electricInput) { + if (mode.electricInput.test(getLine(cm.doc, range$$1.head.line).text.slice(0, range$$1.head.ch))) + { indented = indentLine(cm, range$$1.head.line, "smart"); } + } + if (indented) { signalLater(cm, "electricInput", cm, range$$1.head.line); } + } + } + + function copyableRanges(cm) { + var text = [], ranges = []; + for (var i = 0; i < cm.doc.sel.ranges.length; i++) { + var line = cm.doc.sel.ranges[i].head.line; + var lineRange = {anchor: Pos(line, 0), head: Pos(line + 1, 0)}; + ranges.push(lineRange); + text.push(cm.getRange(lineRange.anchor, lineRange.head)); + } + return {text: text, ranges: ranges} + } + + function disableBrowserMagic(field, spellcheck, autocorrect, autocapitalize) { + field.setAttribute("autocorrect", autocorrect ? "" : "off"); + field.setAttribute("autocapitalize", autocapitalize ? "" : "off"); + field.setAttribute("spellcheck", !!spellcheck); + } + + function hiddenTextarea() { + var te = elt("textarea", null, null, "position: absolute; bottom: -1em; padding: 0; width: 1px; height: 1em; outline: none"); + var div = elt("div", [te], null, "overflow: hidden; position: relative; width: 3px; height: 0px;"); + // The textarea is kept positioned near the cursor to prevent the + // fact that it'll be scrolled into view on input from scrolling + // our fake cursor out of view. On webkit, when wrap=off, paste is + // very slow. So make the area wide instead. + if (webkit) { te.style.width = "1000px"; } + else { te.setAttribute("wrap", "off"); } + // If border: 0; -- iOS fails to open keyboard (issue #1287) + if (ios) { te.style.border = "1px solid black"; } + disableBrowserMagic(te); + return div + } + + // The publicly visible API. Note that methodOp(f) means + // 'wrap f in an operation, performed on its `this` parameter'. + + // This is not the complete set of editor methods. Most of the + // methods defined on the Doc type are also injected into + // CodeMirror.prototype, for backwards compatibility and + // convenience. + + function addEditorMethods(CodeMirror) { + var optionHandlers = CodeMirror.optionHandlers; + + var helpers = CodeMirror.helpers = {}; + + CodeMirror.prototype = { + constructor: CodeMirror, + focus: function(){window.focus(); this.display.input.focus();}, + + setOption: function(option, value) { + var options = this.options, old = options[option]; + if (options[option] == value && option != "mode") { return } + options[option] = value; + if (optionHandlers.hasOwnProperty(option)) + { operation(this, optionHandlers[option])(this, value, old); } + signal(this, "optionChange", this, option); + }, -function directionChanged(cm) { - runInOp(cm, function () { - setDirectionClass(cm); - regChange(cm); - }); -} + getOption: function(option) {return this.options[option]}, + getDoc: function() {return this.doc}, -function History(startGen) { - // Arrays of change events and selections. Doing something adds an - // event to done and clears undo. Undoing moves events from done - // to undone, redoing moves them in the other direction. - this.done = []; this.undone = []; - this.undoDepth = Infinity; - // Used to track when changes can be merged into a single undo - // event - this.lastModTime = this.lastSelTime = 0; - this.lastOp = this.lastSelOp = null; - this.lastOrigin = this.lastSelOrigin = null; - // Used by the isClean() method - this.generation = this.maxGeneration = startGen || 1; -} + addKeyMap: function(map$$1, bottom) { + this.state.keyMaps[bottom ? "push" : "unshift"](getKeyMap(map$$1)); + }, + removeKeyMap: function(map$$1) { + var maps = this.state.keyMaps; + for (var i = 0; i < maps.length; ++i) + { if (maps[i] == map$$1 || maps[i].name == map$$1) { + maps.splice(i, 1); + return true + } } + }, -// Create a history change event from an updateDoc-style change -// object. -function historyChangeFromChange(doc, change) { - var histChange = {from: copyPos(change.from), to: changeEnd(change), text: getBetween(doc, change.from, change.to)}; - attachLocalSpans(doc, histChange, change.from.line, change.to.line + 1); - linkedDocs(doc, function (doc) { return attachLocalSpans(doc, histChange, change.from.line, change.to.line + 1); }, true); - return histChange -} + addOverlay: methodOp(function(spec, options) { + var mode = spec.token ? spec : CodeMirror.getMode(this.options, spec); + if (mode.startState) { throw new Error("Overlays may not be stateful.") } + insertSorted(this.state.overlays, + {mode: mode, modeSpec: spec, opaque: options && options.opaque, + priority: (options && options.priority) || 0}, + function (overlay) { return overlay.priority; }); + this.state.modeGen++; + regChange(this); + }), + removeOverlay: methodOp(function(spec) { + var this$1 = this; + + var overlays = this.state.overlays; + for (var i = 0; i < overlays.length; ++i) { + var cur = overlays[i].modeSpec; + if (cur == spec || typeof spec == "string" && cur.name == spec) { + overlays.splice(i, 1); + this$1.state.modeGen++; + regChange(this$1); + return + } + } + }), + + indentLine: methodOp(function(n, dir, aggressive) { + if (typeof dir != "string" && typeof dir != "number") { + if (dir == null) { dir = this.options.smartIndent ? "smart" : "prev"; } + else { dir = dir ? "add" : "subtract"; } + } + if (isLine(this.doc, n)) { indentLine(this, n, dir, aggressive); } + }), + indentSelection: methodOp(function(how) { + var this$1 = this; + + var ranges = this.doc.sel.ranges, end = -1; + for (var i = 0; i < ranges.length; i++) { + var range$$1 = ranges[i]; + if (!range$$1.empty()) { + var from = range$$1.from(), to = range$$1.to(); + var start = Math.max(end, from.line); + end = Math.min(this$1.lastLine(), to.line - (to.ch ? 0 : 1)) + 1; + for (var j = start; j < end; ++j) + { indentLine(this$1, j, how); } + var newRanges = this$1.doc.sel.ranges; + if (from.ch == 0 && ranges.length == newRanges.length && newRanges[i].from().ch > 0) + { replaceOneSelection(this$1.doc, i, new Range(from, newRanges[i].to()), sel_dontScroll); } + } else if (range$$1.head.line > end) { + indentLine(this$1, range$$1.head.line, how, true); + end = range$$1.head.line; + if (i == this$1.doc.sel.primIndex) { ensureCursorVisible(this$1); } + } + } + }), -// Pop all selection events off the end of a history array. Stop at -// a change event. -function clearSelectionEvents(array) { - while (array.length) { - var last = lst(array); - if (last.ranges) { array.pop(); } - else { break } - } -} + // Fetch the parser token for a given character. Useful for hacks + // that want to inspect the mode state (say, for completion). + getTokenAt: function(pos, precise) { + return takeToken(this, pos, precise) + }, -// Find the top change event in the history. Pop off selection -// events that are in the way. -function lastChangeEvent(hist, force) { - if (force) { - clearSelectionEvents(hist.done); - return lst(hist.done) - } else if (hist.done.length && !lst(hist.done).ranges) { - return lst(hist.done) - } else if (hist.done.length > 1 && !hist.done[hist.done.length - 2].ranges) { - hist.done.pop(); - return lst(hist.done) - } -} + getLineTokens: function(line, precise) { + return takeToken(this, Pos(line), precise, true) + }, -// Register a change in the history. Merges changes that are within -// a single operation, or are close together with an origin that -// allows merging (starting with "+") into a single event. -function addChangeToHistory(doc, change, selAfter, opId) { - var hist = doc.history; - hist.undone.length = 0; - var time = +new Date, cur; - var last; - - if ((hist.lastOp == opId || - hist.lastOrigin == change.origin && change.origin && - ((change.origin.charAt(0) == "+" && doc.cm && hist.lastModTime > time - doc.cm.options.historyEventDelay) || - change.origin.charAt(0) == "*")) && - (cur = lastChangeEvent(hist, hist.lastOp == opId))) { - // Merge this change into the last event - last = lst(cur.changes); - if (cmp(change.from, change.to) == 0 && cmp(change.from, last.to) == 0) { - // Optimized case for simple insertion -- don't want to add - // new changesets for every character typed - last.to = changeEnd(change); - } else { - // Add new sub-event - cur.changes.push(historyChangeFromChange(doc, change)); - } - } else { - // Can not be merged, start a new event. - var before = lst(hist.done); - if (!before || !before.ranges) - { pushSelectionToHistory(doc.sel, hist.done); } - cur = {changes: [historyChangeFromChange(doc, change)], - generation: hist.generation}; - hist.done.push(cur); - while (hist.done.length > hist.undoDepth) { - hist.done.shift(); - if (!hist.done[0].ranges) { hist.done.shift(); } - } - } - hist.done.push(selAfter); - hist.generation = ++hist.maxGeneration; - hist.lastModTime = hist.lastSelTime = time; - hist.lastOp = hist.lastSelOp = opId; - hist.lastOrigin = hist.lastSelOrigin = change.origin; - - if (!last) { signal(doc, "historyAdded"); } -} + getTokenTypeAt: function(pos) { + pos = clipPos(this.doc, pos); + var styles = getLineStyles(this, getLine(this.doc, pos.line)); + var before = 0, after = (styles.length - 1) / 2, ch = pos.ch; + var type; + if (ch == 0) { type = styles[2]; } + else { for (;;) { + var mid = (before + after) >> 1; + if ((mid ? styles[mid * 2 - 1] : 0) >= ch) { after = mid; } + else if (styles[mid * 2 + 1] < ch) { before = mid + 1; } + else { type = styles[mid * 2 + 2]; break } + } } + var cut = type ? type.indexOf("overlay ") : -1; + return cut < 0 ? type : cut == 0 ? null : type.slice(0, cut - 1) + }, -function selectionEventCanBeMerged(doc, origin, prev, sel) { - var ch = origin.charAt(0); - return ch == "*" || - ch == "+" && - prev.ranges.length == sel.ranges.length && - prev.somethingSelected() == sel.somethingSelected() && - new Date - doc.history.lastSelTime <= (doc.cm ? doc.cm.options.historyEventDelay : 500) -} + getModeAt: function(pos) { + var mode = this.doc.mode; + if (!mode.innerMode) { return mode } + return CodeMirror.innerMode(mode, this.getTokenAt(pos).state).mode + }, -// Called whenever the selection changes, sets the new selection as -// the pending selection in the history, and pushes the old pending -// selection into the 'done' array when it was significantly -// different (in number of selected ranges, emptiness, or time). -function addSelectionToHistory(doc, sel, opId, options) { - var hist = doc.history, origin = options && options.origin; - - // A new event is started when the previous origin does not match - // the current, or the origins don't allow matching. Origins - // starting with * are always merged, those starting with + are - // merged when similar and close together in time. - if (opId == hist.lastSelOp || - (origin && hist.lastSelOrigin == origin && - (hist.lastModTime == hist.lastSelTime && hist.lastOrigin == origin || - selectionEventCanBeMerged(doc, origin, lst(hist.done), sel)))) - { hist.done[hist.done.length - 1] = sel; } - else - { pushSelectionToHistory(sel, hist.done); } - - hist.lastSelTime = +new Date; - hist.lastSelOrigin = origin; - hist.lastSelOp = opId; - if (options && options.clearRedo !== false) - { clearSelectionEvents(hist.undone); } -} + getHelper: function(pos, type) { + return this.getHelpers(pos, type)[0] + }, -function pushSelectionToHistory(sel, dest) { - var top = lst(dest); - if (!(top && top.ranges && top.equals(sel))) - { dest.push(sel); } -} + getHelpers: function(pos, type) { + var this$1 = this; + + var found = []; + if (!helpers.hasOwnProperty(type)) { return found } + var help = helpers[type], mode = this.getModeAt(pos); + if (typeof mode[type] == "string") { + if (help[mode[type]]) { found.push(help[mode[type]]); } + } else if (mode[type]) { + for (var i = 0; i < mode[type].length; i++) { + var val = help[mode[type][i]]; + if (val) { found.push(val); } + } + } else if (mode.helperType && help[mode.helperType]) { + found.push(help[mode.helperType]); + } else if (help[mode.name]) { + found.push(help[mode.name]); + } + for (var i$1 = 0; i$1 < help._global.length; i$1++) { + var cur = help._global[i$1]; + if (cur.pred(mode, this$1) && indexOf(found, cur.val) == -1) + { found.push(cur.val); } + } + return found + }, -// Used to store marked span information in the history. -function attachLocalSpans(doc, change, from, to) { - var existing = change["spans_" + doc.id], n = 0; - doc.iter(Math.max(doc.first, from), Math.min(doc.first + doc.size, to), function (line) { - if (line.markedSpans) - { (existing || (existing = change["spans_" + doc.id] = {}))[n] = line.markedSpans; } - ++n; - }); -} + getStateAfter: function(line, precise) { + var doc = this.doc; + line = clipLine(doc, line == null ? doc.first + doc.size - 1: line); + return getContextBefore(this, line + 1, precise).state + }, -// When un/re-doing restores text containing marked spans, those -// that have been explicitly cleared should not be restored. -function removeClearedSpans(spans) { - if (!spans) { return null } - var out; - for (var i = 0; i < spans.length; ++i) { - if (spans[i].marker.explicitlyCleared) { if (!out) { out = spans.slice(0, i); } } - else if (out) { out.push(spans[i]); } - } - return !out ? spans : out.length ? out : null -} + cursorCoords: function(start, mode) { + var pos, range$$1 = this.doc.sel.primary(); + if (start == null) { pos = range$$1.head; } + else if (typeof start == "object") { pos = clipPos(this.doc, start); } + else { pos = start ? range$$1.from() : range$$1.to(); } + return cursorCoords(this, pos, mode || "page") + }, -// Retrieve and filter the old marked spans stored in a change event. -function getOldSpans(doc, change) { - var found = change["spans_" + doc.id]; - if (!found) { return null } - var nw = []; - for (var i = 0; i < change.text.length; ++i) - { nw.push(removeClearedSpans(found[i])); } - return nw -} + charCoords: function(pos, mode) { + return charCoords(this, clipPos(this.doc, pos), mode || "page") + }, -// Used for un/re-doing changes from the history. Combines the -// result of computing the existing spans with the set of spans that -// existed in the history (so that deleting around a span and then -// undoing brings back the span). -function mergeOldSpans(doc, change) { - var old = getOldSpans(doc, change); - var stretched = stretchSpansOverChange(doc, change); - if (!old) { return stretched } - if (!stretched) { return old } - - for (var i = 0; i < old.length; ++i) { - var oldCur = old[i], stretchCur = stretched[i]; - if (oldCur && stretchCur) { - spans: for (var j = 0; j < stretchCur.length; ++j) { - var span = stretchCur[j]; - for (var k = 0; k < oldCur.length; ++k) - { if (oldCur[k].marker == span.marker) { continue spans } } - oldCur.push(span); - } - } else if (stretchCur) { - old[i] = stretchCur; - } - } - return old -} + coordsChar: function(coords, mode) { + coords = fromCoordSystem(this, coords, mode || "page"); + return coordsChar(this, coords.left, coords.top) + }, -// Used both to provide a JSON-safe object in .getHistory, and, when -// detaching a document, to split the history in two -function copyHistoryArray(events, newGroup, instantiateSel) { - var copy = []; - for (var i = 0; i < events.length; ++i) { - var event = events[i]; - if (event.ranges) { - copy.push(instantiateSel ? Selection.prototype.deepCopy.call(event) : event); - continue - } - var changes = event.changes, newChanges = []; - copy.push({changes: newChanges}); - for (var j = 0; j < changes.length; ++j) { - var change = changes[j], m = (void 0); - newChanges.push({from: change.from, to: change.to, text: change.text}); - if (newGroup) { for (var prop in change) { if (m = prop.match(/^spans_(\d+)$/)) { - if (indexOf(newGroup, Number(m[1])) > -1) { - lst(newChanges)[prop] = change[prop]; - delete change[prop]; - } - } } } - } - } - return copy -} + lineAtHeight: function(height, mode) { + height = fromCoordSystem(this, {top: height, left: 0}, mode || "page").top; + return lineAtHeight(this.doc, height + this.display.viewOffset) + }, + heightAtLine: function(line, mode, includeWidgets) { + var end = false, lineObj; + if (typeof line == "number") { + var last = this.doc.first + this.doc.size - 1; + if (line < this.doc.first) { line = this.doc.first; } + else if (line > last) { line = last; end = true; } + lineObj = getLine(this.doc, line); + } else { + lineObj = line; + } + return intoCoordSystem(this, lineObj, {top: 0, left: 0}, mode || "page", includeWidgets || end).top + + (end ? this.doc.height - heightAtLine(lineObj) : 0) + }, -// The 'scroll' parameter given to many of these indicated whether -// the new cursor position should be scrolled into view after -// modifying the selection. - -// If shift is held or the extend flag is set, extends a range to -// include a given position (and optionally a second position). -// Otherwise, simply returns the range between the given positions. -// Used for cursor motion and such. -function extendRange(range, head, other, extend) { - if (extend) { - var anchor = range.anchor; - if (other) { - var posBefore = cmp(head, anchor) < 0; - if (posBefore != (cmp(other, anchor) < 0)) { - anchor = head; - head = other; - } else if (posBefore != (cmp(head, other) < 0)) { - head = other; - } - } - return new Range(anchor, head) - } else { - return new Range(other || head, head) - } -} + defaultTextHeight: function() { return textHeight(this.display) }, + defaultCharWidth: function() { return charWidth(this.display) }, + + getViewport: function() { return {from: this.display.viewFrom, to: this.display.viewTo}}, + + addWidget: function(pos, node, scroll, vert, horiz) { + var display = this.display; + pos = cursorCoords(this, clipPos(this.doc, pos)); + var top = pos.bottom, left = pos.left; + node.style.position = "absolute"; + node.setAttribute("cm-ignore-events", "true"); + this.display.input.setUneditable(node); + display.sizer.appendChild(node); + if (vert == "over") { + top = pos.top; + } else if (vert == "above" || vert == "near") { + var vspace = Math.max(display.wrapper.clientHeight, this.doc.height), + hspace = Math.max(display.sizer.clientWidth, display.lineSpace.clientWidth); + // Default to positioning above (if specified and possible); otherwise default to positioning below + if ((vert == 'above' || pos.bottom + node.offsetHeight > vspace) && pos.top > node.offsetHeight) + { top = pos.top - node.offsetHeight; } + else if (pos.bottom + node.offsetHeight <= vspace) + { top = pos.bottom; } + if (left + node.offsetWidth > hspace) + { left = hspace - node.offsetWidth; } + } + node.style.top = top + "px"; + node.style.left = node.style.right = ""; + if (horiz == "right") { + left = display.sizer.clientWidth - node.offsetWidth; + node.style.right = "0px"; + } else { + if (horiz == "left") { left = 0; } + else if (horiz == "middle") { left = (display.sizer.clientWidth - node.offsetWidth) / 2; } + node.style.left = left + "px"; + } + if (scroll) + { scrollIntoView(this, {left: left, top: top, right: left + node.offsetWidth, bottom: top + node.offsetHeight}); } + }, -// Extend the primary selection range, discard the rest. -function extendSelection(doc, head, other, options, extend) { - if (extend == null) { extend = doc.cm && (doc.cm.display.shift || doc.extend); } - setSelection(doc, new Selection([extendRange(doc.sel.primary(), head, other, extend)], 0), options); -} + triggerOnKeyDown: methodOp(onKeyDown), + triggerOnKeyPress: methodOp(onKeyPress), + triggerOnKeyUp: onKeyUp, + triggerOnMouseDown: methodOp(onMouseDown), -// Extend all selections (pos is an array of selections with length -// equal the number of selections) -function extendSelections(doc, heads, options) { - var out = []; - var extend = doc.cm && (doc.cm.display.shift || doc.extend); - for (var i = 0; i < doc.sel.ranges.length; i++) - { out[i] = extendRange(doc.sel.ranges[i], heads[i], null, extend); } - var newSel = normalizeSelection(out, doc.sel.primIndex); - setSelection(doc, newSel, options); -} + execCommand: function(cmd) { + if (commands.hasOwnProperty(cmd)) + { return commands[cmd].call(null, this) } + }, -// Updates a single range in the selection. -function replaceOneSelection(doc, i, range, options) { - var ranges = doc.sel.ranges.slice(0); - ranges[i] = range; - setSelection(doc, normalizeSelection(ranges, doc.sel.primIndex), options); -} + triggerElectric: methodOp(function(text) { triggerElectric(this, text); }), -// Reset the selection to a single range. -function setSimpleSelection(doc, anchor, head, options) { - setSelection(doc, simpleSelection(anchor, head), options); -} + findPosH: function(from, amount, unit, visually) { + var this$1 = this; -// Give beforeSelectionChange handlers a change to influence a -// selection update. -function filterSelectionChange(doc, sel, options) { - var obj = { - ranges: sel.ranges, - update: function(ranges) { - var this$1 = this; + var dir = 1; + if (amount < 0) { dir = -1; amount = -amount; } + var cur = clipPos(this.doc, from); + for (var i = 0; i < amount; ++i) { + cur = findPosH(this$1.doc, cur, dir, unit, visually); + if (cur.hitSide) { break } + } + return cur + }, - this.ranges = []; - for (var i = 0; i < ranges.length; i++) - { this$1.ranges[i] = new Range(clipPos(doc, ranges[i].anchor), - clipPos(doc, ranges[i].head)); } - }, - origin: options && options.origin - }; - signal(doc, "beforeSelectionChange", doc, obj); - if (doc.cm) { signal(doc.cm, "beforeSelectionChange", doc.cm, obj); } - if (obj.ranges != sel.ranges) { return normalizeSelection(obj.ranges, obj.ranges.length - 1) } - else { return sel } -} + moveH: methodOp(function(dir, unit) { + var this$1 = this; -function setSelectionReplaceHistory(doc, sel, options) { - var done = doc.history.done, last = lst(done); - if (last && last.ranges) { - done[done.length - 1] = sel; - setSelectionNoUndo(doc, sel, options); - } else { - setSelection(doc, sel, options); - } -} + this.extendSelectionsBy(function (range$$1) { + if (this$1.display.shift || this$1.doc.extend || range$$1.empty()) + { return findPosH(this$1.doc, range$$1.head, dir, unit, this$1.options.rtlMoveVisually) } + else + { return dir < 0 ? range$$1.from() : range$$1.to() } + }, sel_move); + }), + + deleteH: methodOp(function(dir, unit) { + var sel = this.doc.sel, doc = this.doc; + if (sel.somethingSelected()) + { doc.replaceSelection("", null, "+delete"); } + else + { deleteNearSelection(this, function (range$$1) { + var other = findPosH(doc, range$$1.head, dir, unit, false); + return dir < 0 ? {from: other, to: range$$1.head} : {from: range$$1.head, to: other} + }); } + }), + + findPosV: function(from, amount, unit, goalColumn) { + var this$1 = this; + + var dir = 1, x = goalColumn; + if (amount < 0) { dir = -1; amount = -amount; } + var cur = clipPos(this.doc, from); + for (var i = 0; i < amount; ++i) { + var coords = cursorCoords(this$1, cur, "div"); + if (x == null) { x = coords.left; } + else { coords.left = x; } + cur = findPosV(this$1, coords, dir, unit); + if (cur.hitSide) { break } + } + return cur + }, -// Set a new selection. -function setSelection(doc, sel, options) { - setSelectionNoUndo(doc, sel, options); - addSelectionToHistory(doc, doc.sel, doc.cm ? doc.cm.curOp.id : NaN, options); -} + moveV: methodOp(function(dir, unit) { + var this$1 = this; + + var doc = this.doc, goals = []; + var collapse = !this.display.shift && !doc.extend && doc.sel.somethingSelected(); + doc.extendSelectionsBy(function (range$$1) { + if (collapse) + { return dir < 0 ? range$$1.from() : range$$1.to() } + var headPos = cursorCoords(this$1, range$$1.head, "div"); + if (range$$1.goalColumn != null) { headPos.left = range$$1.goalColumn; } + goals.push(headPos.left); + var pos = findPosV(this$1, headPos, dir, unit); + if (unit == "page" && range$$1 == doc.sel.primary()) + { addToScrollTop(this$1, charCoords(this$1, pos, "div").top - headPos.top); } + return pos + }, sel_move); + if (goals.length) { for (var i = 0; i < doc.sel.ranges.length; i++) + { doc.sel.ranges[i].goalColumn = goals[i]; } } + }), + + // Find the word at the given position (as returned by coordsChar). + findWordAt: function(pos) { + var doc = this.doc, line = getLine(doc, pos.line).text; + var start = pos.ch, end = pos.ch; + if (line) { + var helper = this.getHelper(pos, "wordChars"); + if ((pos.sticky == "before" || end == line.length) && start) { --start; } else { ++end; } + var startChar = line.charAt(start); + var check = isWordChar(startChar, helper) + ? function (ch) { return isWordChar(ch, helper); } + : /\s/.test(startChar) ? function (ch) { return /\s/.test(ch); } + : function (ch) { return (!/\s/.test(ch) && !isWordChar(ch)); }; + while (start > 0 && check(line.charAt(start - 1))) { --start; } + while (end < line.length && check(line.charAt(end))) { ++end; } + } + return new Range(Pos(pos.line, start), Pos(pos.line, end)) + }, -function setSelectionNoUndo(doc, sel, options) { - if (hasHandler(doc, "beforeSelectionChange") || doc.cm && hasHandler(doc.cm, "beforeSelectionChange")) - { sel = filterSelectionChange(doc, sel, options); } + toggleOverwrite: function(value) { + if (value != null && value == this.state.overwrite) { return } + if (this.state.overwrite = !this.state.overwrite) + { addClass(this.display.cursorDiv, "CodeMirror-overwrite"); } + else + { rmClass(this.display.cursorDiv, "CodeMirror-overwrite"); } - var bias = options && options.bias || - (cmp(sel.primary().head, doc.sel.primary().head) < 0 ? -1 : 1); - setSelectionInner(doc, skipAtomicInSelection(doc, sel, bias, true)); + signal(this, "overwriteToggle", this, this.state.overwrite); + }, + hasFocus: function() { return this.display.input.getField() == activeElt() }, + isReadOnly: function() { return !!(this.options.readOnly || this.doc.cantEdit) }, + + scrollTo: methodOp(function (x, y) { scrollToCoords(this, x, y); }), + getScrollInfo: function() { + var scroller = this.display.scroller; + return {left: scroller.scrollLeft, top: scroller.scrollTop, + height: scroller.scrollHeight - scrollGap(this) - this.display.barHeight, + width: scroller.scrollWidth - scrollGap(this) - this.display.barWidth, + clientHeight: displayHeight(this), clientWidth: displayWidth(this)} + }, - if (!(options && options.scroll === false) && doc.cm) - { ensureCursorVisible(doc.cm); } -} + scrollIntoView: methodOp(function(range$$1, margin) { + if (range$$1 == null) { + range$$1 = {from: this.doc.sel.primary().head, to: null}; + if (margin == null) { margin = this.options.cursorScrollMargin; } + } else if (typeof range$$1 == "number") { + range$$1 = {from: Pos(range$$1, 0), to: null}; + } else if (range$$1.from == null) { + range$$1 = {from: range$$1, to: null}; + } + if (!range$$1.to) { range$$1.to = range$$1.from; } + range$$1.margin = margin || 0; -function setSelectionInner(doc, sel) { - if (sel.equals(doc.sel)) { return } + if (range$$1.from.line != null) { + scrollToRange(this, range$$1); + } else { + scrollToCoordsRange(this, range$$1.from, range$$1.to, range$$1.margin); + } + }), + + setSize: methodOp(function(width, height) { + var this$1 = this; + + var interpret = function (val) { return typeof val == "number" || /^\d+$/.test(String(val)) ? val + "px" : val; }; + if (width != null) { this.display.wrapper.style.width = interpret(width); } + if (height != null) { this.display.wrapper.style.height = interpret(height); } + if (this.options.lineWrapping) { clearLineMeasurementCache(this); } + var lineNo$$1 = this.display.viewFrom; + this.doc.iter(lineNo$$1, this.display.viewTo, function (line) { + if (line.widgets) { for (var i = 0; i < line.widgets.length; i++) + { if (line.widgets[i].noHScroll) { regLineChange(this$1, lineNo$$1, "widget"); break } } } + ++lineNo$$1; + }); + this.curOp.forceUpdate = true; + signal(this, "refresh", this); + }), + + operation: function(f){return runInOp(this, f)}, + startOperation: function(){return startOperation(this)}, + endOperation: function(){return endOperation(this)}, + + refresh: methodOp(function() { + var oldHeight = this.display.cachedTextHeight; + regChange(this); + this.curOp.forceUpdate = true; + clearCaches(this); + scrollToCoords(this, this.doc.scrollLeft, this.doc.scrollTop); + updateGutterSpace(this.display); + if (oldHeight == null || Math.abs(oldHeight - textHeight(this.display)) > .5) + { estimateLineHeights(this); } + signal(this, "refresh", this); + }), + + swapDoc: methodOp(function(doc) { + var old = this.doc; + old.cm = null; + // Cancel the current text selection if any (#5821) + if (this.state.selectingText) { this.state.selectingText(); } + attachDoc(this, doc); + clearCaches(this); + this.display.input.reset(); + scrollToCoords(this, doc.scrollLeft, doc.scrollTop); + this.curOp.forceScroll = true; + signalLater(this, "swapDoc", this, old); + return old + }), + + phrase: function(phraseText) { + var phrases = this.options.phrases; + return phrases && Object.prototype.hasOwnProperty.call(phrases, phraseText) ? phrases[phraseText] : phraseText + }, - doc.sel = sel; + getInputField: function(){return this.display.input.getField()}, + getWrapperElement: function(){return this.display.wrapper}, + getScrollerElement: function(){return this.display.scroller}, + getGutterElement: function(){return this.display.gutters} + }; + eventMixin(CodeMirror); - if (doc.cm) { - doc.cm.curOp.updateInput = doc.cm.curOp.selectionChanged = true; - signalCursorActivity(doc.cm); + CodeMirror.registerHelper = function(type, name, value) { + if (!helpers.hasOwnProperty(type)) { helpers[type] = CodeMirror[type] = {_global: []}; } + helpers[type][name] = value; + }; + CodeMirror.registerGlobalHelper = function(type, name, predicate, value) { + CodeMirror.registerHelper(type, name, value); + helpers[type]._global.push({pred: predicate, val: value}); + }; } - signalLater(doc, "cursorActivity", doc); -} -// Verify that the selection does not partially select any atomic -// marked ranges. -function reCheckSelection(doc) { - setSelectionInner(doc, skipAtomicInSelection(doc, doc.sel, null, false)); -} - -// Return a selection that does not partially select any atomic -// ranges. -function skipAtomicInSelection(doc, sel, bias, mayClear) { - var out; - for (var i = 0; i < sel.ranges.length; i++) { - var range = sel.ranges[i]; - var old = sel.ranges.length == doc.sel.ranges.length && doc.sel.ranges[i]; - var newAnchor = skipAtomic(doc, range.anchor, old && old.anchor, bias, mayClear); - var newHead = skipAtomic(doc, range.head, old && old.head, bias, mayClear); - if (out || newAnchor != range.anchor || newHead != range.head) { - if (!out) { out = sel.ranges.slice(0, i); } - out[i] = new Range(newAnchor, newHead); - } - } - return out ? normalizeSelection(out, sel.primIndex) : sel -} + // Used for horizontal relative motion. Dir is -1 or 1 (left or + // right), unit can be "char", "column" (like char, but doesn't + // cross line boundaries), "word" (across next word), or "group" (to + // the start of next group of word or non-word-non-whitespace + // chars). The visually param controls whether, in right-to-left + // text, direction 1 means to move towards the next index in the + // string, or towards the character to the right of the current + // position. The resulting position will have a hitSide=true + // property if it reached the end of the document. + function findPosH(doc, pos, dir, unit, visually) { + var oldPos = pos; + var origDir = dir; + var lineObj = getLine(doc, pos.line); + function findNextLine() { + var l = pos.line + dir; + if (l < doc.first || l >= doc.first + doc.size) { return false } + pos = new Pos(l, pos.ch, pos.sticky); + return lineObj = getLine(doc, l) + } + function moveOnce(boundToLine) { + var next; + if (visually) { + next = moveVisually(doc.cm, lineObj, pos, dir); + } else { + next = moveLogically(lineObj, pos, dir); + } + if (next == null) { + if (!boundToLine && findNextLine()) + { pos = endOfLine(visually, doc.cm, lineObj, pos.line, dir); } + else + { return false } + } else { + pos = next; + } + return true + } -function skipAtomicInner(doc, pos, oldPos, dir, mayClear) { - var line = getLine(doc, pos.line); - if (line.markedSpans) { for (var i = 0; i < line.markedSpans.length; ++i) { - var sp = line.markedSpans[i], m = sp.marker; - if ((sp.from == null || (m.inclusiveLeft ? sp.from <= pos.ch : sp.from < pos.ch)) && - (sp.to == null || (m.inclusiveRight ? sp.to >= pos.ch : sp.to > pos.ch))) { - if (mayClear) { - signal(m, "beforeCursorEnter"); - if (m.explicitlyCleared) { - if (!line.markedSpans) { break } - else {--i; continue} + if (unit == "char") { + moveOnce(); + } else if (unit == "column") { + moveOnce(true); + } else if (unit == "word" || unit == "group") { + var sawType = null, group = unit == "group"; + var helper = doc.cm && doc.cm.getHelper(pos, "wordChars"); + for (var first = true;; first = false) { + if (dir < 0 && !moveOnce(!first)) { break } + var cur = lineObj.text.charAt(pos.ch) || "\n"; + var type = isWordChar(cur, helper) ? "w" + : group && cur == "\n" ? "n" + : !group || /\s/.test(cur) ? null + : "p"; + if (group && !first && !type) { type = "s"; } + if (sawType && sawType != type) { + if (dir < 0) {dir = 1; moveOnce(); pos.sticky = "after";} + break } - } - if (!m.atomic) { continue } - if (oldPos) { - var near = m.find(dir < 0 ? 1 : -1), diff = (void 0); - if (dir < 0 ? m.inclusiveRight : m.inclusiveLeft) - { near = movePos(doc, near, -dir, near && near.line == pos.line ? line : null); } - if (near && near.line == pos.line && (diff = cmp(near, oldPos)) && (dir < 0 ? diff < 0 : diff > 0)) - { return skipAtomicInner(doc, near, pos, dir, mayClear) } + if (type) { sawType = type; } + if (dir > 0 && !moveOnce(!first)) { break } } - - var far = m.find(dir < 0 ? -1 : 1); - if (dir < 0 ? m.inclusiveLeft : m.inclusiveRight) - { far = movePos(doc, far, dir, far.line == pos.line ? line : null); } - return far ? skipAtomicInner(doc, far, pos, dir, mayClear) : null } - } } - return pos -} + var result = skipAtomic(doc, pos, oldPos, origDir, true); + if (equalCursorPos(oldPos, result)) { result.hitSide = true; } + return result + } -// Ensure a given position is not inside an atomic range. -function skipAtomic(doc, pos, oldPos, bias, mayClear) { - var dir = bias || 1; - var found = skipAtomicInner(doc, pos, oldPos, dir, mayClear) || - (!mayClear && skipAtomicInner(doc, pos, oldPos, dir, true)) || - skipAtomicInner(doc, pos, oldPos, -dir, mayClear) || - (!mayClear && skipAtomicInner(doc, pos, oldPos, -dir, true)); - if (!found) { - doc.cantEdit = true; - return Pos(doc.first, 0) - } - return found -} + // For relative vertical movement. Dir may be -1 or 1. Unit can be + // "page" or "line". The resulting position will have a hitSide=true + // property if it reached the end of the document. + function findPosV(cm, pos, dir, unit) { + var doc = cm.doc, x = pos.left, y; + if (unit == "page") { + var pageSize = Math.min(cm.display.wrapper.clientHeight, window.innerHeight || document.documentElement.clientHeight); + var moveAmount = Math.max(pageSize - .5 * textHeight(cm.display), 3); + y = (dir > 0 ? pos.bottom : pos.top) + dir * moveAmount; -function movePos(doc, pos, dir, line) { - if (dir < 0 && pos.ch == 0) { - if (pos.line > doc.first) { return clipPos(doc, Pos(pos.line - 1)) } - else { return null } - } else if (dir > 0 && pos.ch == (line || getLine(doc, pos.line)).text.length) { - if (pos.line < doc.first + doc.size - 1) { return Pos(pos.line + 1, 0) } - else { return null } - } else { - return new Pos(pos.line, pos.ch + dir) + } else if (unit == "line") { + y = dir > 0 ? pos.bottom + 3 : pos.top - 3; + } + var target; + for (;;) { + target = coordsChar(cm, x, y); + if (!target.outside) { break } + if (dir < 0 ? y <= 0 : y >= doc.height) { target.hitSide = true; break } + y += dir * 5; + } + return target } -} -function selectAll(cm) { - cm.setSelection(Pos(cm.firstLine(), 0), Pos(cm.lastLine()), sel_dontScroll); -} + // CONTENTEDITABLE INPUT STYLE -// UPDATING - -// Allow "beforeChange" event handlers to influence a change -function filterChange(doc, change, update) { - var obj = { - canceled: false, - from: change.from, - to: change.to, - text: change.text, - origin: change.origin, - cancel: function () { return obj.canceled = true; } - }; - if (update) { obj.update = function (from, to, text, origin) { - if (from) { obj.from = clipPos(doc, from); } - if (to) { obj.to = clipPos(doc, to); } - if (text) { obj.text = text; } - if (origin !== undefined) { obj.origin = origin; } - }; } - signal(doc, "beforeChange", doc, obj); - if (doc.cm) { signal(doc.cm, "beforeChange", doc.cm, obj); } + var ContentEditableInput = function(cm) { + this.cm = cm; + this.lastAnchorNode = this.lastAnchorOffset = this.lastFocusNode = this.lastFocusOffset = null; + this.polling = new Delayed(); + this.composing = null; + this.gracePeriod = false; + this.readDOMTimeout = null; + }; - if (obj.canceled) { return null } - return {from: obj.from, to: obj.to, text: obj.text, origin: obj.origin} -} + ContentEditableInput.prototype.init = function (display) { + var this$1 = this; -// Apply a change to a document, and add it to the document's -// history, and propagating it to all linked documents. -function makeChange(doc, change, ignoreReadOnly) { - if (doc.cm) { - if (!doc.cm.curOp) { return operation(doc.cm, makeChange)(doc, change, ignoreReadOnly) } - if (doc.cm.state.suppressEdits) { return } - } + var input = this, cm = input.cm; + var div = input.div = display.lineDiv; + disableBrowserMagic(div, cm.options.spellcheck, cm.options.autocorrect, cm.options.autocapitalize); - if (hasHandler(doc, "beforeChange") || doc.cm && hasHandler(doc.cm, "beforeChange")) { - change = filterChange(doc, change, true); - if (!change) { return } - } + on(div, "paste", function (e) { + if (signalDOMEvent(cm, e) || handlePaste(e, cm)) { return } + // IE doesn't fire input events, so we schedule a read for the pasted content in this way + if (ie_version <= 11) { setTimeout(operation(cm, function () { return this$1.updateFromDOM(); }), 20); } + }); - // Possibly split or suppress the update based on the presence - // of read-only spans in its range. - var split = sawReadOnlySpans && !ignoreReadOnly && removeReadOnlyRanges(doc, change.from, change.to); - if (split) { - for (var i = split.length - 1; i >= 0; --i) - { makeChangeInner(doc, {from: split[i].from, to: split[i].to, text: i ? [""] : change.text, origin: change.origin}); } - } else { - makeChangeInner(doc, change); - } -} - -function makeChangeInner(doc, change) { - if (change.text.length == 1 && change.text[0] == "" && cmp(change.from, change.to) == 0) { return } - var selAfter = computeSelAfterChange(doc, change); - addChangeToHistory(doc, change, selAfter, doc.cm ? doc.cm.curOp.id : NaN); + on(div, "compositionstart", function (e) { + this$1.composing = {data: e.data, done: false}; + }); + on(div, "compositionupdate", function (e) { + if (!this$1.composing) { this$1.composing = {data: e.data, done: false}; } + }); + on(div, "compositionend", function (e) { + if (this$1.composing) { + if (e.data != this$1.composing.data) { this$1.readFromDOMSoon(); } + this$1.composing.done = true; + } + }); - makeChangeSingleDoc(doc, change, selAfter, stretchSpansOverChange(doc, change)); - var rebased = []; + on(div, "touchstart", function () { return input.forceCompositionEnd(); }); - linkedDocs(doc, function (doc, sharedHist) { - if (!sharedHist && indexOf(rebased, doc.history) == -1) { - rebaseHist(doc.history, change); - rebased.push(doc.history); - } - makeChangeSingleDoc(doc, change, null, stretchSpansOverChange(doc, change)); - }); -} + on(div, "input", function () { + if (!this$1.composing) { this$1.readFromDOMSoon(); } + }); -// Revert a change stored in a document's history. -function makeChangeFromHistory(doc, type, allowSelectionOnly) { - if (doc.cm && doc.cm.state.suppressEdits && !allowSelectionOnly) { return } - - var hist = doc.history, event, selAfter = doc.sel; - var source = type == "undo" ? hist.done : hist.undone, dest = type == "undo" ? hist.undone : hist.done; - - // Verify that there is a useable event (so that ctrl-z won't - // needlessly clear selection events) - var i = 0; - for (; i < source.length; i++) { - event = source[i]; - if (allowSelectionOnly ? event.ranges && !event.equals(doc.sel) : !event.ranges) - { break } - } - if (i == source.length) { return } - hist.lastOrigin = hist.lastSelOrigin = null; - - for (;;) { - event = source.pop(); - if (event.ranges) { - pushSelectionToHistory(event, dest); - if (allowSelectionOnly && !event.equals(doc.sel)) { - setSelection(doc, event, {clearRedo: false}); + function onCopyCut(e) { + if (signalDOMEvent(cm, e)) { return } + if (cm.somethingSelected()) { + setLastCopied({lineWise: false, text: cm.getSelections()}); + if (e.type == "cut") { cm.replaceSelection("", null, "cut"); } + } else if (!cm.options.lineWiseCopyCut) { return + } else { + var ranges = copyableRanges(cm); + setLastCopied({lineWise: true, text: ranges.text}); + if (e.type == "cut") { + cm.operation(function () { + cm.setSelections(ranges.ranges, 0, sel_dontScroll); + cm.replaceSelection("", null, "cut"); + }); + } + } + if (e.clipboardData) { + e.clipboardData.clearData(); + var content = lastCopied.text.join("\n"); + // iOS exposes the clipboard API, but seems to discard content inserted into it + e.clipboardData.setData("Text", content); + if (e.clipboardData.getData("Text") == content) { + e.preventDefault(); + return + } } - selAfter = event; + // Old-fashioned briefly-focus-a-textarea hack + var kludge = hiddenTextarea(), te = kludge.firstChild; + cm.display.lineSpace.insertBefore(kludge, cm.display.lineSpace.firstChild); + te.value = lastCopied.text.join("\n"); + var hadFocus = document.activeElement; + selectInput(te); + setTimeout(function () { + cm.display.lineSpace.removeChild(kludge); + hadFocus.focus(); + if (hadFocus == div) { input.showPrimarySelection(); } + }, 50); } - else { break } - } + on(div, "copy", onCopyCut); + on(div, "cut", onCopyCut); + }; + + ContentEditableInput.prototype.prepareSelection = function () { + var result = prepareSelection(this.cm, false); + result.focus = this.cm.state.focused; + return result + }; + + ContentEditableInput.prototype.showSelection = function (info, takeFocus) { + if (!info || !this.cm.display.view.length) { return } + if (info.focus || takeFocus) { this.showPrimarySelection(); } + this.showMultipleSelections(info); + }; - // Build up a reverse change object to add to the opposite history - // stack (redo when undoing, and vice versa). - var antiChanges = []; - pushSelectionToHistory(selAfter, dest); - dest.push({changes: antiChanges, generation: hist.generation}); - hist.generation = event.generation || ++hist.maxGeneration; + ContentEditableInput.prototype.getSelection = function () { + return this.cm.display.wrapper.ownerDocument.getSelection() + }; - var filter = hasHandler(doc, "beforeChange") || doc.cm && hasHandler(doc.cm, "beforeChange"); + ContentEditableInput.prototype.showPrimarySelection = function () { + var sel = this.getSelection(), cm = this.cm, prim = cm.doc.sel.primary(); + var from = prim.from(), to = prim.to(); - var loop = function ( i ) { - var change = event.changes[i]; - change.origin = type; - if (filter && !filterChange(doc, change, false)) { - source.length = 0; - return {} + if (cm.display.viewTo == cm.display.viewFrom || from.line >= cm.display.viewTo || to.line < cm.display.viewFrom) { + sel.removeAllRanges(); + return } - antiChanges.push(historyChangeFromChange(doc, change)); + var curAnchor = domToPos(cm, sel.anchorNode, sel.anchorOffset); + var curFocus = domToPos(cm, sel.focusNode, sel.focusOffset); + if (curAnchor && !curAnchor.bad && curFocus && !curFocus.bad && + cmp(minPos(curAnchor, curFocus), from) == 0 && + cmp(maxPos(curAnchor, curFocus), to) == 0) + { return } - var after = i ? computeSelAfterChange(doc, change) : lst(source); - makeChangeSingleDoc(doc, change, after, mergeOldSpans(doc, change)); - if (!i && doc.cm) { doc.cm.scrollIntoView({from: change.from, to: changeEnd(change)}); } - var rebased = []; + var view = cm.display.view; + var start = (from.line >= cm.display.viewFrom && posToDOM(cm, from)) || + {node: view[0].measure.map[2], offset: 0}; + var end = to.line < cm.display.viewTo && posToDOM(cm, to); + if (!end) { + var measure = view[view.length - 1].measure; + var map$$1 = measure.maps ? measure.maps[measure.maps.length - 1] : measure.map; + end = {node: map$$1[map$$1.length - 1], offset: map$$1[map$$1.length - 2] - map$$1[map$$1.length - 3]}; + } - // Propagate to the linked documents - linkedDocs(doc, function (doc, sharedHist) { - if (!sharedHist && indexOf(rebased, doc.history) == -1) { - rebaseHist(doc.history, change); - rebased.push(doc.history); + if (!start || !end) { + sel.removeAllRanges(); + return + } + + var old = sel.rangeCount && sel.getRangeAt(0), rng; + try { rng = range(start.node, start.offset, end.offset, end.node); } + catch(e) {} // Our model of the DOM might be outdated, in which case the range we try to set can be impossible + if (rng) { + if (!gecko && cm.state.focused) { + sel.collapse(start.node, start.offset); + if (!rng.collapsed) { + sel.removeAllRanges(); + sel.addRange(rng); + } + } else { + sel.removeAllRanges(); + sel.addRange(rng); } - makeChangeSingleDoc(doc, change, null, mergeOldSpans(doc, change)); - }); + if (old && sel.anchorNode == null) { sel.addRange(old); } + else if (gecko) { this.startGracePeriod(); } + } + this.rememberSelection(); }; - for (var i$1 = event.changes.length - 1; i$1 >= 0; --i$1) { - var returned = loop( i$1 ); + ContentEditableInput.prototype.startGracePeriod = function () { + var this$1 = this; - if ( returned ) return returned.v; - } -} + clearTimeout(this.gracePeriod); + this.gracePeriod = setTimeout(function () { + this$1.gracePeriod = false; + if (this$1.selectionChanged()) + { this$1.cm.operation(function () { return this$1.cm.curOp.selectionChanged = true; }); } + }, 20); + }; -// Sub-views need their line numbers shifted when text is added -// above or below them in the parent document. -function shiftDoc(doc, distance) { - if (distance == 0) { return } - doc.first += distance; - doc.sel = new Selection(map(doc.sel.ranges, function (range) { return new Range( - Pos(range.anchor.line + distance, range.anchor.ch), - Pos(range.head.line + distance, range.head.ch) - ); }), doc.sel.primIndex); - if (doc.cm) { - regChange(doc.cm, doc.first, doc.first - distance, distance); - for (var d = doc.cm.display, l = d.viewFrom; l < d.viewTo; l++) - { regLineChange(doc.cm, l, "gutter"); } - } -} + ContentEditableInput.prototype.showMultipleSelections = function (info) { + removeChildrenAndAdd(this.cm.display.cursorDiv, info.cursors); + removeChildrenAndAdd(this.cm.display.selectionDiv, info.selection); + }; -// More lower-level change function, handling only a single document -// (not linked ones). -function makeChangeSingleDoc(doc, change, selAfter, spans) { - if (doc.cm && !doc.cm.curOp) - { return operation(doc.cm, makeChangeSingleDoc)(doc, change, selAfter, spans) } + ContentEditableInput.prototype.rememberSelection = function () { + var sel = this.getSelection(); + this.lastAnchorNode = sel.anchorNode; this.lastAnchorOffset = sel.anchorOffset; + this.lastFocusNode = sel.focusNode; this.lastFocusOffset = sel.focusOffset; + }; - if (change.to.line < doc.first) { - shiftDoc(doc, change.text.length - 1 - (change.to.line - change.from.line)); - return - } - if (change.from.line > doc.lastLine()) { return } + ContentEditableInput.prototype.selectionInEditor = function () { + var sel = this.getSelection(); + if (!sel.rangeCount) { return false } + var node = sel.getRangeAt(0).commonAncestorContainer; + return contains(this.div, node) + }; - // Clip the change to the size of this doc - if (change.from.line < doc.first) { - var shift = change.text.length - 1 - (doc.first - change.from.line); - shiftDoc(doc, shift); - change = {from: Pos(doc.first, 0), to: Pos(change.to.line + shift, change.to.ch), - text: [lst(change.text)], origin: change.origin}; - } - var last = doc.lastLine(); - if (change.to.line > last) { - change = {from: change.from, to: Pos(last, getLine(doc, last).text.length), - text: [change.text[0]], origin: change.origin}; - } + ContentEditableInput.prototype.focus = function () { + if (this.cm.options.readOnly != "nocursor") { + if (!this.selectionInEditor()) + { this.showSelection(this.prepareSelection(), true); } + this.div.focus(); + } + }; + ContentEditableInput.prototype.blur = function () { this.div.blur(); }; + ContentEditableInput.prototype.getField = function () { return this.div }; - change.removed = getBetween(doc, change.from, change.to); + ContentEditableInput.prototype.supportsTouch = function () { return true }; - if (!selAfter) { selAfter = computeSelAfterChange(doc, change); } - if (doc.cm) { makeChangeSingleDocInEditor(doc.cm, change, spans); } - else { updateDoc(doc, change, spans); } - setSelectionNoUndo(doc, selAfter, sel_dontScroll); -} + ContentEditableInput.prototype.receivedFocus = function () { + var input = this; + if (this.selectionInEditor()) + { this.pollSelection(); } + else + { runInOp(this.cm, function () { return input.cm.curOp.selectionChanged = true; }); } -// Handle the interaction of a change to a document with the editor -// that this document is part of. -function makeChangeSingleDocInEditor(cm, change, spans) { - var doc = cm.doc, display = cm.display, from = change.from, to = change.to; - - var recomputeMaxLength = false, checkWidthStart = from.line; - if (!cm.options.lineWrapping) { - checkWidthStart = lineNo(visualLine(getLine(doc, from.line))); - doc.iter(checkWidthStart, to.line + 1, function (line) { - if (line == display.maxLine) { - recomputeMaxLength = true; - return true + function poll() { + if (input.cm.state.focused) { + input.pollSelection(); + input.polling.set(input.cm.options.pollInterval, poll); } - }); - } - - if (doc.sel.contains(change.from, change.to) > -1) - { signalCursorActivity(cm); } - - updateDoc(doc, change, spans, estimateHeight(cm)); + } + this.polling.set(this.cm.options.pollInterval, poll); + }; - if (!cm.options.lineWrapping) { - doc.iter(checkWidthStart, from.line + change.text.length, function (line) { - var len = lineLength(line); - if (len > display.maxLineLength) { - display.maxLine = line; - display.maxLineLength = len; - display.maxLineChanged = true; - recomputeMaxLength = false; - } - }); - if (recomputeMaxLength) { cm.curOp.updateMaxLine = true; } - } + ContentEditableInput.prototype.selectionChanged = function () { + var sel = this.getSelection(); + return sel.anchorNode != this.lastAnchorNode || sel.anchorOffset != this.lastAnchorOffset || + sel.focusNode != this.lastFocusNode || sel.focusOffset != this.lastFocusOffset + }; - retreatFrontier(doc, from.line); - startWorker(cm, 400); + ContentEditableInput.prototype.pollSelection = function () { + if (this.readDOMTimeout != null || this.gracePeriod || !this.selectionChanged()) { return } + var sel = this.getSelection(), cm = this.cm; + // On Android Chrome (version 56, at least), backspacing into an + // uneditable block element will put the cursor in that element, + // and then, because it's not editable, hide the virtual keyboard. + // Because Android doesn't allow us to actually detect backspace + // presses in a sane way, this code checks for when that happens + // and simulates a backspace press in this case. + if (android && chrome && this.cm.display.gutterSpecs.length && isInGutter(sel.anchorNode)) { + this.cm.triggerOnKeyDown({type: "keydown", keyCode: 8, preventDefault: Math.abs}); + this.blur(); + this.focus(); + return + } + if (this.composing) { return } + this.rememberSelection(); + var anchor = domToPos(cm, sel.anchorNode, sel.anchorOffset); + var head = domToPos(cm, sel.focusNode, sel.focusOffset); + if (anchor && head) { runInOp(cm, function () { + setSelection(cm.doc, simpleSelection(anchor, head), sel_dontScroll); + if (anchor.bad || head.bad) { cm.curOp.selectionChanged = true; } + }); } + }; + + ContentEditableInput.prototype.pollContent = function () { + if (this.readDOMTimeout != null) { + clearTimeout(this.readDOMTimeout); + this.readDOMTimeout = null; + } + + var cm = this.cm, display = cm.display, sel = cm.doc.sel.primary(); + var from = sel.from(), to = sel.to(); + if (from.ch == 0 && from.line > cm.firstLine()) + { from = Pos(from.line - 1, getLine(cm.doc, from.line - 1).length); } + if (to.ch == getLine(cm.doc, to.line).text.length && to.line < cm.lastLine()) + { to = Pos(to.line + 1, 0); } + if (from.line < display.viewFrom || to.line > display.viewTo - 1) { return false } + + var fromIndex, fromLine, fromNode; + if (from.line == display.viewFrom || (fromIndex = findViewIndex(cm, from.line)) == 0) { + fromLine = lineNo(display.view[0].line); + fromNode = display.view[0].node; + } else { + fromLine = lineNo(display.view[fromIndex].line); + fromNode = display.view[fromIndex - 1].node.nextSibling; + } + var toIndex = findViewIndex(cm, to.line); + var toLine, toNode; + if (toIndex == display.view.length - 1) { + toLine = display.viewTo - 1; + toNode = display.lineDiv.lastChild; + } else { + toLine = lineNo(display.view[toIndex + 1].line) - 1; + toNode = display.view[toIndex + 1].node.previousSibling; + } + + if (!fromNode) { return false } + var newText = cm.doc.splitLines(domTextBetween(cm, fromNode, toNode, fromLine, toLine)); + var oldText = getBetween(cm.doc, Pos(fromLine, 0), Pos(toLine, getLine(cm.doc, toLine).text.length)); + while (newText.length > 1 && oldText.length > 1) { + if (lst(newText) == lst(oldText)) { newText.pop(); oldText.pop(); toLine--; } + else if (newText[0] == oldText[0]) { newText.shift(); oldText.shift(); fromLine++; } + else { break } + } + + var cutFront = 0, cutEnd = 0; + var newTop = newText[0], oldTop = oldText[0], maxCutFront = Math.min(newTop.length, oldTop.length); + while (cutFront < maxCutFront && newTop.charCodeAt(cutFront) == oldTop.charCodeAt(cutFront)) + { ++cutFront; } + var newBot = lst(newText), oldBot = lst(oldText); + var maxCutEnd = Math.min(newBot.length - (newText.length == 1 ? cutFront : 0), + oldBot.length - (oldText.length == 1 ? cutFront : 0)); + while (cutEnd < maxCutEnd && + newBot.charCodeAt(newBot.length - cutEnd - 1) == oldBot.charCodeAt(oldBot.length - cutEnd - 1)) + { ++cutEnd; } + // Try to move start of change to start of selection if ambiguous + if (newText.length == 1 && oldText.length == 1 && fromLine == from.line) { + while (cutFront && cutFront > from.ch && + newBot.charCodeAt(newBot.length - cutEnd - 1) == oldBot.charCodeAt(oldBot.length - cutEnd - 1)) { + cutFront--; + cutEnd++; + } + } + + newText[newText.length - 1] = newBot.slice(0, newBot.length - cutEnd).replace(/^\u200b+/, ""); + newText[0] = newText[0].slice(cutFront).replace(/\u200b+$/, ""); + + var chFrom = Pos(fromLine, cutFront); + var chTo = Pos(toLine, oldText.length ? lst(oldText).length - cutEnd : 0); + if (newText.length > 1 || newText[0] || cmp(chFrom, chTo)) { + replaceRange(cm.doc, newText, chFrom, chTo, "+input"); + return true + } + }; - var lendiff = change.text.length - (to.line - from.line) - 1; - // Remember that these lines changed, for updating the display - if (change.full) - { regChange(cm); } - else if (from.line == to.line && change.text.length == 1 && !isWholeLineUpdate(cm.doc, change)) - { regLineChange(cm, from.line, "text"); } - else - { regChange(cm, from.line, to.line + 1, lendiff); } + ContentEditableInput.prototype.ensurePolled = function () { + this.forceCompositionEnd(); + }; + ContentEditableInput.prototype.reset = function () { + this.forceCompositionEnd(); + }; + ContentEditableInput.prototype.forceCompositionEnd = function () { + if (!this.composing) { return } + clearTimeout(this.readDOMTimeout); + this.composing = null; + this.updateFromDOM(); + this.div.blur(); + this.div.focus(); + }; + ContentEditableInput.prototype.readFromDOMSoon = function () { + var this$1 = this; - var changesHandler = hasHandler(cm, "changes"), changeHandler = hasHandler(cm, "change"); - if (changeHandler || changesHandler) { - var obj = { - from: from, to: to, - text: change.text, - removed: change.removed, - origin: change.origin - }; - if (changeHandler) { signalLater(cm, "change", cm, obj); } - if (changesHandler) { (cm.curOp.changeObjs || (cm.curOp.changeObjs = [])).push(obj); } - } - cm.display.selForContextMenu = null; -} + if (this.readDOMTimeout != null) { return } + this.readDOMTimeout = setTimeout(function () { + this$1.readDOMTimeout = null; + if (this$1.composing) { + if (this$1.composing.done) { this$1.composing = null; } + else { return } + } + this$1.updateFromDOM(); + }, 80); + }; -function replaceRange(doc, code, from, to, origin) { - if (!to) { to = from; } - if (cmp(to, from) < 0) { var assign; - (assign = [to, from], from = assign[0], to = assign[1], assign); } - if (typeof code == "string") { code = doc.splitLines(code); } - makeChange(doc, {from: from, to: to, text: code, origin: origin}); -} + ContentEditableInput.prototype.updateFromDOM = function () { + var this$1 = this; -// Rebasing/resetting history to deal with externally-sourced changes + if (this.cm.isReadOnly() || !this.pollContent()) + { runInOp(this.cm, function () { return regChange(this$1.cm); }); } + }; -function rebaseHistSelSingle(pos, from, to, diff) { - if (to < pos.line) { - pos.line += diff; - } else if (from < pos.line) { - pos.line = from; - pos.ch = 0; - } -} + ContentEditableInput.prototype.setUneditable = function (node) { + node.contentEditable = "false"; + }; -// Tries to rebase an array of history events given a change in the -// document. If the change touches the same lines as the event, the -// event, and everything 'behind' it, is discarded. If the change is -// before the event, the event's positions are updated. Uses a -// copy-on-write scheme for the positions, to avoid having to -// reallocate them all on every rebase, but also avoid problems with -// shared position objects being unsafely updated. -function rebaseHistArray(array, from, to, diff) { - for (var i = 0; i < array.length; ++i) { - var sub = array[i], ok = true; - if (sub.ranges) { - if (!sub.copied) { sub = array[i] = sub.deepCopy(); sub.copied = true; } - for (var j = 0; j < sub.ranges.length; j++) { - rebaseHistSelSingle(sub.ranges[j].anchor, from, to, diff); - rebaseHistSelSingle(sub.ranges[j].head, from, to, diff); - } - continue - } - for (var j$1 = 0; j$1 < sub.changes.length; ++j$1) { - var cur = sub.changes[j$1]; - if (to < cur.from.line) { - cur.from = Pos(cur.from.line + diff, cur.from.ch); - cur.to = Pos(cur.to.line + diff, cur.to.ch); - } else if (from <= cur.to.line) { - ok = false; - break - } - } - if (!ok) { - array.splice(0, i + 1); - i = 0; - } - } -} + ContentEditableInput.prototype.onKeyPress = function (e) { + if (e.charCode == 0 || this.composing) { return } + e.preventDefault(); + if (!this.cm.isReadOnly()) + { operation(this.cm, applyTextInput)(this.cm, String.fromCharCode(e.charCode == null ? e.keyCode : e.charCode), 0); } + }; -function rebaseHist(hist, change) { - var from = change.from.line, to = change.to.line, diff = change.text.length - (to - from) - 1; - rebaseHistArray(hist.done, from, to, diff); - rebaseHistArray(hist.undone, from, to, diff); -} + ContentEditableInput.prototype.readOnlyChanged = function (val) { + this.div.contentEditable = String(val != "nocursor"); + }; -// Utility for applying a change to a line by handle or number, -// returning the number and optionally registering the line as -// changed. -function changeLine(doc, handle, changeType, op) { - var no = handle, line = handle; - if (typeof handle == "number") { line = getLine(doc, clipLine(doc, handle)); } - else { no = lineNo(handle); } - if (no == null) { return null } - if (op(line, no) && doc.cm) { regLineChange(doc.cm, no, changeType); } - return line -} + ContentEditableInput.prototype.onContextMenu = function () {}; + ContentEditableInput.prototype.resetPosition = function () {}; -// The document is represented as a BTree consisting of leaves, with -// chunk of lines in them, and branches, with up to ten leaves or -// other branch nodes below them. The top node is always a branch -// node, and is the document object itself (meaning it has -// additional methods and properties). -// -// All nodes have parent links. The tree is used both to go from -// line numbers to line objects, and to go from objects to numbers. -// It also indexes by height, and is used to convert between height -// and line object, and to find the total height of the document. -// -// See also http://marijnhaverbeke.nl/blog/codemirror-line-tree.html + ContentEditableInput.prototype.needsContentAttribute = true; -function LeafChunk(lines) { - var this$1 = this; + function posToDOM(cm, pos) { + var view = findViewForLine(cm, pos.line); + if (!view || view.hidden) { return null } + var line = getLine(cm.doc, pos.line); + var info = mapFromLineView(view, line, pos.line); - this.lines = lines; - this.parent = null; - var height = 0; - for (var i = 0; i < lines.length; ++i) { - lines[i].parent = this$1; - height += lines[i].height; + var order = getOrder(line, cm.doc.direction), side = "left"; + if (order) { + var partPos = getBidiPartAt(order, pos.ch); + side = partPos % 2 ? "right" : "left"; + } + var result = nodeAndOffsetInLineMap(info.map, pos.ch, side); + result.offset = result.collapse == "right" ? result.end : result.start; + return result } - this.height = height; -} -LeafChunk.prototype = { - chunkSize: function chunkSize() { return this.lines.length }, + function isInGutter(node) { + for (var scan = node; scan; scan = scan.parentNode) + { if (/CodeMirror-gutter-wrapper/.test(scan.className)) { return true } } + return false + } - // Remove the n lines at offset 'at'. - removeInner: function removeInner(at, n) { - var this$1 = this; + function badPos(pos, bad) { if (bad) { pos.bad = true; } return pos } - for (var i = at, e = at + n; i < e; ++i) { - var line = this$1.lines[i]; - this$1.height -= line.height; - cleanUpLine(line); - signalLater(line, "delete"); + function domTextBetween(cm, from, to, fromLine, toLine) { + var text = "", closing = false, lineSep = cm.doc.lineSeparator(), extraLinebreak = false; + function recognizeMarker(id) { return function (marker) { return marker.id == id; } } + function close() { + if (closing) { + text += lineSep; + if (extraLinebreak) { text += lineSep; } + closing = extraLinebreak = false; + } } - this.lines.splice(at, n); - }, - - // Helper used to collapse a small branch into a single leaf. - collapse: function collapse(lines) { - lines.push.apply(lines, this.lines); - }, - - // Insert the given array of lines at offset 'at', count them as - // having the given height. - insertInner: function insertInner(at, lines, height) { - var this$1 = this; - - this.height += height; - this.lines = this.lines.slice(0, at).concat(lines).concat(this.lines.slice(at)); - for (var i = 0; i < lines.length; ++i) { lines[i].parent = this$1; } - }, + function addText(str) { + if (str) { + close(); + text += str; + } + } + function walk(node) { + if (node.nodeType == 1) { + var cmText = node.getAttribute("cm-text"); + if (cmText) { + addText(cmText); + return + } + var markerID = node.getAttribute("cm-marker"), range$$1; + if (markerID) { + var found = cm.findMarks(Pos(fromLine, 0), Pos(toLine + 1, 0), recognizeMarker(+markerID)); + if (found.length && (range$$1 = found[0].find(0))) + { addText(getBetween(cm.doc, range$$1.from, range$$1.to).join(lineSep)); } + return + } + if (node.getAttribute("contenteditable") == "false") { return } + var isBlock = /^(pre|div|p|li|table|br)$/i.test(node.nodeName); + if (!/^br$/i.test(node.nodeName) && node.textContent.length == 0) { return } - // Used to iterate over a part of the tree. - iterN: function iterN(at, n, op) { - var this$1 = this; + if (isBlock) { close(); } + for (var i = 0; i < node.childNodes.length; i++) + { walk(node.childNodes[i]); } - for (var e = at + n; at < e; ++at) - { if (op(this$1.lines[at])) { return true } } + if (/^(pre|p)$/i.test(node.nodeName)) { extraLinebreak = true; } + if (isBlock) { closing = true; } + } else if (node.nodeType == 3) { + addText(node.nodeValue.replace(/\u200b/g, "").replace(/\u00a0/g, " ")); + } + } + for (;;) { + walk(from); + if (from == to) { break } + from = from.nextSibling; + extraLinebreak = false; + } + return text } -}; -function BranchChunk(children) { - var this$1 = this; - - this.children = children; - var size = 0, height = 0; - for (var i = 0; i < children.length; ++i) { - var ch = children[i]; - size += ch.chunkSize(); height += ch.height; - ch.parent = this$1; + function domToPos(cm, node, offset) { + var lineNode; + if (node == cm.display.lineDiv) { + lineNode = cm.display.lineDiv.childNodes[offset]; + if (!lineNode) { return badPos(cm.clipPos(Pos(cm.display.viewTo - 1)), true) } + node = null; offset = 0; + } else { + for (lineNode = node;; lineNode = lineNode.parentNode) { + if (!lineNode || lineNode == cm.display.lineDiv) { return null } + if (lineNode.parentNode && lineNode.parentNode == cm.display.lineDiv) { break } + } + } + for (var i = 0; i < cm.display.view.length; i++) { + var lineView = cm.display.view[i]; + if (lineView.node == lineNode) + { return locateNodeInLineView(lineView, node, offset) } + } } - this.size = size; - this.height = height; - this.parent = null; -} - -BranchChunk.prototype = { - chunkSize: function chunkSize() { return this.size }, - - removeInner: function removeInner(at, n) { - var this$1 = this; - - this.size -= n; - for (var i = 0; i < this.children.length; ++i) { - var child = this$1.children[i], sz = child.chunkSize(); - if (at < sz) { - var rm = Math.min(n, sz - at), oldHeight = child.height; - child.removeInner(at, rm); - this$1.height -= oldHeight - child.height; - if (sz == rm) { this$1.children.splice(i--, 1); child.parent = null; } - if ((n -= rm) == 0) { break } - at = 0; - } else { at -= sz; } - } - // If the result is smaller than 25 lines, ensure that it is a - // single leaf node. - if (this.size - n < 25 && - (this.children.length > 1 || !(this.children[0] instanceof LeafChunk))) { - var lines = []; - this.collapse(lines); - this.children = [new LeafChunk(lines)]; - this.children[0].parent = this; - } - }, - - collapse: function collapse(lines) { - var this$1 = this; - for (var i = 0; i < this.children.length; ++i) { this$1.children[i].collapse(lines); } - }, + function locateNodeInLineView(lineView, node, offset) { + var wrapper = lineView.text.firstChild, bad = false; + if (!node || !contains(wrapper, node)) { return badPos(Pos(lineNo(lineView.line), 0), true) } + if (node == wrapper) { + bad = true; + node = wrapper.childNodes[offset]; + offset = 0; + if (!node) { + var line = lineView.rest ? lst(lineView.rest) : lineView.line; + return badPos(Pos(lineNo(line), line.text.length), bad) + } + } - insertInner: function insertInner(at, lines, height) { - var this$1 = this; + var textNode = node.nodeType == 3 ? node : null, topNode = node; + if (!textNode && node.childNodes.length == 1 && node.firstChild.nodeType == 3) { + textNode = node.firstChild; + if (offset) { offset = textNode.nodeValue.length; } + } + while (topNode.parentNode != wrapper) { topNode = topNode.parentNode; } + var measure = lineView.measure, maps = measure.maps; - this.size += lines.length; - this.height += height; - for (var i = 0; i < this.children.length; ++i) { - var child = this$1.children[i], sz = child.chunkSize(); - if (at <= sz) { - child.insertInner(at, lines, height); - if (child.lines && child.lines.length > 50) { - // To avoid memory thrashing when child.lines is huge (e.g. first view of a large file), it's never spliced. - // Instead, small slices are taken. They're taken in order because sequential memory accesses are fastest. - var remaining = child.lines.length % 25 + 25; - for (var pos = remaining; pos < child.lines.length;) { - var leaf = new LeafChunk(child.lines.slice(pos, pos += 25)); - child.height -= leaf.height; - this$1.children.splice(++i, 0, leaf); - leaf.parent = this$1; + function find(textNode, topNode, offset) { + for (var i = -1; i < (maps ? maps.length : 0); i++) { + var map$$1 = i < 0 ? measure.map : maps[i]; + for (var j = 0; j < map$$1.length; j += 3) { + var curNode = map$$1[j + 2]; + if (curNode == textNode || curNode == topNode) { + var line = lineNo(i < 0 ? lineView.line : lineView.rest[i]); + var ch = map$$1[j] + offset; + if (offset < 0 || curNode != textNode) { ch = map$$1[j + (offset ? 1 : 0)]; } + return Pos(line, ch) } - child.lines = child.lines.slice(0, remaining); - this$1.maybeSpill(); } - break } - at -= sz; } - }, + var found = find(textNode, topNode, offset); + if (found) { return badPos(found, bad) } - // When a node has grown, check whether it should be split. - maybeSpill: function maybeSpill() { - if (this.children.length <= 10) { return } - var me = this; - do { - var spilled = me.children.splice(me.children.length - 5, 5); - var sibling = new BranchChunk(spilled); - if (!me.parent) { // Become the parent node - var copy = new BranchChunk(me.children); - copy.parent = me; - me.children = [copy, sibling]; - me = copy; - } else { - me.size -= sibling.size; - me.height -= sibling.height; - var myIndex = indexOf(me.parent.children, me); - me.parent.children.splice(myIndex + 1, 0, sibling); - } - sibling.parent = me.parent; - } while (me.children.length > 10) - me.parent.maybeSpill(); - }, - - iterN: function iterN(at, n, op) { - var this$1 = this; - - for (var i = 0; i < this.children.length; ++i) { - var child = this$1.children[i], sz = child.chunkSize(); - if (at < sz) { - var used = Math.min(n, sz - at); - if (child.iterN(at, used, op)) { return true } - if ((n -= used) == 0) { break } - at = 0; - } else { at -= sz; } + // FIXME this is all really shaky. might handle the few cases it needs to handle, but likely to cause problems + for (var after = topNode.nextSibling, dist = textNode ? textNode.nodeValue.length - offset : 0; after; after = after.nextSibling) { + found = find(after, after.firstChild, 0); + if (found) + { return badPos(Pos(found.line, found.ch - dist), bad) } + else + { dist += after.textContent.length; } + } + for (var before = topNode.previousSibling, dist$1 = offset; before; before = before.previousSibling) { + found = find(before, before.firstChild, -1); + if (found) + { return badPos(Pos(found.line, found.ch + dist$1), bad) } + else + { dist$1 += before.textContent.length; } } } -}; -// Line widgets are block elements displayed above or below a line. + // TEXTAREA INPUT STYLE -var LineWidget = function(doc, node, options) { - var this$1 = this; + var TextareaInput = function(cm) { + this.cm = cm; + // See input.poll and input.reset + this.prevInput = ""; - if (options) { for (var opt in options) { if (options.hasOwnProperty(opt)) - { this$1[opt] = options[opt]; } } } - this.doc = doc; - this.node = node; -}; + // Flag that indicates whether we expect input to appear real soon + // now (after some event like 'keypress' or 'input') and are + // polling intensively. + this.pollingFast = false; + // Self-resetting timeout for the poller + this.polling = new Delayed(); + // Used to work around IE issue with selection being forgotten when focus moves away from textarea + this.hasSelection = false; + this.composing = null; + }; -LineWidget.prototype.clear = function () { - var this$1 = this; + TextareaInput.prototype.init = function (display) { + var this$1 = this; - var cm = this.doc.cm, ws = this.line.widgets, line = this.line, no = lineNo(line); - if (no == null || !ws) { return } - for (var i = 0; i < ws.length; ++i) { if (ws[i] == this$1) { ws.splice(i--, 1); } } - if (!ws.length) { line.widgets = null; } - var height = widgetHeight(this); - updateLineHeight(line, Math.max(0, line.height - height)); - if (cm) { - runInOp(cm, function () { - adjustScrollWhenAboveVisible(cm, line, -height); - regLineChange(cm, no, "widget"); - }); - signalLater(cm, "lineWidgetCleared", cm, this, no); - } -}; + var input = this, cm = this.cm; + this.createField(display); + var te = this.textarea; -LineWidget.prototype.changed = function () { - var this$1 = this; + display.wrapper.insertBefore(this.wrapper, display.wrapper.firstChild); - var oldH = this.height, cm = this.doc.cm, line = this.line; - this.height = null; - var diff = widgetHeight(this) - oldH; - if (!diff) { return } - updateLineHeight(line, line.height + diff); - if (cm) { - runInOp(cm, function () { - cm.curOp.forceUpdate = true; - adjustScrollWhenAboveVisible(cm, line, diff); - signalLater(cm, "lineWidgetChanged", cm, this$1, lineNo(line)); + // Needed to hide big blue blinking cursor on Mobile Safari (doesn't seem to work in iOS 8 anymore) + if (ios) { te.style.width = "0px"; } + + on(te, "input", function () { + if (ie && ie_version >= 9 && this$1.hasSelection) { this$1.hasSelection = null; } + input.poll(); }); - } -}; -eventMixin(LineWidget); -function adjustScrollWhenAboveVisible(cm, line, diff) { - if (heightAtLine(line) < ((cm.curOp && cm.curOp.scrollTop) || cm.doc.scrollTop)) - { addToScrollTop(cm, diff); } -} + on(te, "paste", function (e) { + if (signalDOMEvent(cm, e) || handlePaste(e, cm)) { return } -function addLineWidget(doc, handle, node, options) { - var widget = new LineWidget(doc, node, options); - var cm = doc.cm; - if (cm && widget.noHScroll) { cm.display.alignWidgets = true; } - changeLine(doc, handle, "widget", function (line) { - var widgets = line.widgets || (line.widgets = []); - if (widget.insertAt == null) { widgets.push(widget); } - else { widgets.splice(Math.min(widgets.length - 1, Math.max(0, widget.insertAt)), 0, widget); } - widget.line = line; - if (cm && !lineIsHidden(doc, line)) { - var aboveVisible = heightAtLine(line) < doc.scrollTop; - updateLineHeight(line, line.height + widgetHeight(widget)); - if (aboveVisible) { addToScrollTop(cm, widget.height); } - cm.curOp.forceUpdate = true; + cm.state.pasteIncoming = +new Date; + input.fastPoll(); + }); + + function prepareCopyCut(e) { + if (signalDOMEvent(cm, e)) { return } + if (cm.somethingSelected()) { + setLastCopied({lineWise: false, text: cm.getSelections()}); + } else if (!cm.options.lineWiseCopyCut) { + return + } else { + var ranges = copyableRanges(cm); + setLastCopied({lineWise: true, text: ranges.text}); + if (e.type == "cut") { + cm.setSelections(ranges.ranges, null, sel_dontScroll); + } else { + input.prevInput = ""; + te.value = ranges.text.join("\n"); + selectInput(te); + } + } + if (e.type == "cut") { cm.state.cutIncoming = +new Date; } } - return true - }); - signalLater(cm, "lineWidgetAdded", cm, widget, typeof handle == "number" ? handle : lineNo(handle)); - return widget -} + on(te, "cut", prepareCopyCut); + on(te, "copy", prepareCopyCut); -// TEXTMARKERS - -// Created with markText and setBookmark methods. A TextMarker is a -// handle that can be used to clear or find a marked position in the -// document. Line objects hold arrays (markedSpans) containing -// {from, to, marker} object pointing to such marker objects, and -// indicating that such a marker is present on that line. Multiple -// lines may point to the same marker when it spans across lines. -// The spans will have null for their from/to properties when the -// marker continues beyond the start/end of the line. Markers have -// links back to the lines they currently touch. - -// Collapsed markers have unique ids, in order to be able to order -// them, which is needed for uniquely determining an outer marker -// when they overlap (they may nest, but not partially overlap). -var nextMarkerId = 0; - -var TextMarker = function(doc, type) { - this.lines = []; - this.type = type; - this.doc = doc; - this.id = ++nextMarkerId; -}; + on(display.scroller, "paste", function (e) { + if (eventInWidget(display, e) || signalDOMEvent(cm, e)) { return } + if (!te.dispatchEvent) { + cm.state.pasteIncoming = +new Date; + input.focus(); + return + } -// Clear the marker. -TextMarker.prototype.clear = function () { - var this$1 = this; + // Pass the `paste` event to the textarea so it's handled by its event listener. + var event = new Event("paste"); + event.clipboardData = e.clipboardData; + te.dispatchEvent(event); + }); - if (this.explicitlyCleared) { return } - var cm = this.doc.cm, withOp = cm && !cm.curOp; - if (withOp) { startOperation(cm); } - if (hasHandler(this, "clear")) { - var found = this.find(); - if (found) { signalLater(this, "clear", found.from, found.to); } - } - var min = null, max = null; - for (var i = 0; i < this.lines.length; ++i) { - var line = this$1.lines[i]; - var span = getMarkedSpanFor(line.markedSpans, this$1); - if (cm && !this$1.collapsed) { regLineChange(cm, lineNo(line), "text"); } - else if (cm) { - if (span.to != null) { max = lineNo(line); } - if (span.from != null) { min = lineNo(line); } - } - line.markedSpans = removeMarkedSpan(line.markedSpans, span); - if (span.from == null && this$1.collapsed && !lineIsHidden(this$1.doc, line) && cm) - { updateLineHeight(line, textHeight(cm.display)); } - } - if (cm && this.collapsed && !cm.options.lineWrapping) { for (var i$1 = 0; i$1 < this.lines.length; ++i$1) { - var visual = visualLine(this$1.lines[i$1]), len = lineLength(visual); - if (len > cm.display.maxLineLength) { - cm.display.maxLine = visual; - cm.display.maxLineLength = len; - cm.display.maxLineChanged = true; - } - } } - - if (min != null && cm && this.collapsed) { regChange(cm, min, max + 1); } - this.lines.length = 0; - this.explicitlyCleared = true; - if (this.atomic && this.doc.cantEdit) { - this.doc.cantEdit = false; - if (cm) { reCheckSelection(cm.doc); } - } - if (cm) { signalLater(cm, "markerCleared", cm, this, min, max); } - if (withOp) { endOperation(cm); } - if (this.parent) { this.parent.clear(); } -}; + // Prevent normal selection in the editor (we handle our own) + on(display.lineSpace, "selectstart", function (e) { + if (!eventInWidget(display, e)) { e_preventDefault(e); } + }); -// Find the position of the marker in the document. Returns a {from, -// to} object by default. Side can be passed to get a specific side -// -- 0 (both), -1 (left), or 1 (right). When lineObj is true, the -// Pos objects returned contain a line object, rather than a line -// number (used to prevent looking up the same line twice). -TextMarker.prototype.find = function (side, lineObj) { - var this$1 = this; + on(te, "compositionstart", function () { + var start = cm.getCursor("from"); + if (input.composing) { input.composing.range.clear(); } + input.composing = { + start: start, + range: cm.markText(start, cm.getCursor("to"), {className: "CodeMirror-composing"}) + }; + }); + on(te, "compositionend", function () { + if (input.composing) { + input.poll(); + input.composing.range.clear(); + input.composing = null; + } + }); + }; - if (side == null && this.type == "bookmark") { side = 1; } - var from, to; - for (var i = 0; i < this.lines.length; ++i) { - var line = this$1.lines[i]; - var span = getMarkedSpanFor(line.markedSpans, this$1); - if (span.from != null) { - from = Pos(lineObj ? line : lineNo(line), span.from); - if (side == -1) { return from } - } - if (span.to != null) { - to = Pos(lineObj ? line : lineNo(line), span.to); - if (side == 1) { return to } - } - } - return from && {from: from, to: to} -}; + TextareaInput.prototype.createField = function (_display) { + // Wraps and hides input textarea + this.wrapper = hiddenTextarea(); + // The semihidden textarea that is focused when the editor is + // focused, and receives input. + this.textarea = this.wrapper.firstChild; + }; -// Signals that the marker's widget changed, and surrounding layout -// should be recomputed. -TextMarker.prototype.changed = function () { - var this$1 = this; + TextareaInput.prototype.prepareSelection = function () { + // Redraw the selection and/or cursor + var cm = this.cm, display = cm.display, doc = cm.doc; + var result = prepareSelection(cm); - var pos = this.find(-1, true), widget = this, cm = this.doc.cm; - if (!pos || !cm) { return } - runInOp(cm, function () { - var line = pos.line, lineN = lineNo(pos.line); - var view = findViewForLine(cm, lineN); - if (view) { - clearLineMeasurementCacheFor(view); - cm.curOp.selectionChanged = cm.curOp.forceUpdate = true; - } - cm.curOp.updateMaxLine = true; - if (!lineIsHidden(widget.doc, line) && widget.height != null) { - var oldHeight = widget.height; - widget.height = null; - var dHeight = widgetHeight(widget) - oldHeight; - if (dHeight) - { updateLineHeight(line, line.height + dHeight); } - } - signalLater(cm, "markerChanged", cm, this$1); - }); -}; + // Move the hidden textarea near the cursor to prevent scrolling artifacts + if (cm.options.moveInputWithCursor) { + var headPos = cursorCoords(cm, doc.sel.primary().head, "div"); + var wrapOff = display.wrapper.getBoundingClientRect(), lineOff = display.lineDiv.getBoundingClientRect(); + result.teTop = Math.max(0, Math.min(display.wrapper.clientHeight - 10, + headPos.top + lineOff.top - wrapOff.top)); + result.teLeft = Math.max(0, Math.min(display.wrapper.clientWidth - 10, + headPos.left + lineOff.left - wrapOff.left)); + } -TextMarker.prototype.attachLine = function (line) { - if (!this.lines.length && this.doc.cm) { - var op = this.doc.cm.curOp; - if (!op.maybeHiddenMarkers || indexOf(op.maybeHiddenMarkers, this) == -1) - { (op.maybeUnhiddenMarkers || (op.maybeUnhiddenMarkers = [])).push(this); } - } - this.lines.push(line); -}; + return result + }; -TextMarker.prototype.detachLine = function (line) { - this.lines.splice(indexOf(this.lines, line), 1); - if (!this.lines.length && this.doc.cm) { - var op = this.doc.cm.curOp;(op.maybeHiddenMarkers || (op.maybeHiddenMarkers = [])).push(this); - } -}; -eventMixin(TextMarker); - -// Create a marker, wire it up to the right lines, and -function markText(doc, from, to, options, type) { - // Shared markers (across linked documents) are handled separately - // (markTextShared will call out to this again, once per - // document). - if (options && options.shared) { return markTextShared(doc, from, to, options, type) } - // Ensure we are in an operation. - if (doc.cm && !doc.cm.curOp) { return operation(doc.cm, markText)(doc, from, to, options, type) } - - var marker = new TextMarker(doc, type), diff = cmp(from, to); - if (options) { copyObj(options, marker, false); } - // Don't connect empty markers unless clearWhenEmpty is false - if (diff > 0 || diff == 0 && marker.clearWhenEmpty !== false) - { return marker } - if (marker.replacedWith) { - // Showing up as a widget implies collapsed (widget replaces text) - marker.collapsed = true; - marker.widgetNode = eltP("span", [marker.replacedWith], "CodeMirror-widget"); - if (!options.handleMouseEvents) { marker.widgetNode.setAttribute("cm-ignore-events", "true"); } - if (options.insertLeft) { marker.widgetNode.insertLeft = true; } - } - if (marker.collapsed) { - if (conflictingCollapsedRange(doc, from.line, from, to, marker) || - from.line != to.line && conflictingCollapsedRange(doc, to.line, from, to, marker)) - { throw new Error("Inserting collapsed marker partially overlapping an existing one") } - seeCollapsedSpans(); - } - - if (marker.addToHistory) - { addChangeToHistory(doc, {from: from, to: to, origin: "markText"}, doc.sel, NaN); } - - var curLine = from.line, cm = doc.cm, updateMaxLine; - doc.iter(curLine, to.line + 1, function (line) { - if (cm && marker.collapsed && !cm.options.lineWrapping && visualLine(line) == cm.display.maxLine) - { updateMaxLine = true; } - if (marker.collapsed && curLine != from.line) { updateLineHeight(line, 0); } - addMarkedSpan(line, new MarkedSpan(marker, - curLine == from.line ? from.ch : null, - curLine == to.line ? to.ch : null)); - ++curLine; - }); - // lineIsHidden depends on the presence of the spans, so needs a second pass - if (marker.collapsed) { doc.iter(from.line, to.line + 1, function (line) { - if (lineIsHidden(doc, line)) { updateLineHeight(line, 0); } - }); } - - if (marker.clearOnEnter) { on(marker, "beforeCursorEnter", function () { return marker.clear(); }); } - - if (marker.readOnly) { - seeReadOnlySpans(); - if (doc.history.done.length || doc.history.undone.length) - { doc.clearHistory(); } - } - if (marker.collapsed) { - marker.id = ++nextMarkerId; - marker.atomic = true; - } - if (cm) { - // Sync editor state - if (updateMaxLine) { cm.curOp.updateMaxLine = true; } - if (marker.collapsed) - { regChange(cm, from.line, to.line + 1); } - else if (marker.className || marker.title || marker.startStyle || marker.endStyle || marker.css) - { for (var i = from.line; i <= to.line; i++) { regLineChange(cm, i, "text"); } } - if (marker.atomic) { reCheckSelection(cm.doc); } - signalLater(cm, "markerAdded", cm, marker); - } - return marker -} + TextareaInput.prototype.showSelection = function (drawn) { + var cm = this.cm, display = cm.display; + removeChildrenAndAdd(display.cursorDiv, drawn.cursors); + removeChildrenAndAdd(display.selectionDiv, drawn.selection); + if (drawn.teTop != null) { + this.wrapper.style.top = drawn.teTop + "px"; + this.wrapper.style.left = drawn.teLeft + "px"; + } + }; -// SHARED TEXTMARKERS + // Reset the input to correspond to the selection (or to be empty, + // when not typing and nothing is selected) + TextareaInput.prototype.reset = function (typing) { + if (this.contextMenuPending || this.composing) { return } + var cm = this.cm; + if (cm.somethingSelected()) { + this.prevInput = ""; + var content = cm.getSelection(); + this.textarea.value = content; + if (cm.state.focused) { selectInput(this.textarea); } + if (ie && ie_version >= 9) { this.hasSelection = content; } + } else if (!typing) { + this.prevInput = this.textarea.value = ""; + if (ie && ie_version >= 9) { this.hasSelection = null; } + } + }; -// A shared marker spans multiple linked documents. It is -// implemented as a meta-marker-object controlling multiple normal -// markers. -var SharedTextMarker = function(markers, primary) { - var this$1 = this; + TextareaInput.prototype.getField = function () { return this.textarea }; - this.markers = markers; - this.primary = primary; - for (var i = 0; i < markers.length; ++i) - { markers[i].parent = this$1; } -}; + TextareaInput.prototype.supportsTouch = function () { return false }; -SharedTextMarker.prototype.clear = function () { - var this$1 = this; + TextareaInput.prototype.focus = function () { + if (this.cm.options.readOnly != "nocursor" && (!mobile || activeElt() != this.textarea)) { + try { this.textarea.focus(); } + catch (e) {} // IE8 will throw if the textarea is display: none or not in DOM + } + }; - if (this.explicitlyCleared) { return } - this.explicitlyCleared = true; - for (var i = 0; i < this.markers.length; ++i) - { this$1.markers[i].clear(); } - signalLater(this, "clear"); -}; + TextareaInput.prototype.blur = function () { this.textarea.blur(); }; -SharedTextMarker.prototype.find = function (side, lineObj) { - return this.primary.find(side, lineObj) -}; -eventMixin(SharedTextMarker); - -function markTextShared(doc, from, to, options, type) { - options = copyObj(options); - options.shared = false; - var markers = [markText(doc, from, to, options, type)], primary = markers[0]; - var widget = options.widgetNode; - linkedDocs(doc, function (doc) { - if (widget) { options.widgetNode = widget.cloneNode(true); } - markers.push(markText(doc, clipPos(doc, from), clipPos(doc, to), options, type)); - for (var i = 0; i < doc.linked.length; ++i) - { if (doc.linked[i].isParent) { return } } - primary = lst(markers); - }); - return new SharedTextMarker(markers, primary) -} + TextareaInput.prototype.resetPosition = function () { + this.wrapper.style.top = this.wrapper.style.left = 0; + }; -function findSharedMarkers(doc) { - return doc.findMarks(Pos(doc.first, 0), doc.clipPos(Pos(doc.lastLine())), function (m) { return m.parent; }) -} + TextareaInput.prototype.receivedFocus = function () { this.slowPoll(); }; -function copySharedMarkers(doc, markers) { - for (var i = 0; i < markers.length; i++) { - var marker = markers[i], pos = marker.find(); - var mFrom = doc.clipPos(pos.from), mTo = doc.clipPos(pos.to); - if (cmp(mFrom, mTo)) { - var subMark = markText(doc, mFrom, mTo, marker.primary, marker.primary.type); - marker.markers.push(subMark); - subMark.parent = marker; - } - } -} + // Poll for input changes, using the normal rate of polling. This + // runs as long as the editor is focused. + TextareaInput.prototype.slowPoll = function () { + var this$1 = this; -function detachSharedMarkers(markers) { - var loop = function ( i ) { - var marker = markers[i], linked = [marker.primary.doc]; - linkedDocs(marker.primary.doc, function (d) { return linked.push(d); }); - for (var j = 0; j < marker.markers.length; j++) { - var subMarker = marker.markers[j]; - if (indexOf(linked, subMarker.doc) == -1) { - subMarker.parent = null; - marker.markers.splice(j--, 1); - } + if (this.pollingFast) { return } + this.polling.set(this.cm.options.pollInterval, function () { + this$1.poll(); + if (this$1.cm.state.focused) { this$1.slowPoll(); } + }); + }; + + // When an event has just come in that is likely to add or change + // something in the input textarea, we poll faster, to ensure that + // the change appears on the screen quickly. + TextareaInput.prototype.fastPoll = function () { + var missed = false, input = this; + input.pollingFast = true; + function p() { + var changed = input.poll(); + if (!changed && !missed) {missed = true; input.polling.set(60, p);} + else {input.pollingFast = false; input.slowPoll();} } + input.polling.set(20, p); }; - for (var i = 0; i < markers.length; i++) loop( i ); -} + // Read input from the textarea, and update the document to match. + // When something is selected, it is present in the textarea, and + // selected (unless it is huge, in which case a placeholder is + // used). When nothing is selected, the cursor sits after previously + // seen text (can be empty), which is stored in prevInput (we must + // not reset the textarea when typing, because that breaks IME). + TextareaInput.prototype.poll = function () { + var this$1 = this; -var nextDocId = 0; -var Doc = function(text, mode, firstLine, lineSep, direction) { - if (!(this instanceof Doc)) { return new Doc(text, mode, firstLine, lineSep, direction) } - if (firstLine == null) { firstLine = 0; } - - BranchChunk.call(this, [new LeafChunk([new Line("", null)])]); - this.first = firstLine; - this.scrollTop = this.scrollLeft = 0; - this.cantEdit = false; - this.cleanGeneration = 1; - this.modeFrontier = this.highlightFrontier = firstLine; - var start = Pos(firstLine, 0); - this.sel = simpleSelection(start); - this.history = new History(null); - this.id = ++nextDocId; - this.modeOption = mode; - this.lineSep = lineSep; - this.direction = (direction == "rtl") ? "rtl" : "ltr"; - this.extend = false; - - if (typeof text == "string") { text = this.splitLines(text); } - updateDoc(this, {from: start, to: start, text: text}); - setSelection(this, simpleSelection(start), sel_dontScroll); -}; - -Doc.prototype = createObj(BranchChunk.prototype, { - constructor: Doc, - // Iterate over the document. Supports two forms -- with only one - // argument, it calls that for each line in the document. With - // three, it iterates over the range given by the first two (with - // the second being non-inclusive). - iter: function(from, to, op) { - if (op) { this.iterN(from - this.first, to - from, op); } - else { this.iterN(this.first, this.first + this.size, from); } - }, - - // Non-public interface for adding and removing lines. - insert: function(at, lines) { - var height = 0; - for (var i = 0; i < lines.length; ++i) { height += lines[i].height; } - this.insertInner(at - this.first, lines, height); - }, - remove: function(at, n) { this.removeInner(at - this.first, n); }, - - // From here, the methods are part of the public interface. Most - // are also available from CodeMirror (editor) instances. + var cm = this.cm, input = this.textarea, prevInput = this.prevInput; + // Since this is called a *lot*, try to bail out as cheaply as + // possible when it is clear that nothing happened. hasSelection + // will be the case when there is a lot of text in the textarea, + // in which case reading its value would be expensive. + if (this.contextMenuPending || !cm.state.focused || + (hasSelection(input) && !prevInput && !this.composing) || + cm.isReadOnly() || cm.options.disableInput || cm.state.keySeq) + { return false } + + var text = input.value; + // If nothing changed, bail. + if (text == prevInput && !cm.somethingSelected()) { return false } + // Work around nonsensical selection resetting in IE9/10, and + // inexplicable appearance of private area unicode characters on + // some key combos in Mac (#2689). + if (ie && ie_version >= 9 && this.hasSelection === text || + mac && /[\uf700-\uf7ff]/.test(text)) { + cm.display.input.reset(); + return false + } - getValue: function(lineSep) { - var lines = getLines(this, this.first, this.first + this.size); - if (lineSep === false) { return lines } - return lines.join(lineSep || this.lineSeparator()) - }, - setValue: docMethodOp(function(code) { - var top = Pos(this.first, 0), last = this.first + this.size - 1; - makeChange(this, {from: top, to: Pos(last, getLine(this, last).text.length), - text: this.splitLines(code), origin: "setValue", full: true}, true); - if (this.cm) { scrollToCoords(this.cm, 0, 0); } - setSelection(this, simpleSelection(top), sel_dontScroll); - }), - replaceRange: function(code, from, to, origin) { - from = clipPos(this, from); - to = to ? clipPos(this, to) : from; - replaceRange(this, code, from, to, origin); - }, - getRange: function(from, to, lineSep) { - var lines = getBetween(this, clipPos(this, from), clipPos(this, to)); - if (lineSep === false) { return lines } - return lines.join(lineSep || this.lineSeparator()) - }, + if (cm.doc.sel == cm.display.selForContextMenu) { + var first = text.charCodeAt(0); + if (first == 0x200b && !prevInput) { prevInput = "\u200b"; } + if (first == 0x21da) { this.reset(); return this.cm.execCommand("undo") } + } + // Find the part of the input that is actually new + var same = 0, l = Math.min(prevInput.length, text.length); + while (same < l && prevInput.charCodeAt(same) == text.charCodeAt(same)) { ++same; } - getLine: function(line) {var l = this.getLineHandle(line); return l && l.text}, + runInOp(cm, function () { + applyTextInput(cm, text.slice(same), prevInput.length - same, + null, this$1.composing ? "*compose" : null); - getLineHandle: function(line) {if (isLine(this, line)) { return getLine(this, line) }}, - getLineNumber: function(line) {return lineNo(line)}, + // Don't leave long text in the textarea, since it makes further polling slow + if (text.length > 1000 || text.indexOf("\n") > -1) { input.value = this$1.prevInput = ""; } + else { this$1.prevInput = text; } - getLineHandleVisualStart: function(line) { - if (typeof line == "number") { line = getLine(this, line); } - return visualLine(line) - }, + if (this$1.composing) { + this$1.composing.range.clear(); + this$1.composing.range = cm.markText(this$1.composing.start, cm.getCursor("to"), + {className: "CodeMirror-composing"}); + } + }); + return true + }; - lineCount: function() {return this.size}, - firstLine: function() {return this.first}, - lastLine: function() {return this.first + this.size - 1}, + TextareaInput.prototype.ensurePolled = function () { + if (this.pollingFast && this.poll()) { this.pollingFast = false; } + }; - clipPos: function(pos) {return clipPos(this, pos)}, + TextareaInput.prototype.onKeyPress = function () { + if (ie && ie_version >= 9) { this.hasSelection = null; } + this.fastPoll(); + }; + + TextareaInput.prototype.onContextMenu = function (e) { + var input = this, cm = input.cm, display = cm.display, te = input.textarea; + if (input.contextMenuPending) { input.contextMenuPending(); } + var pos = posFromMouse(cm, e), scrollPos = display.scroller.scrollTop; + if (!pos || presto) { return } // Opera is difficult. + + // Reset the current text selection only if the click is done outside of the selection + // and 'resetSelectionOnContextMenu' option is true. + var reset = cm.options.resetSelectionOnContextMenu; + if (reset && cm.doc.sel.contains(pos) == -1) + { operation(cm, setSelection)(cm.doc, simpleSelection(pos), sel_dontScroll); } + + var oldCSS = te.style.cssText, oldWrapperCSS = input.wrapper.style.cssText; + var wrapperBox = input.wrapper.offsetParent.getBoundingClientRect(); + input.wrapper.style.cssText = "position: static"; + te.style.cssText = "position: absolute; width: 30px; height: 30px;\n top: " + (e.clientY - wrapperBox.top - 5) + "px; left: " + (e.clientX - wrapperBox.left - 5) + "px;\n z-index: 1000; background: " + (ie ? "rgba(255, 255, 255, .05)" : "transparent") + ";\n outline: none; border-width: 0; outline: none; overflow: hidden; opacity: .05; filter: alpha(opacity=5);"; + var oldScrollY; + if (webkit) { oldScrollY = window.scrollY; } // Work around Chrome issue (#2712) + display.input.focus(); + if (webkit) { window.scrollTo(null, oldScrollY); } + display.input.reset(); + // Adds "Select all" to context menu in FF + if (!cm.somethingSelected()) { te.value = input.prevInput = " "; } + input.contextMenuPending = rehide; + display.selForContextMenu = cm.doc.sel; + clearTimeout(display.detectingSelectAll); + + // Select-all will be greyed out if there's nothing to select, so + // this adds a zero-width space so that we can later check whether + // it got selected. + function prepareSelectAllHack() { + if (te.selectionStart != null) { + var selected = cm.somethingSelected(); + var extval = "\u200b" + (selected ? te.value : ""); + te.value = "\u21da"; // Used to catch context-menu undo + te.value = extval; + input.prevInput = selected ? "" : "\u200b"; + te.selectionStart = 1; te.selectionEnd = extval.length; + // Re-set this, in case some other handler touched the + // selection in the meantime. + display.selForContextMenu = cm.doc.sel; + } + } + function rehide() { + if (input.contextMenuPending != rehide) { return } + input.contextMenuPending = false; + input.wrapper.style.cssText = oldWrapperCSS; + te.style.cssText = oldCSS; + if (ie && ie_version < 9) { display.scrollbars.setScrollTop(display.scroller.scrollTop = scrollPos); } + + // Try to detect the user choosing select-all + if (te.selectionStart != null) { + if (!ie || (ie && ie_version < 9)) { prepareSelectAllHack(); } + var i = 0, poll = function () { + if (display.selForContextMenu == cm.doc.sel && te.selectionStart == 0 && + te.selectionEnd > 0 && input.prevInput == "\u200b") { + operation(cm, selectAll)(cm); + } else if (i++ < 10) { + display.detectingSelectAll = setTimeout(poll, 500); + } else { + display.selForContextMenu = null; + display.input.reset(); + } + }; + display.detectingSelectAll = setTimeout(poll, 200); + } + } - getCursor: function(start) { - var range$$1 = this.sel.primary(), pos; - if (start == null || start == "head") { pos = range$$1.head; } - else if (start == "anchor") { pos = range$$1.anchor; } - else if (start == "end" || start == "to" || start === false) { pos = range$$1.to(); } - else { pos = range$$1.from(); } - return pos - }, - listSelections: function() { return this.sel.ranges }, - somethingSelected: function() {return this.sel.somethingSelected()}, + if (ie && ie_version >= 9) { prepareSelectAllHack(); } + if (captureRightClick) { + e_stop(e); + var mouseup = function () { + off(window, "mouseup", mouseup); + setTimeout(rehide, 20); + }; + on(window, "mouseup", mouseup); + } else { + setTimeout(rehide, 50); + } + }; - setCursor: docMethodOp(function(line, ch, options) { - setSimpleSelection(this, clipPos(this, typeof line == "number" ? Pos(line, ch || 0) : line), null, options); - }), - setSelection: docMethodOp(function(anchor, head, options) { - setSimpleSelection(this, clipPos(this, anchor), clipPos(this, head || anchor), options); - }), - extendSelection: docMethodOp(function(head, other, options) { - extendSelection(this, clipPos(this, head), other && clipPos(this, other), options); - }), - extendSelections: docMethodOp(function(heads, options) { - extendSelections(this, clipPosArray(this, heads), options); - }), - extendSelectionsBy: docMethodOp(function(f, options) { - var heads = map(this.sel.ranges, f); - extendSelections(this, clipPosArray(this, heads), options); - }), - setSelections: docMethodOp(function(ranges, primary, options) { - var this$1 = this; + TextareaInput.prototype.readOnlyChanged = function (val) { + if (!val) { this.reset(); } + this.textarea.disabled = val == "nocursor"; + }; - if (!ranges.length) { return } - var out = []; - for (var i = 0; i < ranges.length; i++) - { out[i] = new Range(clipPos(this$1, ranges[i].anchor), - clipPos(this$1, ranges[i].head)); } - if (primary == null) { primary = Math.min(ranges.length - 1, this.sel.primIndex); } - setSelection(this, normalizeSelection(out, primary), options); - }), - addSelection: docMethodOp(function(anchor, head, options) { - var ranges = this.sel.ranges.slice(0); - ranges.push(new Range(clipPos(this, anchor), clipPos(this, head || anchor))); - setSelection(this, normalizeSelection(ranges, ranges.length - 1), options); - }), + TextareaInput.prototype.setUneditable = function () {}; - getSelection: function(lineSep) { - var this$1 = this; + TextareaInput.prototype.needsContentAttribute = false; - var ranges = this.sel.ranges, lines; - for (var i = 0; i < ranges.length; i++) { - var sel = getBetween(this$1, ranges[i].from(), ranges[i].to()); - lines = lines ? lines.concat(sel) : sel; + function fromTextArea(textarea, options) { + options = options ? copyObj(options) : {}; + options.value = textarea.value; + if (!options.tabindex && textarea.tabIndex) + { options.tabindex = textarea.tabIndex; } + if (!options.placeholder && textarea.placeholder) + { options.placeholder = textarea.placeholder; } + // Set autofocus to true if this textarea is focused, or if it has + // autofocus and no other element is focused. + if (options.autofocus == null) { + var hasFocus = activeElt(); + options.autofocus = hasFocus == textarea || + textarea.getAttribute("autofocus") != null && hasFocus == document.body; } - if (lineSep === false) { return lines } - else { return lines.join(lineSep || this.lineSeparator()) } - }, - getSelections: function(lineSep) { - var this$1 = this; - var parts = [], ranges = this.sel.ranges; - for (var i = 0; i < ranges.length; i++) { - var sel = getBetween(this$1, ranges[i].from(), ranges[i].to()); - if (lineSep !== false) { sel = sel.join(lineSep || this$1.lineSeparator()); } - parts[i] = sel; - } - return parts - }, - replaceSelection: function(code, collapse, origin) { - var dup = []; - for (var i = 0; i < this.sel.ranges.length; i++) - { dup[i] = code; } - this.replaceSelections(dup, collapse, origin || "+input"); - }, - replaceSelections: docMethodOp(function(code, collapse, origin) { - var this$1 = this; + function save() {textarea.value = cm.getValue();} - var changes = [], sel = this.sel; - for (var i = 0; i < sel.ranges.length; i++) { - var range$$1 = sel.ranges[i]; - changes[i] = {from: range$$1.from(), to: range$$1.to(), text: this$1.splitLines(code[i]), origin: origin}; + var realSubmit; + if (textarea.form) { + on(textarea.form, "submit", save); + // Deplorable hack to make the submit method do the right thing. + if (!options.leaveSubmitMethodAlone) { + var form = textarea.form; + realSubmit = form.submit; + try { + var wrappedSubmit = form.submit = function () { + save(); + form.submit = realSubmit; + form.submit(); + form.submit = wrappedSubmit; + }; + } catch(e) {} + } } - var newSel = collapse && collapse != "end" && computeReplacedSel(this, changes, collapse); - for (var i$1 = changes.length - 1; i$1 >= 0; i$1--) - { makeChange(this$1, changes[i$1]); } - if (newSel) { setSelectionReplaceHistory(this, newSel); } - else if (this.cm) { ensureCursorVisible(this.cm); } - }), - undo: docMethodOp(function() {makeChangeFromHistory(this, "undo");}), - redo: docMethodOp(function() {makeChangeFromHistory(this, "redo");}), - undoSelection: docMethodOp(function() {makeChangeFromHistory(this, "undo", true);}), - redoSelection: docMethodOp(function() {makeChangeFromHistory(this, "redo", true);}), - setExtending: function(val) {this.extend = val;}, - getExtending: function() {return this.extend}, - - historySize: function() { - var hist = this.history, done = 0, undone = 0; - for (var i = 0; i < hist.done.length; i++) { if (!hist.done[i].ranges) { ++done; } } - for (var i$1 = 0; i$1 < hist.undone.length; i$1++) { if (!hist.undone[i$1].ranges) { ++undone; } } - return {undo: done, redo: undone} - }, - clearHistory: function() {this.history = new History(this.history.maxGeneration);}, - - markClean: function() { - this.cleanGeneration = this.changeGeneration(true); - }, - changeGeneration: function(forceSplit) { - if (forceSplit) - { this.history.lastOp = this.history.lastSelOp = this.history.lastOrigin = null; } - return this.history.generation - }, - isClean: function (gen) { - return this.history.generation == (gen || this.cleanGeneration) - }, + options.finishInit = function (cm) { + cm.save = save; + cm.getTextArea = function () { return textarea; }; + cm.toTextArea = function () { + cm.toTextArea = isNaN; // Prevent this from being ran twice + save(); + textarea.parentNode.removeChild(cm.getWrapperElement()); + textarea.style.display = ""; + if (textarea.form) { + off(textarea.form, "submit", save); + if (typeof textarea.form.submit == "function") + { textarea.form.submit = realSubmit; } + } + }; + }; - getHistory: function() { - return {done: copyHistoryArray(this.history.done), - undone: copyHistoryArray(this.history.undone)} - }, - setHistory: function(histData) { - var hist = this.history = new History(this.history.maxGeneration); - hist.done = copyHistoryArray(histData.done.slice(0), null, true); - hist.undone = copyHistoryArray(histData.undone.slice(0), null, true); - }, + textarea.style.display = "none"; + var cm = CodeMirror(function (node) { return textarea.parentNode.insertBefore(node, textarea.nextSibling); }, + options); + return cm + } + + function addLegacyProps(CodeMirror) { + CodeMirror.off = off; + CodeMirror.on = on; + CodeMirror.wheelEventPixels = wheelEventPixels; + CodeMirror.Doc = Doc; + CodeMirror.splitLines = splitLinesAuto; + CodeMirror.countColumn = countColumn; + CodeMirror.findColumn = findColumn; + CodeMirror.isWordChar = isWordCharBasic; + CodeMirror.Pass = Pass; + CodeMirror.signal = signal; + CodeMirror.Line = Line; + CodeMirror.changeEnd = changeEnd; + CodeMirror.scrollbarModel = scrollbarModel; + CodeMirror.Pos = Pos; + CodeMirror.cmpPos = cmp; + CodeMirror.modes = modes; + CodeMirror.mimeModes = mimeModes; + CodeMirror.resolveMode = resolveMode; + CodeMirror.getMode = getMode; + CodeMirror.modeExtensions = modeExtensions; + CodeMirror.extendMode = extendMode; + CodeMirror.copyState = copyState; + CodeMirror.startState = startState; + CodeMirror.innerMode = innerMode; + CodeMirror.commands = commands; + CodeMirror.keyMap = keyMap; + CodeMirror.keyName = keyName; + CodeMirror.isModifierKey = isModifierKey; + CodeMirror.lookupKey = lookupKey; + CodeMirror.normalizeKeyMap = normalizeKeyMap; + CodeMirror.StringStream = StringStream; + CodeMirror.SharedTextMarker = SharedTextMarker; + CodeMirror.TextMarker = TextMarker; + CodeMirror.LineWidget = LineWidget; + CodeMirror.e_preventDefault = e_preventDefault; + CodeMirror.e_stopPropagation = e_stopPropagation; + CodeMirror.e_stop = e_stop; + CodeMirror.addClass = addClass; + CodeMirror.contains = contains; + CodeMirror.rmClass = rmClass; + CodeMirror.keyNames = keyNames; + } + + // EDITOR CONSTRUCTOR + + defineOptions(CodeMirror); + + addEditorMethods(CodeMirror); + + // Set up methods on CodeMirror's prototype to redirect to the editor's document. + var dontDelegate = "iter insert remove copy getEditor constructor".split(" "); + for (var prop in Doc.prototype) { if (Doc.prototype.hasOwnProperty(prop) && indexOf(dontDelegate, prop) < 0) + { CodeMirror.prototype[prop] = (function(method) { + return function() {return method.apply(this.doc, arguments)} + })(Doc.prototype[prop]); } } + + eventMixin(Doc); + CodeMirror.inputStyles = {"textarea": TextareaInput, "contenteditable": ContentEditableInput}; + + // Extra arguments are stored as the mode's dependencies, which is + // used by (legacy) mechanisms like loadmode.js to automatically + // load a mode. (Preferred mechanism is the require/define calls.) + CodeMirror.defineMode = function(name/*, mode, …*/) { + if (!CodeMirror.defaults.mode && name != "null") { CodeMirror.defaults.mode = name; } + defineMode.apply(this, arguments); + }; + + CodeMirror.defineMIME = defineMIME; + + // Minimal default mode. + CodeMirror.defineMode("null", function () { return ({token: function (stream) { return stream.skipToEnd(); }}); }); + CodeMirror.defineMIME("text/plain", "null"); + + // EXTENSIONS + + CodeMirror.defineExtension = function (name, func) { + CodeMirror.prototype[name] = func; + }; + CodeMirror.defineDocExtension = function (name, func) { + Doc.prototype[name] = func; + }; + + CodeMirror.fromTextArea = fromTextArea; + + addLegacyProps(CodeMirror); + + CodeMirror.version = "5.48.4"; + + return CodeMirror; - setGutterMarker: docMethodOp(function(line, gutterID, value) { - return changeLine(this, line, "gutter", function (line) { - var markers = line.gutterMarkers || (line.gutterMarkers = {}); - markers[gutterID] = value; - if (!value && isEmpty(markers)) { line.gutterMarkers = null; } - return true - }) - }), +}))); - clearGutter: docMethodOp(function(gutterID) { - var this$1 = this; - this.iter(function (line) { - if (line.gutterMarkers && line.gutterMarkers[gutterID]) { - changeLine(this$1, line, "gutter", function () { - line.gutterMarkers[gutterID] = null; - if (isEmpty(line.gutterMarkers)) { line.gutterMarkers = null; } - return true - }); - } - }); - }), +/***/ }), - lineInfo: function(line) { - var n; - if (typeof line == "number") { - if (!isLine(this, line)) { return null } - n = line; - line = getLine(this, line); - if (!line) { return null } - } else { - n = lineNo(line); - if (n == null) { return null } - } - return {line: n, handle: line, text: line.text, gutterMarkers: line.gutterMarkers, - textClass: line.textClass, bgClass: line.bgClass, wrapClass: line.wrapClass, - widgets: line.widgets} - }, - - addLineClass: docMethodOp(function(handle, where, cls) { - return changeLine(this, handle, where == "gutter" ? "gutter" : "class", function (line) { - var prop = where == "text" ? "textClass" - : where == "background" ? "bgClass" - : where == "gutter" ? "gutterClass" : "wrapClass"; - if (!line[prop]) { line[prop] = cls; } - else if (classTest(cls).test(line[prop])) { return false } - else { line[prop] += " " + cls; } - return true - }) - }), - removeLineClass: docMethodOp(function(handle, where, cls) { - return changeLine(this, handle, where == "gutter" ? "gutter" : "class", function (line) { - var prop = where == "text" ? "textClass" - : where == "background" ? "bgClass" - : where == "gutter" ? "gutterClass" : "wrapClass"; - var cur = line[prop]; - if (!cur) { return false } - else if (cls == null) { line[prop] = null; } - else { - var found = cur.match(classTest(cls)); - if (!found) { return false } - var end = found.index + found[0].length; - line[prop] = cur.slice(0, found.index) + (!found.index || end == cur.length ? "" : " ") + cur.slice(end) || null; - } - return true - }) - }), +/***/ "./node_modules/codemirror/mode/css/css.js": +/*!*************************************************!*\ + !*** ./node_modules/codemirror/mode/css/css.js ***! + \*************************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { - addLineWidget: docMethodOp(function(handle, node, options) { - return addLineWidget(this, handle, node, options) - }), - removeLineWidget: function(widget) { widget.clear(); }, - - markText: function(from, to, options) { - return markText(this, clipPos(this, from), clipPos(this, to), options, options && options.type || "range") - }, - setBookmark: function(pos, options) { - var realOpts = {replacedWith: options && (options.nodeType == null ? options.widget : options), - insertLeft: options && options.insertLeft, - clearWhenEmpty: false, shared: options && options.shared, - handleMouseEvents: options && options.handleMouseEvents}; - pos = clipPos(this, pos); - return markText(this, pos, pos, realOpts, "bookmark") - }, - findMarksAt: function(pos) { - pos = clipPos(this, pos); - var markers = [], spans = getLine(this, pos.line).markedSpans; - if (spans) { for (var i = 0; i < spans.length; ++i) { - var span = spans[i]; - if ((span.from == null || span.from <= pos.ch) && - (span.to == null || span.to >= pos.ch)) - { markers.push(span.marker.parent || span.marker); } - } } - return markers - }, - findMarks: function(from, to, filter) { - from = clipPos(this, from); to = clipPos(this, to); - var found = [], lineNo$$1 = from.line; - this.iter(from.line, to.line + 1, function (line) { - var spans = line.markedSpans; - if (spans) { for (var i = 0; i < spans.length; i++) { - var span = spans[i]; - if (!(span.to != null && lineNo$$1 == from.line && from.ch >= span.to || - span.from == null && lineNo$$1 != from.line || - span.from != null && lineNo$$1 == to.line && span.from >= to.ch) && - (!filter || filter(span.marker))) - { found.push(span.marker.parent || span.marker); } - } } - ++lineNo$$1; - }); - return found - }, - getAllMarks: function() { - var markers = []; - this.iter(function (line) { - var sps = line.markedSpans; - if (sps) { for (var i = 0; i < sps.length; ++i) - { if (sps[i].from != null) { markers.push(sps[i].marker); } } } - }); - return markers - }, +// CodeMirror, copyright (c) by Marijn Haverbeke and others +// Distributed under an MIT license: https://codemirror.net/LICENSE - posFromIndex: function(off) { - var ch, lineNo$$1 = this.first, sepSize = this.lineSeparator().length; - this.iter(function (line) { - var sz = line.text.length + sepSize; - if (sz > off) { ch = off; return true } - off -= sz; - ++lineNo$$1; - }); - return clipPos(this, Pos(lineNo$$1, ch)) - }, - indexFromPos: function (coords) { - coords = clipPos(this, coords); - var index = coords.ch; - if (coords.line < this.first || coords.ch < 0) { return 0 } - var sepSize = this.lineSeparator().length; - this.iter(this.first, coords.line, function (line) { // iter aborts when callback returns a truthy value - index += line.text.length + sepSize; - }); - return index - }, - - copy: function(copyHistory) { - var doc = new Doc(getLines(this, this.first, this.first + this.size), - this.modeOption, this.first, this.lineSep, this.direction); - doc.scrollTop = this.scrollTop; doc.scrollLeft = this.scrollLeft; - doc.sel = this.sel; - doc.extend = false; - if (copyHistory) { - doc.history.undoDepth = this.history.undoDepth; - doc.setHistory(this.getHistory()); - } - return doc - }, - - linkedDoc: function(options) { - if (!options) { options = {}; } - var from = this.first, to = this.first + this.size; - if (options.from != null && options.from > from) { from = options.from; } - if (options.to != null && options.to < to) { to = options.to; } - var copy = new Doc(getLines(this, from, to), options.mode || this.modeOption, from, this.lineSep, this.direction); - if (options.sharedHist) { copy.history = this.history - ; }(this.linked || (this.linked = [])).push({doc: copy, sharedHist: options.sharedHist}); - copy.linked = [{doc: this, isParent: true, sharedHist: options.sharedHist}]; - copySharedMarkers(copy, findSharedMarkers(this)); - return copy - }, - unlinkDoc: function(other) { - var this$1 = this; +(function(mod) { + if (true) // CommonJS + mod(__webpack_require__(/*! ../../lib/codemirror */ "./node_modules/codemirror/lib/codemirror.js")); + else {} +})(function(CodeMirror) { +"use strict"; - if (other instanceof CodeMirror$1) { other = other.doc; } - if (this.linked) { for (var i = 0; i < this.linked.length; ++i) { - var link = this$1.linked[i]; - if (link.doc != other) { continue } - this$1.linked.splice(i, 1); - other.unlinkDoc(this$1); - detachSharedMarkers(findSharedMarkers(this$1)); - break - } } - // If the histories were shared, split them again - if (other.history == this.history) { - var splitIds = [other.id]; - linkedDocs(other, function (doc) { return splitIds.push(doc.id); }, true); - other.history = new History(null); - other.history.done = copyHistoryArray(this.history.done, splitIds); - other.history.undone = copyHistoryArray(this.history.undone, splitIds); - } - }, - iterLinkedDocs: function(f) {linkedDocs(this, f);}, +CodeMirror.defineMode("css", function(config, parserConfig) { + var inline = parserConfig.inline + if (!parserConfig.propertyKeywords) parserConfig = CodeMirror.resolveMode("text/css"); - getMode: function() {return this.mode}, - getEditor: function() {return this.cm}, + var indentUnit = config.indentUnit, + tokenHooks = parserConfig.tokenHooks, + documentTypes = parserConfig.documentTypes || {}, + mediaTypes = parserConfig.mediaTypes || {}, + mediaFeatures = parserConfig.mediaFeatures || {}, + mediaValueKeywords = parserConfig.mediaValueKeywords || {}, + propertyKeywords = parserConfig.propertyKeywords || {}, + nonStandardPropertyKeywords = parserConfig.nonStandardPropertyKeywords || {}, + fontProperties = parserConfig.fontProperties || {}, + counterDescriptors = parserConfig.counterDescriptors || {}, + colorKeywords = parserConfig.colorKeywords || {}, + valueKeywords = parserConfig.valueKeywords || {}, + allowNested = parserConfig.allowNested, + lineComment = parserConfig.lineComment, + supportsAtComponent = parserConfig.supportsAtComponent === true; - splitLines: function(str) { - if (this.lineSep) { return str.split(this.lineSep) } - return splitLinesAuto(str) - }, - lineSeparator: function() { return this.lineSep || "\n" }, + var type, override; + function ret(style, tp) { type = tp; return style; } - setDirection: docMethodOp(function (dir) { - if (dir != "rtl") { dir = "ltr"; } - if (dir == this.direction) { return } - this.direction = dir; - this.iter(function (line) { return line.order = null; }); - if (this.cm) { directionChanged(this.cm); } - }) -}); + // Tokenizers -// Public alias. -Doc.prototype.eachLine = Doc.prototype.iter; - -// Kludge to work around strange IE behavior where it'll sometimes -// re-fire a series of drag-related events right after the drop (#1551) -var lastDrop = 0; - -function onDrop(e) { - var cm = this; - clearDragCursor(cm); - if (signalDOMEvent(cm, e) || eventInWidget(cm.display, e)) - { return } - e_preventDefault(e); - if (ie) { lastDrop = +new Date; } - var pos = posFromMouse(cm, e, true), files = e.dataTransfer.files; - if (!pos || cm.isReadOnly()) { return } - // Might be a file drop, in which case we simply extract the text - // and insert it. - if (files && files.length && window.FileReader && window.File) { - var n = files.length, text = Array(n), read = 0; - var loadFile = function (file, i) { - if (cm.options.allowDropFileTypes && - indexOf(cm.options.allowDropFileTypes, file.type) == -1) - { return } - - var reader = new FileReader; - reader.onload = operation(cm, function () { - var content = reader.result; - if (/[\x00-\x08\x0e-\x1f]{2}/.test(content)) { content = ""; } - text[i] = content; - if (++read == n) { - pos = clipPos(cm.doc, pos); - var change = {from: pos, to: pos, - text: cm.doc.splitLines(text.join(cm.doc.lineSeparator())), - origin: "paste"}; - makeChange(cm.doc, change); - setSelectionReplaceHistory(cm.doc, simpleSelection(pos, changeEnd(change))); - } - }); - reader.readAsText(file); - }; - for (var i = 0; i < n; ++i) { loadFile(files[i], i); } - } else { // Normal drop - // Don't do a replace if the drop happened inside of the selected text. - if (cm.state.draggingText && cm.doc.sel.contains(pos) > -1) { - cm.state.draggingText(e); - // Ensure the editor is re-focused - setTimeout(function () { return cm.display.input.focus(); }, 20); - return + function tokenBase(stream, state) { + var ch = stream.next(); + if (tokenHooks[ch]) { + var result = tokenHooks[ch](stream, state); + if (result !== false) return result; } - try { - var text$1 = e.dataTransfer.getData("Text"); - if (text$1) { - var selected; - if (cm.state.draggingText && !cm.state.draggingText.copy) - { selected = cm.listSelections(); } - setSelectionNoUndo(cm.doc, simpleSelection(pos, pos)); - if (selected) { for (var i$1 = 0; i$1 < selected.length; ++i$1) - { replaceRange(cm.doc, "", selected[i$1].anchor, selected[i$1].head, "drag"); } } - cm.replaceSelection(text$1, "around", "paste"); - cm.display.input.focus(); + if (ch == "@") { + stream.eatWhile(/[\w\\\-]/); + return ret("def", stream.current()); + } else if (ch == "=" || (ch == "~" || ch == "|") && stream.eat("=")) { + return ret(null, "compare"); + } else if (ch == "\"" || ch == "'") { + state.tokenize = tokenString(ch); + return state.tokenize(stream, state); + } else if (ch == "#") { + stream.eatWhile(/[\w\\\-]/); + return ret("atom", "hash"); + } else if (ch == "!") { + stream.match(/^\s*\w*/); + return ret("keyword", "important"); + } else if (/\d/.test(ch) || ch == "." && stream.eat(/\d/)) { + stream.eatWhile(/[\w.%]/); + return ret("number", "unit"); + } else if (ch === "-") { + if (/[\d.]/.test(stream.peek())) { + stream.eatWhile(/[\w.%]/); + return ret("number", "unit"); + } else if (stream.match(/^-[\w\\\-]*/)) { + stream.eatWhile(/[\w\\\-]/); + if (stream.match(/^\s*:/, false)) + return ret("variable-2", "variable-definition"); + return ret("variable-2", "variable"); + } else if (stream.match(/^\w+-/)) { + return ret("meta", "meta"); } + } else if (/[,+>*\/]/.test(ch)) { + return ret(null, "select-op"); + } else if (ch == "." && stream.match(/^-?[_a-z][_a-z0-9-]*/i)) { + return ret("qualifier", "qualifier"); + } else if (/[:;{}\[\]\(\)]/.test(ch)) { + return ret(null, ch); + } else if (stream.match(/[\w-.]+(?=\()/)) { + if (/^(url(-prefix)?|domain|regexp)$/.test(stream.current().toLowerCase())) { + state.tokenize = tokenParenthesized; + } + return ret("variable callee", "variable"); + } else if (/[\w\\\-]/.test(ch)) { + stream.eatWhile(/[\w\\\-]/); + return ret("property", "word"); + } else { + return ret(null, null); } - catch(e){} } -} - -function onDragStart(cm, e) { - if (ie && (!cm.state.draggingText || +new Date - lastDrop < 100)) { e_stop(e); return } - if (signalDOMEvent(cm, e) || eventInWidget(cm.display, e)) { return } - e.dataTransfer.setData("Text", cm.getSelection()); - e.dataTransfer.effectAllowed = "copyMove"; + function tokenString(quote) { + return function(stream, state) { + var escaped = false, ch; + while ((ch = stream.next()) != null) { + if (ch == quote && !escaped) { + if (quote == ")") stream.backUp(1); + break; + } + escaped = !escaped && ch == "\\"; + } + if (ch == quote || !escaped && quote != ")") state.tokenize = null; + return ret("string", "string"); + }; + } - // Use dummy image instead of default browsers image. - // Recent Safari (~6.0.2) have a tendency to segfault when this happens, so we don't do it there. - if (e.dataTransfer.setDragImage && !safari) { - var img = elt("img", null, null, "position: fixed; left: 0; top: 0;"); - img.src = "data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw=="; - if (presto) { - img.width = img.height = 1; - cm.display.wrapper.appendChild(img); - // Force a relayout, or Opera won't use our image for some obscure reason - img._top = img.offsetTop; - } - e.dataTransfer.setDragImage(img, 0, 0); - if (presto) { img.parentNode.removeChild(img); } + function tokenParenthesized(stream, state) { + stream.next(); // Must be '(' + if (!stream.match(/\s*[\"\')]/, false)) + state.tokenize = tokenString(")"); + else + state.tokenize = null; + return ret(null, "("); } -} -function onDragOver(cm, e) { - var pos = posFromMouse(cm, e); - if (!pos) { return } - var frag = document.createDocumentFragment(); - drawSelectionCursor(cm, pos, frag); - if (!cm.display.dragCursor) { - cm.display.dragCursor = elt("div", null, "CodeMirror-cursors CodeMirror-dragcursors"); - cm.display.lineSpace.insertBefore(cm.display.dragCursor, cm.display.cursorDiv); + // Context management + + function Context(type, indent, prev) { + this.type = type; + this.indent = indent; + this.prev = prev; } - removeChildrenAndAdd(cm.display.dragCursor, frag); -} -function clearDragCursor(cm) { - if (cm.display.dragCursor) { - cm.display.lineSpace.removeChild(cm.display.dragCursor); - cm.display.dragCursor = null; + function pushContext(state, stream, type, indent) { + state.context = new Context(type, stream.indentation() + (indent === false ? 0 : indentUnit), state.context); + return type; } -} -// These must be handled carefully, because naively registering a -// handler for each editor will cause the editors to never be -// garbage collected. + function popContext(state) { + if (state.context.prev) + state.context = state.context.prev; + return state.context.type; + } -function forEachCodeMirror(f) { - if (!document.getElementsByClassName) { return } - var byClass = document.getElementsByClassName("CodeMirror"); - for (var i = 0; i < byClass.length; i++) { - var cm = byClass[i].CodeMirror; - if (cm) { f(cm); } + function pass(type, stream, state) { + return states[state.context.type](type, stream, state); + } + function popAndPass(type, stream, state, n) { + for (var i = n || 1; i > 0; i--) + state.context = state.context.prev; + return pass(type, stream, state); } -} -var globalsRegistered = false; -function ensureGlobalHandlers() { - if (globalsRegistered) { return } - registerGlobalHandlers(); - globalsRegistered = true; -} -function registerGlobalHandlers() { - // When the window resizes, we need to refresh active editors. - var resizeTimer; - on(window, "resize", function () { - if (resizeTimer == null) { resizeTimer = setTimeout(function () { - resizeTimer = null; - forEachCodeMirror(onResize); - }, 100); } - }); - // When the window loses focus, we want to show the editor as blurred - on(window, "blur", function () { return forEachCodeMirror(onBlur); }); -} -// Called when the window resizes -function onResize(cm) { - var d = cm.display; - if (d.lastWrapHeight == d.wrapper.clientHeight && d.lastWrapWidth == d.wrapper.clientWidth) - { return } - // Might be a text scaling operation, clear size caches. - d.cachedCharWidth = d.cachedTextHeight = d.cachedPaddingH = null; - d.scrollbarsClipped = false; - cm.setSize(); -} + // Parser -var keyNames = { - 3: "Enter", 8: "Backspace", 9: "Tab", 13: "Enter", 16: "Shift", 17: "Ctrl", 18: "Alt", - 19: "Pause", 20: "CapsLock", 27: "Esc", 32: "Space", 33: "PageUp", 34: "PageDown", 35: "End", - 36: "Home", 37: "Left", 38: "Up", 39: "Right", 40: "Down", 44: "PrintScrn", 45: "Insert", - 46: "Delete", 59: ";", 61: "=", 91: "Mod", 92: "Mod", 93: "Mod", - 106: "*", 107: "=", 109: "-", 110: ".", 111: "/", 127: "Delete", - 173: "-", 186: ";", 187: "=", 188: ",", 189: "-", 190: ".", 191: "/", 192: "`", 219: "[", 220: "\\", - 221: "]", 222: "'", 63232: "Up", 63233: "Down", 63234: "Left", 63235: "Right", 63272: "Delete", - 63273: "Home", 63275: "End", 63276: "PageUp", 63277: "PageDown", 63302: "Insert" -}; + function wordAsValue(stream) { + var word = stream.current().toLowerCase(); + if (valueKeywords.hasOwnProperty(word)) + override = "atom"; + else if (colorKeywords.hasOwnProperty(word)) + override = "keyword"; + else + override = "variable"; + } -// Number keys -for (var i = 0; i < 10; i++) { keyNames[i + 48] = keyNames[i + 96] = String(i); } -// Alphabetic keys -for (var i$1 = 65; i$1 <= 90; i$1++) { keyNames[i$1] = String.fromCharCode(i$1); } -// Function keys -for (var i$2 = 1; i$2 <= 12; i$2++) { keyNames[i$2 + 111] = keyNames[i$2 + 63235] = "F" + i$2; } - -var keyMap = {}; - -keyMap.basic = { - "Left": "goCharLeft", "Right": "goCharRight", "Up": "goLineUp", "Down": "goLineDown", - "End": "goLineEnd", "Home": "goLineStartSmart", "PageUp": "goPageUp", "PageDown": "goPageDown", - "Delete": "delCharAfter", "Backspace": "delCharBefore", "Shift-Backspace": "delCharBefore", - "Tab": "defaultTab", "Shift-Tab": "indentAuto", - "Enter": "newlineAndIndent", "Insert": "toggleOverwrite", - "Esc": "singleSelection" -}; -// Note that the save and find-related commands aren't defined by -// default. User code or addons can define them. Unknown commands -// are simply ignored. -keyMap.pcDefault = { - "Ctrl-A": "selectAll", "Ctrl-D": "deleteLine", "Ctrl-Z": "undo", "Shift-Ctrl-Z": "redo", "Ctrl-Y": "redo", - "Ctrl-Home": "goDocStart", "Ctrl-End": "goDocEnd", "Ctrl-Up": "goLineUp", "Ctrl-Down": "goLineDown", - "Ctrl-Left": "goGroupLeft", "Ctrl-Right": "goGroupRight", "Alt-Left": "goLineStart", "Alt-Right": "goLineEnd", - "Ctrl-Backspace": "delGroupBefore", "Ctrl-Delete": "delGroupAfter", "Ctrl-S": "save", "Ctrl-F": "find", - "Ctrl-G": "findNext", "Shift-Ctrl-G": "findPrev", "Shift-Ctrl-F": "replace", "Shift-Ctrl-R": "replaceAll", - "Ctrl-[": "indentLess", "Ctrl-]": "indentMore", - "Ctrl-U": "undoSelection", "Shift-Ctrl-U": "redoSelection", "Alt-U": "redoSelection", - fallthrough: "basic" -}; -// Very basic readline/emacs-style bindings, which are standard on Mac. -keyMap.emacsy = { - "Ctrl-F": "goCharRight", "Ctrl-B": "goCharLeft", "Ctrl-P": "goLineUp", "Ctrl-N": "goLineDown", - "Alt-F": "goWordRight", "Alt-B": "goWordLeft", "Ctrl-A": "goLineStart", "Ctrl-E": "goLineEnd", - "Ctrl-V": "goPageDown", "Shift-Ctrl-V": "goPageUp", "Ctrl-D": "delCharAfter", "Ctrl-H": "delCharBefore", - "Alt-D": "delWordAfter", "Alt-Backspace": "delWordBefore", "Ctrl-K": "killLine", "Ctrl-T": "transposeChars", - "Ctrl-O": "openLine" -}; -keyMap.macDefault = { - "Cmd-A": "selectAll", "Cmd-D": "deleteLine", "Cmd-Z": "undo", "Shift-Cmd-Z": "redo", "Cmd-Y": "redo", - "Cmd-Home": "goDocStart", "Cmd-Up": "goDocStart", "Cmd-End": "goDocEnd", "Cmd-Down": "goDocEnd", "Alt-Left": "goGroupLeft", - "Alt-Right": "goGroupRight", "Cmd-Left": "goLineLeft", "Cmd-Right": "goLineRight", "Alt-Backspace": "delGroupBefore", - "Ctrl-Alt-Backspace": "delGroupAfter", "Alt-Delete": "delGroupAfter", "Cmd-S": "save", "Cmd-F": "find", - "Cmd-G": "findNext", "Shift-Cmd-G": "findPrev", "Cmd-Alt-F": "replace", "Shift-Cmd-Alt-F": "replaceAll", - "Cmd-[": "indentLess", "Cmd-]": "indentMore", "Cmd-Backspace": "delWrappedLineLeft", "Cmd-Delete": "delWrappedLineRight", - "Cmd-U": "undoSelection", "Shift-Cmd-U": "redoSelection", "Ctrl-Up": "goDocStart", "Ctrl-Down": "goDocEnd", - fallthrough: ["basic", "emacsy"] -}; -keyMap["default"] = mac ? keyMap.macDefault : keyMap.pcDefault; - -// KEYMAP DISPATCH - -function normalizeKeyName(name) { - var parts = name.split(/-(?!$)/); - name = parts[parts.length - 1]; - var alt, ctrl, shift, cmd; - for (var i = 0; i < parts.length - 1; i++) { - var mod = parts[i]; - if (/^(cmd|meta|m)$/i.test(mod)) { cmd = true; } - else if (/^a(lt)?$/i.test(mod)) { alt = true; } - else if (/^(c|ctrl|control)$/i.test(mod)) { ctrl = true; } - else if (/^s(hift)?$/i.test(mod)) { shift = true; } - else { throw new Error("Unrecognized modifier name: " + mod) } - } - if (alt) { name = "Alt-" + name; } - if (ctrl) { name = "Ctrl-" + name; } - if (cmd) { name = "Cmd-" + name; } - if (shift) { name = "Shift-" + name; } - return name -} + var states = {}; -// This is a kludge to keep keymaps mostly working as raw objects -// (backwards compatibility) while at the same time support features -// like normalization and multi-stroke key bindings. It compiles a -// new normalized keymap, and then updates the old object to reflect -// this. -function normalizeKeyMap(keymap) { - var copy = {}; - for (var keyname in keymap) { if (keymap.hasOwnProperty(keyname)) { - var value = keymap[keyname]; - if (/^(name|fallthrough|(de|at)tach)$/.test(keyname)) { continue } - if (value == "...") { delete keymap[keyname]; continue } - - var keys = map(keyname.split(" "), normalizeKeyName); - for (var i = 0; i < keys.length; i++) { - var val = (void 0), name = (void 0); - if (i == keys.length - 1) { - name = keys.join(" "); - val = value; - } else { - name = keys.slice(0, i + 1).join(" "); - val = "..."; - } - var prev = copy[name]; - if (!prev) { copy[name] = val; } - else if (prev != val) { throw new Error("Inconsistent bindings for " + name) } + states.top = function(type, stream, state) { + if (type == "{") { + return pushContext(state, stream, "block"); + } else if (type == "}" && state.context.prev) { + return popContext(state); + } else if (supportsAtComponent && /@component/i.test(type)) { + return pushContext(state, stream, "atComponentBlock"); + } else if (/^@(-moz-)?document$/i.test(type)) { + return pushContext(state, stream, "documentTypes"); + } else if (/^@(media|supports|(-moz-)?document|import)$/i.test(type)) { + return pushContext(state, stream, "atBlock"); + } else if (/^@(font-face|counter-style)/i.test(type)) { + state.stateArg = type; + return "restricted_atBlock_before"; + } else if (/^@(-(moz|ms|o|webkit)-)?keyframes$/i.test(type)) { + return "keyframes"; + } else if (type && type.charAt(0) == "@") { + return pushContext(state, stream, "at"); + } else if (type == "hash") { + override = "builtin"; + } else if (type == "word") { + override = "tag"; + } else if (type == "variable-definition") { + return "maybeprop"; + } else if (type == "interpolation") { + return pushContext(state, stream, "interpolation"); + } else if (type == ":") { + return "pseudo"; + } else if (allowNested && type == "(") { + return pushContext(state, stream, "parens"); } - delete keymap[keyname]; - } } - for (var prop in copy) { keymap[prop] = copy[prop]; } - return keymap -} + return state.context.type; + }; -function lookupKey(key, map$$1, handle, context) { - map$$1 = getKeyMap(map$$1); - var found = map$$1.call ? map$$1.call(key, context) : map$$1[key]; - if (found === false) { return "nothing" } - if (found === "...") { return "multi" } - if (found != null && handle(found)) { return "handled" } - - if (map$$1.fallthrough) { - if (Object.prototype.toString.call(map$$1.fallthrough) != "[object Array]") - { return lookupKey(key, map$$1.fallthrough, handle, context) } - for (var i = 0; i < map$$1.fallthrough.length; i++) { - var result = lookupKey(key, map$$1.fallthrough[i], handle, context); - if (result) { return result } + states.block = function(type, stream, state) { + if (type == "word") { + var word = stream.current().toLowerCase(); + if (propertyKeywords.hasOwnProperty(word)) { + override = "property"; + return "maybeprop"; + } else if (nonStandardPropertyKeywords.hasOwnProperty(word)) { + override = "string-2"; + return "maybeprop"; + } else if (allowNested) { + override = stream.match(/^\s*:(?:\s|$)/, false) ? "property" : "tag"; + return "block"; + } else { + override += " error"; + return "maybeprop"; + } + } else if (type == "meta") { + return "block"; + } else if (!allowNested && (type == "hash" || type == "qualifier")) { + override = "error"; + return "block"; + } else { + return states.top(type, stream, state); } - } -} - -// Modifier key presses don't count as 'real' key presses for the -// purpose of keymap fallthrough. -function isModifierKey(value) { - var name = typeof value == "string" ? value : keyNames[value.keyCode]; - return name == "Ctrl" || name == "Alt" || name == "Shift" || name == "Mod" -} - -function addModifierNames(name, event, noShift) { - var base = name; - if (event.altKey && base != "Alt") { name = "Alt-" + name; } - if ((flipCtrlCmd ? event.metaKey : event.ctrlKey) && base != "Ctrl") { name = "Ctrl-" + name; } - if ((flipCtrlCmd ? event.ctrlKey : event.metaKey) && base != "Cmd") { name = "Cmd-" + name; } - if (!noShift && event.shiftKey && base != "Shift") { name = "Shift-" + name; } - return name -} + }; -// Look up the name of a key as indicated by an event object. -function keyName(event, noShift) { - if (presto && event.keyCode == 34 && event["char"]) { return false } - var name = keyNames[event.keyCode]; - if (name == null || event.altGraphKey) { return false } - return addModifierNames(name, event, noShift) -} + states.maybeprop = function(type, stream, state) { + if (type == ":") return pushContext(state, stream, "prop"); + return pass(type, stream, state); + }; -function getKeyMap(val) { - return typeof val == "string" ? keyMap[val] : val -} + states.prop = function(type, stream, state) { + if (type == ";") return popContext(state); + if (type == "{" && allowNested) return pushContext(state, stream, "propBlock"); + if (type == "}" || type == "{") return popAndPass(type, stream, state); + if (type == "(") return pushContext(state, stream, "parens"); -// Helper for deleting text near the selection(s), used to implement -// backspace, delete, and similar functionality. -function deleteNearSelection(cm, compute) { - var ranges = cm.doc.sel.ranges, kill = []; - // Build up a set of ranges to kill first, merging overlapping - // ranges. - for (var i = 0; i < ranges.length; i++) { - var toKill = compute(ranges[i]); - while (kill.length && cmp(toKill.from, lst(kill).to) <= 0) { - var replaced = kill.pop(); - if (cmp(replaced.from, toKill.from) < 0) { - toKill.from = replaced.from; - break - } + if (type == "hash" && !/^#([0-9a-fA-f]{3,4}|[0-9a-fA-f]{6}|[0-9a-fA-f]{8})$/.test(stream.current())) { + override += " error"; + } else if (type == "word") { + wordAsValue(stream); + } else if (type == "interpolation") { + return pushContext(state, stream, "interpolation"); } - kill.push(toKill); - } - // Next, remove those actual ranges. - runInOp(cm, function () { - for (var i = kill.length - 1; i >= 0; i--) - { replaceRange(cm.doc, "", kill[i].from, kill[i].to, "+delete"); } - ensureCursorVisible(cm); - }); -} - -function moveCharLogically(line, ch, dir) { - var target = skipExtendingChars(line.text, ch + dir, dir); - return target < 0 || target > line.text.length ? null : target -} + return "prop"; + }; -function moveLogically(line, start, dir) { - var ch = moveCharLogically(line, start.ch, dir); - return ch == null ? null : new Pos(start.line, ch, dir < 0 ? "after" : "before") -} + states.propBlock = function(type, _stream, state) { + if (type == "}") return popContext(state); + if (type == "word") { override = "property"; return "maybeprop"; } + return state.context.type; + }; -function endOfLine(visually, cm, lineObj, lineNo, dir) { - if (visually) { - var order = getOrder(lineObj, cm.doc.direction); - if (order) { - var part = dir < 0 ? lst(order) : order[0]; - var moveInStorageOrder = (dir < 0) == (part.level == 1); - var sticky = moveInStorageOrder ? "after" : "before"; - var ch; - // With a wrapped rtl chunk (possibly spanning multiple bidi parts), - // it could be that the last bidi part is not on the last visual line, - // since visual lines contain content order-consecutive chunks. - // Thus, in rtl, we are looking for the first (content-order) character - // in the rtl chunk that is on the last line (that is, the same line - // as the last (content-order) character). - if (part.level > 0 || cm.doc.direction == "rtl") { - var prep = prepareMeasureForLine(cm, lineObj); - ch = dir < 0 ? lineObj.text.length - 1 : 0; - var targetTop = measureCharPrepared(cm, prep, ch).top; - ch = findFirst(function (ch) { return measureCharPrepared(cm, prep, ch).top == targetTop; }, (dir < 0) == (part.level == 1) ? part.from : part.to - 1, ch); - if (sticky == "before") { ch = moveCharLogically(lineObj, ch, 1); } - } else { ch = dir < 0 ? part.to : part.from; } - return new Pos(lineNo, ch, sticky) - } - } - return new Pos(lineNo, dir < 0 ? lineObj.text.length : 0, dir < 0 ? "before" : "after") -} + states.parens = function(type, stream, state) { + if (type == "{" || type == "}") return popAndPass(type, stream, state); + if (type == ")") return popContext(state); + if (type == "(") return pushContext(state, stream, "parens"); + if (type == "interpolation") return pushContext(state, stream, "interpolation"); + if (type == "word") wordAsValue(stream); + return "parens"; + }; -function moveVisually(cm, line, start, dir) { - var bidi = getOrder(line, cm.doc.direction); - if (!bidi) { return moveLogically(line, start, dir) } - if (start.ch >= line.text.length) { - start.ch = line.text.length; - start.sticky = "before"; - } else if (start.ch <= 0) { - start.ch = 0; - start.sticky = "after"; - } - var partPos = getBidiPartAt(bidi, start.ch, start.sticky), part = bidi[partPos]; - if (cm.doc.direction == "ltr" && part.level % 2 == 0 && (dir > 0 ? part.to > start.ch : part.from < start.ch)) { - // Case 1: We move within an ltr part in an ltr editor. Even with wrapped lines, - // nothing interesting happens. - return moveLogically(line, start, dir) - } + states.pseudo = function(type, stream, state) { + if (type == "meta") return "pseudo"; - var mv = function (pos, dir) { return moveCharLogically(line, pos instanceof Pos ? pos.ch : pos, dir); }; - var prep; - var getWrappedLineExtent = function (ch) { - if (!cm.options.lineWrapping) { return {begin: 0, end: line.text.length} } - prep = prep || prepareMeasureForLine(cm, line); - return wrappedLineExtentChar(cm, line, prep, ch) + if (type == "word") { + override = "variable-3"; + return state.context.type; + } + return pass(type, stream, state); }; - var wrappedLineExtent = getWrappedLineExtent(start.sticky == "before" ? mv(start, -1) : start.ch); - if (cm.doc.direction == "rtl" || part.level == 1) { - var moveInStorageOrder = (part.level == 1) == (dir < 0); - var ch = mv(start, moveInStorageOrder ? 1 : -1); - if (ch != null && (!moveInStorageOrder ? ch >= part.from && ch >= wrappedLineExtent.begin : ch <= part.to && ch <= wrappedLineExtent.end)) { - // Case 2: We move within an rtl part or in an rtl editor on the same visual line - var sticky = moveInStorageOrder ? "before" : "after"; - return new Pos(start.line, ch, sticky) + states.documentTypes = function(type, stream, state) { + if (type == "word" && documentTypes.hasOwnProperty(stream.current())) { + override = "tag"; + return state.context.type; + } else { + return states.atBlock(type, stream, state); } - } + }; - // Case 3: Could not move within this bidi part in this visual line, so leave - // the current bidi part + states.atBlock = function(type, stream, state) { + if (type == "(") return pushContext(state, stream, "atBlock_parens"); + if (type == "}" || type == ";") return popAndPass(type, stream, state); + if (type == "{") return popContext(state) && pushContext(state, stream, allowNested ? "block" : "top"); - var searchInVisualLine = function (partPos, dir, wrappedLineExtent) { - var getRes = function (ch, moveInStorageOrder) { return moveInStorageOrder - ? new Pos(start.line, mv(ch, 1), "before") - : new Pos(start.line, ch, "after"); }; + if (type == "interpolation") return pushContext(state, stream, "interpolation"); - for (; partPos >= 0 && partPos < bidi.length; partPos += dir) { - var part = bidi[partPos]; - var moveInStorageOrder = (dir > 0) == (part.level != 1); - var ch = moveInStorageOrder ? wrappedLineExtent.begin : mv(wrappedLineExtent.end, -1); - if (part.from <= ch && ch < part.to) { return getRes(ch, moveInStorageOrder) } - ch = moveInStorageOrder ? part.from : mv(part.to, -1); - if (wrappedLineExtent.begin <= ch && ch < wrappedLineExtent.end) { return getRes(ch, moveInStorageOrder) } + if (type == "word") { + var word = stream.current().toLowerCase(); + if (word == "only" || word == "not" || word == "and" || word == "or") + override = "keyword"; + else if (mediaTypes.hasOwnProperty(word)) + override = "attribute"; + else if (mediaFeatures.hasOwnProperty(word)) + override = "property"; + else if (mediaValueKeywords.hasOwnProperty(word)) + override = "keyword"; + else if (propertyKeywords.hasOwnProperty(word)) + override = "property"; + else if (nonStandardPropertyKeywords.hasOwnProperty(word)) + override = "string-2"; + else if (valueKeywords.hasOwnProperty(word)) + override = "atom"; + else if (colorKeywords.hasOwnProperty(word)) + override = "keyword"; + else + override = "error"; } + return state.context.type; }; - // Case 3a: Look for other bidi parts on the same visual line - var res = searchInVisualLine(partPos + dir, dir, wrappedLineExtent); - if (res) { return res } + states.atComponentBlock = function(type, stream, state) { + if (type == "}") + return popAndPass(type, stream, state); + if (type == "{") + return popContext(state) && pushContext(state, stream, allowNested ? "block" : "top", false); + if (type == "word") + override = "error"; + return state.context.type; + }; - // Case 3b: Look for other bidi parts on the next visual line - var nextCh = dir > 0 ? wrappedLineExtent.end : mv(wrappedLineExtent.begin, -1); - if (nextCh != null && !(dir > 0 && nextCh == line.text.length)) { - res = searchInVisualLine(dir > 0 ? 0 : bidi.length - 1, dir, getWrappedLineExtent(nextCh)); - if (res) { return res } - } + states.atBlock_parens = function(type, stream, state) { + if (type == ")") return popContext(state); + if (type == "{" || type == "}") return popAndPass(type, stream, state, 2); + return states.atBlock(type, stream, state); + }; - // Case 4: Nowhere to move - return null -} + states.restricted_atBlock_before = function(type, stream, state) { + if (type == "{") + return pushContext(state, stream, "restricted_atBlock"); + if (type == "word" && state.stateArg == "@counter-style") { + override = "variable"; + return "restricted_atBlock_before"; + } + return pass(type, stream, state); + }; -// Commands are parameter-less actions that can be performed on an -// editor, mostly used for keybindings. -var commands = { - selectAll: selectAll, - singleSelection: function (cm) { return cm.setSelection(cm.getCursor("anchor"), cm.getCursor("head"), sel_dontScroll); }, - killLine: function (cm) { return deleteNearSelection(cm, function (range) { - if (range.empty()) { - var len = getLine(cm.doc, range.head.line).text.length; - if (range.head.ch == len && range.head.line < cm.lastLine()) - { return {from: range.head, to: Pos(range.head.line + 1, 0)} } - else - { return {from: range.head, to: Pos(range.head.line, len)} } - } else { - return {from: range.from(), to: range.to()} - } - }); }, - deleteLine: function (cm) { return deleteNearSelection(cm, function (range) { return ({ - from: Pos(range.from().line, 0), - to: clipPos(cm.doc, Pos(range.to().line + 1, 0)) - }); }); }, - delLineLeft: function (cm) { return deleteNearSelection(cm, function (range) { return ({ - from: Pos(range.from().line, 0), to: range.from() - }); }); }, - delWrappedLineLeft: function (cm) { return deleteNearSelection(cm, function (range) { - var top = cm.charCoords(range.head, "div").top + 5; - var leftPos = cm.coordsChar({left: 0, top: top}, "div"); - return {from: leftPos, to: range.from()} - }); }, - delWrappedLineRight: function (cm) { return deleteNearSelection(cm, function (range) { - var top = cm.charCoords(range.head, "div").top + 5; - var rightPos = cm.coordsChar({left: cm.display.lineDiv.offsetWidth + 100, top: top}, "div"); - return {from: range.from(), to: rightPos } - }); }, - undo: function (cm) { return cm.undo(); }, - redo: function (cm) { return cm.redo(); }, - undoSelection: function (cm) { return cm.undoSelection(); }, - redoSelection: function (cm) { return cm.redoSelection(); }, - goDocStart: function (cm) { return cm.extendSelection(Pos(cm.firstLine(), 0)); }, - goDocEnd: function (cm) { return cm.extendSelection(Pos(cm.lastLine())); }, - goLineStart: function (cm) { return cm.extendSelectionsBy(function (range) { return lineStart(cm, range.head.line); }, - {origin: "+move", bias: 1} - ); }, - goLineStartSmart: function (cm) { return cm.extendSelectionsBy(function (range) { return lineStartSmart(cm, range.head); }, - {origin: "+move", bias: 1} - ); }, - goLineEnd: function (cm) { return cm.extendSelectionsBy(function (range) { return lineEnd(cm, range.head.line); }, - {origin: "+move", bias: -1} - ); }, - goLineRight: function (cm) { return cm.extendSelectionsBy(function (range) { - var top = cm.cursorCoords(range.head, "div").top + 5; - return cm.coordsChar({left: cm.display.lineDiv.offsetWidth + 100, top: top}, "div") - }, sel_move); }, - goLineLeft: function (cm) { return cm.extendSelectionsBy(function (range) { - var top = cm.cursorCoords(range.head, "div").top + 5; - return cm.coordsChar({left: 0, top: top}, "div") - }, sel_move); }, - goLineLeftSmart: function (cm) { return cm.extendSelectionsBy(function (range) { - var top = cm.cursorCoords(range.head, "div").top + 5; - var pos = cm.coordsChar({left: 0, top: top}, "div"); - if (pos.ch < cm.getLine(pos.line).search(/\S/)) { return lineStartSmart(cm, range.head) } - return pos - }, sel_move); }, - goLineUp: function (cm) { return cm.moveV(-1, "line"); }, - goLineDown: function (cm) { return cm.moveV(1, "line"); }, - goPageUp: function (cm) { return cm.moveV(-1, "page"); }, - goPageDown: function (cm) { return cm.moveV(1, "page"); }, - goCharLeft: function (cm) { return cm.moveH(-1, "char"); }, - goCharRight: function (cm) { return cm.moveH(1, "char"); }, - goColumnLeft: function (cm) { return cm.moveH(-1, "column"); }, - goColumnRight: function (cm) { return cm.moveH(1, "column"); }, - goWordLeft: function (cm) { return cm.moveH(-1, "word"); }, - goGroupRight: function (cm) { return cm.moveH(1, "group"); }, - goGroupLeft: function (cm) { return cm.moveH(-1, "group"); }, - goWordRight: function (cm) { return cm.moveH(1, "word"); }, - delCharBefore: function (cm) { return cm.deleteH(-1, "char"); }, - delCharAfter: function (cm) { return cm.deleteH(1, "char"); }, - delWordBefore: function (cm) { return cm.deleteH(-1, "word"); }, - delWordAfter: function (cm) { return cm.deleteH(1, "word"); }, - delGroupBefore: function (cm) { return cm.deleteH(-1, "group"); }, - delGroupAfter: function (cm) { return cm.deleteH(1, "group"); }, - indentAuto: function (cm) { return cm.indentSelection("smart"); }, - indentMore: function (cm) { return cm.indentSelection("add"); }, - indentLess: function (cm) { return cm.indentSelection("subtract"); }, - insertTab: function (cm) { return cm.replaceSelection("\t"); }, - insertSoftTab: function (cm) { - var spaces = [], ranges = cm.listSelections(), tabSize = cm.options.tabSize; - for (var i = 0; i < ranges.length; i++) { - var pos = ranges[i].from(); - var col = countColumn(cm.getLine(pos.line), pos.ch, tabSize); - spaces.push(spaceStr(tabSize - col % tabSize)); + states.restricted_atBlock = function(type, stream, state) { + if (type == "}") { + state.stateArg = null; + return popContext(state); } - cm.replaceSelections(spaces); - }, - defaultTab: function (cm) { - if (cm.somethingSelected()) { cm.indentSelection("add"); } - else { cm.execCommand("insertTab"); } - }, - // Swap the two chars left and right of each selection's head. - // Move cursor behind the two swapped characters afterwards. - // - // Doesn't consider line feeds a character. - // Doesn't scan more than one line above to find a character. - // Doesn't do anything on an empty line. - // Doesn't do anything with non-empty selections. - transposeChars: function (cm) { return runInOp(cm, function () { - var ranges = cm.listSelections(), newSel = []; - for (var i = 0; i < ranges.length; i++) { - if (!ranges[i].empty()) { continue } - var cur = ranges[i].head, line = getLine(cm.doc, cur.line).text; - if (line) { - if (cur.ch == line.length) { cur = new Pos(cur.line, cur.ch - 1); } - if (cur.ch > 0) { - cur = new Pos(cur.line, cur.ch + 1); - cm.replaceRange(line.charAt(cur.ch - 1) + line.charAt(cur.ch - 2), - Pos(cur.line, cur.ch - 2), cur, "+transpose"); - } else if (cur.line > cm.doc.first) { - var prev = getLine(cm.doc, cur.line - 1).text; - if (prev) { - cur = new Pos(cur.line, 1); - cm.replaceRange(line.charAt(0) + cm.doc.lineSeparator() + - prev.charAt(prev.length - 1), - Pos(cur.line - 1, prev.length - 1), cur, "+transpose"); - } - } - } - newSel.push(new Range(cur, cur)); + if (type == "word") { + if ((state.stateArg == "@font-face" && !fontProperties.hasOwnProperty(stream.current().toLowerCase())) || + (state.stateArg == "@counter-style" && !counterDescriptors.hasOwnProperty(stream.current().toLowerCase()))) + override = "error"; + else + override = "property"; + return "maybeprop"; } - cm.setSelections(newSel); - }); }, - newlineAndIndent: function (cm) { return runInOp(cm, function () { - var sels = cm.listSelections(); - for (var i = sels.length - 1; i >= 0; i--) - { cm.replaceRange(cm.doc.lineSeparator(), sels[i].anchor, sels[i].head, "+input"); } - sels = cm.listSelections(); - for (var i$1 = 0; i$1 < sels.length; i$1++) - { cm.indentLine(sels[i$1].from().line, null, true); } - ensureCursorVisible(cm); - }); }, - openLine: function (cm) { return cm.replaceSelection("\n", "start"); }, - toggleOverwrite: function (cm) { return cm.toggleOverwrite(); } -}; + return "restricted_atBlock"; + }; + states.keyframes = function(type, stream, state) { + if (type == "word") { override = "variable"; return "keyframes"; } + if (type == "{") return pushContext(state, stream, "top"); + return pass(type, stream, state); + }; -function lineStart(cm, lineN) { - var line = getLine(cm.doc, lineN); - var visual = visualLine(line); - if (visual != line) { lineN = lineNo(visual); } - return endOfLine(true, cm, visual, lineN, 1) -} -function lineEnd(cm, lineN) { - var line = getLine(cm.doc, lineN); - var visual = visualLineEnd(line); - if (visual != line) { lineN = lineNo(visual); } - return endOfLine(true, cm, line, lineN, -1) -} -function lineStartSmart(cm, pos) { - var start = lineStart(cm, pos.line); - var line = getLine(cm.doc, start.line); - var order = getOrder(line, cm.doc.direction); - if (!order || order[0].level == 0) { - var firstNonWS = Math.max(0, line.text.search(/\S/)); - var inWS = pos.line == start.line && pos.ch <= firstNonWS && pos.ch; - return Pos(start.line, inWS ? 0 : firstNonWS, start.sticky) - } - return start -} + states.at = function(type, stream, state) { + if (type == ";") return popContext(state); + if (type == "{" || type == "}") return popAndPass(type, stream, state); + if (type == "word") override = "tag"; + else if (type == "hash") override = "builtin"; + return "at"; + }; -// Run a handler that was bound to a key. -function doHandleBinding(cm, bound, dropShift) { - if (typeof bound == "string") { - bound = commands[bound]; - if (!bound) { return false } - } - // Ensure previous input has been read, so that the handler sees a - // consistent view of the document - cm.display.input.ensurePolled(); - var prevShift = cm.display.shift, done = false; - try { - if (cm.isReadOnly()) { cm.state.suppressEdits = true; } - if (dropShift) { cm.display.shift = false; } - done = bound(cm) != Pass; - } finally { - cm.display.shift = prevShift; - cm.state.suppressEdits = false; - } - return done -} + states.interpolation = function(type, stream, state) { + if (type == "}") return popContext(state); + if (type == "{" || type == ";") return popAndPass(type, stream, state); + if (type == "word") override = "variable"; + else if (type != "variable" && type != "(" && type != ")") override = "error"; + return "interpolation"; + }; -function lookupKeyForEditor(cm, name, handle) { - for (var i = 0; i < cm.state.keyMaps.length; i++) { - var result = lookupKey(name, cm.state.keyMaps[i], handle, cm); - if (result) { return result } - } - return (cm.options.extraKeys && lookupKey(name, cm.options.extraKeys, handle, cm)) - || lookupKey(name, cm.options.keyMap, handle, cm) -} + return { + startState: function(base) { + return {tokenize: null, + state: inline ? "block" : "top", + stateArg: null, + context: new Context(inline ? "block" : "top", base || 0, null)}; + }, -// Note that, despite the name, this function is also used to check -// for bound mouse clicks. - -var stopSeq = new Delayed; -function dispatchKey(cm, name, e, handle) { - var seq = cm.state.keySeq; - if (seq) { - if (isModifierKey(name)) { return "handled" } - stopSeq.set(50, function () { - if (cm.state.keySeq == seq) { - cm.state.keySeq = null; - cm.display.input.reset(); + token: function(stream, state) { + if (!state.tokenize && stream.eatSpace()) return null; + var style = (state.tokenize || tokenBase)(stream, state); + if (style && typeof style == "object") { + type = style[1]; + style = style[0]; } - }); - name = seq + " " + name; - } - var result = lookupKeyForEditor(cm, name, handle); + override = style; + if (type != "comment") + state.state = states[state.state](type, stream, state); + return override; + }, - if (result == "multi") - { cm.state.keySeq = name; } - if (result == "handled") - { signalLater(cm, "keyHandled", cm, name, e); } - - if (result == "handled" || result == "multi") { - e_preventDefault(e); - restartBlink(cm); - } - - if (seq && !result && /\'$/.test(name)) { - e_preventDefault(e); - return true - } - return !!result -} - -// Handle a key from the keydown event. -function handleKeyBinding(cm, e) { - var name = keyName(e, true); - if (!name) { return false } - - if (e.shiftKey && !cm.state.keySeq) { - // First try to resolve full name (including 'Shift-'). Failing - // that, see if there is a cursor-motion command (starting with - // 'go') bound to the keyname without 'Shift-'. - return dispatchKey(cm, "Shift-" + name, e, function (b) { return doHandleBinding(cm, b, true); }) - || dispatchKey(cm, name, e, function (b) { - if (typeof b == "string" ? /^go[A-Z]/.test(b) : b.motion) - { return doHandleBinding(cm, b) } - }) - } else { - return dispatchKey(cm, name, e, function (b) { return doHandleBinding(cm, b); }) - } -} - -// Handle a key from the keypress event -function handleCharBinding(cm, e, ch) { - return dispatchKey(cm, "'" + ch + "'", e, function (b) { return doHandleBinding(cm, b, true); }) -} - -var lastStoppedKey = null; -function onKeyDown(e) { - var cm = this; - cm.curOp.focus = activeElt(); - if (signalDOMEvent(cm, e)) { return } - // IE does strange things with escape. - if (ie && ie_version < 11 && e.keyCode == 27) { e.returnValue = false; } - var code = e.keyCode; - cm.display.shift = code == 16 || e.shiftKey; - var handled = handleKeyBinding(cm, e); - if (presto) { - lastStoppedKey = handled ? code : null; - // Opera has no cut event... we try to at least catch the key combo - if (!handled && code == 88 && !hasCopyEvent && (mac ? e.metaKey : e.ctrlKey)) - { cm.replaceSelection("", null, "cut"); } - } - - // Turn mouse into crosshair when Alt is held on Mac. - if (code == 18 && !/\bCodeMirror-crosshair\b/.test(cm.display.lineDiv.className)) - { showCrossHair(cm); } -} + indent: function(state, textAfter) { + var cx = state.context, ch = textAfter && textAfter.charAt(0); + var indent = cx.indent; + if (cx.type == "prop" && (ch == "}" || ch == ")")) cx = cx.prev; + if (cx.prev) { + if (ch == "}" && (cx.type == "block" || cx.type == "top" || + cx.type == "interpolation" || cx.type == "restricted_atBlock")) { + // Resume indentation from parent context. + cx = cx.prev; + indent = cx.indent; + } else if (ch == ")" && (cx.type == "parens" || cx.type == "atBlock_parens") || + ch == "{" && (cx.type == "at" || cx.type == "atBlock")) { + // Dedent relative to current context. + indent = Math.max(0, cx.indent - indentUnit); + } + } + return indent; + }, -function showCrossHair(cm) { - var lineDiv = cm.display.lineDiv; - addClass(lineDiv, "CodeMirror-crosshair"); + electricChars: "}", + blockCommentStart: "/*", + blockCommentEnd: "*/", + blockCommentContinue: " * ", + lineComment: lineComment, + fold: "brace" + }; +}); - function up(e) { - if (e.keyCode == 18 || !e.altKey) { - rmClass(lineDiv, "CodeMirror-crosshair"); - off(document, "keyup", up); - off(document, "mouseover", up); + function keySet(array) { + var keys = {}; + for (var i = 0; i < array.length; ++i) { + keys[array[i].toLowerCase()] = true; } + return keys; } - on(document, "keyup", up); - on(document, "mouseover", up); -} - -function onKeyUp(e) { - if (e.keyCode == 16) { this.doc.sel.shift = false; } - signalDOMEvent(this, e); -} - -function onKeyPress(e) { - var cm = this; - if (eventInWidget(cm.display, e) || signalDOMEvent(cm, e) || e.ctrlKey && !e.altKey || mac && e.metaKey) { return } - var keyCode = e.keyCode, charCode = e.charCode; - if (presto && keyCode == lastStoppedKey) {lastStoppedKey = null; e_preventDefault(e); return} - if ((presto && (!e.which || e.which < 10)) && handleKeyBinding(cm, e)) { return } - var ch = String.fromCharCode(charCode == null ? keyCode : charCode); - // Some browsers fire keypress events for backspace - if (ch == "\x08") { return } - if (handleCharBinding(cm, e, ch)) { return } - cm.display.input.onKeyPress(e); -} - -var DOUBLECLICK_DELAY = 400; - -var PastClick = function(time, pos, button) { - this.time = time; - this.pos = pos; - this.button = button; -}; - -PastClick.prototype.compare = function (time, pos, button) { - return this.time + DOUBLECLICK_DELAY > time && - cmp(pos, this.pos) == 0 && button == this.button -}; - -var lastClick; -var lastDoubleClick; -function clickRepeat(pos, button) { - var now = +new Date; - if (lastDoubleClick && lastDoubleClick.compare(now, pos, button)) { - lastClick = lastDoubleClick = null; - return "triple" - } else if (lastClick && lastClick.compare(now, pos, button)) { - lastDoubleClick = new PastClick(now, pos, button); - lastClick = null; - return "double" - } else { - lastClick = new PastClick(now, pos, button); - lastDoubleClick = null; - return "single" - } -} - -// A mouse down can be a single click, double click, triple click, -// start of selection drag, start of text drag, new cursor -// (ctrl-click), rectangle drag (alt-drag), or xwin -// middle-click-paste. Or it might be a click on something we should -// not interfere with, such as a scrollbar or widget. -function onMouseDown(e) { - var cm = this, display = cm.display; - if (signalDOMEvent(cm, e) || display.activeTouch && display.input.supportsTouch()) { return } - display.input.ensurePolled(); - display.shift = e.shiftKey; - - if (eventInWidget(display, e)) { - if (!webkit) { - // Briefly turn off draggability, to allow widgets to do - // normal dragging things. - display.scroller.draggable = false; - setTimeout(function () { return display.scroller.draggable = true; }, 100); - } - return - } - if (clickInGutter(cm, e)) { return } - var pos = posFromMouse(cm, e), button = e_button(e), repeat = pos ? clickRepeat(pos, button) : "single"; - window.focus(); - - // #3261: make sure, that we're not starting a second selection - if (button == 1 && cm.state.selectingText) - { cm.state.selectingText(e); } - - if (pos && handleMappedButton(cm, button, pos, repeat, e)) { return } - - if (button == 1) { - if (pos) { leftButtonDown(cm, pos, repeat, e); } - else if (e_target(e) == display.scroller) { e_preventDefault(e); } - } else if (button == 2) { - if (pos) { extendSelection(cm.doc, pos); } - setTimeout(function () { return display.input.focus(); }, 20); - } else if (button == 3) { - if (captureRightClick) { onContextMenu(cm, e); } - else { delayBlurEvent(cm); } - } -} - -function handleMappedButton(cm, button, pos, repeat, event) { - var name = "Click"; - if (repeat == "double") { name = "Double" + name; } - else if (repeat == "triple") { name = "Triple" + name; } - name = (button == 1 ? "Left" : button == 2 ? "Middle" : "Right") + name; - - return dispatchKey(cm, addModifierNames(name, event), event, function (bound) { - if (typeof bound == "string") { bound = commands[bound]; } - if (!bound) { return false } - var done = false; - try { - if (cm.isReadOnly()) { cm.state.suppressEdits = true; } - done = bound(cm, pos) != Pass; - } finally { - cm.state.suppressEdits = false; - } - return done - }) -} -function configureMouse(cm, repeat, event) { - var option = cm.getOption("configureMouse"); - var value = option ? option(cm, repeat, event) : {}; - if (value.unit == null) { - var rect = chromeOS ? event.shiftKey && event.metaKey : event.altKey; - value.unit = rect ? "rectangle" : repeat == "single" ? "char" : repeat == "double" ? "word" : "line"; - } - if (value.extend == null || cm.doc.extend) { value.extend = cm.doc.extend || event.shiftKey; } - if (value.addNew == null) { value.addNew = mac ? event.metaKey : event.ctrlKey; } - if (value.moveOnDrag == null) { value.moveOnDrag = !(mac ? event.altKey : event.ctrlKey); } - return value -} - -function leftButtonDown(cm, pos, repeat, event) { - if (ie) { setTimeout(bind(ensureFocus, cm), 0); } - else { cm.curOp.focus = activeElt(); } - - var behavior = configureMouse(cm, repeat, event); + var documentTypes_ = [ + "domain", "regexp", "url", "url-prefix" + ], documentTypes = keySet(documentTypes_); - var sel = cm.doc.sel, contained; - if (cm.options.dragDrop && dragAndDrop && !cm.isReadOnly() && - repeat == "single" && (contained = sel.contains(pos)) > -1 && - (cmp((contained = sel.ranges[contained]).from(), pos) < 0 || pos.xRel > 0) && - (cmp(contained.to(), pos) > 0 || pos.xRel < 0)) - { leftButtonStartDrag(cm, event, pos, behavior); } - else - { leftButtonSelect(cm, event, pos, behavior); } -} + var mediaTypes_ = [ + "all", "aural", "braille", "handheld", "print", "projection", "screen", + "tty", "tv", "embossed" + ], mediaTypes = keySet(mediaTypes_); -// Start a text drag. When it ends, see if any dragging actually -// happen, and treat as a click if it didn't. -function leftButtonStartDrag(cm, event, pos, behavior) { - var display = cm.display, moved = false; - var dragEnd = operation(cm, function (e) { - if (webkit) { display.scroller.draggable = false; } - cm.state.draggingText = false; - off(document, "mouseup", dragEnd); - off(document, "mousemove", mouseMove); - off(display.scroller, "dragstart", dragStart); - off(display.scroller, "drop", dragEnd); - if (!moved) { - e_preventDefault(e); - if (!behavior.addNew) - { extendSelection(cm.doc, pos, null, null, behavior.extend); } - // Work around unexplainable focus problem in IE9 (#2127) and Chrome (#3081) - if (webkit || ie && ie_version == 9) - { setTimeout(function () {document.body.focus(); display.input.focus();}, 20); } - else - { display.input.focus(); } - } - }); - var mouseMove = function(e2) { - moved = moved || Math.abs(event.clientX - e2.clientX) + Math.abs(event.clientY - e2.clientY) >= 10; - }; - var dragStart = function () { return moved = true; }; - // Let the drag handler handle this. - if (webkit) { display.scroller.draggable = true; } - cm.state.draggingText = dragEnd; - dragEnd.copy = !behavior.moveOnDrag; - // IE's approach to draggable - if (display.scroller.dragDrop) { display.scroller.dragDrop(); } - on(document, "mouseup", dragEnd); - on(document, "mousemove", mouseMove); - on(display.scroller, "dragstart", dragStart); - on(display.scroller, "drop", dragEnd); - - delayBlurEvent(cm); - setTimeout(function () { return display.input.focus(); }, 20); -} + var mediaFeatures_ = [ + "width", "min-width", "max-width", "height", "min-height", "max-height", + "device-width", "min-device-width", "max-device-width", "device-height", + "min-device-height", "max-device-height", "aspect-ratio", + "min-aspect-ratio", "max-aspect-ratio", "device-aspect-ratio", + "min-device-aspect-ratio", "max-device-aspect-ratio", "color", "min-color", + "max-color", "color-index", "min-color-index", "max-color-index", + "monochrome", "min-monochrome", "max-monochrome", "resolution", + "min-resolution", "max-resolution", "scan", "grid", "orientation", + "device-pixel-ratio", "min-device-pixel-ratio", "max-device-pixel-ratio", + "pointer", "any-pointer", "hover", "any-hover" + ], mediaFeatures = keySet(mediaFeatures_); -function rangeForUnit(cm, pos, unit) { - if (unit == "char") { return new Range(pos, pos) } - if (unit == "word") { return cm.findWordAt(pos) } - if (unit == "line") { return new Range(Pos(pos.line, 0), clipPos(cm.doc, Pos(pos.line + 1, 0))) } - var result = unit(cm, pos); - return new Range(result.from, result.to) -} + var mediaValueKeywords_ = [ + "landscape", "portrait", "none", "coarse", "fine", "on-demand", "hover", + "interlace", "progressive" + ], mediaValueKeywords = keySet(mediaValueKeywords_); -// Normal selection, as opposed to text dragging. -function leftButtonSelect(cm, event, start, behavior) { - var display = cm.display, doc = cm.doc; - e_preventDefault(event); + var propertyKeywords_ = [ + "align-content", "align-items", "align-self", "alignment-adjust", + "alignment-baseline", "anchor-point", "animation", "animation-delay", + "animation-direction", "animation-duration", "animation-fill-mode", + "animation-iteration-count", "animation-name", "animation-play-state", + "animation-timing-function", "appearance", "azimuth", "backface-visibility", + "background", "background-attachment", "background-blend-mode", "background-clip", + "background-color", "background-image", "background-origin", "background-position", + "background-repeat", "background-size", "baseline-shift", "binding", + "bleed", "bookmark-label", "bookmark-level", "bookmark-state", + "bookmark-target", "border", "border-bottom", "border-bottom-color", + "border-bottom-left-radius", "border-bottom-right-radius", + "border-bottom-style", "border-bottom-width", "border-collapse", + "border-color", "border-image", "border-image-outset", + "border-image-repeat", "border-image-slice", "border-image-source", + "border-image-width", "border-left", "border-left-color", + "border-left-style", "border-left-width", "border-radius", "border-right", + "border-right-color", "border-right-style", "border-right-width", + "border-spacing", "border-style", "border-top", "border-top-color", + "border-top-left-radius", "border-top-right-radius", "border-top-style", + "border-top-width", "border-width", "bottom", "box-decoration-break", + "box-shadow", "box-sizing", "break-after", "break-before", "break-inside", + "caption-side", "caret-color", "clear", "clip", "color", "color-profile", "column-count", + "column-fill", "column-gap", "column-rule", "column-rule-color", + "column-rule-style", "column-rule-width", "column-span", "column-width", + "columns", "content", "counter-increment", "counter-reset", "crop", "cue", + "cue-after", "cue-before", "cursor", "direction", "display", + "dominant-baseline", "drop-initial-after-adjust", + "drop-initial-after-align", "drop-initial-before-adjust", + "drop-initial-before-align", "drop-initial-size", "drop-initial-value", + "elevation", "empty-cells", "fit", "fit-position", "flex", "flex-basis", + "flex-direction", "flex-flow", "flex-grow", "flex-shrink", "flex-wrap", + "float", "float-offset", "flow-from", "flow-into", "font", "font-feature-settings", + "font-family", "font-kerning", "font-language-override", "font-size", "font-size-adjust", + "font-stretch", "font-style", "font-synthesis", "font-variant", + "font-variant-alternates", "font-variant-caps", "font-variant-east-asian", + "font-variant-ligatures", "font-variant-numeric", "font-variant-position", + "font-weight", "grid", "grid-area", "grid-auto-columns", "grid-auto-flow", + "grid-auto-rows", "grid-column", "grid-column-end", "grid-column-gap", + "grid-column-start", "grid-gap", "grid-row", "grid-row-end", "grid-row-gap", + "grid-row-start", "grid-template", "grid-template-areas", "grid-template-columns", + "grid-template-rows", "hanging-punctuation", "height", "hyphens", + "icon", "image-orientation", "image-rendering", "image-resolution", + "inline-box-align", "justify-content", "justify-items", "justify-self", "left", "letter-spacing", + "line-break", "line-height", "line-stacking", "line-stacking-ruby", + "line-stacking-shift", "line-stacking-strategy", "list-style", + "list-style-image", "list-style-position", "list-style-type", "margin", + "margin-bottom", "margin-left", "margin-right", "margin-top", + "marks", "marquee-direction", "marquee-loop", + "marquee-play-count", "marquee-speed", "marquee-style", "max-height", + "max-width", "min-height", "min-width", "mix-blend-mode", "move-to", "nav-down", "nav-index", + "nav-left", "nav-right", "nav-up", "object-fit", "object-position", + "opacity", "order", "orphans", "outline", + "outline-color", "outline-offset", "outline-style", "outline-width", + "overflow", "overflow-style", "overflow-wrap", "overflow-x", "overflow-y", + "padding", "padding-bottom", "padding-left", "padding-right", "padding-top", + "page", "page-break-after", "page-break-before", "page-break-inside", + "page-policy", "pause", "pause-after", "pause-before", "perspective", + "perspective-origin", "pitch", "pitch-range", "place-content", "place-items", "place-self", "play-during", "position", + "presentation-level", "punctuation-trim", "quotes", "region-break-after", + "region-break-before", "region-break-inside", "region-fragment", + "rendering-intent", "resize", "rest", "rest-after", "rest-before", "richness", + "right", "rotation", "rotation-point", "ruby-align", "ruby-overhang", + "ruby-position", "ruby-span", "shape-image-threshold", "shape-inside", "shape-margin", + "shape-outside", "size", "speak", "speak-as", "speak-header", + "speak-numeral", "speak-punctuation", "speech-rate", "stress", "string-set", + "tab-size", "table-layout", "target", "target-name", "target-new", + "target-position", "text-align", "text-align-last", "text-decoration", + "text-decoration-color", "text-decoration-line", "text-decoration-skip", + "text-decoration-style", "text-emphasis", "text-emphasis-color", + "text-emphasis-position", "text-emphasis-style", "text-height", + "text-indent", "text-justify", "text-outline", "text-overflow", "text-shadow", + "text-size-adjust", "text-space-collapse", "text-transform", "text-underline-position", + "text-wrap", "top", "transform", "transform-origin", "transform-style", + "transition", "transition-delay", "transition-duration", + "transition-property", "transition-timing-function", "unicode-bidi", + "user-select", "vertical-align", "visibility", "voice-balance", "voice-duration", + "voice-family", "voice-pitch", "voice-range", "voice-rate", "voice-stress", + "voice-volume", "volume", "white-space", "widows", "width", "will-change", "word-break", + "word-spacing", "word-wrap", "z-index", + // SVG-specific + "clip-path", "clip-rule", "mask", "enable-background", "filter", "flood-color", + "flood-opacity", "lighting-color", "stop-color", "stop-opacity", "pointer-events", + "color-interpolation", "color-interpolation-filters", + "color-rendering", "fill", "fill-opacity", "fill-rule", "image-rendering", + "marker", "marker-end", "marker-mid", "marker-start", "shape-rendering", "stroke", + "stroke-dasharray", "stroke-dashoffset", "stroke-linecap", "stroke-linejoin", + "stroke-miterlimit", "stroke-opacity", "stroke-width", "text-rendering", + "baseline-shift", "dominant-baseline", "glyph-orientation-horizontal", + "glyph-orientation-vertical", "text-anchor", "writing-mode" + ], propertyKeywords = keySet(propertyKeywords_); - var ourRange, ourIndex, startSel = doc.sel, ranges = startSel.ranges; - if (behavior.addNew && !behavior.extend) { - ourIndex = doc.sel.contains(start); - if (ourIndex > -1) - { ourRange = ranges[ourIndex]; } - else - { ourRange = new Range(start, start); } - } else { - ourRange = doc.sel.primary(); - ourIndex = doc.sel.primIndex; - } + var nonStandardPropertyKeywords_ = [ + "scrollbar-arrow-color", "scrollbar-base-color", "scrollbar-dark-shadow-color", + "scrollbar-face-color", "scrollbar-highlight-color", "scrollbar-shadow-color", + "scrollbar-3d-light-color", "scrollbar-track-color", "shape-inside", + "searchfield-cancel-button", "searchfield-decoration", "searchfield-results-button", + "searchfield-results-decoration", "zoom" + ], nonStandardPropertyKeywords = keySet(nonStandardPropertyKeywords_); - if (behavior.unit == "rectangle") { - if (!behavior.addNew) { ourRange = new Range(start, start); } - start = posFromMouse(cm, event, true, true); - ourIndex = -1; - } else { - var range$$1 = rangeForUnit(cm, start, behavior.unit); - if (behavior.extend) - { ourRange = extendRange(ourRange, range$$1.anchor, range$$1.head, behavior.extend); } - else - { ourRange = range$$1; } - } - - if (!behavior.addNew) { - ourIndex = 0; - setSelection(doc, new Selection([ourRange], 0), sel_mouse); - startSel = doc.sel; - } else if (ourIndex == -1) { - ourIndex = ranges.length; - setSelection(doc, normalizeSelection(ranges.concat([ourRange]), ourIndex), - {scroll: false, origin: "*mouse"}); - } else if (ranges.length > 1 && ranges[ourIndex].empty() && behavior.unit == "char" && !behavior.extend) { - setSelection(doc, normalizeSelection(ranges.slice(0, ourIndex).concat(ranges.slice(ourIndex + 1)), 0), - {scroll: false, origin: "*mouse"}); - startSel = doc.sel; - } else { - replaceOneSelection(doc, ourIndex, ourRange, sel_mouse); - } + var fontProperties_ = [ + "font-family", "src", "unicode-range", "font-variant", "font-feature-settings", + "font-stretch", "font-weight", "font-style" + ], fontProperties = keySet(fontProperties_); - var lastPos = start; - function extendTo(pos) { - if (cmp(lastPos, pos) == 0) { return } - lastPos = pos; + var counterDescriptors_ = [ + "additive-symbols", "fallback", "negative", "pad", "prefix", "range", + "speak-as", "suffix", "symbols", "system" + ], counterDescriptors = keySet(counterDescriptors_); - if (behavior.unit == "rectangle") { - var ranges = [], tabSize = cm.options.tabSize; - var startCol = countColumn(getLine(doc, start.line).text, start.ch, tabSize); - var posCol = countColumn(getLine(doc, pos.line).text, pos.ch, tabSize); - var left = Math.min(startCol, posCol), right = Math.max(startCol, posCol); - for (var line = Math.min(start.line, pos.line), end = Math.min(cm.lastLine(), Math.max(start.line, pos.line)); - line <= end; line++) { - var text = getLine(doc, line).text, leftPos = findColumn(text, left, tabSize); - if (left == right) - { ranges.push(new Range(Pos(line, leftPos), Pos(line, leftPos))); } - else if (text.length > leftPos) - { ranges.push(new Range(Pos(line, leftPos), Pos(line, findColumn(text, right, tabSize)))); } - } - if (!ranges.length) { ranges.push(new Range(start, start)); } - setSelection(doc, normalizeSelection(startSel.ranges.slice(0, ourIndex).concat(ranges), ourIndex), - {origin: "*mouse", scroll: false}); - cm.scrollIntoView(pos); - } else { - var oldRange = ourRange; - var range$$1 = rangeForUnit(cm, pos, behavior.unit); - var anchor = oldRange.anchor, head; - if (cmp(range$$1.anchor, anchor) > 0) { - head = range$$1.head; - anchor = minPos(oldRange.from(), range$$1.anchor); - } else { - head = range$$1.anchor; - anchor = maxPos(oldRange.to(), range$$1.head); - } - var ranges$1 = startSel.ranges.slice(0); - ranges$1[ourIndex] = bidiSimplify(cm, new Range(clipPos(doc, anchor), head)); - setSelection(doc, normalizeSelection(ranges$1, ourIndex), sel_mouse); - } - } - - var editorSize = display.wrapper.getBoundingClientRect(); - // Used to ensure timeout re-tries don't fire when another extend - // happened in the meantime (clearTimeout isn't reliable -- at - // least on Chrome, the timeouts still happen even when cleared, - // if the clear happens after their scheduled firing time). - var counter = 0; - - function extend(e) { - var curCount = ++counter; - var cur = posFromMouse(cm, e, true, behavior.unit == "rectangle"); - if (!cur) { return } - if (cmp(cur, lastPos) != 0) { - cm.curOp.focus = activeElt(); - extendTo(cur); - var visible = visibleLines(display, doc); - if (cur.line >= visible.to || cur.line < visible.from) - { setTimeout(operation(cm, function () {if (counter == curCount) { extend(e); }}), 150); } - } else { - var outside = e.clientY < editorSize.top ? -20 : e.clientY > editorSize.bottom ? 20 : 0; - if (outside) { setTimeout(operation(cm, function () { - if (counter != curCount) { return } - display.scroller.scrollTop += outside; - extend(e); - }), 50); } - } - } + var colorKeywords_ = [ + "aliceblue", "antiquewhite", "aqua", "aquamarine", "azure", "beige", + "bisque", "black", "blanchedalmond", "blue", "blueviolet", "brown", + "burlywood", "cadetblue", "chartreuse", "chocolate", "coral", "cornflowerblue", + "cornsilk", "crimson", "cyan", "darkblue", "darkcyan", "darkgoldenrod", + "darkgray", "darkgreen", "darkkhaki", "darkmagenta", "darkolivegreen", + "darkorange", "darkorchid", "darkred", "darksalmon", "darkseagreen", + "darkslateblue", "darkslategray", "darkturquoise", "darkviolet", + "deeppink", "deepskyblue", "dimgray", "dodgerblue", "firebrick", + "floralwhite", "forestgreen", "fuchsia", "gainsboro", "ghostwhite", + "gold", "goldenrod", "gray", "grey", "green", "greenyellow", "honeydew", + "hotpink", "indianred", "indigo", "ivory", "khaki", "lavender", + "lavenderblush", "lawngreen", "lemonchiffon", "lightblue", "lightcoral", + "lightcyan", "lightgoldenrodyellow", "lightgray", "lightgreen", "lightpink", + "lightsalmon", "lightseagreen", "lightskyblue", "lightslategray", + "lightsteelblue", "lightyellow", "lime", "limegreen", "linen", "magenta", + "maroon", "mediumaquamarine", "mediumblue", "mediumorchid", "mediumpurple", + "mediumseagreen", "mediumslateblue", "mediumspringgreen", "mediumturquoise", + "mediumvioletred", "midnightblue", "mintcream", "mistyrose", "moccasin", + "navajowhite", "navy", "oldlace", "olive", "olivedrab", "orange", "orangered", + "orchid", "palegoldenrod", "palegreen", "paleturquoise", "palevioletred", + "papayawhip", "peachpuff", "peru", "pink", "plum", "powderblue", + "purple", "rebeccapurple", "red", "rosybrown", "royalblue", "saddlebrown", + "salmon", "sandybrown", "seagreen", "seashell", "sienna", "silver", "skyblue", + "slateblue", "slategray", "snow", "springgreen", "steelblue", "tan", + "teal", "thistle", "tomato", "turquoise", "violet", "wheat", "white", + "whitesmoke", "yellow", "yellowgreen" + ], colorKeywords = keySet(colorKeywords_); - function done(e) { - cm.state.selectingText = false; - counter = Infinity; - e_preventDefault(e); - display.input.focus(); - off(document, "mousemove", move); - off(document, "mouseup", up); - doc.history.lastSelOrigin = null; - } - - var move = operation(cm, function (e) { - if (!e_button(e)) { done(e); } - else { extend(e); } - }); - var up = operation(cm, done); - cm.state.selectingText = up; - on(document, "mousemove", move); - on(document, "mouseup", up); -} - -// Used when mouse-selecting to adjust the anchor to the proper side -// of a bidi jump depending on the visual position of the head. -function bidiSimplify(cm, range$$1) { - var anchor = range$$1.anchor; - var head = range$$1.head; - var anchorLine = getLine(cm.doc, anchor.line); - if (cmp(anchor, head) == 0 && anchor.sticky == head.sticky) { return range$$1 } - var order = getOrder(anchorLine); - if (!order) { return range$$1 } - var index = getBidiPartAt(order, anchor.ch, anchor.sticky), part = order[index]; - if (part.from != anchor.ch && part.to != anchor.ch) { return range$$1 } - var boundary = index + ((part.from == anchor.ch) == (part.level != 1) ? 0 : 1); - if (boundary == 0 || boundary == order.length) { return range$$1 } - - // Compute the relative visual position of the head compared to the - // anchor (<0 is to the left, >0 to the right) - var leftSide; - if (head.line != anchor.line) { - leftSide = (head.line - anchor.line) * (cm.doc.direction == "ltr" ? 1 : -1) > 0; - } else { - var headIndex = getBidiPartAt(order, head.ch, head.sticky); - var dir = headIndex - index || (head.ch - anchor.ch) * (part.level == 1 ? -1 : 1); - if (headIndex == boundary - 1 || headIndex == boundary) - { leftSide = dir < 0; } - else - { leftSide = dir > 0; } - } - - var usePart = order[boundary + (leftSide ? -1 : 0)]; - var from = leftSide == (usePart.level == 1); - var ch = from ? usePart.from : usePart.to, sticky = from ? "after" : "before"; - return anchor.ch == ch && anchor.sticky == sticky ? range$$1 : new Range(new Pos(anchor.line, ch, sticky), head) -} - - -// Determines whether an event happened in the gutter, and fires the -// handlers for the corresponding event. -function gutterEvent(cm, e, type, prevent) { - var mX, mY; - if (e.touches) { - mX = e.touches[0].clientX; - mY = e.touches[0].clientY; - } else { - try { mX = e.clientX; mY = e.clientY; } - catch(e) { return false } - } - if (mX >= Math.floor(cm.display.gutters.getBoundingClientRect().right)) { return false } - if (prevent) { e_preventDefault(e); } - - var display = cm.display; - var lineBox = display.lineDiv.getBoundingClientRect(); + var valueKeywords_ = [ + "above", "absolute", "activeborder", "additive", "activecaption", "afar", + "after-white-space", "ahead", "alias", "all", "all-scroll", "alphabetic", "alternate", + "always", "amharic", "amharic-abegede", "antialiased", "appworkspace", + "arabic-indic", "armenian", "asterisks", "attr", "auto", "auto-flow", "avoid", "avoid-column", "avoid-page", + "avoid-region", "background", "backwards", "baseline", "below", "bidi-override", "binary", + "bengali", "blink", "block", "block-axis", "bold", "bolder", "border", "border-box", + "both", "bottom", "break", "break-all", "break-word", "bullets", "button", "button-bevel", + "buttonface", "buttonhighlight", "buttonshadow", "buttontext", "calc", "cambodian", + "capitalize", "caps-lock-indicator", "caption", "captiontext", "caret", + "cell", "center", "checkbox", "circle", "cjk-decimal", "cjk-earthly-branch", + "cjk-heavenly-stem", "cjk-ideographic", "clear", "clip", "close-quote", + "col-resize", "collapse", "color", "color-burn", "color-dodge", "column", "column-reverse", + "compact", "condensed", "contain", "content", "contents", + "content-box", "context-menu", "continuous", "copy", "counter", "counters", "cover", "crop", + "cross", "crosshair", "currentcolor", "cursive", "cyclic", "darken", "dashed", "decimal", + "decimal-leading-zero", "default", "default-button", "dense", "destination-atop", + "destination-in", "destination-out", "destination-over", "devanagari", "difference", + "disc", "discard", "disclosure-closed", "disclosure-open", "document", + "dot-dash", "dot-dot-dash", + "dotted", "double", "down", "e-resize", "ease", "ease-in", "ease-in-out", "ease-out", + "element", "ellipse", "ellipsis", "embed", "end", "ethiopic", "ethiopic-abegede", + "ethiopic-abegede-am-et", "ethiopic-abegede-gez", "ethiopic-abegede-ti-er", + "ethiopic-abegede-ti-et", "ethiopic-halehame-aa-er", + "ethiopic-halehame-aa-et", "ethiopic-halehame-am-et", + "ethiopic-halehame-gez", "ethiopic-halehame-om-et", + "ethiopic-halehame-sid-et", "ethiopic-halehame-so-et", + "ethiopic-halehame-ti-er", "ethiopic-halehame-ti-et", "ethiopic-halehame-tig", + "ethiopic-numeric", "ew-resize", "exclusion", "expanded", "extends", "extra-condensed", + "extra-expanded", "fantasy", "fast", "fill", "fixed", "flat", "flex", "flex-end", "flex-start", "footnotes", + "forwards", "from", "geometricPrecision", "georgian", "graytext", "grid", "groove", + "gujarati", "gurmukhi", "hand", "hangul", "hangul-consonant", "hard-light", "hebrew", + "help", "hidden", "hide", "higher", "highlight", "highlighttext", + "hiragana", "hiragana-iroha", "horizontal", "hsl", "hsla", "hue", "icon", "ignore", + "inactiveborder", "inactivecaption", "inactivecaptiontext", "infinite", + "infobackground", "infotext", "inherit", "initial", "inline", "inline-axis", + "inline-block", "inline-flex", "inline-grid", "inline-table", "inset", "inside", "intrinsic", "invert", + "italic", "japanese-formal", "japanese-informal", "justify", "kannada", + "katakana", "katakana-iroha", "keep-all", "khmer", + "korean-hangul-formal", "korean-hanja-formal", "korean-hanja-informal", + "landscape", "lao", "large", "larger", "left", "level", "lighter", "lighten", + "line-through", "linear", "linear-gradient", "lines", "list-item", "listbox", "listitem", + "local", "logical", "loud", "lower", "lower-alpha", "lower-armenian", + "lower-greek", "lower-hexadecimal", "lower-latin", "lower-norwegian", + "lower-roman", "lowercase", "ltr", "luminosity", "malayalam", "match", "matrix", "matrix3d", + "media-controls-background", "media-current-time-display", + "media-fullscreen-button", "media-mute-button", "media-play-button", + "media-return-to-realtime-button", "media-rewind-button", + "media-seek-back-button", "media-seek-forward-button", "media-slider", + "media-sliderthumb", "media-time-remaining-display", "media-volume-slider", + "media-volume-slider-container", "media-volume-sliderthumb", "medium", + "menu", "menulist", "menulist-button", "menulist-text", + "menulist-textfield", "menutext", "message-box", "middle", "min-intrinsic", + "mix", "mongolian", "monospace", "move", "multiple", "multiply", "myanmar", "n-resize", + "narrower", "ne-resize", "nesw-resize", "no-close-quote", "no-drop", + "no-open-quote", "no-repeat", "none", "normal", "not-allowed", "nowrap", + "ns-resize", "numbers", "numeric", "nw-resize", "nwse-resize", "oblique", "octal", "opacity", "open-quote", + "optimizeLegibility", "optimizeSpeed", "oriya", "oromo", "outset", + "outside", "outside-shape", "overlay", "overline", "padding", "padding-box", + "painted", "page", "paused", "persian", "perspective", "plus-darker", "plus-lighter", + "pointer", "polygon", "portrait", "pre", "pre-line", "pre-wrap", "preserve-3d", + "progress", "push-button", "radial-gradient", "radio", "read-only", + "read-write", "read-write-plaintext-only", "rectangle", "region", + "relative", "repeat", "repeating-linear-gradient", + "repeating-radial-gradient", "repeat-x", "repeat-y", "reset", "reverse", + "rgb", "rgba", "ridge", "right", "rotate", "rotate3d", "rotateX", "rotateY", + "rotateZ", "round", "row", "row-resize", "row-reverse", "rtl", "run-in", "running", + "s-resize", "sans-serif", "saturation", "scale", "scale3d", "scaleX", "scaleY", "scaleZ", "screen", + "scroll", "scrollbar", "scroll-position", "se-resize", "searchfield", + "searchfield-cancel-button", "searchfield-decoration", + "searchfield-results-button", "searchfield-results-decoration", "self-start", "self-end", + "semi-condensed", "semi-expanded", "separate", "serif", "show", "sidama", + "simp-chinese-formal", "simp-chinese-informal", "single", + "skew", "skewX", "skewY", "skip-white-space", "slide", "slider-horizontal", + "slider-vertical", "sliderthumb-horizontal", "sliderthumb-vertical", "slow", + "small", "small-caps", "small-caption", "smaller", "soft-light", "solid", "somali", + "source-atop", "source-in", "source-out", "source-over", "space", "space-around", "space-between", "space-evenly", "spell-out", "square", + "square-button", "start", "static", "status-bar", "stretch", "stroke", "sub", + "subpixel-antialiased", "super", "sw-resize", "symbolic", "symbols", "system-ui", "table", + "table-caption", "table-cell", "table-column", "table-column-group", + "table-footer-group", "table-header-group", "table-row", "table-row-group", + "tamil", + "telugu", "text", "text-bottom", "text-top", "textarea", "textfield", "thai", + "thick", "thin", "threeddarkshadow", "threedface", "threedhighlight", + "threedlightshadow", "threedshadow", "tibetan", "tigre", "tigrinya-er", + "tigrinya-er-abegede", "tigrinya-et", "tigrinya-et-abegede", "to", "top", + "trad-chinese-formal", "trad-chinese-informal", "transform", + "translate", "translate3d", "translateX", "translateY", "translateZ", + "transparent", "ultra-condensed", "ultra-expanded", "underline", "unset", "up", + "upper-alpha", "upper-armenian", "upper-greek", "upper-hexadecimal", + "upper-latin", "upper-norwegian", "upper-roman", "uppercase", "urdu", "url", + "var", "vertical", "vertical-text", "visible", "visibleFill", "visiblePainted", + "visibleStroke", "visual", "w-resize", "wait", "wave", "wider", + "window", "windowframe", "windowtext", "words", "wrap", "wrap-reverse", "x-large", "x-small", "xor", + "xx-large", "xx-small" + ], valueKeywords = keySet(valueKeywords_); - if (mY > lineBox.bottom || !hasHandler(cm, type)) { return e_defaultPrevented(e) } - mY -= lineBox.top - display.viewOffset; + var allWords = documentTypes_.concat(mediaTypes_).concat(mediaFeatures_).concat(mediaValueKeywords_) + .concat(propertyKeywords_).concat(nonStandardPropertyKeywords_).concat(colorKeywords_) + .concat(valueKeywords_); + CodeMirror.registerHelper("hintWords", "css", allWords); - for (var i = 0; i < cm.options.gutters.length; ++i) { - var g = display.gutters.childNodes[i]; - if (g && g.getBoundingClientRect().right >= mX) { - var line = lineAtHeight(cm.doc, mY); - var gutter = cm.options.gutters[i]; - signal(cm, type, cm, line, gutter, e); - return e_defaultPrevented(e) + function tokenCComment(stream, state) { + var maybeEnd = false, ch; + while ((ch = stream.next()) != null) { + if (maybeEnd && ch == "/") { + state.tokenize = null; + break; + } + maybeEnd = (ch == "*"); } + return ["comment", "comment"]; } -} -function clickInGutter(cm, e) { - return gutterEvent(cm, e, "gutterClick", true) -} + CodeMirror.defineMIME("text/css", { + documentTypes: documentTypes, + mediaTypes: mediaTypes, + mediaFeatures: mediaFeatures, + mediaValueKeywords: mediaValueKeywords, + propertyKeywords: propertyKeywords, + nonStandardPropertyKeywords: nonStandardPropertyKeywords, + fontProperties: fontProperties, + counterDescriptors: counterDescriptors, + colorKeywords: colorKeywords, + valueKeywords: valueKeywords, + tokenHooks: { + "/": function(stream, state) { + if (!stream.eat("*")) return false; + state.tokenize = tokenCComment; + return tokenCComment(stream, state); + } + }, + name: "css" + }); -// CONTEXT MENU HANDLING + CodeMirror.defineMIME("text/x-scss", { + mediaTypes: mediaTypes, + mediaFeatures: mediaFeatures, + mediaValueKeywords: mediaValueKeywords, + propertyKeywords: propertyKeywords, + nonStandardPropertyKeywords: nonStandardPropertyKeywords, + colorKeywords: colorKeywords, + valueKeywords: valueKeywords, + fontProperties: fontProperties, + allowNested: true, + lineComment: "//", + tokenHooks: { + "/": function(stream, state) { + if (stream.eat("/")) { + stream.skipToEnd(); + return ["comment", "comment"]; + } else if (stream.eat("*")) { + state.tokenize = tokenCComment; + return tokenCComment(stream, state); + } else { + return ["operator", "operator"]; + } + }, + ":": function(stream) { + if (stream.match(/\s*\{/, false)) + return [null, null] + return false; + }, + "$": function(stream) { + stream.match(/^[\w-]+/); + if (stream.match(/^\s*:/, false)) + return ["variable-2", "variable-definition"]; + return ["variable-2", "variable"]; + }, + "#": function(stream) { + if (!stream.eat("{")) return false; + return [null, "interpolation"]; + } + }, + name: "css", + helperType: "scss" + }); -// To make the context menu work, we need to briefly unhide the -// textarea (making it as unobtrusive as possible) to let the -// right-click take effect on it. -function onContextMenu(cm, e) { - if (eventInWidget(cm.display, e) || contextMenuInGutter(cm, e)) { return } - if (signalDOMEvent(cm, e, "contextmenu")) { return } - cm.display.input.onContextMenu(e); -} + CodeMirror.defineMIME("text/x-less", { + mediaTypes: mediaTypes, + mediaFeatures: mediaFeatures, + mediaValueKeywords: mediaValueKeywords, + propertyKeywords: propertyKeywords, + nonStandardPropertyKeywords: nonStandardPropertyKeywords, + colorKeywords: colorKeywords, + valueKeywords: valueKeywords, + fontProperties: fontProperties, + allowNested: true, + lineComment: "//", + tokenHooks: { + "/": function(stream, state) { + if (stream.eat("/")) { + stream.skipToEnd(); + return ["comment", "comment"]; + } else if (stream.eat("*")) { + state.tokenize = tokenCComment; + return tokenCComment(stream, state); + } else { + return ["operator", "operator"]; + } + }, + "@": function(stream) { + if (stream.eat("{")) return [null, "interpolation"]; + if (stream.match(/^(charset|document|font-face|import|(-(moz|ms|o|webkit)-)?keyframes|media|namespace|page|supports)\b/i, false)) return false; + stream.eatWhile(/[\w\\\-]/); + if (stream.match(/^\s*:/, false)) + return ["variable-2", "variable-definition"]; + return ["variable-2", "variable"]; + }, + "&": function() { + return ["atom", "atom"]; + } + }, + name: "css", + helperType: "less" + }); -function contextMenuInGutter(cm, e) { - if (!hasHandler(cm, "gutterContextMenu")) { return false } - return gutterEvent(cm, e, "gutterContextMenu", false) -} + CodeMirror.defineMIME("text/x-gss", { + documentTypes: documentTypes, + mediaTypes: mediaTypes, + mediaFeatures: mediaFeatures, + propertyKeywords: propertyKeywords, + nonStandardPropertyKeywords: nonStandardPropertyKeywords, + fontProperties: fontProperties, + counterDescriptors: counterDescriptors, + colorKeywords: colorKeywords, + valueKeywords: valueKeywords, + supportsAtComponent: true, + tokenHooks: { + "/": function(stream, state) { + if (!stream.eat("*")) return false; + state.tokenize = tokenCComment; + return tokenCComment(stream, state); + } + }, + name: "css", + helperType: "gss" + }); -function themeChanged(cm) { - cm.display.wrapper.className = cm.display.wrapper.className.replace(/\s*cm-s-\S+/g, "") + - cm.options.theme.replace(/(^|\s)\s*/g, " cm-s-"); - clearCaches(cm); -} +}); -var Init = {toString: function(){return "CodeMirror.Init"}}; -var defaults = {}; -var optionHandlers = {}; +/***/ }), -function defineOptions(CodeMirror) { - var optionHandlers = CodeMirror.optionHandlers; +/***/ "./node_modules/codemirror/mode/htmlmixed/htmlmixed.js": +/*!*************************************************************!*\ + !*** ./node_modules/codemirror/mode/htmlmixed/htmlmixed.js ***! + \*************************************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { - function option(name, deflt, handle, notOnInit) { - CodeMirror.defaults[name] = deflt; - if (handle) { optionHandlers[name] = - notOnInit ? function (cm, val, old) {if (old != Init) { handle(cm, val, old); }} : handle; } - } +// CodeMirror, copyright (c) by Marijn Haverbeke and others +// Distributed under an MIT license: https://codemirror.net/LICENSE - CodeMirror.defineOption = option; - - // Passed to option handlers when there is no old value. - CodeMirror.Init = Init; - - // These two are, on init, called from the constructor because they - // have to be initialized before the editor can start at all. - option("value", "", function (cm, val) { return cm.setValue(val); }, true); - option("mode", null, function (cm, val) { - cm.doc.modeOption = val; - loadMode(cm); - }, true); - - option("indentUnit", 2, loadMode, true); - option("indentWithTabs", false); - option("smartIndent", true); - option("tabSize", 4, function (cm) { - resetModeState(cm); - clearCaches(cm); - regChange(cm); - }, true); - option("lineSeparator", null, function (cm, val) { - cm.doc.lineSep = val; - if (!val) { return } - var newBreaks = [], lineNo = cm.doc.first; - cm.doc.iter(function (line) { - for (var pos = 0;;) { - var found = line.text.indexOf(val, pos); - if (found == -1) { break } - pos = found + val.length; - newBreaks.push(Pos(lineNo, found)); - } - lineNo++; - }); - for (var i = newBreaks.length - 1; i >= 0; i--) - { replaceRange(cm.doc, val, newBreaks[i], Pos(newBreaks[i].line, newBreaks[i].ch + val.length)); } - }); - option("specialChars", /[\u0000-\u001f\u007f-\u009f\u00ad\u061c\u200b-\u200f\u2028\u2029\ufeff]/g, function (cm, val, old) { - cm.state.specialChars = new RegExp(val.source + (val.test("\t") ? "" : "|\t"), "g"); - if (old != Init) { cm.refresh(); } - }); - option("specialCharPlaceholder", defaultSpecialCharPlaceholder, function (cm) { return cm.refresh(); }, true); - option("electricChars", true); - option("inputStyle", mobile ? "contenteditable" : "textarea", function () { - throw new Error("inputStyle can not (yet) be changed in a running editor") // FIXME - }, true); - option("spellcheck", false, function (cm, val) { return cm.getInputField().spellcheck = val; }, true); - option("rtlMoveVisually", !windows); - option("wholeLineUpdateBefore", true); - - option("theme", "default", function (cm) { - themeChanged(cm); - guttersChanged(cm); - }, true); - option("keyMap", "default", function (cm, val, old) { - var next = getKeyMap(val); - var prev = old != Init && getKeyMap(old); - if (prev && prev.detach) { prev.detach(cm, next); } - if (next.attach) { next.attach(cm, prev || null); } - }); - option("extraKeys", null); - option("configureMouse", null); - - option("lineWrapping", false, wrappingChanged, true); - option("gutters", [], function (cm) { - setGuttersForLineNumbers(cm.options); - guttersChanged(cm); - }, true); - option("fixedGutter", true, function (cm, val) { - cm.display.gutters.style.left = val ? compensateForHScroll(cm.display) + "px" : "0"; - cm.refresh(); - }, true); - option("coverGutterNextToScrollbar", false, function (cm) { return updateScrollbars(cm); }, true); - option("scrollbarStyle", "native", function (cm) { - initScrollbars(cm); - updateScrollbars(cm); - cm.display.scrollbars.setScrollTop(cm.doc.scrollTop); - cm.display.scrollbars.setScrollLeft(cm.doc.scrollLeft); - }, true); - option("lineNumbers", false, function (cm) { - setGuttersForLineNumbers(cm.options); - guttersChanged(cm); - }, true); - option("firstLineNumber", 1, guttersChanged, true); - option("lineNumberFormatter", function (integer) { return integer; }, guttersChanged, true); - option("showCursorWhenSelecting", false, updateSelection, true); +(function(mod) { + if (true) // CommonJS + mod(__webpack_require__(/*! ../../lib/codemirror */ "./node_modules/codemirror/lib/codemirror.js"), __webpack_require__(/*! ../xml/xml */ "./node_modules/codemirror/mode/xml/xml.js"), __webpack_require__(/*! ../javascript/javascript */ "./node_modules/codemirror/mode/javascript/javascript.js"), __webpack_require__(/*! ../css/css */ "./node_modules/codemirror/mode/css/css.js")); + else {} +})(function(CodeMirror) { + "use strict"; - option("resetSelectionOnContextMenu", true); - option("lineWiseCopyCut", true); - option("pasteLinesPerSelection", true); + var defaultTags = { + script: [ + ["lang", /(javascript|babel)/i, "javascript"], + ["type", /^(?:text|application)\/(?:x-)?(?:java|ecma)script$|^module$|^$/i, "javascript"], + ["type", /./, "text/plain"], + [null, null, "javascript"] + ], + style: [ + ["lang", /^css$/i, "css"], + ["type", /^(text\/)?(x-)?(stylesheet|css)$/i, "css"], + ["type", /./, "text/plain"], + [null, null, "css"] + ] + }; - option("readOnly", false, function (cm, val) { - if (val == "nocursor") { - onBlur(cm); - cm.display.input.blur(); + function maybeBackup(stream, pat, style) { + var cur = stream.current(), close = cur.search(pat); + if (close > -1) { + stream.backUp(cur.length - close); + } else if (cur.match(/<\/?$/)) { + stream.backUp(cur.length); + if (!stream.match(pat, false)) stream.match(cur); } - cm.display.input.readOnlyChanged(val); - }); - option("disableInput", false, function (cm, val) {if (!val) { cm.display.input.reset(); }}, true); - option("dragDrop", true, dragDropChanged); - option("allowDropFileTypes", null); - - option("cursorBlinkRate", 530); - option("cursorScrollMargin", 0); - option("cursorHeight", 1, updateSelection, true); - option("singleCursorHeightPerLine", true, updateSelection, true); - option("workTime", 100); - option("workDelay", 100); - option("flattenSpans", true, resetModeState, true); - option("addModeClass", false, resetModeState, true); - option("pollInterval", 100); - option("undoDepth", 200, function (cm, val) { return cm.doc.history.undoDepth = val; }); - option("historyEventDelay", 1250); - option("viewportMargin", 10, function (cm) { return cm.refresh(); }, true); - option("maxHighlightLength", 10000, resetModeState, true); - option("moveInputWithCursor", true, function (cm, val) { - if (!val) { cm.display.input.resetPosition(); } - }); - - option("tabindex", null, function (cm, val) { return cm.display.input.getField().tabIndex = val || ""; }); - option("autofocus", null); - option("direction", "ltr", function (cm, val) { return cm.doc.setDirection(val); }, true); -} - -function guttersChanged(cm) { - updateGutters(cm); - regChange(cm); - alignHorizontally(cm); -} - -function dragDropChanged(cm, value, old) { - var wasOn = old && old != Init; - if (!value != !wasOn) { - var funcs = cm.display.dragFunctions; - var toggle = value ? on : off; - toggle(cm.display.scroller, "dragstart", funcs.start); - toggle(cm.display.scroller, "dragenter", funcs.enter); - toggle(cm.display.scroller, "dragover", funcs.over); - toggle(cm.display.scroller, "dragleave", funcs.leave); - toggle(cm.display.scroller, "drop", funcs.drop); + return style; } -} -function wrappingChanged(cm) { - if (cm.options.lineWrapping) { - addClass(cm.display.wrapper, "CodeMirror-wrap"); - cm.display.sizer.style.minWidth = ""; - cm.display.sizerWidth = null; - } else { - rmClass(cm.display.wrapper, "CodeMirror-wrap"); - findMaxLine(cm); + var attrRegexpCache = {}; + function getAttrRegexp(attr) { + var regexp = attrRegexpCache[attr]; + if (regexp) return regexp; + return attrRegexpCache[attr] = new RegExp("\\s+" + attr + "\\s*=\\s*('|\")?([^'\"]+)('|\")?\\s*"); } - estimateLineHeights(cm); - regChange(cm); - clearCaches(cm); - setTimeout(function () { return updateScrollbars(cm); }, 100); -} - -// A CodeMirror instance represents an editor. This is the object -// that user code is usually dealing with. - -function CodeMirror$1(place, options) { - var this$1 = this; - - if (!(this instanceof CodeMirror$1)) { return new CodeMirror$1(place, options) } - - this.options = options = options ? copyObj(options) : {}; - // Determine effective options based on given values and defaults. - copyObj(defaults, options, false); - setGuttersForLineNumbers(options); - - var doc = options.value; - if (typeof doc == "string") { doc = new Doc(doc, options.mode, null, options.lineSeparator, options.direction); } - this.doc = doc; - - var input = new CodeMirror$1.inputStyles[options.inputStyle](this); - var display = this.display = new Display(place, doc, input); - display.wrapper.CodeMirror = this; - updateGutters(this); - themeChanged(this); - if (options.lineWrapping) - { this.display.wrapper.className += " CodeMirror-wrap"; } - initScrollbars(this); - - this.state = { - keyMaps: [], // stores maps added by addKeyMap - overlays: [], // highlighting overlays, as added by addOverlay - modeGen: 0, // bumped when mode/overlay changes, used to invalidate highlighting info - overwrite: false, - delayingBlurEvent: false, - focused: false, - suppressEdits: false, // used to disable editing during key handlers when in readOnly mode - pasteIncoming: false, cutIncoming: false, // help recognize paste/cut edits in input.poll - selectingText: false, - draggingText: false, - highlight: new Delayed(), // stores highlight worker timeout - keySeq: null, // Unfinished key sequence - specialChars: null - }; - - if (options.autofocus && !mobile) { display.input.focus(); } - - // Override magic textarea content restore that IE sometimes does - // on our hidden textarea on reload - if (ie && ie_version < 11) { setTimeout(function () { return this$1.display.input.reset(true); }, 20); } - - registerEventHandlers(this); - ensureGlobalHandlers(); - - startOperation(this); - this.curOp.forceUpdate = true; - attachDoc(this, doc); - - if ((options.autofocus && !mobile) || this.hasFocus()) - { setTimeout(bind(onFocus, this), 20); } - else - { onBlur(this); } - - for (var opt in optionHandlers) { if (optionHandlers.hasOwnProperty(opt)) - { optionHandlers[opt](this$1, options[opt], Init); } } - maybeUpdateLineNumberWidth(this); - if (options.finishInit) { options.finishInit(this); } - for (var i = 0; i < initHooks.length; ++i) { initHooks[i](this$1); } - endOperation(this); - // Suppress optimizelegibility in Webkit, since it breaks text - // measuring on line wrapping boundaries. - if (webkit && options.lineWrapping && - getComputedStyle(display.lineDiv).textRendering == "optimizelegibility") - { display.lineDiv.style.textRendering = "auto"; } -} - -// The default configuration options. -CodeMirror$1.defaults = defaults; -// Functions to run when options are changed. -CodeMirror$1.optionHandlers = optionHandlers; - -// Attach the necessary event handlers when initializing the editor -function registerEventHandlers(cm) { - var d = cm.display; - on(d.scroller, "mousedown", operation(cm, onMouseDown)); - // Older IE's will not fire a second mousedown for a double click - if (ie && ie_version < 11) - { on(d.scroller, "dblclick", operation(cm, function (e) { - if (signalDOMEvent(cm, e)) { return } - var pos = posFromMouse(cm, e); - if (!pos || clickInGutter(cm, e) || eventInWidget(cm.display, e)) { return } - e_preventDefault(e); - var word = cm.findWordAt(pos); - extendSelection(cm.doc, word.anchor, word.head); - })); } - else - { on(d.scroller, "dblclick", function (e) { return signalDOMEvent(cm, e) || e_preventDefault(e); }); } - // Some browsers fire contextmenu *after* opening the menu, at - // which point we can't mess with it anymore. Context menu is - // handled in onMouseDown for these browsers. - if (!captureRightClick) { on(d.scroller, "contextmenu", function (e) { return onContextMenu(cm, e); }); } - - // Used to suppress mouse event handling when a touch happens - var touchFinished, prevTouch = {end: 0}; - function finishTouch() { - if (d.activeTouch) { - touchFinished = setTimeout(function () { return d.activeTouch = null; }, 1000); - prevTouch = d.activeTouch; - prevTouch.end = +new Date; - } - } - function isMouseLikeTouchEvent(e) { - if (e.touches.length != 1) { return false } - var touch = e.touches[0]; - return touch.radiusX <= 1 && touch.radiusY <= 1 - } - function farAway(touch, other) { - if (other.left == null) { return true } - var dx = other.left - touch.left, dy = other.top - touch.top; - return dx * dx + dy * dy > 20 * 20 - } - on(d.scroller, "touchstart", function (e) { - if (!signalDOMEvent(cm, e) && !isMouseLikeTouchEvent(e) && !clickInGutter(cm, e)) { - d.input.ensurePolled(); - clearTimeout(touchFinished); - var now = +new Date; - d.activeTouch = {start: now, moved: false, - prev: now - prevTouch.end <= 300 ? prevTouch : null}; - if (e.touches.length == 1) { - d.activeTouch.left = e.touches[0].pageX; - d.activeTouch.top = e.touches[0].pageY; - } - } - }); - on(d.scroller, "touchmove", function () { - if (d.activeTouch) { d.activeTouch.moved = true; } - }); - on(d.scroller, "touchend", function (e) { - var touch = d.activeTouch; - if (touch && !eventInWidget(d, e) && touch.left != null && - !touch.moved && new Date - touch.start < 300) { - var pos = cm.coordsChar(d.activeTouch, "page"), range; - if (!touch.prev || farAway(touch, touch.prev)) // Single tap - { range = new Range(pos, pos); } - else if (!touch.prev.prev || farAway(touch, touch.prev.prev)) // Double tap - { range = cm.findWordAt(pos); } - else // Triple tap - { range = new Range(Pos(pos.line, 0), clipPos(cm.doc, Pos(pos.line + 1, 0))); } - cm.setSelection(range.anchor, range.head); - cm.focus(); - e_preventDefault(e); - } - finishTouch(); - }); - on(d.scroller, "touchcancel", finishTouch); - - // Sync scrolling between fake scrollbars and real scrollable - // area, ensure viewport is updated when scrolling. - on(d.scroller, "scroll", function () { - if (d.scroller.clientHeight) { - updateScrollTop(cm, d.scroller.scrollTop); - setScrollLeft(cm, d.scroller.scrollLeft, true); - signal(cm, "scroll", cm); - } - }); - // Listen to wheel events in order to try and update the viewport on time. - on(d.scroller, "mousewheel", function (e) { return onScrollWheel(cm, e); }); - on(d.scroller, "DOMMouseScroll", function (e) { return onScrollWheel(cm, e); }); - - // Prevent wrapper from ever scrolling - on(d.wrapper, "scroll", function () { return d.wrapper.scrollTop = d.wrapper.scrollLeft = 0; }); - - d.dragFunctions = { - enter: function (e) {if (!signalDOMEvent(cm, e)) { e_stop(e); }}, - over: function (e) {if (!signalDOMEvent(cm, e)) { onDragOver(cm, e); e_stop(e); }}, - start: function (e) { return onDragStart(cm, e); }, - drop: operation(cm, onDrop), - leave: function (e) {if (!signalDOMEvent(cm, e)) { clearDragCursor(cm); }} - }; - - var inp = d.input.getField(); - on(inp, "keyup", function (e) { return onKeyUp.call(cm, e); }); - on(inp, "keydown", operation(cm, onKeyDown)); - on(inp, "keypress", operation(cm, onKeyPress)); - on(inp, "focus", function (e) { return onFocus(cm, e); }); - on(inp, "blur", function (e) { return onBlur(cm, e); }); -} - -var initHooks = []; -CodeMirror$1.defineInitHook = function (f) { return initHooks.push(f); }; - -// Indent the given line. The how parameter can be "smart", -// "add"/null, "subtract", or "prev". When aggressive is false -// (typically set to true for forced single-line indents), empty -// lines are not indented, and places where the mode returns Pass -// are left alone. -function indentLine(cm, n, how, aggressive) { - var doc = cm.doc, state; - if (how == null) { how = "add"; } - if (how == "smart") { - // Fall back to "prev" when the mode doesn't have an indentation - // method. - if (!doc.mode.indent) { how = "prev"; } - else { state = getContextBefore(cm, n).state; } - } - - var tabSize = cm.options.tabSize; - var line = getLine(doc, n), curSpace = countColumn(line.text, null, tabSize); - if (line.stateAfter) { line.stateAfter = null; } - var curSpaceString = line.text.match(/^\s*/)[0], indentation; - if (!aggressive && !/\S/.test(line.text)) { - indentation = 0; - how = "not"; - } else if (how == "smart") { - indentation = doc.mode.indent(state, line.text.slice(curSpaceString.length), line.text); - if (indentation == Pass || indentation > 150) { - if (!aggressive) { return } - how = "prev"; - } - } - if (how == "prev") { - if (n > doc.first) { indentation = countColumn(getLine(doc, n-1).text, null, tabSize); } - else { indentation = 0; } - } else if (how == "add") { - indentation = curSpace + cm.options.indentUnit; - } else if (how == "subtract") { - indentation = curSpace - cm.options.indentUnit; - } else if (typeof how == "number") { - indentation = curSpace + how; - } - indentation = Math.max(0, indentation); - - var indentString = "", pos = 0; - if (cm.options.indentWithTabs) - { for (var i = Math.floor(indentation / tabSize); i; --i) {pos += tabSize; indentString += "\t";} } - if (pos < indentation) { indentString += spaceStr(indentation - pos); } - - if (indentString != curSpaceString) { - replaceRange(doc, indentString, Pos(n, 0), Pos(n, curSpaceString.length), "+input"); - line.stateAfter = null; - return true - } else { - // Ensure that, if the cursor was in the whitespace at the start - // of the line, it is moved to the end of that space. - for (var i$1 = 0; i$1 < doc.sel.ranges.length; i$1++) { - var range = doc.sel.ranges[i$1]; - if (range.head.line == n && range.head.ch < curSpaceString.length) { - var pos$1 = Pos(n, curSpaceString.length); - replaceOneSelection(doc, i$1, new Range(pos$1, pos$1)); - break - } - } + function getAttrValue(text, attr) { + var match = text.match(getAttrRegexp(attr)) + return match ? /^\s*(.*?)\s*$/.exec(match[2])[1] : "" } -} - -// This will be set to a {lineWise: bool, text: [string]} object, so -// that, when pasting, we know what kind of selections the copied -// text was made out of. -var lastCopied = null; -function setLastCopied(newLastCopied) { - lastCopied = newLastCopied; -} - -function applyTextInput(cm, inserted, deleted, sel, origin) { - var doc = cm.doc; - cm.display.shift = false; - if (!sel) { sel = doc.sel; } - - var paste = cm.state.pasteIncoming || origin == "paste"; - var textLines = splitLinesAuto(inserted), multiPaste = null; - // When pasing N lines into N selections, insert one line per selection - if (paste && sel.ranges.length > 1) { - if (lastCopied && lastCopied.text.join("\n") == inserted) { - if (sel.ranges.length % lastCopied.text.length == 0) { - multiPaste = []; - for (var i = 0; i < lastCopied.text.length; i++) - { multiPaste.push(doc.splitLines(lastCopied.text[i])); } - } - } else if (textLines.length == sel.ranges.length && cm.options.pasteLinesPerSelection) { - multiPaste = map(textLines, function (l) { return [l]; }); - } - } - - var updateInput; - // Normal behavior is to insert the new text into every selection - for (var i$1 = sel.ranges.length - 1; i$1 >= 0; i$1--) { - var range$$1 = sel.ranges[i$1]; - var from = range$$1.from(), to = range$$1.to(); - if (range$$1.empty()) { - if (deleted && deleted > 0) // Handle deletion - { from = Pos(from.line, from.ch - deleted); } - else if (cm.state.overwrite && !paste) // Handle overwrite - { to = Pos(to.line, Math.min(getLine(doc, to.line).text.length, to.ch + lst(textLines).length)); } - else if (lastCopied && lastCopied.lineWise && lastCopied.text.join("\n") == inserted) - { from = to = Pos(from.line, 0); } - } - updateInput = cm.curOp.updateInput; - var changeEvent = {from: from, to: to, text: multiPaste ? multiPaste[i$1 % multiPaste.length] : textLines, - origin: origin || (paste ? "paste" : cm.state.cutIncoming ? "cut" : "+input")}; - makeChange(cm.doc, changeEvent); - signalLater(cm, "inputRead", cm, changeEvent); - } - if (inserted && !paste) - { triggerElectric(cm, inserted); } - - ensureCursorVisible(cm); - cm.curOp.updateInput = updateInput; - cm.curOp.typing = true; - cm.state.pasteIncoming = cm.state.cutIncoming = false; -} - -function handlePaste(e, cm) { - var pasted = e.clipboardData && e.clipboardData.getData("Text"); - if (pasted) { - e.preventDefault(); - if (!cm.isReadOnly() && !cm.options.disableInput) - { runInOp(cm, function () { return applyTextInput(cm, pasted, 0, null, "paste"); }); } - return true + function getTagRegexp(tagName, anchored) { + return new RegExp((anchored ? "^" : "") + "<\/\s*" + tagName + "\s*>", "i"); } -} -function triggerElectric(cm, inserted) { - // When an 'electric' character is inserted, immediately trigger a reindent - if (!cm.options.electricChars || !cm.options.smartIndent) { return } - var sel = cm.doc.sel; - - for (var i = sel.ranges.length - 1; i >= 0; i--) { - var range$$1 = sel.ranges[i]; - if (range$$1.head.ch > 100 || (i && sel.ranges[i - 1].head.line == range$$1.head.line)) { continue } - var mode = cm.getModeAt(range$$1.head); - var indented = false; - if (mode.electricChars) { - for (var j = 0; j < mode.electricChars.length; j++) - { if (inserted.indexOf(mode.electricChars.charAt(j)) > -1) { - indented = indentLine(cm, range$$1.head.line, "smart"); - break - } } - } else if (mode.electricInput) { - if (mode.electricInput.test(getLine(cm.doc, range$$1.head.line).text.slice(0, range$$1.head.ch))) - { indented = indentLine(cm, range$$1.head.line, "smart"); } + function addTags(from, to) { + for (var tag in from) { + var dest = to[tag] || (to[tag] = []); + var source = from[tag]; + for (var i = source.length - 1; i >= 0; i--) + dest.unshift(source[i]) } - if (indented) { signalLater(cm, "electricInput", cm, range$$1.head.line); } } -} -function copyableRanges(cm) { - var text = [], ranges = []; - for (var i = 0; i < cm.doc.sel.ranges.length; i++) { - var line = cm.doc.sel.ranges[i].head.line; - var lineRange = {anchor: Pos(line, 0), head: Pos(line + 1, 0)}; - ranges.push(lineRange); - text.push(cm.getRange(lineRange.anchor, lineRange.head)); + function findMatchingMode(tagInfo, tagText) { + for (var i = 0; i < tagInfo.length; i++) { + var spec = tagInfo[i]; + if (!spec[0] || spec[1].test(getAttrValue(tagText, spec[0]))) return spec[2]; + } } - return {text: text, ranges: ranges} -} - -function disableBrowserMagic(field, spellcheck) { - field.setAttribute("autocorrect", "off"); - field.setAttribute("autocapitalize", "off"); - field.setAttribute("spellcheck", !!spellcheck); -} - -function hiddenTextarea() { - var te = elt("textarea", null, null, "position: absolute; bottom: -1em; padding: 0; width: 1px; height: 1em; outline: none"); - var div = elt("div", [te], null, "overflow: hidden; position: relative; width: 3px; height: 0px;"); - // The textarea is kept positioned near the cursor to prevent the - // fact that it'll be scrolled into view on input from scrolling - // our fake cursor out of view. On webkit, when wrap=off, paste is - // very slow. So make the area wide instead. - if (webkit) { te.style.width = "1000px"; } - else { te.setAttribute("wrap", "off"); } - // If border: 0; -- iOS fails to open keyboard (issue #1287) - if (ios) { te.style.border = "1px solid black"; } - disableBrowserMagic(te); - return div -} - -// The publicly visible API. Note that methodOp(f) means -// 'wrap f in an operation, performed on its `this` parameter'. - -// This is not the complete set of editor methods. Most of the -// methods defined on the Doc type are also injected into -// CodeMirror.prototype, for backwards compatibility and -// convenience. - -var addEditorMethods = function(CodeMirror) { - var optionHandlers = CodeMirror.optionHandlers; - - var helpers = CodeMirror.helpers = {}; - CodeMirror.prototype = { - constructor: CodeMirror, - focus: function(){window.focus(); this.display.input.focus();}, - - setOption: function(option, value) { - var options = this.options, old = options[option]; - if (options[option] == value && option != "mode") { return } - options[option] = value; - if (optionHandlers.hasOwnProperty(option)) - { operation(this, optionHandlers[option])(this, value, old); } - signal(this, "optionChange", this, option); - }, - - getOption: function(option) {return this.options[option]}, - getDoc: function() {return this.doc}, - - addKeyMap: function(map$$1, bottom) { - this.state.keyMaps[bottom ? "push" : "unshift"](getKeyMap(map$$1)); - }, - removeKeyMap: function(map$$1) { - var maps = this.state.keyMaps; - for (var i = 0; i < maps.length; ++i) - { if (maps[i] == map$$1 || maps[i].name == map$$1) { - maps.splice(i, 1); - return true - } } - }, + CodeMirror.defineMode("htmlmixed", function (config, parserConfig) { + var htmlMode = CodeMirror.getMode(config, { + name: "xml", + htmlMode: true, + multilineTagIndentFactor: parserConfig.multilineTagIndentFactor, + multilineTagIndentPastTag: parserConfig.multilineTagIndentPastTag + }); - addOverlay: methodOp(function(spec, options) { - var mode = spec.token ? spec : CodeMirror.getMode(this.options, spec); - if (mode.startState) { throw new Error("Overlays may not be stateful.") } - insertSorted(this.state.overlays, - {mode: mode, modeSpec: spec, opaque: options && options.opaque, - priority: (options && options.priority) || 0}, - function (overlay) { return overlay.priority; }); - this.state.modeGen++; - regChange(this); - }), - removeOverlay: methodOp(function(spec) { - var this$1 = this; + var tags = {}; + var configTags = parserConfig && parserConfig.tags, configScript = parserConfig && parserConfig.scriptTypes; + addTags(defaultTags, tags); + if (configTags) addTags(configTags, tags); + if (configScript) for (var i = configScript.length - 1; i >= 0; i--) + tags.script.unshift(["type", configScript[i].matches, configScript[i].mode]) - var overlays = this.state.overlays; - for (var i = 0; i < overlays.length; ++i) { - var cur = overlays[i].modeSpec; - if (cur == spec || typeof spec == "string" && cur.name == spec) { - overlays.splice(i, 1); - this$1.state.modeGen++; - regChange(this$1); - return - } + function html(stream, state) { + var style = htmlMode.token(stream, state.htmlState), tag = /\btag\b/.test(style), tagName + if (tag && !/[<>\s\/]/.test(stream.current()) && + (tagName = state.htmlState.tagName && state.htmlState.tagName.toLowerCase()) && + tags.hasOwnProperty(tagName)) { + state.inTag = tagName + " " + } else if (state.inTag && tag && />$/.test(stream.current())) { + var inTag = /^([\S]+) (.*)/.exec(state.inTag) + state.inTag = null + var modeSpec = stream.current() == ">" && findMatchingMode(tags[inTag[1]], inTag[2]) + var mode = CodeMirror.getMode(config, modeSpec) + var endTagA = getTagRegexp(inTag[1], true), endTag = getTagRegexp(inTag[1], false); + state.token = function (stream, state) { + if (stream.match(endTagA, false)) { + state.token = html; + state.localState = state.localMode = null; + return null; + } + return maybeBackup(stream, endTag, state.localMode.token(stream, state.localState)); + }; + state.localMode = mode; + state.localState = CodeMirror.startState(mode, htmlMode.indent(state.htmlState, "", "")); + } else if (state.inTag) { + state.inTag += stream.current() + if (stream.eol()) state.inTag += " " } - }), + return style; + }; - indentLine: methodOp(function(n, dir, aggressive) { - if (typeof dir != "string" && typeof dir != "number") { - if (dir == null) { dir = this.options.smartIndent ? "smart" : "prev"; } - else { dir = dir ? "add" : "subtract"; } - } - if (isLine(this.doc, n)) { indentLine(this, n, dir, aggressive); } - }), - indentSelection: methodOp(function(how) { - var this$1 = this; + return { + startState: function () { + var state = CodeMirror.startState(htmlMode); + return {token: html, inTag: null, localMode: null, localState: null, htmlState: state}; + }, - var ranges = this.doc.sel.ranges, end = -1; - for (var i = 0; i < ranges.length; i++) { - var range$$1 = ranges[i]; - if (!range$$1.empty()) { - var from = range$$1.from(), to = range$$1.to(); - var start = Math.max(end, from.line); - end = Math.min(this$1.lastLine(), to.line - (to.ch ? 0 : 1)) + 1; - for (var j = start; j < end; ++j) - { indentLine(this$1, j, how); } - var newRanges = this$1.doc.sel.ranges; - if (from.ch == 0 && ranges.length == newRanges.length && newRanges[i].from().ch > 0) - { replaceOneSelection(this$1.doc, i, new Range(from, newRanges[i].to()), sel_dontScroll); } - } else if (range$$1.head.line > end) { - indentLine(this$1, range$$1.head.line, how, true); - end = range$$1.head.line; - if (i == this$1.doc.sel.primIndex) { ensureCursorVisible(this$1); } + copyState: function (state) { + var local; + if (state.localState) { + local = CodeMirror.copyState(state.localMode, state.localState); } - } - }), - - // Fetch the parser token for a given character. Useful for hacks - // that want to inspect the mode state (say, for completion). - getTokenAt: function(pos, precise) { - return takeToken(this, pos, precise) - }, - - getLineTokens: function(line, precise) { - return takeToken(this, Pos(line), precise, true) - }, - - getTokenTypeAt: function(pos) { - pos = clipPos(this.doc, pos); - var styles = getLineStyles(this, getLine(this.doc, pos.line)); - var before = 0, after = (styles.length - 1) / 2, ch = pos.ch; - var type; - if (ch == 0) { type = styles[2]; } - else { for (;;) { - var mid = (before + after) >> 1; - if ((mid ? styles[mid * 2 - 1] : 0) >= ch) { after = mid; } - else if (styles[mid * 2 + 1] < ch) { before = mid + 1; } - else { type = styles[mid * 2 + 2]; break } - } } - var cut = type ? type.indexOf("overlay ") : -1; - return cut < 0 ? type : cut == 0 ? null : type.slice(0, cut - 1) - }, - - getModeAt: function(pos) { - var mode = this.doc.mode; - if (!mode.innerMode) { return mode } - return CodeMirror.innerMode(mode, this.getTokenAt(pos).state).mode - }, + return {token: state.token, inTag: state.inTag, + localMode: state.localMode, localState: local, + htmlState: CodeMirror.copyState(htmlMode, state.htmlState)}; + }, - getHelper: function(pos, type) { - return this.getHelpers(pos, type)[0] - }, + token: function (stream, state) { + return state.token(stream, state); + }, - getHelpers: function(pos, type) { - var this$1 = this; + indent: function (state, textAfter, line) { + if (!state.localMode || /^\s*<\//.test(textAfter)) + return htmlMode.indent(state.htmlState, textAfter, line); + else if (state.localMode.indent) + return state.localMode.indent(state.localState, textAfter, line); + else + return CodeMirror.Pass; + }, - var found = []; - if (!helpers.hasOwnProperty(type)) { return found } - var help = helpers[type], mode = this.getModeAt(pos); - if (typeof mode[type] == "string") { - if (help[mode[type]]) { found.push(help[mode[type]]); } - } else if (mode[type]) { - for (var i = 0; i < mode[type].length; i++) { - var val = help[mode[type][i]]; - if (val) { found.push(val); } - } - } else if (mode.helperType && help[mode.helperType]) { - found.push(help[mode.helperType]); - } else if (help[mode.name]) { - found.push(help[mode.name]); - } - for (var i$1 = 0; i$1 < help._global.length; i$1++) { - var cur = help._global[i$1]; - if (cur.pred(mode, this$1) && indexOf(found, cur.val) == -1) - { found.push(cur.val); } + innerMode: function (state) { + return {state: state.localState || state.htmlState, mode: state.localMode || htmlMode}; } - return found - }, + }; + }, "xml", "javascript", "css"); - getStateAfter: function(line, precise) { - var doc = this.doc; - line = clipLine(doc, line == null ? doc.first + doc.size - 1: line); - return getContextBefore(this, line + 1, precise).state - }, + CodeMirror.defineMIME("text/html", "htmlmixed"); +}); - cursorCoords: function(start, mode) { - var pos, range$$1 = this.doc.sel.primary(); - if (start == null) { pos = range$$1.head; } - else if (typeof start == "object") { pos = clipPos(this.doc, start); } - else { pos = start ? range$$1.from() : range$$1.to(); } - return cursorCoords(this, pos, mode || "page") - }, - charCoords: function(pos, mode) { - return charCoords(this, clipPos(this.doc, pos), mode || "page") - }, +/***/ }), - coordsChar: function(coords, mode) { - coords = fromCoordSystem(this, coords, mode || "page"); - return coordsChar(this, coords.left, coords.top) - }, +/***/ "./node_modules/codemirror/mode/javascript/javascript.js": +/*!***************************************************************!*\ + !*** ./node_modules/codemirror/mode/javascript/javascript.js ***! + \***************************************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { - lineAtHeight: function(height, mode) { - height = fromCoordSystem(this, {top: height, left: 0}, mode || "page").top; - return lineAtHeight(this.doc, height + this.display.viewOffset) - }, - heightAtLine: function(line, mode, includeWidgets) { - var end = false, lineObj; - if (typeof line == "number") { - var last = this.doc.first + this.doc.size - 1; - if (line < this.doc.first) { line = this.doc.first; } - else if (line > last) { line = last; end = true; } - lineObj = getLine(this.doc, line); - } else { - lineObj = line; - } - return intoCoordSystem(this, lineObj, {top: 0, left: 0}, mode || "page", includeWidgets || end).top + - (end ? this.doc.height - heightAtLine(lineObj) : 0) - }, - - defaultTextHeight: function() { return textHeight(this.display) }, - defaultCharWidth: function() { return charWidth(this.display) }, - - getViewport: function() { return {from: this.display.viewFrom, to: this.display.viewTo}}, - - addWidget: function(pos, node, scroll, vert, horiz) { - var display = this.display; - pos = cursorCoords(this, clipPos(this.doc, pos)); - var top = pos.bottom, left = pos.left; - node.style.position = "absolute"; - node.setAttribute("cm-ignore-events", "true"); - this.display.input.setUneditable(node); - display.sizer.appendChild(node); - if (vert == "over") { - top = pos.top; - } else if (vert == "above" || vert == "near") { - var vspace = Math.max(display.wrapper.clientHeight, this.doc.height), - hspace = Math.max(display.sizer.clientWidth, display.lineSpace.clientWidth); - // Default to positioning above (if specified and possible); otherwise default to positioning below - if ((vert == 'above' || pos.bottom + node.offsetHeight > vspace) && pos.top > node.offsetHeight) - { top = pos.top - node.offsetHeight; } - else if (pos.bottom + node.offsetHeight <= vspace) - { top = pos.bottom; } - if (left + node.offsetWidth > hspace) - { left = hspace - node.offsetWidth; } - } - node.style.top = top + "px"; - node.style.left = node.style.right = ""; - if (horiz == "right") { - left = display.sizer.clientWidth - node.offsetWidth; - node.style.right = "0px"; - } else { - if (horiz == "left") { left = 0; } - else if (horiz == "middle") { left = (display.sizer.clientWidth - node.offsetWidth) / 2; } - node.style.left = left + "px"; - } - if (scroll) - { scrollIntoView(this, {left: left, top: top, right: left + node.offsetWidth, bottom: top + node.offsetHeight}); } - }, +// CodeMirror, copyright (c) by Marijn Haverbeke and others +// Distributed under an MIT license: https://codemirror.net/LICENSE - triggerOnKeyDown: methodOp(onKeyDown), - triggerOnKeyPress: methodOp(onKeyPress), - triggerOnKeyUp: onKeyUp, - triggerOnMouseDown: methodOp(onMouseDown), +(function(mod) { + if (true) // CommonJS + mod(__webpack_require__(/*! ../../lib/codemirror */ "./node_modules/codemirror/lib/codemirror.js")); + else {} +})(function(CodeMirror) { +"use strict"; - execCommand: function(cmd) { - if (commands.hasOwnProperty(cmd)) - { return commands[cmd].call(null, this) } - }, +CodeMirror.defineMode("javascript", function(config, parserConfig) { + var indentUnit = config.indentUnit; + var statementIndent = parserConfig.statementIndent; + var jsonldMode = parserConfig.jsonld; + var jsonMode = parserConfig.json || jsonldMode; + var isTS = parserConfig.typescript; + var wordRE = parserConfig.wordCharacters || /[\w$\xa1-\uffff]/; - triggerElectric: methodOp(function(text) { triggerElectric(this, text); }), + // Tokenizer - findPosH: function(from, amount, unit, visually) { - var this$1 = this; - - var dir = 1; - if (amount < 0) { dir = -1; amount = -amount; } - var cur = clipPos(this.doc, from); - for (var i = 0; i < amount; ++i) { - cur = findPosH(this$1.doc, cur, dir, unit, visually); - if (cur.hitSide) { break } - } - return cur - }, - - moveH: methodOp(function(dir, unit) { - var this$1 = this; - - this.extendSelectionsBy(function (range$$1) { - if (this$1.display.shift || this$1.doc.extend || range$$1.empty()) - { return findPosH(this$1.doc, range$$1.head, dir, unit, this$1.options.rtlMoveVisually) } - else - { return dir < 0 ? range$$1.from() : range$$1.to() } - }, sel_move); - }), - - deleteH: methodOp(function(dir, unit) { - var sel = this.doc.sel, doc = this.doc; - if (sel.somethingSelected()) - { doc.replaceSelection("", null, "+delete"); } - else - { deleteNearSelection(this, function (range$$1) { - var other = findPosH(doc, range$$1.head, dir, unit, false); - return dir < 0 ? {from: other, to: range$$1.head} : {from: range$$1.head, to: other} - }); } - }), - - findPosV: function(from, amount, unit, goalColumn) { - var this$1 = this; - - var dir = 1, x = goalColumn; - if (amount < 0) { dir = -1; amount = -amount; } - var cur = clipPos(this.doc, from); - for (var i = 0; i < amount; ++i) { - var coords = cursorCoords(this$1, cur, "div"); - if (x == null) { x = coords.left; } - else { coords.left = x; } - cur = findPosV(this$1, coords, dir, unit); - if (cur.hitSide) { break } - } - return cur - }, - - moveV: methodOp(function(dir, unit) { - var this$1 = this; - - var doc = this.doc, goals = []; - var collapse = !this.display.shift && !doc.extend && doc.sel.somethingSelected(); - doc.extendSelectionsBy(function (range$$1) { - if (collapse) - { return dir < 0 ? range$$1.from() : range$$1.to() } - var headPos = cursorCoords(this$1, range$$1.head, "div"); - if (range$$1.goalColumn != null) { headPos.left = range$$1.goalColumn; } - goals.push(headPos.left); - var pos = findPosV(this$1, headPos, dir, unit); - if (unit == "page" && range$$1 == doc.sel.primary()) - { addToScrollTop(this$1, charCoords(this$1, pos, "div").top - headPos.top); } - return pos - }, sel_move); - if (goals.length) { for (var i = 0; i < doc.sel.ranges.length; i++) - { doc.sel.ranges[i].goalColumn = goals[i]; } } - }), - - // Find the word at the given position (as returned by coordsChar). - findWordAt: function(pos) { - var doc = this.doc, line = getLine(doc, pos.line).text; - var start = pos.ch, end = pos.ch; - if (line) { - var helper = this.getHelper(pos, "wordChars"); - if ((pos.sticky == "before" || end == line.length) && start) { --start; } else { ++end; } - var startChar = line.charAt(start); - var check = isWordChar(startChar, helper) - ? function (ch) { return isWordChar(ch, helper); } - : /\s/.test(startChar) ? function (ch) { return /\s/.test(ch); } - : function (ch) { return (!/\s/.test(ch) && !isWordChar(ch)); }; - while (start > 0 && check(line.charAt(start - 1))) { --start; } - while (end < line.length && check(line.charAt(end))) { ++end; } - } - return new Range(Pos(pos.line, start), Pos(pos.line, end)) - }, - - toggleOverwrite: function(value) { - if (value != null && value == this.state.overwrite) { return } - if (this.state.overwrite = !this.state.overwrite) - { addClass(this.display.cursorDiv, "CodeMirror-overwrite"); } - else - { rmClass(this.display.cursorDiv, "CodeMirror-overwrite"); } + var keywords = function(){ + function kw(type) {return {type: type, style: "keyword"};} + var A = kw("keyword a"), B = kw("keyword b"), C = kw("keyword c"), D = kw("keyword d"); + var operator = kw("operator"), atom = {type: "atom", style: "atom"}; - signal(this, "overwriteToggle", this, this.state.overwrite); - }, - hasFocus: function() { return this.display.input.getField() == activeElt() }, - isReadOnly: function() { return !!(this.options.readOnly || this.doc.cantEdit) }, + return { + "if": kw("if"), "while": A, "with": A, "else": B, "do": B, "try": B, "finally": B, + "return": D, "break": D, "continue": D, "new": kw("new"), "delete": C, "void": C, "throw": C, + "debugger": kw("debugger"), "var": kw("var"), "const": kw("var"), "let": kw("var"), + "function": kw("function"), "catch": kw("catch"), + "for": kw("for"), "switch": kw("switch"), "case": kw("case"), "default": kw("default"), + "in": operator, "typeof": operator, "instanceof": operator, + "true": atom, "false": atom, "null": atom, "undefined": atom, "NaN": atom, "Infinity": atom, + "this": kw("this"), "class": kw("class"), "super": kw("atom"), + "yield": C, "export": kw("export"), "import": kw("import"), "extends": C, + "await": C + }; + }(); - scrollTo: methodOp(function (x, y) { scrollToCoords(this, x, y); }), - getScrollInfo: function() { - var scroller = this.display.scroller; - return {left: scroller.scrollLeft, top: scroller.scrollTop, - height: scroller.scrollHeight - scrollGap(this) - this.display.barHeight, - width: scroller.scrollWidth - scrollGap(this) - this.display.barWidth, - clientHeight: displayHeight(this), clientWidth: displayWidth(this)} - }, + var isOperatorChar = /[+\-*&%=<>!?|~^@]/; + var isJsonldKeyword = /^@(context|id|value|language|type|container|list|set|reverse|index|base|vocab|graph)"/; - scrollIntoView: methodOp(function(range$$1, margin) { - if (range$$1 == null) { - range$$1 = {from: this.doc.sel.primary().head, to: null}; - if (margin == null) { margin = this.options.cursorScrollMargin; } - } else if (typeof range$$1 == "number") { - range$$1 = {from: Pos(range$$1, 0), to: null}; - } else if (range$$1.from == null) { - range$$1 = {from: range$$1, to: null}; + function readRegexp(stream) { + var escaped = false, next, inSet = false; + while ((next = stream.next()) != null) { + if (!escaped) { + if (next == "/" && !inSet) return; + if (next == "[") inSet = true; + else if (inSet && next == "]") inSet = false; } - if (!range$$1.to) { range$$1.to = range$$1.from; } - range$$1.margin = margin || 0; + escaped = !escaped && next == "\\"; + } + } - if (range$$1.from.line != null) { - scrollToRange(this, range$$1); + // Used as scratch variables to communicate multiple values without + // consing up tons of objects. + var type, content; + function ret(tp, style, cont) { + type = tp; content = cont; + return style; + } + function tokenBase(stream, state) { + var ch = stream.next(); + if (ch == '"' || ch == "'") { + state.tokenize = tokenString(ch); + return state.tokenize(stream, state); + } else if (ch == "." && stream.match(/^\d[\d_]*(?:[eE][+\-]?[\d_]+)?/)) { + return ret("number", "number"); + } else if (ch == "." && stream.match("..")) { + return ret("spread", "meta"); + } else if (/[\[\]{}\(\),;\:\.]/.test(ch)) { + return ret(ch); + } else if (ch == "=" && stream.eat(">")) { + return ret("=>", "operator"); + } else if (ch == "0" && stream.match(/^(?:x[\dA-Fa-f_]+|o[0-7_]+|b[01_]+)n?/)) { + return ret("number", "number"); + } else if (/\d/.test(ch)) { + stream.match(/^[\d_]*(?:n|(?:\.[\d_]*)?(?:[eE][+\-]?[\d_]+)?)?/); + return ret("number", "number"); + } else if (ch == "/") { + if (stream.eat("*")) { + state.tokenize = tokenComment; + return tokenComment(stream, state); + } else if (stream.eat("/")) { + stream.skipToEnd(); + return ret("comment", "comment"); + } else if (expressionAllowed(stream, state, 1)) { + readRegexp(stream); + stream.match(/^\b(([gimyus])(?![gimyus]*\2))+\b/); + return ret("regexp", "string-2"); } else { - scrollToCoordsRange(this, range$$1.from, range$$1.to, range$$1.margin); + stream.eat("="); + return ret("operator", "operator", stream.current()); } - }), - - setSize: methodOp(function(width, height) { - var this$1 = this; - - var interpret = function (val) { return typeof val == "number" || /^\d+$/.test(String(val)) ? val + "px" : val; }; - if (width != null) { this.display.wrapper.style.width = interpret(width); } - if (height != null) { this.display.wrapper.style.height = interpret(height); } - if (this.options.lineWrapping) { clearLineMeasurementCache(this); } - var lineNo$$1 = this.display.viewFrom; - this.doc.iter(lineNo$$1, this.display.viewTo, function (line) { - if (line.widgets) { for (var i = 0; i < line.widgets.length; i++) - { if (line.widgets[i].noHScroll) { regLineChange(this$1, lineNo$$1, "widget"); break } } } - ++lineNo$$1; - }); - this.curOp.forceUpdate = true; - signal(this, "refresh", this); - }), - - operation: function(f){return runInOp(this, f)}, - startOperation: function(){return startOperation(this)}, - endOperation: function(){return endOperation(this)}, - - refresh: methodOp(function() { - var oldHeight = this.display.cachedTextHeight; - regChange(this); - this.curOp.forceUpdate = true; - clearCaches(this); - scrollToCoords(this, this.doc.scrollLeft, this.doc.scrollTop); - updateGutterSpace(this); - if (oldHeight == null || Math.abs(oldHeight - textHeight(this.display)) > .5) - { estimateLineHeights(this); } - signal(this, "refresh", this); - }), - - swapDoc: methodOp(function(doc) { - var old = this.doc; - old.cm = null; - attachDoc(this, doc); - clearCaches(this); - this.display.input.reset(); - scrollToCoords(this, doc.scrollLeft, doc.scrollTop); - this.curOp.forceScroll = true; - signalLater(this, "swapDoc", this, old); - return old - }), - - getInputField: function(){return this.display.input.getField()}, - getWrapperElement: function(){return this.display.wrapper}, - getScrollerElement: function(){return this.display.scroller}, - getGutterElement: function(){return this.display.gutters} - }; - eventMixin(CodeMirror); - - CodeMirror.registerHelper = function(type, name, value) { - if (!helpers.hasOwnProperty(type)) { helpers[type] = CodeMirror[type] = {_global: []}; } - helpers[type][name] = value; - }; - CodeMirror.registerGlobalHelper = function(type, name, predicate, value) { - CodeMirror.registerHelper(type, name, value); - helpers[type]._global.push({pred: predicate, val: value}); - }; -}; - -// Used for horizontal relative motion. Dir is -1 or 1 (left or -// right), unit can be "char", "column" (like char, but doesn't -// cross line boundaries), "word" (across next word), or "group" (to -// the start of next group of word or non-word-non-whitespace -// chars). The visually param controls whether, in right-to-left -// text, direction 1 means to move towards the next index in the -// string, or towards the character to the right of the current -// position. The resulting position will have a hitSide=true -// property if it reached the end of the document. -function findPosH(doc, pos, dir, unit, visually) { - var oldPos = pos; - var origDir = dir; - var lineObj = getLine(doc, pos.line); - function findNextLine() { - var l = pos.line + dir; - if (l < doc.first || l >= doc.first + doc.size) { return false } - pos = new Pos(l, pos.ch, pos.sticky); - return lineObj = getLine(doc, l) - } - function moveOnce(boundToLine) { - var next; - if (visually) { - next = moveVisually(doc.cm, lineObj, pos, dir); - } else { - next = moveLogically(lineObj, pos, dir); - } - if (next == null) { - if (!boundToLine && findNextLine()) - { pos = endOfLine(visually, doc.cm, lineObj, pos.line, dir); } - else - { return false } - } else { - pos = next; + } else if (ch == "`") { + state.tokenize = tokenQuasi; + return tokenQuasi(stream, state); + } else if (ch == "#") { + stream.skipToEnd(); + return ret("error", "error"); + } else if (isOperatorChar.test(ch)) { + if (ch != ">" || !state.lexical || state.lexical.type != ">") { + if (stream.eat("=")) { + if (ch == "!" || ch == "=") stream.eat("=") + } else if (/[<>*+\-]/.test(ch)) { + stream.eat(ch) + if (ch == ">") stream.eat(ch) + } + } + return ret("operator", "operator", stream.current()); + } else if (wordRE.test(ch)) { + stream.eatWhile(wordRE); + var word = stream.current() + if (state.lastType != ".") { + if (keywords.propertyIsEnumerable(word)) { + var kw = keywords[word] + return ret(kw.type, kw.style, word) + } + if (word == "async" && stream.match(/^(\s|\/\*.*?\*\/)*[\[\(\w]/, false)) + return ret("async", "keyword", word) + } + return ret("variable", "variable", word) } - return true } - if (unit == "char") { - moveOnce(); - } else if (unit == "column") { - moveOnce(true); - } else if (unit == "word" || unit == "group") { - var sawType = null, group = unit == "group"; - var helper = doc.cm && doc.cm.getHelper(pos, "wordChars"); - for (var first = true;; first = false) { - if (dir < 0 && !moveOnce(!first)) { break } - var cur = lineObj.text.charAt(pos.ch) || "\n"; - var type = isWordChar(cur, helper) ? "w" - : group && cur == "\n" ? "n" - : !group || /\s/.test(cur) ? null - : "p"; - if (group && !first && !type) { type = "s"; } - if (sawType && sawType != type) { - if (dir < 0) {dir = 1; moveOnce(); pos.sticky = "after";} - break + function tokenString(quote) { + return function(stream, state) { + var escaped = false, next; + if (jsonldMode && stream.peek() == "@" && stream.match(isJsonldKeyword)){ + state.tokenize = tokenBase; + return ret("jsonld-keyword", "meta"); + } + while ((next = stream.next()) != null) { + if (next == quote && !escaped) break; + escaped = !escaped && next == "\\"; } + if (!escaped) state.tokenize = tokenBase; + return ret("string", "string"); + }; + } - if (type) { sawType = type; } - if (dir > 0 && !moveOnce(!first)) { break } + function tokenComment(stream, state) { + var maybeEnd = false, ch; + while (ch = stream.next()) { + if (ch == "/" && maybeEnd) { + state.tokenize = tokenBase; + break; + } + maybeEnd = (ch == "*"); } + return ret("comment", "comment"); } - var result = skipAtomic(doc, pos, oldPos, origDir, true); - if (equalCursorPos(oldPos, result)) { result.hitSide = true; } - return result -} - -// For relative vertical movement. Dir may be -1 or 1. Unit can be -// "page" or "line". The resulting position will have a hitSide=true -// property if it reached the end of the document. -function findPosV(cm, pos, dir, unit) { - var doc = cm.doc, x = pos.left, y; - if (unit == "page") { - var pageSize = Math.min(cm.display.wrapper.clientHeight, window.innerHeight || document.documentElement.clientHeight); - var moveAmount = Math.max(pageSize - .5 * textHeight(cm.display), 3); - y = (dir > 0 ? pos.bottom : pos.top) + dir * moveAmount; - - } else if (unit == "line") { - y = dir > 0 ? pos.bottom + 3 : pos.top - 3; - } - var target; - for (;;) { - target = coordsChar(cm, x, y); - if (!target.outside) { break } - if (dir < 0 ? y <= 0 : y >= doc.height) { target.hitSide = true; break } - y += dir * 5; - } - return target -} - -// CONTENTEDITABLE INPUT STYLE -var ContentEditableInput = function(cm) { - this.cm = cm; - this.lastAnchorNode = this.lastAnchorOffset = this.lastFocusNode = this.lastFocusOffset = null; - this.polling = new Delayed(); - this.composing = null; - this.gracePeriod = false; - this.readDOMTimeout = null; -}; - -ContentEditableInput.prototype.init = function (display) { - var this$1 = this; - - var input = this, cm = input.cm; - var div = input.div = display.lineDiv; - disableBrowserMagic(div, cm.options.spellcheck); - - on(div, "paste", function (e) { - if (signalDOMEvent(cm, e) || handlePaste(e, cm)) { return } - // IE doesn't fire input events, so we schedule a read for the pasted content in this way - if (ie_version <= 11) { setTimeout(operation(cm, function () { return this$1.updateFromDOM(); }), 20); } - }); - - on(div, "compositionstart", function (e) { - this$1.composing = {data: e.data, done: false}; - }); - on(div, "compositionupdate", function (e) { - if (!this$1.composing) { this$1.composing = {data: e.data, done: false}; } - }); - on(div, "compositionend", function (e) { - if (this$1.composing) { - if (e.data != this$1.composing.data) { this$1.readFromDOMSoon(); } - this$1.composing.done = true; + function tokenQuasi(stream, state) { + var escaped = false, next; + while ((next = stream.next()) != null) { + if (!escaped && (next == "`" || next == "$" && stream.eat("{"))) { + state.tokenize = tokenBase; + break; + } + escaped = !escaped && next == "\\"; } - }); - - on(div, "touchstart", function () { return input.forceCompositionEnd(); }); + return ret("quasi", "string-2", stream.current()); + } - on(div, "input", function () { - if (!this$1.composing) { this$1.readFromDOMSoon(); } - }); + var brackets = "([{}])"; + // This is a crude lookahead trick to try and notice that we're + // parsing the argument patterns for a fat-arrow function before we + // actually hit the arrow token. It only works if the arrow is on + // the same line as the arguments and there's no strange noise + // (comments) in between. Fallback is to only notice when we hit the + // arrow, and not declare the arguments as locals for the arrow + // body. + function findFatArrow(stream, state) { + if (state.fatArrowAt) state.fatArrowAt = null; + var arrow = stream.string.indexOf("=>", stream.start); + if (arrow < 0) return; - function onCopyCut(e) { - if (signalDOMEvent(cm, e)) { return } - if (cm.somethingSelected()) { - setLastCopied({lineWise: false, text: cm.getSelections()}); - if (e.type == "cut") { cm.replaceSelection("", null, "cut"); } - } else if (!cm.options.lineWiseCopyCut) { - return - } else { - var ranges = copyableRanges(cm); - setLastCopied({lineWise: true, text: ranges.text}); - if (e.type == "cut") { - cm.operation(function () { - cm.setSelections(ranges.ranges, 0, sel_dontScroll); - cm.replaceSelection("", null, "cut"); - }); - } + if (isTS) { // Try to skip TypeScript return type declarations after the arguments + var m = /:\s*(?:\w+(?:<[^>]*>|\[\])?|\{[^}]*\})\s*$/.exec(stream.string.slice(stream.start, arrow)) + if (m) arrow = m.index } - if (e.clipboardData) { - e.clipboardData.clearData(); - var content = lastCopied.text.join("\n"); - // iOS exposes the clipboard API, but seems to discard content inserted into it - e.clipboardData.setData("Text", content); - if (e.clipboardData.getData("Text") == content) { - e.preventDefault(); - return + + var depth = 0, sawSomething = false; + for (var pos = arrow - 1; pos >= 0; --pos) { + var ch = stream.string.charAt(pos); + var bracket = brackets.indexOf(ch); + if (bracket >= 0 && bracket < 3) { + if (!depth) { ++pos; break; } + if (--depth == 0) { if (ch == "(") sawSomething = true; break; } + } else if (bracket >= 3 && bracket < 6) { + ++depth; + } else if (wordRE.test(ch)) { + sawSomething = true; + } else if (/["'\/`]/.test(ch)) { + for (;; --pos) { + if (pos == 0) return + var next = stream.string.charAt(pos - 1) + if (next == ch && stream.string.charAt(pos - 2) != "\\") { pos--; break } + } + } else if (sawSomething && !depth) { + ++pos; + break; } } - // Old-fashioned briefly-focus-a-textarea hack - var kludge = hiddenTextarea(), te = kludge.firstChild; - cm.display.lineSpace.insertBefore(kludge, cm.display.lineSpace.firstChild); - te.value = lastCopied.text.join("\n"); - var hadFocus = document.activeElement; - selectInput(te); - setTimeout(function () { - cm.display.lineSpace.removeChild(kludge); - hadFocus.focus(); - if (hadFocus == div) { input.showPrimarySelection(); } - }, 50); + if (sawSomething && !depth) state.fatArrowAt = pos; } - on(div, "copy", onCopyCut); - on(div, "cut", onCopyCut); -}; -ContentEditableInput.prototype.prepareSelection = function () { - var result = prepareSelection(this.cm, false); - result.focus = this.cm.state.focused; - return result -}; - -ContentEditableInput.prototype.showSelection = function (info, takeFocus) { - if (!info || !this.cm.display.view.length) { return } - if (info.focus || takeFocus) { this.showPrimarySelection(); } - this.showMultipleSelections(info); -}; - -ContentEditableInput.prototype.showPrimarySelection = function () { - var sel = window.getSelection(), cm = this.cm, prim = cm.doc.sel.primary(); - var from = prim.from(), to = prim.to(); - - if (cm.display.viewTo == cm.display.viewFrom || from.line >= cm.display.viewTo || to.line < cm.display.viewFrom) { - sel.removeAllRanges(); - return - } + // Parser - var curAnchor = domToPos(cm, sel.anchorNode, sel.anchorOffset); - var curFocus = domToPos(cm, sel.focusNode, sel.focusOffset); - if (curAnchor && !curAnchor.bad && curFocus && !curFocus.bad && - cmp(minPos(curAnchor, curFocus), from) == 0 && - cmp(maxPos(curAnchor, curFocus), to) == 0) - { return } + var atomicTypes = {"atom": true, "number": true, "variable": true, "string": true, "regexp": true, "this": true, "jsonld-keyword": true}; - var view = cm.display.view; - var start = (from.line >= cm.display.viewFrom && posToDOM(cm, from)) || - {node: view[0].measure.map[2], offset: 0}; - var end = to.line < cm.display.viewTo && posToDOM(cm, to); - if (!end) { - var measure = view[view.length - 1].measure; - var map$$1 = measure.maps ? measure.maps[measure.maps.length - 1] : measure.map; - end = {node: map$$1[map$$1.length - 1], offset: map$$1[map$$1.length - 2] - map$$1[map$$1.length - 3]}; + function JSLexical(indented, column, type, align, prev, info) { + this.indented = indented; + this.column = column; + this.type = type; + this.prev = prev; + this.info = info; + if (align != null) this.align = align; } - if (!start || !end) { - sel.removeAllRanges(); - return + function inScope(state, varname) { + for (var v = state.localVars; v; v = v.next) + if (v.name == varname) return true; + for (var cx = state.context; cx; cx = cx.prev) { + for (var v = cx.vars; v; v = v.next) + if (v.name == varname) return true; + } } - var old = sel.rangeCount && sel.getRangeAt(0), rng; - try { rng = range(start.node, start.offset, end.offset, end.node); } - catch(e) {} // Our model of the DOM might be outdated, in which case the range we try to set can be impossible - if (rng) { - if (!gecko && cm.state.focused) { - sel.collapse(start.node, start.offset); - if (!rng.collapsed) { - sel.removeAllRanges(); - sel.addRange(rng); - } - } else { - sel.removeAllRanges(); - sel.addRange(rng); - } - if (old && sel.anchorNode == null) { sel.addRange(old); } - else if (gecko) { this.startGracePeriod(); } - } - this.rememberSelection(); -}; - -ContentEditableInput.prototype.startGracePeriod = function () { - var this$1 = this; - - clearTimeout(this.gracePeriod); - this.gracePeriod = setTimeout(function () { - this$1.gracePeriod = false; - if (this$1.selectionChanged()) - { this$1.cm.operation(function () { return this$1.cm.curOp.selectionChanged = true; }); } - }, 20); -}; - -ContentEditableInput.prototype.showMultipleSelections = function (info) { - removeChildrenAndAdd(this.cm.display.cursorDiv, info.cursors); - removeChildrenAndAdd(this.cm.display.selectionDiv, info.selection); -}; - -ContentEditableInput.prototype.rememberSelection = function () { - var sel = window.getSelection(); - this.lastAnchorNode = sel.anchorNode; this.lastAnchorOffset = sel.anchorOffset; - this.lastFocusNode = sel.focusNode; this.lastFocusOffset = sel.focusOffset; -}; - -ContentEditableInput.prototype.selectionInEditor = function () { - var sel = window.getSelection(); - if (!sel.rangeCount) { return false } - var node = sel.getRangeAt(0).commonAncestorContainer; - return contains(this.div, node) -}; - -ContentEditableInput.prototype.focus = function () { - if (this.cm.options.readOnly != "nocursor") { - if (!this.selectionInEditor()) - { this.showSelection(this.prepareSelection(), true); } - this.div.focus(); - } -}; -ContentEditableInput.prototype.blur = function () { this.div.blur(); }; -ContentEditableInput.prototype.getField = function () { return this.div }; - -ContentEditableInput.prototype.supportsTouch = function () { return true }; + function parseJS(state, style, type, content, stream) { + var cc = state.cc; + // Communicate our context to the combinators. + // (Less wasteful than consing up a hundred closures on every call.) + cx.state = state; cx.stream = stream; cx.marked = null, cx.cc = cc; cx.style = style; -ContentEditableInput.prototype.receivedFocus = function () { - var input = this; - if (this.selectionInEditor()) - { this.pollSelection(); } - else - { runInOp(this.cm, function () { return input.cm.curOp.selectionChanged = true; }); } + if (!state.lexical.hasOwnProperty("align")) + state.lexical.align = true; - function poll() { - if (input.cm.state.focused) { - input.pollSelection(); - input.polling.set(input.cm.options.pollInterval, poll); + while(true) { + var combinator = cc.length ? cc.pop() : jsonMode ? expression : statement; + if (combinator(type, content)) { + while(cc.length && cc[cc.length - 1].lex) + cc.pop()(); + if (cx.marked) return cx.marked; + if (type == "variable" && inScope(state, content)) return "variable-2"; + return style; + } } } - this.polling.set(this.cm.options.pollInterval, poll); -}; - -ContentEditableInput.prototype.selectionChanged = function () { - var sel = window.getSelection(); - return sel.anchorNode != this.lastAnchorNode || sel.anchorOffset != this.lastAnchorOffset || - sel.focusNode != this.lastFocusNode || sel.focusOffset != this.lastFocusOffset -}; - -ContentEditableInput.prototype.pollSelection = function () { - if (this.readDOMTimeout != null || this.gracePeriod || !this.selectionChanged()) { return } - var sel = window.getSelection(), cm = this.cm; - // On Android Chrome (version 56, at least), backspacing into an - // uneditable block element will put the cursor in that element, - // and then, because it's not editable, hide the virtual keyboard. - // Because Android doesn't allow us to actually detect backspace - // presses in a sane way, this code checks for when that happens - // and simulates a backspace press in this case. - if (android && chrome && this.cm.options.gutters.length && isInGutter(sel.anchorNode)) { - this.cm.triggerOnKeyDown({type: "keydown", keyCode: 8, preventDefault: Math.abs}); - this.blur(); - this.focus(); - return - } - if (this.composing) { return } - this.rememberSelection(); - var anchor = domToPos(cm, sel.anchorNode, sel.anchorOffset); - var head = domToPos(cm, sel.focusNode, sel.focusOffset); - if (anchor && head) { runInOp(cm, function () { - setSelection(cm.doc, simpleSelection(anchor, head), sel_dontScroll); - if (anchor.bad || head.bad) { cm.curOp.selectionChanged = true; } - }); } -}; - -ContentEditableInput.prototype.pollContent = function () { - if (this.readDOMTimeout != null) { - clearTimeout(this.readDOMTimeout); - this.readDOMTimeout = null; - } - - var cm = this.cm, display = cm.display, sel = cm.doc.sel.primary(); - var from = sel.from(), to = sel.to(); - if (from.ch == 0 && from.line > cm.firstLine()) - { from = Pos(from.line - 1, getLine(cm.doc, from.line - 1).length); } - if (to.ch == getLine(cm.doc, to.line).text.length && to.line < cm.lastLine()) - { to = Pos(to.line + 1, 0); } - if (from.line < display.viewFrom || to.line > display.viewTo - 1) { return false } - - var fromIndex, fromLine, fromNode; - if (from.line == display.viewFrom || (fromIndex = findViewIndex(cm, from.line)) == 0) { - fromLine = lineNo(display.view[0].line); - fromNode = display.view[0].node; - } else { - fromLine = lineNo(display.view[fromIndex].line); - fromNode = display.view[fromIndex - 1].node.nextSibling; - } - var toIndex = findViewIndex(cm, to.line); - var toLine, toNode; - if (toIndex == display.view.length - 1) { - toLine = display.viewTo - 1; - toNode = display.lineDiv.lastChild; - } else { - toLine = lineNo(display.view[toIndex + 1].line) - 1; - toNode = display.view[toIndex + 1].node.previousSibling; - } - - if (!fromNode) { return false } - var newText = cm.doc.splitLines(domTextBetween(cm, fromNode, toNode, fromLine, toLine)); - var oldText = getBetween(cm.doc, Pos(fromLine, 0), Pos(toLine, getLine(cm.doc, toLine).text.length)); - while (newText.length > 1 && oldText.length > 1) { - if (lst(newText) == lst(oldText)) { newText.pop(); oldText.pop(); toLine--; } - else if (newText[0] == oldText[0]) { newText.shift(); oldText.shift(); fromLine++; } - else { break } - } - - var cutFront = 0, cutEnd = 0; - var newTop = newText[0], oldTop = oldText[0], maxCutFront = Math.min(newTop.length, oldTop.length); - while (cutFront < maxCutFront && newTop.charCodeAt(cutFront) == oldTop.charCodeAt(cutFront)) - { ++cutFront; } - var newBot = lst(newText), oldBot = lst(oldText); - var maxCutEnd = Math.min(newBot.length - (newText.length == 1 ? cutFront : 0), - oldBot.length - (oldText.length == 1 ? cutFront : 0)); - while (cutEnd < maxCutEnd && - newBot.charCodeAt(newBot.length - cutEnd - 1) == oldBot.charCodeAt(oldBot.length - cutEnd - 1)) - { ++cutEnd; } - // Try to move start of change to start of selection if ambiguous - if (newText.length == 1 && oldText.length == 1 && fromLine == from.line) { - while (cutFront && cutFront > from.ch && - newBot.charCodeAt(newBot.length - cutEnd - 1) == oldBot.charCodeAt(oldBot.length - cutEnd - 1)) { - cutFront--; - cutEnd++; - } - } - - newText[newText.length - 1] = newBot.slice(0, newBot.length - cutEnd).replace(/^\u200b+/, ""); - newText[0] = newText[0].slice(cutFront).replace(/\u200b+$/, ""); - - var chFrom = Pos(fromLine, cutFront); - var chTo = Pos(toLine, oldText.length ? lst(oldText).length - cutEnd : 0); - if (newText.length > 1 || newText[0] || cmp(chFrom, chTo)) { - replaceRange(cm.doc, newText, chFrom, chTo, "+input"); - return true - } -}; - -ContentEditableInput.prototype.ensurePolled = function () { - this.forceCompositionEnd(); -}; -ContentEditableInput.prototype.reset = function () { - this.forceCompositionEnd(); -}; -ContentEditableInput.prototype.forceCompositionEnd = function () { - if (!this.composing) { return } - clearTimeout(this.readDOMTimeout); - this.composing = null; - this.updateFromDOM(); - this.div.blur(); - this.div.focus(); -}; -ContentEditableInput.prototype.readFromDOMSoon = function () { - var this$1 = this; - - if (this.readDOMTimeout != null) { return } - this.readDOMTimeout = setTimeout(function () { - this$1.readDOMTimeout = null; - if (this$1.composing) { - if (this$1.composing.done) { this$1.composing = null; } - else { return } - } - this$1.updateFromDOM(); - }, 80); -}; - -ContentEditableInput.prototype.updateFromDOM = function () { - var this$1 = this; - - if (this.cm.isReadOnly() || !this.pollContent()) - { runInOp(this.cm, function () { return regChange(this$1.cm); }); } -}; - -ContentEditableInput.prototype.setUneditable = function (node) { - node.contentEditable = "false"; -}; - -ContentEditableInput.prototype.onKeyPress = function (e) { - if (e.charCode == 0) { return } - e.preventDefault(); - if (!this.cm.isReadOnly()) - { operation(this.cm, applyTextInput)(this.cm, String.fromCharCode(e.charCode == null ? e.keyCode : e.charCode), 0); } -}; - -ContentEditableInput.prototype.readOnlyChanged = function (val) { - this.div.contentEditable = String(val != "nocursor"); -}; - -ContentEditableInput.prototype.onContextMenu = function () {}; -ContentEditableInput.prototype.resetPosition = function () {}; -ContentEditableInput.prototype.needsContentAttribute = true; - -function posToDOM(cm, pos) { - var view = findViewForLine(cm, pos.line); - if (!view || view.hidden) { return null } - var line = getLine(cm.doc, pos.line); - var info = mapFromLineView(view, line, pos.line); + // Combinator utils - var order = getOrder(line, cm.doc.direction), side = "left"; - if (order) { - var partPos = getBidiPartAt(order, pos.ch); - side = partPos % 2 ? "right" : "left"; + var cx = {state: null, column: null, marked: null, cc: null}; + function pass() { + for (var i = arguments.length - 1; i >= 0; i--) cx.cc.push(arguments[i]); } - var result = nodeAndOffsetInLineMap(info.map, pos.ch, side); - result.offset = result.collapse == "right" ? result.end : result.start; - return result -} - -function isInGutter(node) { - for (var scan = node; scan; scan = scan.parentNode) - { if (/CodeMirror-gutter-wrapper/.test(scan.className)) { return true } } - return false -} - -function badPos(pos, bad) { if (bad) { pos.bad = true; } return pos } - -function domTextBetween(cm, from, to, fromLine, toLine) { - var text = "", closing = false, lineSep = cm.doc.lineSeparator(); - function recognizeMarker(id) { return function (marker) { return marker.id == id; } } - function close() { - if (closing) { - text += lineSep; - closing = false; - } + function cont() { + pass.apply(null, arguments); + return true; } - function addText(str) { - if (str) { - close(); - text += str; - } + function inList(name, list) { + for (var v = list; v; v = v.next) if (v.name == name) return true + return false; } - function walk(node) { - if (node.nodeType == 1) { - var cmText = node.getAttribute("cm-text"); - if (cmText != null) { - addText(cmText || node.textContent.replace(/\u200b/g, "")); - return - } - var markerID = node.getAttribute("cm-marker"), range$$1; - if (markerID) { - var found = cm.findMarks(Pos(fromLine, 0), Pos(toLine + 1, 0), recognizeMarker(+markerID)); - if (found.length && (range$$1 = found[0].find(0))) - { addText(getBetween(cm.doc, range$$1.from, range$$1.to).join(lineSep)); } + function register(varname) { + var state = cx.state; + cx.marked = "def"; + if (state.context) { + if (state.lexical.info == "var" && state.context && state.context.block) { + // FIXME function decls are also not block scoped + var newContext = registerVarScoped(varname, state.context) + if (newContext != null) { + state.context = newContext + return + } + } else if (!inList(varname, state.localVars)) { + state.localVars = new Var(varname, state.localVars) return } - if (node.getAttribute("contenteditable") == "false") { return } - var isBlock = /^(pre|div|p)$/i.test(node.nodeName); - if (isBlock) { close(); } - for (var i = 0; i < node.childNodes.length; i++) - { walk(node.childNodes[i]); } - if (isBlock) { closing = true; } - } else if (node.nodeType == 3) { - addText(node.nodeValue); + } + // Fall through means this is global + if (parserConfig.globalVars && !inList(varname, state.globalVars)) + state.globalVars = new Var(varname, state.globalVars) + } + function registerVarScoped(varname, context) { + if (!context) { + return null + } else if (context.block) { + var inner = registerVarScoped(varname, context.prev) + if (!inner) return null + if (inner == context.prev) return context + return new Context(inner, context.vars, true) + } else if (inList(varname, context.vars)) { + return context + } else { + return new Context(context.prev, new Var(varname, context.vars), false) } } - for (;;) { - walk(from); - if (from == to) { break } - from = from.nextSibling; + + function isModifier(name) { + return name == "public" || name == "private" || name == "protected" || name == "abstract" || name == "readonly" } - return text -} -function domToPos(cm, node, offset) { - var lineNode; - if (node == cm.display.lineDiv) { - lineNode = cm.display.lineDiv.childNodes[offset]; - if (!lineNode) { return badPos(cm.clipPos(Pos(cm.display.viewTo - 1)), true) } - node = null; offset = 0; - } else { - for (lineNode = node;; lineNode = lineNode.parentNode) { - if (!lineNode || lineNode == cm.display.lineDiv) { return null } - if (lineNode.parentNode && lineNode.parentNode == cm.display.lineDiv) { break } - } + // Combinators + + function Context(prev, vars, block) { this.prev = prev; this.vars = vars; this.block = block } + function Var(name, next) { this.name = name; this.next = next } + + var defaultVars = new Var("this", new Var("arguments", null)) + function pushcontext() { + cx.state.context = new Context(cx.state.context, cx.state.localVars, false) + cx.state.localVars = defaultVars } - for (var i = 0; i < cm.display.view.length; i++) { - var lineView = cm.display.view[i]; - if (lineView.node == lineNode) - { return locateNodeInLineView(lineView, node, offset) } + function pushblockcontext() { + cx.state.context = new Context(cx.state.context, cx.state.localVars, true) + cx.state.localVars = null } -} - -function locateNodeInLineView(lineView, node, offset) { - var wrapper = lineView.text.firstChild, bad = false; - if (!node || !contains(wrapper, node)) { return badPos(Pos(lineNo(lineView.line), 0), true) } - if (node == wrapper) { - bad = true; - node = wrapper.childNodes[offset]; - offset = 0; - if (!node) { - var line = lineView.rest ? lst(lineView.rest) : lineView.line; - return badPos(Pos(lineNo(line), line.text.length), bad) - } + function popcontext() { + cx.state.localVars = cx.state.context.vars + cx.state.context = cx.state.context.prev } - - var textNode = node.nodeType == 3 ? node : null, topNode = node; - if (!textNode && node.childNodes.length == 1 && node.firstChild.nodeType == 3) { - textNode = node.firstChild; - if (offset) { offset = textNode.nodeValue.length; } + popcontext.lex = true + function pushlex(type, info) { + var result = function() { + var state = cx.state, indent = state.indented; + if (state.lexical.type == "stat") indent = state.lexical.indented; + else for (var outer = state.lexical; outer && outer.type == ")" && outer.align; outer = outer.prev) + indent = outer.indented; + state.lexical = new JSLexical(indent, cx.stream.column(), type, null, state.lexical, info); + }; + result.lex = true; + return result; } - while (topNode.parentNode != wrapper) { topNode = topNode.parentNode; } - var measure = lineView.measure, maps = measure.maps; - - function find(textNode, topNode, offset) { - for (var i = -1; i < (maps ? maps.length : 0); i++) { - var map$$1 = i < 0 ? measure.map : maps[i]; - for (var j = 0; j < map$$1.length; j += 3) { - var curNode = map$$1[j + 2]; - if (curNode == textNode || curNode == topNode) { - var line = lineNo(i < 0 ? lineView.line : lineView.rest[i]); - var ch = map$$1[j] + offset; - if (offset < 0 || curNode != textNode) { ch = map$$1[j + (offset ? 1 : 0)]; } - return Pos(line, ch) - } - } + function poplex() { + var state = cx.state; + if (state.lexical.prev) { + if (state.lexical.type == ")") + state.indented = state.lexical.indented; + state.lexical = state.lexical.prev; } } - var found = find(textNode, topNode, offset); - if (found) { return badPos(found, bad) } + poplex.lex = true; - // FIXME this is all really shaky. might handle the few cases it needs to handle, but likely to cause problems - for (var after = topNode.nextSibling, dist = textNode ? textNode.nodeValue.length - offset : 0; after; after = after.nextSibling) { - found = find(after, after.firstChild, 0); - if (found) - { return badPos(Pos(found.line, found.ch - dist), bad) } - else - { dist += after.textContent.length; } - } - for (var before = topNode.previousSibling, dist$1 = offset; before; before = before.previousSibling) { - found = find(before, before.firstChild, -1); - if (found) - { return badPos(Pos(found.line, found.ch + dist$1), bad) } - else - { dist$1 += before.textContent.length; } + function expect(wanted) { + function exp(type) { + if (type == wanted) return cont(); + else if (wanted == ";" || type == "}" || type == ")" || type == "]") return pass(); + else return cont(exp); + }; + return exp; } -} - -// TEXTAREA INPUT STYLE - -var TextareaInput = function(cm) { - this.cm = cm; - // See input.poll and input.reset - this.prevInput = ""; - - // Flag that indicates whether we expect input to appear real soon - // now (after some event like 'keypress' or 'input') and are - // polling intensively. - this.pollingFast = false; - // Self-resetting timeout for the poller - this.polling = new Delayed(); - // Used to work around IE issue with selection being forgotten when focus moves away from textarea - this.hasSelection = false; - this.composing = null; -}; - -TextareaInput.prototype.init = function (display) { - var this$1 = this; - - var input = this, cm = this.cm; - - // Wraps and hides input textarea - var div = this.wrapper = hiddenTextarea(); - // The semihidden textarea that is focused when the editor is - // focused, and receives input. - var te = this.textarea = div.firstChild; - display.wrapper.insertBefore(div, display.wrapper.firstChild); - - // Needed to hide big blue blinking cursor on Mobile Safari (doesn't seem to work in iOS 8 anymore) - if (ios) { te.style.width = "0px"; } - - on(te, "input", function () { - if (ie && ie_version >= 9 && this$1.hasSelection) { this$1.hasSelection = null; } - input.poll(); - }); - on(te, "paste", function (e) { - if (signalDOMEvent(cm, e) || handlePaste(e, cm)) { return } - - cm.state.pasteIncoming = true; - input.fastPoll(); - }); - - function prepareCopyCut(e) { - if (signalDOMEvent(cm, e)) { return } - if (cm.somethingSelected()) { - setLastCopied({lineWise: false, text: cm.getSelections()}); - } else if (!cm.options.lineWiseCopyCut) { - return - } else { - var ranges = copyableRanges(cm); - setLastCopied({lineWise: true, text: ranges.text}); - if (e.type == "cut") { - cm.setSelections(ranges.ranges, null, sel_dontScroll); + function statement(type, value) { + if (type == "var") return cont(pushlex("vardef", value), vardef, expect(";"), poplex); + if (type == "keyword a") return cont(pushlex("form"), parenExpr, statement, poplex); + if (type == "keyword b") return cont(pushlex("form"), statement, poplex); + if (type == "keyword d") return cx.stream.match(/^\s*$/, false) ? cont() : cont(pushlex("stat"), maybeexpression, expect(";"), poplex); + if (type == "debugger") return cont(expect(";")); + if (type == "{") return cont(pushlex("}"), pushblockcontext, block, poplex, popcontext); + if (type == ";") return cont(); + if (type == "if") { + if (cx.state.lexical.info == "else" && cx.state.cc[cx.state.cc.length - 1] == poplex) + cx.state.cc.pop()(); + return cont(pushlex("form"), parenExpr, statement, poplex, maybeelse); + } + if (type == "function") return cont(functiondef); + if (type == "for") return cont(pushlex("form"), forspec, statement, poplex); + if (type == "class" || (isTS && value == "interface")) { + cx.marked = "keyword" + return cont(pushlex("form", type == "class" ? type : value), className, poplex) + } + if (type == "variable") { + if (isTS && value == "declare") { + cx.marked = "keyword" + return cont(statement) + } else if (isTS && (value == "module" || value == "enum" || value == "type") && cx.stream.match(/^\s*\w/, false)) { + cx.marked = "keyword" + if (value == "enum") return cont(enumdef); + else if (value == "type") return cont(typename, expect("operator"), typeexpr, expect(";")); + else return cont(pushlex("form"), pattern, expect("{"), pushlex("}"), block, poplex, poplex) + } else if (isTS && value == "namespace") { + cx.marked = "keyword" + return cont(pushlex("form"), expression, statement, poplex) + } else if (isTS && value == "abstract") { + cx.marked = "keyword" + return cont(statement) } else { - input.prevInput = ""; - te.value = ranges.text.join("\n"); - selectInput(te); + return cont(pushlex("stat"), maybelabel); } } - if (e.type == "cut") { cm.state.cutIncoming = true; } + if (type == "switch") return cont(pushlex("form"), parenExpr, expect("{"), pushlex("}", "switch"), pushblockcontext, + block, poplex, poplex, popcontext); + if (type == "case") return cont(expression, expect(":")); + if (type == "default") return cont(expect(":")); + if (type == "catch") return cont(pushlex("form"), pushcontext, maybeCatchBinding, statement, poplex, popcontext); + if (type == "export") return cont(pushlex("stat"), afterExport, poplex); + if (type == "import") return cont(pushlex("stat"), afterImport, poplex); + if (type == "async") return cont(statement) + if (value == "@") return cont(expression, statement) + return pass(pushlex("stat"), expression, expect(";"), poplex); } - on(te, "cut", prepareCopyCut); - on(te, "copy", prepareCopyCut); - - on(display.scroller, "paste", function (e) { - if (eventInWidget(display, e) || signalDOMEvent(cm, e)) { return } - cm.state.pasteIncoming = true; - input.focus(); - }); - - // Prevent normal selection in the editor (we handle our own) - on(display.lineSpace, "selectstart", function (e) { - if (!eventInWidget(display, e)) { e_preventDefault(e); } - }); - - on(te, "compositionstart", function () { - var start = cm.getCursor("from"); - if (input.composing) { input.composing.range.clear(); } - input.composing = { - start: start, - range: cm.markText(start, cm.getCursor("to"), {className: "CodeMirror-composing"}) - }; - }); - on(te, "compositionend", function () { - if (input.composing) { - input.poll(); - input.composing.range.clear(); - input.composing = null; - } - }); -}; - -TextareaInput.prototype.prepareSelection = function () { - // Redraw the selection and/or cursor - var cm = this.cm, display = cm.display, doc = cm.doc; - var result = prepareSelection(cm); - - // Move the hidden textarea near the cursor to prevent scrolling artifacts - if (cm.options.moveInputWithCursor) { - var headPos = cursorCoords(cm, doc.sel.primary().head, "div"); - var wrapOff = display.wrapper.getBoundingClientRect(), lineOff = display.lineDiv.getBoundingClientRect(); - result.teTop = Math.max(0, Math.min(display.wrapper.clientHeight - 10, - headPos.top + lineOff.top - wrapOff.top)); - result.teLeft = Math.max(0, Math.min(display.wrapper.clientWidth - 10, - headPos.left + lineOff.left - wrapOff.left)); + function maybeCatchBinding(type) { + if (type == "(") return cont(funarg, expect(")")) } - - return result -}; - -TextareaInput.prototype.showSelection = function (drawn) { - var cm = this.cm, display = cm.display; - removeChildrenAndAdd(display.cursorDiv, drawn.cursors); - removeChildrenAndAdd(display.selectionDiv, drawn.selection); - if (drawn.teTop != null) { - this.wrapper.style.top = drawn.teTop + "px"; - this.wrapper.style.left = drawn.teLeft + "px"; + function expression(type, value) { + return expressionInner(type, value, false); } -}; - -// Reset the input to correspond to the selection (or to be empty, -// when not typing and nothing is selected) -TextareaInput.prototype.reset = function (typing) { - if (this.contextMenuPending || this.composing) { return } - var cm = this.cm; - if (cm.somethingSelected()) { - this.prevInput = ""; - var content = cm.getSelection(); - this.textarea.value = content; - if (cm.state.focused) { selectInput(this.textarea); } - if (ie && ie_version >= 9) { this.hasSelection = content; } - } else if (!typing) { - this.prevInput = this.textarea.value = ""; - if (ie && ie_version >= 9) { this.hasSelection = null; } + function expressionNoComma(type, value) { + return expressionInner(type, value, true); } -}; - -TextareaInput.prototype.getField = function () { return this.textarea }; - -TextareaInput.prototype.supportsTouch = function () { return false }; - -TextareaInput.prototype.focus = function () { - if (this.cm.options.readOnly != "nocursor" && (!mobile || activeElt() != this.textarea)) { - try { this.textarea.focus(); } - catch (e) {} // IE8 will throw if the textarea is display: none or not in DOM + function parenExpr(type) { + if (type != "(") return pass() + return cont(pushlex(")"), expression, expect(")"), poplex) } -}; - -TextareaInput.prototype.blur = function () { this.textarea.blur(); }; - -TextareaInput.prototype.resetPosition = function () { - this.wrapper.style.top = this.wrapper.style.left = 0; -}; - -TextareaInput.prototype.receivedFocus = function () { this.slowPoll(); }; - -// Poll for input changes, using the normal rate of polling. This -// runs as long as the editor is focused. -TextareaInput.prototype.slowPoll = function () { - var this$1 = this; - - if (this.pollingFast) { return } - this.polling.set(this.cm.options.pollInterval, function () { - this$1.poll(); - if (this$1.cm.state.focused) { this$1.slowPoll(); } - }); -}; - -// When an event has just come in that is likely to add or change -// something in the input textarea, we poll faster, to ensure that -// the change appears on the screen quickly. -TextareaInput.prototype.fastPoll = function () { - var missed = false, input = this; - input.pollingFast = true; - function p() { - var changed = input.poll(); - if (!changed && !missed) {missed = true; input.polling.set(60, p);} - else {input.pollingFast = false; input.slowPoll();} - } - input.polling.set(20, p); -}; - -// Read input from the textarea, and update the document to match. -// When something is selected, it is present in the textarea, and -// selected (unless it is huge, in which case a placeholder is -// used). When nothing is selected, the cursor sits after previously -// seen text (can be empty), which is stored in prevInput (we must -// not reset the textarea when typing, because that breaks IME). -TextareaInput.prototype.poll = function () { - var this$1 = this; + function expressionInner(type, value, noComma) { + if (cx.state.fatArrowAt == cx.stream.start) { + var body = noComma ? arrowBodyNoComma : arrowBody; + if (type == "(") return cont(pushcontext, pushlex(")"), commasep(funarg, ")"), poplex, expect("=>"), body, popcontext); + else if (type == "variable") return pass(pushcontext, pattern, expect("=>"), body, popcontext); + } - var cm = this.cm, input = this.textarea, prevInput = this.prevInput; - // Since this is called a *lot*, try to bail out as cheaply as - // possible when it is clear that nothing happened. hasSelection - // will be the case when there is a lot of text in the textarea, - // in which case reading its value would be expensive. - if (this.contextMenuPending || !cm.state.focused || - (hasSelection(input) && !prevInput && !this.composing) || - cm.isReadOnly() || cm.options.disableInput || cm.state.keySeq) - { return false } - - var text = input.value; - // If nothing changed, bail. - if (text == prevInput && !cm.somethingSelected()) { return false } - // Work around nonsensical selection resetting in IE9/10, and - // inexplicable appearance of private area unicode characters on - // some key combos in Mac (#2689). - if (ie && ie_version >= 9 && this.hasSelection === text || - mac && /[\uf700-\uf7ff]/.test(text)) { - cm.display.input.reset(); - return false + var maybeop = noComma ? maybeoperatorNoComma : maybeoperatorComma; + if (atomicTypes.hasOwnProperty(type)) return cont(maybeop); + if (type == "function") return cont(functiondef, maybeop); + if (type == "class" || (isTS && value == "interface")) { cx.marked = "keyword"; return cont(pushlex("form"), classExpression, poplex); } + if (type == "keyword c" || type == "async") return cont(noComma ? expressionNoComma : expression); + if (type == "(") return cont(pushlex(")"), maybeexpression, expect(")"), poplex, maybeop); + if (type == "operator" || type == "spread") return cont(noComma ? expressionNoComma : expression); + if (type == "[") return cont(pushlex("]"), arrayLiteral, poplex, maybeop); + if (type == "{") return contCommasep(objprop, "}", null, maybeop); + if (type == "quasi") return pass(quasi, maybeop); + if (type == "new") return cont(maybeTarget(noComma)); + if (type == "import") return cont(expression); + return cont(); } - - if (cm.doc.sel == cm.display.selForContextMenu) { - var first = text.charCodeAt(0); - if (first == 0x200b && !prevInput) { prevInput = "\u200b"; } - if (first == 0x21da) { this.reset(); return this.cm.execCommand("undo") } + function maybeexpression(type) { + if (type.match(/[;\}\)\],]/)) return pass(); + return pass(expression); } - // Find the part of the input that is actually new - var same = 0, l = Math.min(prevInput.length, text.length); - while (same < l && prevInput.charCodeAt(same) == text.charCodeAt(same)) { ++same; } - - runInOp(cm, function () { - applyTextInput(cm, text.slice(same), prevInput.length - same, - null, this$1.composing ? "*compose" : null); - - // Don't leave long text in the textarea, since it makes further polling slow - if (text.length > 1000 || text.indexOf("\n") > -1) { input.value = this$1.prevInput = ""; } - else { this$1.prevInput = text; } - - if (this$1.composing) { - this$1.composing.range.clear(); - this$1.composing.range = cm.markText(this$1.composing.start, cm.getCursor("to"), - {className: "CodeMirror-composing"}); - } - }); - return true -}; -TextareaInput.prototype.ensurePolled = function () { - if (this.pollingFast && this.poll()) { this.pollingFast = false; } -}; - -TextareaInput.prototype.onKeyPress = function () { - if (ie && ie_version >= 9) { this.hasSelection = null; } - this.fastPoll(); -}; - -TextareaInput.prototype.onContextMenu = function (e) { - var input = this, cm = input.cm, display = cm.display, te = input.textarea; - var pos = posFromMouse(cm, e), scrollPos = display.scroller.scrollTop; - if (!pos || presto) { return } // Opera is difficult. - - // Reset the current text selection only if the click is done outside of the selection - // and 'resetSelectionOnContextMenu' option is true. - var reset = cm.options.resetSelectionOnContextMenu; - if (reset && cm.doc.sel.contains(pos) == -1) - { operation(cm, setSelection)(cm.doc, simpleSelection(pos), sel_dontScroll); } - - var oldCSS = te.style.cssText, oldWrapperCSS = input.wrapper.style.cssText; - input.wrapper.style.cssText = "position: absolute"; - var wrapperBox = input.wrapper.getBoundingClientRect(); - te.style.cssText = "position: absolute; width: 30px; height: 30px;\n top: " + (e.clientY - wrapperBox.top - 5) + "px; left: " + (e.clientX - wrapperBox.left - 5) + "px;\n z-index: 1000; background: " + (ie ? "rgba(255, 255, 255, .05)" : "transparent") + ";\n outline: none; border-width: 0; outline: none; overflow: hidden; opacity: .05; filter: alpha(opacity=5);"; - var oldScrollY; - if (webkit) { oldScrollY = window.scrollY; } // Work around Chrome issue (#2712) - display.input.focus(); - if (webkit) { window.scrollTo(null, oldScrollY); } - display.input.reset(); - // Adds "Select all" to context menu in FF - if (!cm.somethingSelected()) { te.value = input.prevInput = " "; } - input.contextMenuPending = true; - display.selForContextMenu = cm.doc.sel; - clearTimeout(display.detectingSelectAll); - - // Select-all will be greyed out if there's nothing to select, so - // this adds a zero-width space so that we can later check whether - // it got selected. - function prepareSelectAllHack() { - if (te.selectionStart != null) { - var selected = cm.somethingSelected(); - var extval = "\u200b" + (selected ? te.value : ""); - te.value = "\u21da"; // Used to catch context-menu undo - te.value = extval; - input.prevInput = selected ? "" : "\u200b"; - te.selectionStart = 1; te.selectionEnd = extval.length; - // Re-set this, in case some other handler touched the - // selection in the meantime. - display.selForContextMenu = cm.doc.sel; - } - } - function rehide() { - input.contextMenuPending = false; - input.wrapper.style.cssText = oldWrapperCSS; - te.style.cssText = oldCSS; - if (ie && ie_version < 9) { display.scrollbars.setScrollTop(display.scroller.scrollTop = scrollPos); } - - // Try to detect the user choosing select-all - if (te.selectionStart != null) { - if (!ie || (ie && ie_version < 9)) { prepareSelectAllHack(); } - var i = 0, poll = function () { - if (display.selForContextMenu == cm.doc.sel && te.selectionStart == 0 && - te.selectionEnd > 0 && input.prevInput == "\u200b") { - operation(cm, selectAll)(cm); - } else if (i++ < 10) { - display.detectingSelectAll = setTimeout(poll, 500); - } else { - display.selForContextMenu = null; - display.input.reset(); - } - }; - display.detectingSelectAll = setTimeout(poll, 200); + function maybeoperatorComma(type, value) { + if (type == ",") return cont(expression); + return maybeoperatorNoComma(type, value, false); + } + function maybeoperatorNoComma(type, value, noComma) { + var me = noComma == false ? maybeoperatorComma : maybeoperatorNoComma; + var expr = noComma == false ? expression : expressionNoComma; + if (type == "=>") return cont(pushcontext, noComma ? arrowBodyNoComma : arrowBody, popcontext); + if (type == "operator") { + if (/\+\+|--/.test(value) || isTS && value == "!") return cont(me); + if (isTS && value == "<" && cx.stream.match(/^([^>]|<.*?>)*>\s*\(/, false)) + return cont(pushlex(">"), commasep(typeexpr, ">"), poplex, me); + if (value == "?") return cont(expression, expect(":"), expr); + return cont(expr); + } + if (type == "quasi") { return pass(quasi, me); } + if (type == ";") return; + if (type == "(") return contCommasep(expressionNoComma, ")", "call", me); + if (type == ".") return cont(property, me); + if (type == "[") return cont(pushlex("]"), maybeexpression, expect("]"), poplex, me); + if (isTS && value == "as") { cx.marked = "keyword"; return cont(typeexpr, me) } + if (type == "regexp") { + cx.state.lastType = cx.marked = "operator" + cx.stream.backUp(cx.stream.pos - cx.stream.start - 1) + return cont(expr) } } - - if (ie && ie_version >= 9) { prepareSelectAllHack(); } - if (captureRightClick) { - e_stop(e); - var mouseup = function () { - off(window, "mouseup", mouseup); - setTimeout(rehide, 20); + function quasi(type, value) { + if (type != "quasi") return pass(); + if (value.slice(value.length - 2) != "${") return cont(quasi); + return cont(expression, continueQuasi); + } + function continueQuasi(type) { + if (type == "}") { + cx.marked = "string-2"; + cx.state.tokenize = tokenQuasi; + return cont(quasi); + } + } + function arrowBody(type) { + findFatArrow(cx.stream, cx.state); + return pass(type == "{" ? statement : expression); + } + function arrowBodyNoComma(type) { + findFatArrow(cx.stream, cx.state); + return pass(type == "{" ? statement : expressionNoComma); + } + function maybeTarget(noComma) { + return function(type) { + if (type == ".") return cont(noComma ? targetNoComma : target); + else if (type == "variable" && isTS) return cont(maybeTypeArgs, noComma ? maybeoperatorNoComma : maybeoperatorComma) + else return pass(noComma ? expressionNoComma : expression); }; - on(window, "mouseup", mouseup); - } else { - setTimeout(rehide, 50); } -}; - -TextareaInput.prototype.readOnlyChanged = function (val) { - if (!val) { this.reset(); } - this.textarea.disabled = val == "nocursor"; -}; - -TextareaInput.prototype.setUneditable = function () {}; - -TextareaInput.prototype.needsContentAttribute = false; - -function fromTextArea(textarea, options) { - options = options ? copyObj(options) : {}; - options.value = textarea.value; - if (!options.tabindex && textarea.tabIndex) - { options.tabindex = textarea.tabIndex; } - if (!options.placeholder && textarea.placeholder) - { options.placeholder = textarea.placeholder; } - // Set autofocus to true if this textarea is focused, or if it has - // autofocus and no other element is focused. - if (options.autofocus == null) { - var hasFocus = activeElt(); - options.autofocus = hasFocus == textarea || - textarea.getAttribute("autofocus") != null && hasFocus == document.body; - } - - function save() {textarea.value = cm.getValue();} - - var realSubmit; - if (textarea.form) { - on(textarea.form, "submit", save); - // Deplorable hack to make the submit method do the right thing. - if (!options.leaveSubmitMethodAlone) { - var form = textarea.form; - realSubmit = form.submit; - try { - var wrappedSubmit = form.submit = function () { - save(); - form.submit = realSubmit; - form.submit(); - form.submit = wrappedSubmit; - }; - } catch(e) {} + function target(_, value) { + if (value == "target") { cx.marked = "keyword"; return cont(maybeoperatorComma); } + } + function targetNoComma(_, value) { + if (value == "target") { cx.marked = "keyword"; return cont(maybeoperatorNoComma); } + } + function maybelabel(type) { + if (type == ":") return cont(poplex, statement); + return pass(maybeoperatorComma, expect(";"), poplex); + } + function property(type) { + if (type == "variable") {cx.marked = "property"; return cont();} + } + function objprop(type, value) { + if (type == "async") { + cx.marked = "property"; + return cont(objprop); + } else if (type == "variable" || cx.style == "keyword") { + cx.marked = "property"; + if (value == "get" || value == "set") return cont(getterSetter); + var m // Work around fat-arrow-detection complication for detecting typescript typed arrow params + if (isTS && cx.state.fatArrowAt == cx.stream.start && (m = cx.stream.match(/^\s*:\s*/, false))) + cx.state.fatArrowAt = cx.stream.pos + m[0].length + return cont(afterprop); + } else if (type == "number" || type == "string") { + cx.marked = jsonldMode ? "property" : (cx.style + " property"); + return cont(afterprop); + } else if (type == "jsonld-keyword") { + return cont(afterprop); + } else if (isTS && isModifier(value)) { + cx.marked = "keyword" + return cont(objprop) + } else if (type == "[") { + return cont(expression, maybetype, expect("]"), afterprop); + } else if (type == "spread") { + return cont(expressionNoComma, afterprop); + } else if (value == "*") { + cx.marked = "keyword"; + return cont(objprop); + } else if (type == ":") { + return pass(afterprop) } } - - options.finishInit = function (cm) { - cm.save = save; - cm.getTextArea = function () { return textarea; }; - cm.toTextArea = function () { - cm.toTextArea = isNaN; // Prevent this from being ran twice - save(); - textarea.parentNode.removeChild(cm.getWrapperElement()); - textarea.style.display = ""; - if (textarea.form) { - off(textarea.form, "submit", save); - if (typeof textarea.form.submit == "function") - { textarea.form.submit = realSubmit; } + function getterSetter(type) { + if (type != "variable") return pass(afterprop); + cx.marked = "property"; + return cont(functiondef); + } + function afterprop(type) { + if (type == ":") return cont(expressionNoComma); + if (type == "(") return pass(functiondef); + } + function commasep(what, end, sep) { + function proceed(type, value) { + if (sep ? sep.indexOf(type) > -1 : type == ",") { + var lex = cx.state.lexical; + if (lex.info == "call") lex.pos = (lex.pos || 0) + 1; + return cont(function(type, value) { + if (type == end || value == end) return pass() + return pass(what) + }, proceed); } + if (type == end || value == end) return cont(); + if (sep && sep.indexOf(";") > -1) return pass(what) + return cont(expect(end)); + } + return function(type, value) { + if (type == end || value == end) return cont(); + return pass(what, proceed); }; - }; - - textarea.style.display = "none"; - var cm = CodeMirror$1(function (node) { return textarea.parentNode.insertBefore(node, textarea.nextSibling); }, - options); - return cm -} - -function addLegacyProps(CodeMirror) { - CodeMirror.off = off; - CodeMirror.on = on; - CodeMirror.wheelEventPixels = wheelEventPixels; - CodeMirror.Doc = Doc; - CodeMirror.splitLines = splitLinesAuto; - CodeMirror.countColumn = countColumn; - CodeMirror.findColumn = findColumn; - CodeMirror.isWordChar = isWordCharBasic; - CodeMirror.Pass = Pass; - CodeMirror.signal = signal; - CodeMirror.Line = Line; - CodeMirror.changeEnd = changeEnd; - CodeMirror.scrollbarModel = scrollbarModel; - CodeMirror.Pos = Pos; - CodeMirror.cmpPos = cmp; - CodeMirror.modes = modes; - CodeMirror.mimeModes = mimeModes; - CodeMirror.resolveMode = resolveMode; - CodeMirror.getMode = getMode; - CodeMirror.modeExtensions = modeExtensions; - CodeMirror.extendMode = extendMode; - CodeMirror.copyState = copyState; - CodeMirror.startState = startState; - CodeMirror.innerMode = innerMode; - CodeMirror.commands = commands; - CodeMirror.keyMap = keyMap; - CodeMirror.keyName = keyName; - CodeMirror.isModifierKey = isModifierKey; - CodeMirror.lookupKey = lookupKey; - CodeMirror.normalizeKeyMap = normalizeKeyMap; - CodeMirror.StringStream = StringStream; - CodeMirror.SharedTextMarker = SharedTextMarker; - CodeMirror.TextMarker = TextMarker; - CodeMirror.LineWidget = LineWidget; - CodeMirror.e_preventDefault = e_preventDefault; - CodeMirror.e_stopPropagation = e_stopPropagation; - CodeMirror.e_stop = e_stop; - CodeMirror.addClass = addClass; - CodeMirror.contains = contains; - CodeMirror.rmClass = rmClass; - CodeMirror.keyNames = keyNames; -} - -// EDITOR CONSTRUCTOR - -defineOptions(CodeMirror$1); - -addEditorMethods(CodeMirror$1); - -// Set up methods on CodeMirror's prototype to redirect to the editor's document. -var dontDelegate = "iter insert remove copy getEditor constructor".split(" "); -for (var prop in Doc.prototype) { if (Doc.prototype.hasOwnProperty(prop) && indexOf(dontDelegate, prop) < 0) - { CodeMirror$1.prototype[prop] = (function(method) { - return function() {return method.apply(this.doc, arguments)} - })(Doc.prototype[prop]); } } - -eventMixin(Doc); - -// INPUT HANDLING - -CodeMirror$1.inputStyles = {"textarea": TextareaInput, "contenteditable": ContentEditableInput}; - -// MODE DEFINITION AND QUERYING - -// Extra arguments are stored as the mode's dependencies, which is -// used by (legacy) mechanisms like loadmode.js to automatically -// load a mode. (Preferred mechanism is the require/define calls.) -CodeMirror$1.defineMode = function(name/*, mode, …*/) { - if (!CodeMirror$1.defaults.mode && name != "null") { CodeMirror$1.defaults.mode = name; } - defineMode.apply(this, arguments); -}; - -CodeMirror$1.defineMIME = defineMIME; - -// Minimal default mode. -CodeMirror$1.defineMode("null", function () { return ({token: function (stream) { return stream.skipToEnd(); }}); }); -CodeMirror$1.defineMIME("text/plain", "null"); - -// EXTENSIONS - -CodeMirror$1.defineExtension = function (name, func) { - CodeMirror$1.prototype[name] = func; -}; -CodeMirror$1.defineDocExtension = function (name, func) { - Doc.prototype[name] = func; -}; - -CodeMirror$1.fromTextArea = fromTextArea; - -addLegacyProps(CodeMirror$1); - -CodeMirror$1.version = "5.31.0"; - -return CodeMirror$1; - -}))); - - -/***/ }), -/* 7 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -var Backbone = __webpack_require__(0); - -var TYPE_CLASS = 1; -var TYPE_ID = 2; - -var Selector = Backbone.Model.extend({ - - idAttribute: 'name', - - defaults: { - name: '', - - label: '', - - // Type of the selector - type: TYPE_CLASS, - - // If not active it's not selectable by the style manager (uncheckboxed) - active: true, - - // Can't be seen by the style manager, therefore even by the user - // Will be rendered only in export code - private: false, - - // If true, can't be removed from the attacched element - protected: false - }, - - initialize: function initialize() { - var name = this.get('name'); - var label = this.get('label'); - - if (!name) { - this.set('name', label); - } else if (!label) { - this.set('label', name); + } + function contCommasep(what, end, info) { + for (var i = 3; i < arguments.length; i++) + cx.cc.push(arguments[i]); + return cont(pushlex(end, info), commasep(what, end), poplex); + } + function block(type) { + if (type == "}") return cont(); + return pass(statement, block); + } + function maybetype(type, value) { + if (isTS) { + if (type == ":") return cont(typeexpr); + if (value == "?") return cont(maybetype); } - - this.set('name', Selector.escapeName(this.get('name'))); - }, - - - /** - * Get full selector name - * @return {string} - */ - getFullName: function getFullName() { - var init = ''; - - switch (this.get('type')) { - case TYPE_CLASS: - init = '.'; - break; - case TYPE_ID: - init = '#'; - break; + } + function maybetypeOrIn(type, value) { + if (isTS && (type == ":" || value == "in")) return cont(typeexpr) + } + function mayberettype(type) { + if (isTS && type == ":") { + if (cx.stream.match(/^\s*\w+\s+is\b/, false)) return cont(expression, isKW, typeexpr) + else return cont(typeexpr) } - - return init + this.get('name'); } -}, { - // All type selectors: https://developer.mozilla.org/it/docs/Web/CSS/CSS_Selectors - // Here I define only what I need - TYPE_CLASS: TYPE_CLASS, - - TYPE_ID: TYPE_ID, - - /** - * Escape string - * @param {string} name - * @return {string} - * @private - */ - escapeName: function escapeName(name) { - return ('' + name).trim().replace(/([^a-z0-9\w-]+)/gi, '-'); + function isKW(_, value) { + if (value == "is") { + cx.marked = "keyword" + return cont() + } } -}); - -module.exports = Selector; - -/***/ }), -/* 8 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -var _underscore = __webpack_require__(1); - -var Backbone = __webpack_require__(0); -var $ = Backbone.$; - -module.exports = Backbone.View.extend({ - - events: { - 'change': 'onChange' - }, - - attributes: function attributes() { - return this.model.get('attributes'); - }, - initialize: function initialize(o) { - var model = this.model; - var name = model.get('name'); - var target = model.target; - this.config = o.config || {}; - this.pfx = this.config.stylePrefix || ''; - this.ppfx = this.config.pStylePrefix || ''; - this.target = target; - this.className = this.pfx + 'trait'; - this.labelClass = this.ppfx + 'label'; - this.fieldClass = this.ppfx + 'field ' + this.ppfx + 'field-' + model.get('type'); - this.inputhClass = this.ppfx + 'input-holder'; - model.off('change:value', this.onValueChange); - this.listenTo(model, 'change:value', this.onValueChange); - this.tmpl = '
'; - }, - - - /** - * Fires when the input is changed - * @private - */ - onChange: function onChange() { - this.model.set('value', this.getInputEl().value); - }, - getValueForTarget: function getValueForTarget() { - return this.model.get('value'); - }, - setInputValue: function setInputValue(value) { - this.getInputEl().value = value; - }, - - - /** - * On change callback - * @private - */ - onValueChange: function onValueChange(model, value) { - var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; - - var mod = this.model; - var trg = this.target; - var name = mod.get('name'); - - if (opts.fromTarget) { - this.setInputValue(mod.get('value')); - } else { - var _value = this.getValueForTarget(); - mod.setTargetValue(_value); - } - }, - - - /** - * Render label - * @private - */ - renderLabel: function renderLabel() { - this.$el.html('
' + this.getLabel() + '
'); - }, - - - /** - * Returns label for the input - * @return {string} - * @private - */ - getLabel: function getLabel() { - var model = this.model; - var label = model.get('label') || model.get('name'); - return label.charAt(0).toUpperCase() + label.slice(1).replace(/-/g, ' '); - }, - - - /** - * Returns input element - * @return {HTMLElement} - * @private - */ - getInputEl: function getInputEl() { - if (!this.$input) { - var md = this.model; - var trg = this.target; - var name = md.get('name'); - var plh = md.get('placeholder') || md.get('default') || ''; - var type = md.get('type') || 'text'; - var attrs = trg.get('attributes'); - var min = md.get('min'); - var max = md.get('max'); - var value = md.get('changeProp') ? trg.get(name) : md.get('value') || attrs[name]; - var input = $(''); - - if (value) { - input.prop('value', value); - } - - if (min) { - input.prop('min', min); - } - - if (max) { - input.prop('max', max); - } - - this.$input = input; + function typeexpr(type, value) { + if (value == "keyof" || value == "typeof" || value == "infer") { + cx.marked = "keyword" + return cont(value == "typeof" ? expressionNoComma : typeexpr) } - return this.$input.get(0); - }, - getModelValue: function getModelValue() { - var value; - var model = this.model; - var target = this.target; - var name = model.get('name'); - - if (model.get('changeProp')) { - value = target.get(name); - } else { - var attrs = target.get('attributes'); - value = model.get('value') || attrs[name]; + if (type == "variable" || value == "void") { + cx.marked = "type" + return cont(afterType) } - - return value; - }, - - - /** - * Renders input - * @private - * */ - renderField: function renderField() { - if (!this.$input) { - this.$el.append(this.tmpl); - var el = this.getInputEl(); - // I use prepand expecially for checkbox traits - var inputWrap = this.el.querySelector('.' + this.inputhClass); - inputWrap.insertBefore(el, inputWrap.childNodes[0]); + if (value == "|" || value == "&") return cont(typeexpr) + if (type == "string" || type == "number" || type == "atom") return cont(afterType); + if (type == "[") return cont(pushlex("]"), commasep(typeexpr, "]", ","), poplex, afterType) + if (type == "{") return cont(pushlex("}"), commasep(typeprop, "}", ",;"), poplex, afterType) + if (type == "(") return cont(commasep(typearg, ")"), maybeReturnType, afterType) + if (type == "<") return cont(commasep(typeexpr, ">"), typeexpr) + } + function maybeReturnType(type) { + if (type == "=>") return cont(typeexpr) + } + function typeprop(type, value) { + if (type == "variable" || cx.style == "keyword") { + cx.marked = "property" + return cont(typeprop) + } else if (value == "?" || type == "number" || type == "string") { + return cont(typeprop) + } else if (type == ":") { + return cont(typeexpr) + } else if (type == "[") { + return cont(expect("variable"), maybetypeOrIn, expect("]"), typeprop) + } else if (type == "(") { + return pass(functiondecl, typeprop) } - }, - render: function render() { - this.renderLabel(); - this.renderField(); - this.el.className = this.className; - return this; } -}); - -/***/ }), -/* 9 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; -var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_RESULT__; - -/*! cash-dom 1.3.5, https://github.com/kenwheeler/cash @license MIT */ -;(function (root, factory) { - if (true) { - !(__WEBPACK_AMD_DEFINE_FACTORY__ = (factory), - __WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ? - (__WEBPACK_AMD_DEFINE_FACTORY__.call(exports, __webpack_require__, exports, module)) : - __WEBPACK_AMD_DEFINE_FACTORY__), - __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)); - } else if (typeof exports !== "undefined") { - module.exports = factory(); - } else { - root.cash = root.$ = factory(); + function typearg(type, value) { + if (type == "variable" && cx.stream.match(/^\s*[?:]/, false) || value == "?") return cont(typearg) + if (type == ":") return cont(typeexpr) + if (type == "spread") return cont(typearg) + return pass(typeexpr) } -})(this, function () { - var doc = document, win = window, ArrayProto = Array.prototype, slice = ArrayProto.slice, filter = ArrayProto.filter, push = ArrayProto.push; - - var noop = function () {}, isFunction = function (item) { - // @see https://crbug.com/568448 - return typeof item === typeof noop && item.call; - }, isString = function (item) { - return typeof item === typeof ""; - }; - - var idMatch = /^#[\w-]*$/, classMatch = /^\.[\w-]*$/, htmlMatch = /<.+>/, singlet = /^\w+$/; - - function find(selector, context) { - context = context || doc; - var elems = (classMatch.test(selector) ? context.getElementsByClassName(selector.slice(1)) : singlet.test(selector) ? context.getElementsByTagName(selector) : context.querySelectorAll(selector)); - return elems; + function afterType(type, value) { + if (value == "<") return cont(pushlex(">"), commasep(typeexpr, ">"), poplex, afterType) + if (value == "|" || type == "." || value == "&") return cont(typeexpr) + if (type == "[") return cont(typeexpr, expect("]"), afterType) + if (value == "extends" || value == "implements") { cx.marked = "keyword"; return cont(typeexpr) } + if (value == "?") return cont(typeexpr, expect(":"), typeexpr) } - - var frag; - function parseHTML(str) { - if (!frag) { - frag = doc.implementation.createHTMLDocument(); - var base = frag.createElement("base"); - base.href = doc.location.href; - frag.head.appendChild(base); + function maybeTypeArgs(_, value) { + if (value == "<") return cont(pushlex(">"), commasep(typeexpr, ">"), poplex, afterType) + } + function typeparam() { + return pass(typeexpr, maybeTypeDefault) + } + function maybeTypeDefault(_, value) { + if (value == "=") return cont(typeexpr) + } + function vardef(_, value) { + if (value == "enum") {cx.marked = "keyword"; return cont(enumdef)} + return pass(pattern, maybetype, maybeAssign, vardefCont); + } + function pattern(type, value) { + if (isTS && isModifier(value)) { cx.marked = "keyword"; return cont(pattern) } + if (type == "variable") { register(value); return cont(); } + if (type == "spread") return cont(pattern); + if (type == "[") return contCommasep(eltpattern, "]"); + if (type == "{") return contCommasep(proppattern, "}"); + } + function proppattern(type, value) { + if (type == "variable" && !cx.stream.match(/^\s*:/, false)) { + register(value); + return cont(maybeAssign); } - - frag.body.innerHTML = str; - - return frag.body.childNodes; + if (type == "variable") cx.marked = "property"; + if (type == "spread") return cont(pattern); + if (type == "}") return pass(); + if (type == "[") return cont(expression, expect(']'), expect(':'), proppattern); + return cont(expect(":"), pattern, maybeAssign); } - - function onReady(fn) { - if (doc.readyState !== "loading") { - fn(); - } else { - doc.addEventListener("DOMContentLoaded", fn); + function eltpattern() { + return pass(pattern, maybeAssign) + } + function maybeAssign(_type, value) { + if (value == "=") return cont(expressionNoComma); + } + function vardefCont(type) { + if (type == ",") return cont(vardef); + } + function maybeelse(type, value) { + if (type == "keyword b" && value == "else") return cont(pushlex("form", "else"), statement, poplex); + } + function forspec(type, value) { + if (value == "await") return cont(forspec); + if (type == "(") return cont(pushlex(")"), forspec1, poplex); + } + function forspec1(type) { + if (type == "var") return cont(vardef, forspec2); + if (type == "variable") return cont(forspec2); + return pass(forspec2) + } + function forspec2(type, value) { + if (type == ")") return cont() + if (type == ";") return cont(forspec2) + if (value == "in" || value == "of") { cx.marked = "keyword"; return cont(expression, forspec2) } + return pass(expression, forspec2) + } + function functiondef(type, value) { + if (value == "*") {cx.marked = "keyword"; return cont(functiondef);} + if (type == "variable") {register(value); return cont(functiondef);} + if (type == "(") return cont(pushcontext, pushlex(")"), commasep(funarg, ")"), poplex, mayberettype, statement, popcontext); + if (isTS && value == "<") return cont(pushlex(">"), commasep(typeparam, ">"), poplex, functiondef) + } + function functiondecl(type, value) { + if (value == "*") {cx.marked = "keyword"; return cont(functiondecl);} + if (type == "variable") {register(value); return cont(functiondecl);} + if (type == "(") return cont(pushcontext, pushlex(")"), commasep(funarg, ")"), poplex, mayberettype, popcontext); + if (isTS && value == "<") return cont(pushlex(">"), commasep(typeparam, ">"), poplex, functiondecl) + } + function typename(type, value) { + if (type == "keyword" || type == "variable") { + cx.marked = "type" + return cont(typename) + } else if (value == "<") { + return cont(pushlex(">"), commasep(typeparam, ">"), poplex) } } - - function Init(selector, context) { - if (!selector) { - return this; + function funarg(type, value) { + if (value == "@") cont(expression, funarg) + if (type == "spread") return cont(funarg); + if (isTS && isModifier(value)) { cx.marked = "keyword"; return cont(funarg); } + if (isTS && type == "this") return cont(maybetype, maybeAssign) + return pass(pattern, maybetype, maybeAssign); + } + function classExpression(type, value) { + // Class expressions may have an optional name. + if (type == "variable") return className(type, value); + return classNameAfter(type, value); + } + function className(type, value) { + if (type == "variable") {register(value); return cont(classNameAfter);} + } + function classNameAfter(type, value) { + if (value == "<") return cont(pushlex(">"), commasep(typeparam, ">"), poplex, classNameAfter) + if (value == "extends" || value == "implements" || (isTS && type == ",")) { + if (value == "implements") cx.marked = "keyword"; + return cont(isTS ? typeexpr : expression, classNameAfter); } - - // If already a cash collection, don't do any further processing - if (selector.cash && selector !== win) { - return selector; + if (type == "{") return cont(pushlex("}"), classBody, poplex); + } + function classBody(type, value) { + if (type == "async" || + (type == "variable" && + (value == "static" || value == "get" || value == "set" || (isTS && isModifier(value))) && + cx.stream.match(/^\s+[\w$\xa1-\uffff]/, false))) { + cx.marked = "keyword"; + return cont(classBody); } - - var elems = selector, i = 0, length; - - if (isString(selector)) { - elems = (idMatch.test(selector) ? - // If an ID use the faster getElementById check - doc.getElementById(selector.slice(1)) : htmlMatch.test(selector) ? - // If HTML, parse it into real elements - parseHTML(selector) : - // else use `find` - find(selector, context)); - - // If function, use as shortcut for DOM ready - } else if (isFunction(selector)) { - onReady(selector);return this; - } - - if (!elems) { - return this; + if (type == "variable" || cx.style == "keyword") { + cx.marked = "property"; + return cont(isTS ? classfield : functiondef, classBody); } - - // If a single DOM element is passed in or received via ID, return the single element - if (elems.nodeType || elems === win) { - this[0] = elems; - this.length = 1; - } else { - // Treat like an array and loop through each item. - length = this.length = elems.length; - for (; i < length; i++) { - this[i] = elems[i]; - } + if (type == "number" || type == "string") return cont(isTS ? classfield : functiondef, classBody); + if (type == "[") + return cont(expression, maybetype, expect("]"), isTS ? classfield : functiondef, classBody) + if (value == "*") { + cx.marked = "keyword"; + return cont(classBody); } - - return this; + if (isTS && type == "(") return pass(functiondecl, classBody) + if (type == ";" || type == ",") return cont(classBody); + if (type == "}") return cont(); + if (value == "@") return cont(expression, classBody) + } + function classfield(type, value) { + if (value == "?") return cont(classfield) + if (type == ":") return cont(typeexpr, maybeAssign) + if (value == "=") return cont(expressionNoComma) + var context = cx.state.lexical.prev, isInterface = context && context.info == "interface" + return pass(isInterface ? functiondecl : functiondef) + } + function afterExport(type, value) { + if (value == "*") { cx.marked = "keyword"; return cont(maybeFrom, expect(";")); } + if (value == "default") { cx.marked = "keyword"; return cont(expression, expect(";")); } + if (type == "{") return cont(commasep(exportField, "}"), maybeFrom, expect(";")); + return pass(statement); + } + function exportField(type, value) { + if (value == "as") { cx.marked = "keyword"; return cont(expect("variable")); } + if (type == "variable") return pass(expressionNoComma, exportField); + } + function afterImport(type) { + if (type == "string") return cont(); + if (type == "(") return pass(expression); + return pass(importSpec, maybeMoreImports, maybeFrom); + } + function importSpec(type, value) { + if (type == "{") return contCommasep(importSpec, "}"); + if (type == "variable") register(value); + if (value == "*") cx.marked = "keyword"; + return cont(maybeAs); + } + function maybeMoreImports(type) { + if (type == ",") return cont(importSpec, maybeMoreImports) + } + function maybeAs(_type, value) { + if (value == "as") { cx.marked = "keyword"; return cont(importSpec); } + } + function maybeFrom(_type, value) { + if (value == "from") { cx.marked = "keyword"; return cont(expression); } + } + function arrayLiteral(type) { + if (type == "]") return cont(); + return pass(commasep(expressionNoComma, "]")); + } + function enumdef() { + return pass(pushlex("form"), pattern, expect("{"), pushlex("}"), commasep(enummember, "}"), poplex, poplex) + } + function enummember() { + return pass(pattern, maybeAssign); } - function cash(selector, context) { - return new Init(selector, context); + function isContinuedStatement(state, textAfter) { + return state.lastType == "operator" || state.lastType == "," || + isOperatorChar.test(textAfter.charAt(0)) || + /[,.]/.test(textAfter.charAt(0)); } - var fn = cash.fn = cash.prototype = Init.prototype = { // jshint ignore:line - cash: true, - length: 0, - push: push, - splice: ArrayProto.splice, - map: ArrayProto.map, - init: Init - }; + function expressionAllowed(stream, state, backUp) { + return state.tokenize == tokenBase && + /^(?:operator|sof|keyword [bcd]|case|new|export|default|spread|[\[{}\(,;:]|=>)$/.test(state.lastType) || + (state.lastType == "quasi" && /\{\s*$/.test(stream.string.slice(0, stream.pos - (backUp || 0)))) + } - Object.defineProperty(fn, "constructor", { value: cash }); + // Interface - cash.parseHTML = parseHTML; - cash.noop = noop; - cash.isFunction = isFunction; - cash.isString = isString; + return { + startState: function(basecolumn) { + var state = { + tokenize: tokenBase, + lastType: "sof", + cc: [], + lexical: new JSLexical((basecolumn || 0) - indentUnit, 0, "block", false), + localVars: parserConfig.localVars, + context: parserConfig.localVars && new Context(null, null, false), + indented: basecolumn || 0 + }; + if (parserConfig.globalVars && typeof parserConfig.globalVars == "object") + state.globalVars = parserConfig.globalVars; + return state; + }, - cash.extend = fn.extend = function (target) { - target = target || {}; + token: function(stream, state) { + if (stream.sol()) { + if (!state.lexical.hasOwnProperty("align")) + state.lexical.align = false; + state.indented = stream.indentation(); + findFatArrow(stream, state); + } + if (state.tokenize != tokenComment && stream.eatSpace()) return null; + var style = state.tokenize(stream, state); + if (type == "comment") return style; + state.lastType = type == "operator" && (content == "++" || content == "--") ? "incdec" : type; + return parseJS(state, style, type, content, stream); + }, - var args = slice.call(arguments), length = args.length, i = 1; + indent: function(state, textAfter) { + if (state.tokenize == tokenComment) return CodeMirror.Pass; + if (state.tokenize != tokenBase) return 0; + var firstChar = textAfter && textAfter.charAt(0), lexical = state.lexical, top + // Kludge to prevent 'maybelse' from blocking lexical scope pops + if (!/^\s*else\b/.test(textAfter)) for (var i = state.cc.length - 1; i >= 0; --i) { + var c = state.cc[i]; + if (c == poplex) lexical = lexical.prev; + else if (c != maybeelse) break; + } + while ((lexical.type == "stat" || lexical.type == "form") && + (firstChar == "}" || ((top = state.cc[state.cc.length - 1]) && + (top == maybeoperatorComma || top == maybeoperatorNoComma) && + !/^[,\.=+\-*:?[\(]/.test(textAfter)))) + lexical = lexical.prev; + if (statementIndent && lexical.type == ")" && lexical.prev.type == "stat") + lexical = lexical.prev; + var type = lexical.type, closing = firstChar == type; - if (args.length === 1) { - target = this; - i = 0; - } + if (type == "vardef") return lexical.indented + (state.lastType == "operator" || state.lastType == "," ? lexical.info.length + 1 : 0); + else if (type == "form" && firstChar == "{") return lexical.indented; + else if (type == "form") return lexical.indented + indentUnit; + else if (type == "stat") + return lexical.indented + (isContinuedStatement(state, textAfter) ? statementIndent || indentUnit : 0); + else if (lexical.info == "switch" && !closing && parserConfig.doubleIndentSwitch != false) + return lexical.indented + (/^(?:case|default)\b/.test(textAfter) ? indentUnit : 2 * indentUnit); + else if (lexical.align) return lexical.column + (closing ? 0 : 1); + else return lexical.indented + (closing ? 0 : indentUnit); + }, - for (; i < length; i++) { - if (!args[i]) { - continue; - } - for (var key in args[i]) { - if (args[i].hasOwnProperty(key)) { - target[key] = args[i][key]; - } - } - } + electricInput: /^\s*(?:case .*?:|default:|\{|\})$/, + blockCommentStart: jsonMode ? null : "/*", + blockCommentEnd: jsonMode ? null : "*/", + blockCommentContinue: jsonMode ? null : " * ", + lineComment: jsonMode ? null : "//", + fold: "brace", + closeBrackets: "()[]{}''\"\"``", - return target; - }; + helperType: jsonMode ? "json" : "javascript", + jsonldMode: jsonldMode, + jsonMode: jsonMode, - function each(collection, callback) { - var l = collection.length, i = 0; + expressionAllowed: expressionAllowed, - for (; i < l; i++) { - if (callback.call(collection[i], collection[i], i, collection) === false) { - break; - } + skipExpression: function(state) { + var top = state.cc[state.cc.length - 1] + if (top == expression || top == expressionNoComma) state.cc.pop() } - } - - function matches(el, selector) { - var m = el && (el.matches || el.webkitMatchesSelector || el.mozMatchesSelector || el.msMatchesSelector || el.oMatchesSelector); - return !!m && m.call(el, selector); - } + }; +}); - function getCompareFunction(selector) { - return ( - /* Use browser's `matches` function if string */ - isString(selector) ? matches : - /* Match a cash element */ - selector.cash ? function (el) { - return selector.is(el); - } : - /* Direct comparison */ - function (el, selector) { - return el === selector; - }); - } +CodeMirror.registerHelper("wordChars", "javascript", /[\w$]/); - function unique(collection) { - return cash(slice.call(collection).filter(function (item, index, self) { - return self.indexOf(item) === index; - })); - } +CodeMirror.defineMIME("text/javascript", "javascript"); +CodeMirror.defineMIME("text/ecmascript", "javascript"); +CodeMirror.defineMIME("application/javascript", "javascript"); +CodeMirror.defineMIME("application/x-javascript", "javascript"); +CodeMirror.defineMIME("application/ecmascript", "javascript"); +CodeMirror.defineMIME("application/json", {name: "javascript", json: true}); +CodeMirror.defineMIME("application/x-json", {name: "javascript", json: true}); +CodeMirror.defineMIME("application/ld+json", {name: "javascript", jsonld: true}); +CodeMirror.defineMIME("text/typescript", { name: "javascript", typescript: true }); +CodeMirror.defineMIME("application/typescript", { name: "javascript", typescript: true }); - cash.extend({ - merge: function (first, second) { - var len = +second.length, i = first.length, j = 0; +}); - for (; j < len; i++, j++) { - first[i] = second[j]; - } - first.length = i; - return first; - }, +/***/ }), - each: each, - matches: matches, - unique: unique, - isArray: Array.isArray, - isNumeric: function (n) { - return !isNaN(parseFloat(n)) && isFinite(n); - } +/***/ "./node_modules/codemirror/mode/xml/xml.js": +/*!*************************************************!*\ + !*** ./node_modules/codemirror/mode/xml/xml.js ***! + \*************************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { - }); +// CodeMirror, copyright (c) by Marijn Haverbeke and others +// Distributed under an MIT license: https://codemirror.net/LICENSE - var uid = cash.uid = "_cash" + Date.now(); +(function(mod) { + if (true) // CommonJS + mod(__webpack_require__(/*! ../../lib/codemirror */ "./node_modules/codemirror/lib/codemirror.js")); + else {} +})(function(CodeMirror) { +"use strict"; - function getDataCache(node) { - return (node[uid] = node[uid] || {}); - } +var htmlConfig = { + autoSelfClosers: {'area': true, 'base': true, 'br': true, 'col': true, 'command': true, + 'embed': true, 'frame': true, 'hr': true, 'img': true, 'input': true, + 'keygen': true, 'link': true, 'meta': true, 'param': true, 'source': true, + 'track': true, 'wbr': true, 'menuitem': true}, + implicitlyClosed: {'dd': true, 'li': true, 'optgroup': true, 'option': true, 'p': true, + 'rp': true, 'rt': true, 'tbody': true, 'td': true, 'tfoot': true, + 'th': true, 'tr': true}, + contextGrabbers: { + 'dd': {'dd': true, 'dt': true}, + 'dt': {'dd': true, 'dt': true}, + 'li': {'li': true}, + 'option': {'option': true, 'optgroup': true}, + 'optgroup': {'optgroup': true}, + 'p': {'address': true, 'article': true, 'aside': true, 'blockquote': true, 'dir': true, + 'div': true, 'dl': true, 'fieldset': true, 'footer': true, 'form': true, + 'h1': true, 'h2': true, 'h3': true, 'h4': true, 'h5': true, 'h6': true, + 'header': true, 'hgroup': true, 'hr': true, 'menu': true, 'nav': true, 'ol': true, + 'p': true, 'pre': true, 'section': true, 'table': true, 'ul': true}, + 'rp': {'rp': true, 'rt': true}, + 'rt': {'rp': true, 'rt': true}, + 'tbody': {'tbody': true, 'tfoot': true}, + 'td': {'td': true, 'th': true}, + 'tfoot': {'tbody': true}, + 'th': {'td': true, 'th': true}, + 'thead': {'tbody': true, 'tfoot': true}, + 'tr': {'tr': true} + }, + doNotIndent: {"pre": true}, + allowUnquoted: true, + allowMissing: true, + caseFold: true +} - function setData(node, key, value) { - return (getDataCache(node)[key] = value); - } +var xmlConfig = { + autoSelfClosers: {}, + implicitlyClosed: {}, + contextGrabbers: {}, + doNotIndent: {}, + allowUnquoted: false, + allowMissing: false, + allowMissingTagName: false, + caseFold: false +} - function getData(node, key) { - var c = getDataCache(node); - if (c[key] === undefined) { - c[key] = node.dataset ? node.dataset[key] : cash(node).attr("data-" + key); +CodeMirror.defineMode("xml", function(editorConf, config_) { + var indentUnit = editorConf.indentUnit + var config = {} + var defaults = config_.htmlMode ? htmlConfig : xmlConfig + for (var prop in defaults) config[prop] = defaults[prop] + for (var prop in config_) config[prop] = config_[prop] + + // Return variables for tokenizers + var type, setStyle; + + function inText(stream, state) { + function chain(parser) { + state.tokenize = parser; + return parser(stream, state); + } + + var ch = stream.next(); + if (ch == "<") { + if (stream.eat("!")) { + if (stream.eat("[")) { + if (stream.match("CDATA[")) return chain(inBlock("atom", "]]>")); + else return null; + } else if (stream.match("--")) { + return chain(inBlock("comment", "-->")); + } else if (stream.match("DOCTYPE", true, true)) { + stream.eatWhile(/[\w\._\-]/); + return chain(doctype(1)); + } else { + return null; + } + } else if (stream.eat("?")) { + stream.eatWhile(/[\w\._\-]/); + state.tokenize = inBlock("meta", "?>"); + return "meta"; + } else { + type = stream.eat("/") ? "closeTag" : "openTag"; + state.tokenize = inTag; + return "tag bracket"; + } + } else if (ch == "&") { + var ok; + if (stream.eat("#")) { + if (stream.eat("x")) { + ok = stream.eatWhile(/[a-fA-F\d]/) && stream.eat(";"); + } else { + ok = stream.eatWhile(/[\d]/) && stream.eat(";"); + } + } else { + ok = stream.eatWhile(/[\w\.\-:]/) && stream.eat(";"); + } + return ok ? "atom" : "error"; + } else { + stream.eatWhile(/[^&<]/); + return null; } - return c[key]; } + inText.isInText = true; - function removeData(node, key) { - var c = getDataCache(node); - if (c) { - delete c[key]; - } else if (node.dataset) { - delete node.dataset[key]; + function inTag(stream, state) { + var ch = stream.next(); + if (ch == ">" || (ch == "/" && stream.eat(">"))) { + state.tokenize = inText; + type = ch == ">" ? "endTag" : "selfcloseTag"; + return "tag bracket"; + } else if (ch == "=") { + type = "equals"; + return null; + } else if (ch == "<") { + state.tokenize = inText; + state.state = baseState; + state.tagName = state.tagStart = null; + var next = state.tokenize(stream, state); + return next ? next + " tag error" : "tag error"; + } else if (/[\'\"]/.test(ch)) { + state.tokenize = inAttribute(ch); + state.stringStartCol = stream.column(); + return state.tokenize(stream, state); } else { - cash(node).removeAttr("data-" + name); + stream.match(/^[^\s\u00a0=<>\"\']*[^\s\u00a0=<>\"\'\/]/); + return "word"; } } - fn.extend({ - data: function (name, value) { - if (isString(name)) { - return (value === undefined ? getData(this[0], name) : this.each(function (v) { - return setData(v, name, value); - })); + function inAttribute(quote) { + var closure = function(stream, state) { + while (!stream.eol()) { + if (stream.next() == quote) { + state.tokenize = inTag; + break; + } } + return "string"; + }; + closure.isInAttribute = true; + return closure; + } - for (var key in name) { - this.data(key, name[key]); + function inBlock(style, terminator) { + return function(stream, state) { + while (!stream.eol()) { + if (stream.match(terminator)) { + state.tokenize = inText; + break; + } + stream.next(); } - - return this; - }, - - removeData: function (key) { - return this.each(function (v) { - return removeData(v, key); - }); + return style; } - - }); - - var notWhiteMatch = /\S+/g; - - function getClasses(c) { - return isString(c) && c.match(notWhiteMatch); } - function hasClass(v, c) { - return (v.classList ? v.classList.contains(c) : new RegExp("(^| )" + c + "( |$)", "gi").test(v.className)); + function doctype(depth) { + return function(stream, state) { + var ch; + while ((ch = stream.next()) != null) { + if (ch == "<") { + state.tokenize = doctype(depth + 1); + return state.tokenize(stream, state); + } else if (ch == ">") { + if (depth == 1) { + state.tokenize = inText; + break; + } else { + state.tokenize = doctype(depth - 1); + return state.tokenize(stream, state); + } + } + } + return "meta"; + }; } - function addClass(v, c, spacedName) { - if (v.classList) { - v.classList.add(c); - } else if (spacedName.indexOf(" " + c + " ")) { - v.className += " " + c; + function Context(state, tagName, startOfLine) { + this.prev = state.context; + this.tagName = tagName; + this.indent = state.indented; + this.startOfLine = startOfLine; + if (config.doNotIndent.hasOwnProperty(tagName) || (state.context && state.context.noIndent)) + this.noIndent = true; + } + function popContext(state) { + if (state.context) state.context = state.context.prev; + } + function maybePopContext(state, nextTagName) { + var parentTagName; + while (true) { + if (!state.context) { + return; + } + parentTagName = state.context.tagName; + if (!config.contextGrabbers.hasOwnProperty(parentTagName) || + !config.contextGrabbers[parentTagName].hasOwnProperty(nextTagName)) { + return; + } + popContext(state); } } - function removeClass(v, c) { - if (v.classList) { - v.classList.remove(c); + function baseState(type, stream, state) { + if (type == "openTag") { + state.tagStart = stream.column(); + return tagNameState; + } else if (type == "closeTag") { + return closeTagNameState; } else { - v.className = v.className.replace(c, ""); + return baseState; } } - - fn.extend({ - addClass: function (c) { - var classes = getClasses(c); - - return (classes ? this.each(function (v) { - var spacedName = " " + v.className + " "; - each(classes, function (c) { - addClass(v, c, spacedName); - }); - }) : this); - }, - - attr: function (name, value) { - if (!name) { - return undefined; + function tagNameState(type, stream, state) { + if (type == "word") { + state.tagName = stream.current(); + setStyle = "tag"; + return attrState; + } else if (config.allowMissingTagName && type == "endTag") { + setStyle = "tag bracket"; + return attrState(type, stream, state); + } else { + setStyle = "error"; + return tagNameState; + } + } + function closeTagNameState(type, stream, state) { + if (type == "word") { + var tagName = stream.current(); + if (state.context && state.context.tagName != tagName && + config.implicitlyClosed.hasOwnProperty(state.context.tagName)) + popContext(state); + if ((state.context && state.context.tagName == tagName) || config.matchClosing === false) { + setStyle = "tag"; + return closeState; + } else { + setStyle = "tag error"; + return closeStateErr; } + } else if (config.allowMissingTagName && type == "endTag") { + setStyle = "tag bracket"; + return closeState(type, stream, state); + } else { + setStyle = "error"; + return closeStateErr; + } + } - if (isString(name)) { - if (value === undefined) { - return this[0] ? this[0].getAttribute ? this[0].getAttribute(name) : this[0][name] : undefined; - } - - return this.each(function (v) { - if (v.setAttribute) { - v.setAttribute(name, value); - } else { - v[name] = value; - } - }); - } + function closeState(type, _stream, state) { + if (type != "endTag") { + setStyle = "error"; + return closeState; + } + popContext(state); + return baseState; + } + function closeStateErr(type, stream, state) { + setStyle = "error"; + return closeState(type, stream, state); + } - for (var key in name) { - this.attr(key, name[key]); + function attrState(type, _stream, state) { + if (type == "word") { + setStyle = "attribute"; + return attrEqState; + } else if (type == "endTag" || type == "selfcloseTag") { + var tagName = state.tagName, tagStart = state.tagStart; + state.tagName = state.tagStart = null; + if (type == "selfcloseTag" || + config.autoSelfClosers.hasOwnProperty(tagName)) { + maybePopContext(state, tagName); + } else { + maybePopContext(state, tagName); + state.context = new Context(state, tagName, tagStart == state.indented); } + return baseState; + } + setStyle = "error"; + return attrState; + } + function attrEqState(type, stream, state) { + if (type == "equals") return attrValueState; + if (!config.allowMissing) setStyle = "error"; + return attrState(type, stream, state); + } + function attrValueState(type, stream, state) { + if (type == "string") return attrContinuedState; + if (type == "word" && config.allowUnquoted) {setStyle = "string"; return attrState;} + setStyle = "error"; + return attrState(type, stream, state); + } + function attrContinuedState(type, stream, state) { + if (type == "string") return attrContinuedState; + return attrState(type, stream, state); + } - return this; + return { + startState: function(baseIndent) { + var state = {tokenize: inText, + state: baseState, + indented: baseIndent || 0, + tagName: null, tagStart: null, + context: null} + if (baseIndent != null) state.baseIndent = baseIndent + return state }, - hasClass: function (c) { - var check = false, classes = getClasses(c); - if (classes && classes.length) { - this.each(function (v) { - check = hasClass(v, classes[0]); - return !check; - }); + token: function(stream, state) { + if (!state.tagName && stream.sol()) + state.indented = stream.indentation(); + + if (stream.eatSpace()) return null; + type = null; + var style = state.tokenize(stream, state); + if ((style || type) && style != "comment") { + setStyle = null; + state.state = state.state(type || style, stream, state); + if (setStyle) + style = setStyle == "error" ? style + " error" : setStyle; } - return check; + return style; }, - prop: function (name, value) { - if (isString(name)) { - return (value === undefined ? this[0][name] : this.each(function (v) { - v[name] = value; - })); + indent: function(state, textAfter, fullLine) { + var context = state.context; + // Indent multi-line strings (e.g. css). + if (state.tokenize.isInAttribute) { + if (state.tagStart == state.indented) + return state.stringStartCol + 1; + else + return state.indented + indentUnit; } - - for (var key in name) { - this.prop(key, name[key]); + if (context && context.noIndent) return CodeMirror.Pass; + if (state.tokenize != inTag && state.tokenize != inText) + return fullLine ? fullLine.match(/^(\s*)/)[0].length : 0; + // Indent the starts of attribute names. + if (state.tagName) { + if (config.multilineTagIndentPastTag !== false) + return state.tagStart + state.tagName.length + 2; + else + return state.tagStart + indentUnit * (config.multilineTagIndentFactor || 1); } - - return this; - }, - - removeAttr: function (name) { - return this.each(function (v) { - if (v.removeAttribute) { - v.removeAttribute(name); - } else { - delete v[name]; + if (config.alignCDATA && /$/, + blockCommentStart: "", - toggleClass: function (c, state) { - if (state !== undefined) { - return this[state ? "addClass" : "removeClass"](c); - } - var classes = getClasses(c); - return (classes ? this.each(function (v) { - var spacedName = " " + v.className + " "; - each(classes, function (c) { - if (hasClass(v, c)) { - removeClass(v, c); - } else { - addClass(v, c, spacedName); - } - }); - }) : this); - } }); + configuration: config.htmlMode ? "html" : "xml", + helperType: config.htmlMode ? "html" : "xml", - fn.extend({ - add: function (selector, context) { - return unique(cash.merge(this, cash(selector, context))); - }, + skipAttribute: function(state) { + if (state.state == attrValueState) + state.state = attrState + } + }; +}); - each: function (callback) { - each(this, callback); - return this; - }, +CodeMirror.defineMIME("text/xml", "xml"); +CodeMirror.defineMIME("application/xml", "xml"); +if (!CodeMirror.mimeModes.hasOwnProperty("text/html")) + CodeMirror.defineMIME("text/html", {name: "xml", htmlMode: true}); - eq: function (index) { - return cash(this.get(index)); - }, +}); - filter: function (selector) { - if (!selector) { - return this; - } - var comparator = (isFunction(selector) ? selector : getCompareFunction(selector)); +/***/ }), - return cash(filter.call(this, function (e) { - return comparator(e, selector); - })); - }, +/***/ "./node_modules/keymaster/keymaster.js": +/*!*********************************************!*\ + !*** ./node_modules/keymaster/keymaster.js ***! + \*********************************************/ +/*! no static exports found */ +/***/ (function(module, exports, __webpack_require__) { - first: function () { - return this.eq(0); - }, +// keymaster.js +// (c) 2011-2013 Thomas Fuchs +// keymaster.js may be freely distributed under the MIT license. - get: function (index) { - if (index === undefined) { - return slice.call(this); - } - return (index < 0 ? this[index + this.length] : this[index]); +;(function(global){ + var k, + _handlers = {}, + _mods = { 16: false, 18: false, 17: false, 91: false }, + _scope = 'all', + // modifier keys + _MODIFIERS = { + '⇧': 16, shift: 16, + '⌥': 18, alt: 18, option: 18, + '⌃': 17, ctrl: 17, control: 17, + '⌘': 91, command: 91 }, - - index: function (elem) { - var child = elem ? cash(elem)[0] : this[0], collection = elem ? this : cash(child).parent().children(); - return slice.call(collection).indexOf(child); + // special keys + _MAP = { + backspace: 8, tab: 9, clear: 12, + enter: 13, 'return': 13, + esc: 27, escape: 27, space: 32, + left: 37, up: 38, + right: 39, down: 40, + del: 46, 'delete': 46, + home: 36, end: 35, + pageup: 33, pagedown: 34, + ',': 188, '.': 190, '/': 191, + '`': 192, '-': 189, '=': 187, + ';': 186, '\'': 222, + '[': 219, ']': 221, '\\': 220 + }, + code = function(x){ + return _MAP[x] || x.toUpperCase().charCodeAt(0); }, + _downKeys = []; - last: function () { - return this.eq(-1); - } + for(k=1;k<20;k++) _MAP['f'+k] = 111+k; - }); + // IE doesn't support Array#indexOf, so have a simple replacement + function index(array, item){ + var i = array.length; + while(i--) if(array[i]===item) return i; + return -1; + } - var camelCase = (function () { - var camelRegex = /(?:^\w|[A-Z]|\b\w)/g, whiteSpace = /[\s-_]+/g; - return function (str) { - return str.replace(camelRegex, function (letter, index) { - return letter[index === 0 ? "toLowerCase" : "toUpperCase"](); - }).replace(whiteSpace, ""); - }; - }()); + // for comparing mods before unassignment + function compareArray(a1, a2) { + if (a1.length != a2.length) return false; + for (var i = 0; i < a1.length; i++) { + if (a1[i] !== a2[i]) return false; + } + return true; + } - var getPrefixedProp = (function () { - var cache = {}, doc = document, div = doc.createElement("div"), style = div.style; + var modifierMap = { + 16:'shiftKey', + 18:'altKey', + 17:'ctrlKey', + 91:'metaKey' + }; + function updateModifierKey(event) { + for(k in _mods) _mods[k] = event[modifierMap[k]]; + }; - return function (prop) { - prop = camelCase(prop); - if (cache[prop]) { - return cache[prop]; - } + // handle keydown event + function dispatch(event) { + var key, handler, k, i, modifiersMatch, scope; + key = event.keyCode; - var ucProp = prop.charAt(0).toUpperCase() + prop.slice(1), prefixes = ["webkit", "moz", "ms", "o"], props = (prop + " " + (prefixes).join(ucProp + " ") + ucProp).split(" "); + if (index(_downKeys, key) == -1) { + _downKeys.push(key); + } - each(props, function (p) { - if (p in style) { - cache[p] = prop = cache[prop] = p; - return false; - } - }); + // if a modifier key, set the key. property to true and return + if(key == 93 || key == 224) key = 91; // right command on webkit, command on Gecko + if(key in _mods) { + _mods[key] = true; + // 'assignKey' from inside this closure is exported to window.key + for(k in _MODIFIERS) if(_MODIFIERS[k] == key) assignKey[k] = true; + return; + } + updateModifierKey(event); - return cache[prop]; - }; - }()); + // see if we need to ignore the keypress (filter() can can be overridden) + // by default ignore key presses if a select, textarea, or input is focused + if(!assignKey.filter.call(this, event)) return; - cash.prefixedProp = getPrefixedProp; - cash.camelCase = camelCase; + // abort if no potentially matching shortcuts found + if (!(key in _handlers)) return; - fn.extend({ - css: function (prop, value) { - if (isString(prop)) { - prop = getPrefixedProp(prop); - return (arguments.length > 1 ? this.each(function (v) { - return v.style[prop] = value; - }) : win.getComputedStyle(this[0])[prop]); - } + scope = getScope(); - for (var key in prop) { - this.css(key, prop[key]); - } + // for each potential shortcut + for (i = 0; i < _handlers[key].length; i++) { + handler = _handlers[key][i]; - return this; + // see if it's in the current scope + if(handler.scope == scope || handler.scope == 'all'){ + // check if modifiers match if any + modifiersMatch = handler.mods.length > 0; + for(k in _mods) + if((!_mods[k] && index(handler.mods, +k) > -1) || + (_mods[k] && index(handler.mods, +k) == -1)) modifiersMatch = false; + // call the handler and stop the event if neccessary + if((handler.mods.length == 0 && !_mods[16] && !_mods[18] && !_mods[17] && !_mods[91]) || modifiersMatch){ + if(handler.method(event, handler)===false){ + if(event.preventDefault) event.preventDefault(); + else event.returnValue = false; + if(event.stopPropagation) event.stopPropagation(); + if(event.cancelBubble) event.cancelBubble = true; + } + } + } } + }; - }); - - function compute(el, prop) { - return parseInt(win.getComputedStyle(el[0], null)[prop], 10) || 0; - } - - each(["Width", "Height"], function (v) { - var lower = v.toLowerCase(); - - fn[lower] = function () { - return this[0].getBoundingClientRect()[lower]; - }; - - fn["inner" + v] = function () { - return this[0]["client" + v]; - }; + // unset modifier keys on keyup + function clearModifier(event){ + var key = event.keyCode, k, + i = index(_downKeys, key); - fn["outer" + v] = function (margins) { - return this[0]["offset" + v] + (margins ? compute(this, "margin" + (v === "Width" ? "Left" : "Top")) + compute(this, "margin" + (v === "Width" ? "Right" : "Bottom")) : 0); - }; - }); + // remove key from _downKeys + if (i >= 0) { + _downKeys.splice(i, 1); + } - function registerEvent(node, eventName, callback) { - var eventCache = getData(node, "_cashEvents") || setData(node, "_cashEvents", {}); - eventCache[eventName] = eventCache[eventName] || []; - eventCache[eventName].push(callback); - node.addEventListener(eventName, callback); - } + if(key == 93 || key == 224) key = 91; + if(key in _mods) { + _mods[key] = false; + for(k in _MODIFIERS) if(_MODIFIERS[k] == key) assignKey[k] = false; + } + }; - function removeEvent(node, eventName, callback) { - var events = getData(node, "_cashEvents"), eventCache = (events && events[eventName]), index; + function resetModifiers() { + for(k in _mods) _mods[k] = false; + for(k in _MODIFIERS) assignKey[k] = false; + }; - if (!eventCache) { - return; + // parse and assign shortcut + function assignKey(key, scope, method){ + var keys, mods; + keys = getKeys(key); + if (method === undefined) { + method = scope; + scope = 'all'; } - if (callback) { - node.removeEventListener(eventName, callback); - index = eventCache.indexOf(callback); - if (index >= 0) { - eventCache.splice(index, 1); + // for each shortcut + for (var i = 0; i < keys.length; i++) { + // set modifier keys if any + mods = []; + key = keys[i].split('+'); + if (key.length > 1){ + mods = getMods(key); + key = [key[key.length-1]]; } - } else { - each(eventCache, function (event) { - node.removeEventListener(eventName, event); - }); - eventCache = []; + // convert to keycode and... + key = key[0] + key = code(key); + // ...store handler + if (!(key in _handlers)) _handlers[key] = []; + _handlers[key].push({ shortcut: keys[i], scope: scope, method: method, key: keys[i], mods: mods }); } - } + }; - fn.extend({ - off: function (eventName, callback) { - return this.each(function (v) { - return removeEvent(v, eventName, callback); - }); - }, + // unbind all handlers for given key in current scope + function unbindKey(key, scope) { + var multipleKeys, keys, + mods = [], + i, j, obj; - on: function (eventName, delegate, callback, runOnce) { - // jshint ignore:line + multipleKeys = getKeys(key); - var originalCallback; + for (j = 0; j < multipleKeys.length; j++) { + keys = multipleKeys[j].split('+'); - if (!isString(eventName)) { - for (var key in eventName) { - this.on(key, delegate, eventName[key]); - } - return this; + if (keys.length > 1) { + mods = getMods(keys); + key = keys[keys.length - 1]; } - if (isFunction(delegate)) { - callback = delegate; - delegate = null; - } + key = code(key); - if (eventName === "ready") { - onReady(callback); - return this; + if (scope === undefined) { + scope = getScope(); } - - if (delegate) { - originalCallback = callback; - callback = function (e) { - var t = e.target; - - while (!matches(t, delegate)) { - if (t === this) { - return (t = false); - } - t = t.parentNode; - } - - if (t) { - originalCallback.call(t, e); - } - }; + if (!_handlers[key]) { + return; } - - return this.each(function (v) { - var finalCallback = callback; - if (runOnce) { - finalCallback = function () { - callback.apply(this, arguments); - removeEvent(v, eventName, finalCallback); - }; + for (i = 0; i < _handlers[key].length; i++) { + obj = _handlers[key][i]; + // only clear handlers if correct scope and mods match + if (obj.scope === scope && compareArray(obj.mods, mods)) { + _handlers[key][i] = {}; } - registerEvent(v, eventName, finalCallback); - }); - }, - - one: function (eventName, delegate, callback) { - return this.on(eventName, delegate, callback, true); - }, - - ready: onReady, - - trigger: function (eventName, data) { - var evt = doc.createEvent("HTMLEvents"); - evt.data = data; - evt.initEvent(eventName, true, false); - return this.each(function (v) { - return v.dispatchEvent(evt); - }); + } } + }; - }); - - function encode(name, value) { - return "&" + encodeURIComponent(name) + "=" + encodeURIComponent(value).replace(/%20/g, "+"); - } - - function getSelectMultiple_(el) { - var values = []; - each(el.options, function (o) { - if (o.selected) { - values.push(o.value); + // Returns true if the key with code 'keyCode' is currently down + // Converts strings into key codes. + function isPressed(keyCode) { + if (typeof(keyCode)=='string') { + keyCode = code(keyCode); } - }); - return values.length ? values : null; + return index(_downKeys, keyCode) != -1; } - function getSelectSingle_(el) { - var selectedIndex = el.selectedIndex; - return selectedIndex >= 0 ? el.options[selectedIndex].value : null; + function getPressedKeyCodes() { + return _downKeys.slice(0); } - function getValue(el) { - var type = el.type; - if (!type) { - return null; - } - switch (type.toLowerCase()) { - case "select-one": - return getSelectSingle_(el); - case "select-multiple": - return getSelectMultiple_(el); - case "radio": - return (el.checked) ? el.value : null; - case "checkbox": - return (el.checked) ? el.value : null; - default: - return el.value ? el.value : null; - } + function filter(event){ + var tagName = (event.target || event.srcElement).tagName; + // ignore keypressed in any elements that support keyboard data input + return !(tagName == 'INPUT' || tagName == 'SELECT' || tagName == 'TEXTAREA'); } - fn.extend({ - serialize: function () { - var query = ""; + // initialize key. to false + for(k in _MODIFIERS) assignKey[k] = false; - each(this[0].elements || this, function (el) { - if (el.disabled || el.tagName === "FIELDSET") { - return; - } - var name = el.name; - switch (el.type.toLowerCase()) { - case "file": - case "reset": - case "submit": - case "button": - break; - case "select-multiple": - var values = getValue(el); - if (values !== null) { - each(values, function (value) { - query += encode(name, value); - }); - } - break; - default: - var value = getValue(el); - if (value !== null) { - query += encode(name, value); - } - } - }); + // set current scope (default 'all') + function setScope(scope){ _scope = scope || 'all' }; + function getScope(){ return _scope || 'all' }; - return query.substr(1); - }, + // delete all handlers for a given scope + function deleteScope(scope){ + var key, handlers, i; - val: function (value) { - if (value === undefined) { - return getValue(this[0]); - } else { - return this.each(function (v) { - return v.value = value; - }); + for (key in _handlers) { + handlers = _handlers[key]; + for (i = 0; i < handlers.length; ) { + if (handlers[i].scope === scope) handlers.splice(i, 1); + else i++; } } + }; - }); - - function insertElement(el, child, prepend) { - if (prepend) { - var first = el.childNodes[0]; - el.insertBefore(child, first); - } else { - el.appendChild(child); + // abstract key logic for assign and unassign + function getKeys(key) { + var keys; + key = key.replace(/\s/g, ''); + keys = key.split(','); + if ((keys[keys.length - 1]) == '') { + keys[keys.length - 2] += ','; } + return keys; } - function insertContent(parent, child, prepend) { - var str = isString(child); + // abstract mods logic for assign and unassign + function getMods(key) { + var mods = key.slice(0, key.length - 1); + for (var mi = 0; mi < mods.length; mi++) + mods[mi] = _MODIFIERS[mods[mi]]; + return mods; + } - if (!str && child.length) { - each(child, function (v) { - return insertContent(parent, v, prepend); - }); - return; - } + // cross-browser events + function addEvent(object, event, method) { + if (object.addEventListener) + object.addEventListener(event, method, false); + else if(object.attachEvent) + object.attachEvent('on'+event, function(){ method(window.event) }); + }; - each(parent, str ? function (v) { - return v.insertAdjacentHTML(prepend ? "afterbegin" : "beforeend", child); - } : function (v, i) { - return insertElement(v, (i === 0 ? child : child.cloneNode(true)), prepend); - }); + // set the handlers globally on document + addEvent(document, 'keydown', function(event) { dispatch(event) }); // Passing _scope to a callback to ensure it remains the same by execution. Fixes #48 + addEvent(document, 'keyup', clearModifier); + + // reset modifiers to false whenever the window is (re)focused. + addEvent(window, 'focus', resetModifiers); + + // store previously defined key + var previousKey = global.key; + + // restore previously defined key and return reference to our key object + function noConflict() { + var k = global.key; + global.key = previousKey; + return k; } - fn.extend({ - after: function (selector) { - cash(selector).insertAfter(this); - return this; - }, + // set window.key and window.key.set/get/deleteScope, and the default filter + global.key = assignKey; + global.key.setScope = setScope; + global.key.getScope = getScope; + global.key.deleteScope = deleteScope; + global.key.filter = filter; + global.key.isPressed = isPressed; + global.key.getPressedKeyCodes = getPressedKeyCodes; + global.key.noConflict = noConflict; + global.key.unbind = unbindKey; - append: function (content) { - insertContent(this, content); - return this; - }, + if(true) module.exports = assignKey; - appendTo: function (parent) { - insertContent(cash(parent), this); - return this; - }, +})(this); - before: function (selector) { - cash(selector).insertBefore(this); - return this; - }, - clone: function () { - return cash(this.map(function (v) { - return v.cloneNode(true); - })); - }, +/***/ }), - empty: function () { - this.html(""); - return this; - }, +/***/ "./node_modules/process/browser.js": +/*!*****************************************!*\ + !*** ./node_modules/process/browser.js ***! + \*****************************************/ +/*! no static exports found */ +/***/ (function(module, exports) { - html: function (content) { - if (content === undefined) { - return this[0].innerHTML; - } - var source = (content.nodeType ? content[0].outerHTML : content); - return this.each(function (v) { - return v.innerHTML = source; - }); - }, +// shim for using process in browser +var process = module.exports = {}; - insertAfter: function (selector) { - var _this = this; +// cached from whatever global is present so that test runners that stub it +// don't break things. But we need to wrap it in a try catch in case it is +// wrapped in strict mode code which doesn't define any globals. It's inside a +// function because try/catches deoptimize in certain engines. +var cachedSetTimeout; +var cachedClearTimeout; - cash(selector).each(function (el, i) { - var parent = el.parentNode, sibling = el.nextSibling; - _this.each(function (v) { - parent.insertBefore((i === 0 ? v : v.cloneNode(true)), sibling); - }); - }); +function defaultSetTimout() { + throw new Error('setTimeout has not been defined'); +} +function defaultClearTimeout () { + throw new Error('clearTimeout has not been defined'); +} +(function () { + try { + if (typeof setTimeout === 'function') { + cachedSetTimeout = setTimeout; + } else { + cachedSetTimeout = defaultSetTimout; + } + } catch (e) { + cachedSetTimeout = defaultSetTimout; + } + try { + if (typeof clearTimeout === 'function') { + cachedClearTimeout = clearTimeout; + } else { + cachedClearTimeout = defaultClearTimeout; + } + } catch (e) { + cachedClearTimeout = defaultClearTimeout; + } +} ()) +function runTimeout(fun) { + if (cachedSetTimeout === setTimeout) { + //normal enviroments in sane situations + return setTimeout(fun, 0); + } + // if setTimeout wasn't available but was latter defined + if ((cachedSetTimeout === defaultSetTimout || !cachedSetTimeout) && setTimeout) { + cachedSetTimeout = setTimeout; + return setTimeout(fun, 0); + } + try { + // when when somebody has screwed with setTimeout but no I.E. maddness + return cachedSetTimeout(fun, 0); + } catch(e){ + try { + // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally + return cachedSetTimeout.call(null, fun, 0); + } catch(e){ + // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error + return cachedSetTimeout.call(this, fun, 0); + } + } - return this; - }, - insertBefore: function (selector) { - var _this2 = this; - cash(selector).each(function (el, i) { - var parent = el.parentNode; - _this2.each(function (v) { - parent.insertBefore((i === 0 ? v : v.cloneNode(true)), el); - }); - }); - return this; - }, +} +function runClearTimeout(marker) { + if (cachedClearTimeout === clearTimeout) { + //normal enviroments in sane situations + return clearTimeout(marker); + } + // if clearTimeout wasn't available but was latter defined + if ((cachedClearTimeout === defaultClearTimeout || !cachedClearTimeout) && clearTimeout) { + cachedClearTimeout = clearTimeout; + return clearTimeout(marker); + } + try { + // when when somebody has screwed with setTimeout but no I.E. maddness + return cachedClearTimeout(marker); + } catch (e){ + try { + // When we are in I.E. but the script has been evaled so I.E. doesn't trust the global object when called normally + return cachedClearTimeout.call(null, marker); + } catch (e){ + // same as above but when it's a version of I.E. that must have the global object for 'this', hopfully our context correct otherwise it will throw a global error. + // Some versions of I.E. have different rules for clearTimeout vs setTimeout + return cachedClearTimeout.call(this, marker); + } + } - prepend: function (content) { - insertContent(this, content, true); - return this; - }, - prependTo: function (parent) { - insertContent(cash(parent), this, true); - return this; - }, - remove: function () { - return this.each(function (v) { - return v.parentNode.removeChild(v); - }); - }, +} +var queue = []; +var draining = false; +var currentQueue; +var queueIndex = -1; - text: function (content) { - if (content === undefined) { - return this[0].textContent; - } - return this.each(function (v) { - return v.textContent = content; - }); +function cleanUpNextTick() { + if (!draining || !currentQueue) { + return; + } + draining = false; + if (currentQueue.length) { + queue = currentQueue.concat(queue); + } else { + queueIndex = -1; + } + if (queue.length) { + drainQueue(); } +} - }); +function drainQueue() { + if (draining) { + return; + } + var timeout = runTimeout(cleanUpNextTick); + draining = true; - var docEl = doc.documentElement; + var len = queue.length; + while(len) { + currentQueue = queue; + queue = []; + while (++queueIndex < len) { + if (currentQueue) { + currentQueue[queueIndex].run(); + } + } + queueIndex = -1; + len = queue.length; + } + currentQueue = null; + draining = false; + runClearTimeout(timeout); +} - fn.extend({ - position: function () { - var el = this[0]; - return { - left: el.offsetLeft, - top: el.offsetTop - }; - }, +process.nextTick = function (fun) { + var args = new Array(arguments.length - 1); + if (arguments.length > 1) { + for (var i = 1; i < arguments.length; i++) { + args[i - 1] = arguments[i]; + } + } + queue.push(new Item(fun, args)); + if (queue.length === 1 && !draining) { + runTimeout(drainQueue); + } +}; - offset: function () { - var rect = this[0].getBoundingClientRect(); - return { - top: rect.top + win.pageYOffset - docEl.clientTop, - left: rect.left + win.pageXOffset - docEl.clientLeft - }; - }, +// v8 likes predictible objects +function Item(fun, array) { + this.fun = fun; + this.array = array; +} +Item.prototype.run = function () { + this.fun.apply(null, this.array); +}; +process.title = 'browser'; +process.browser = true; +process.env = {}; +process.argv = []; +process.version = ''; // empty string to avoid regexp issues +process.versions = {}; - offsetParent: function () { - return cash(this[0].offsetParent); - } +function noop() {} - }); +process.on = noop; +process.addListener = noop; +process.once = noop; +process.off = noop; +process.removeListener = noop; +process.removeAllListeners = noop; +process.emit = noop; +process.prependListener = noop; +process.prependOnceListener = noop; - fn.extend({ - children: function (selector) { - var elems = []; - this.each(function (el) { - push.apply(elems, el.children); - }); - elems = unique(elems); +process.listeners = function (name) { return [] } - return (!selector ? elems : elems.filter(function (v) { - return matches(v, selector); - })); - }, +process.binding = function (name) { + throw new Error('process.binding is not supported'); +}; - closest: function (selector) { - if (!selector || this.length < 1) { - return cash(); - } - if (this.is(selector)) { - return this.filter(selector); - } - return this.parent().closest(selector); - }, +process.cwd = function () { return '/' }; +process.chdir = function (dir) { + throw new Error('process.chdir is not supported'); +}; +process.umask = function() { return 0; }; - is: function (selector) { - if (!selector) { - return false; - } - var match = false, comparator = getCompareFunction(selector); +/***/ }), - this.each(function (el) { - match = comparator(el, selector); - return !match; - }); +/***/ "./node_modules/promise-polyfill/src/finally.js": +/*!******************************************************!*\ + !*** ./node_modules/promise-polyfill/src/finally.js ***! + \******************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - return match; - }, +"use strict"; +__webpack_require__.r(__webpack_exports__); +/** + * @this {Promise} + */ +function finallyConstructor(callback) { + var constructor = this.constructor; + return this.then(function (value) { + // @ts-ignore + return constructor.resolve(callback()).then(function () { + return value; + }); + }, function (reason) { + // @ts-ignore + return constructor.resolve(callback()).then(function () { + // @ts-ignore + return constructor.reject(reason); + }); + }); +} - find: function (selector) { - if (!selector || selector.nodeType) { - return cash(selector && this.has(selector).length ? selector : null); - } +/* harmony default export */ __webpack_exports__["default"] = (finallyConstructor); - var elems = []; - this.each(function (el) { - push.apply(elems, find(selector, el)); - }); +/***/ }), - return unique(elems); - }, +/***/ "./node_modules/promise-polyfill/src/index.js": +/*!****************************************************!*\ + !*** ./node_modules/promise-polyfill/src/index.js ***! + \****************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - has: function (selector) { - var comparator = (isString(selector) ? function (el) { - return find(selector, el).length !== 0; - } : function (el) { - return el.contains(selector); - }); +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* WEBPACK VAR INJECTION */(function(setImmediate) {/* harmony import */ var _finally__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./finally */ "./node_modules/promise-polyfill/src/finally.js"); + // Store setTimeout reference so promise-polyfill will be unaffected by +// other code modifying setTimeout (like sinon.useFakeTimers()) - return this.filter(comparator); - }, +var setTimeoutFunc = setTimeout; - next: function () { - return cash(this[0].nextElementSibling); - }, +function isArray(x) { + return Boolean(x && typeof x.length !== 'undefined'); +} - not: function (selector) { - if (!selector) { - return this; - } +function noop() {} // Polyfill for Function.prototype.bind - var comparator = getCompareFunction(selector); - return this.filter(function (el) { - return !comparator(el, selector); - }); - }, +function bind(fn, thisArg) { + return function () { + fn.apply(thisArg, arguments); + }; +} +/** + * @constructor + * @param {Function} fn + */ - parent: function () { - var result = []; - this.each(function (item) { - if (item && item.parentNode) { - result.push(item.parentNode); - } - }); +function Promise(fn) { + if (!(this instanceof Promise)) throw new TypeError('Promises must be constructed via new'); + if (typeof fn !== 'function') throw new TypeError('not a function'); + /** @type {!number} */ - return unique(result); - }, + this._state = 0; + /** @type {!boolean} */ - parents: function (selector) { - var last, result = []; + this._handled = false; + /** @type {Promise|undefined} */ - this.each(function (item) { - last = item; + this._value = undefined; + /** @type {!Array} */ - while (last && last.parentNode && last !== doc.body.parentNode) { - last = last.parentNode; + this._deferreds = []; + doResolve(fn, this); +} - if (!selector || (selector && matches(last, selector))) { - result.push(last); - } - } - }); +function handle(self, deferred) { + while (self._state === 3) { + self = self._value; + } - return unique(result); - }, + if (self._state === 0) { + self._deferreds.push(deferred); - prev: function () { - return cash(this[0].previousElementSibling); - }, + return; + } - siblings: function () { - var collection = this.parent().children(), el = this[0]; + self._handled = true; - return collection.filter(function (i) { - return i !== el; - }); + Promise._immediateFn(function () { + var cb = self._state === 1 ? deferred.onFulfilled : deferred.onRejected; + + if (cb === null) { + (self._state === 1 ? resolve : reject)(deferred.promise, self._value); + return; + } + + var ret; + + try { + ret = cb(self._value); + } catch (e) { + reject(deferred.promise, e); + return; } + resolve(deferred.promise, ret); }); +} +function resolve(self, newValue) { + try { + // Promise Resolution Procedure: https://github.com/promises-aplus/promises-spec#the-promise-resolution-procedure + if (newValue === self) throw new TypeError('A promise cannot be resolved with itself.'); - return cash; -}); + if (newValue && (typeof newValue === 'object' || typeof newValue === 'function')) { + var then = newValue.then; -/***/ }), -/* 10 */ -/***/ (function(module, exports, __webpack_require__) { + if (newValue instanceof Promise) { + self._state = 3; + self._value = newValue; + finale(self); + return; + } else if (typeof then === 'function') { + doResolve(bind(then, newValue), self); + return; + } + } -"use strict"; + self._state = 1; + self._value = newValue; + finale(self); + } catch (e) { + reject(self, e); + } +} +function reject(self, newValue) { + self._state = 2; + self._value = newValue; + finale(self); +} -var _underscore = __webpack_require__(1); +function finale(self) { + if (self._state === 2 && self._deferreds.length === 0) { + Promise._immediateFn(function () { + if (!self._handled) { + Promise._unhandledRejectionFn(self._value); + } + }); + } -var Selector = __webpack_require__(7); + for (var i = 0, len = self._deferreds.length; i < len; i++) { + handle(self, self._deferreds[i]); + } -module.exports = __webpack_require__(0).Collection.extend({ - model: Selector, + self._deferreds = null; +} +/** + * @constructor + */ - getStyleable: function getStyleable() { - return (0, _underscore.filter)(this.models, function (item) { - return item.get('active') && !item.get('private'); - }); - }, - getValid: function getValid() { - return (0, _underscore.filter)(this.models, function (item) { - return !item.get('private'); - }); - }, - getFullString: function getFullString(collection) { - var result = []; - var coll = collection || this; - coll.forEach(function (selector) { - return result.push(selector.getFullName()); + +function Handler(onFulfilled, onRejected, promise) { + this.onFulfilled = typeof onFulfilled === 'function' ? onFulfilled : null; + this.onRejected = typeof onRejected === 'function' ? onRejected : null; + this.promise = promise; +} +/** + * Take a potentially misbehaving resolver function and make sure + * onFulfilled and onRejected are only called once. + * + * Makes no guarantees about asynchrony. + */ + + +function doResolve(fn, self) { + var done = false; + + try { + fn(function (value) { + if (done) return; + done = true; + resolve(self, value); + }, function (reason) { + if (done) return; + done = true; + reject(self, reason); }); - return result.join('').trim(); + } catch (ex) { + if (done) return; + done = true; + reject(self, ex); } -}); +} -/***/ }), -/* 11 */ -/***/ (function(module, exports, __webpack_require__) { +Promise.prototype['catch'] = function (onRejected) { + return this.then(null, onRejected); +}; -"use strict"; +Promise.prototype.then = function (onFulfilled, onRejected) { + // @ts-ignore + var prom = new this.constructor(noop); + handle(this, new Handler(onFulfilled, onRejected, prom)); + return prom; +}; +Promise.prototype['finally'] = _finally__WEBPACK_IMPORTED_MODULE_0__["default"]; -var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; +Promise.all = function (arr) { + return new Promise(function (resolve, reject) { + if (!isArray(arr)) { + return reject(new TypeError('Promise.all accepts an array')); + } -var _TypeableCollection = __webpack_require__(32); + var args = Array.prototype.slice.call(arr); + if (args.length === 0) return resolve([]); + var remaining = args.length; -var _TypeableCollection2 = _interopRequireDefault(_TypeableCollection); + function res(i, val) { + try { + if (val && (typeof val === 'object' || typeof val === 'function')) { + var then = val.then; -function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + if (typeof then === 'function') { + then.call(val, function (val) { + res(i, val); + }, reject); + return; + } + } -var Property = __webpack_require__(12); + args[i] = val; -module.exports = __webpack_require__(0).Collection.extend(_TypeableCollection2.default).extend({ - types: [{ - id: 'stack', - model: __webpack_require__(121), - view: __webpack_require__(34), - isType: function isType(value) { - if (value && value.type == 'stack') { - return value; - } - } - }, { - id: 'composite', - model: __webpack_require__(33), - view: __webpack_require__(17), - isType: function isType(value) { - if (value && value.type == 'composite') { - return value; - } - } - }, { - id: 'file', - model: Property, - view: __webpack_require__(40), - isType: function isType(value) { - if (value && value.type == 'file') { - return value; - } - } - }, { - id: 'color', - model: Property, - view: __webpack_require__(38), - isType: function isType(value) { - if (value && value.type == 'color') { - return value; - } - } - }, { - id: 'select', - model: __webpack_require__(41), - view: __webpack_require__(37), - isType: function isType(value) { - if (value && value.type == 'select') { - return value; - } - } - }, { - id: 'radio', - model: __webpack_require__(41), - view: __webpack_require__(36), - isType: function isType(value) { - if (value && value.type == 'radio') { - return value; + if (--remaining === 0) { + resolve(args); + } + } catch (ex) { + reject(ex); } } - }, { - id: 'slider', - model: __webpack_require__(127), - view: __webpack_require__(128), - isType: function isType(value) { - if (value && value.type == 'slider') { - return value; - } + + for (var i = 0; i < args.length; i++) { + res(i, args[i]); } - }, { - id: 'integer', - model: __webpack_require__(42), - view: __webpack_require__(14), - isType: function isType(value) { - if (value && value.type == 'integer') { - return value; - } + }); +}; + +Promise.resolve = function (value) { + if (value && typeof value === 'object' && value.constructor === Promise) { + return value; + } + + return new Promise(function (resolve) { + resolve(value); + }); +}; + +Promise.reject = function (value) { + return new Promise(function (resolve, reject) { + reject(value); + }); +}; + +Promise.race = function (arr) { + return new Promise(function (resolve, reject) { + if (!isArray(arr)) { + return reject(new TypeError('Promise.race accepts an array')); } - }, { - id: 'base', - model: Property, - view: __webpack_require__(5), - isType: function isType(value) { - value.type = 'base'; - return value; + + for (var i = 0, len = arr.length; i < len; i++) { + Promise.resolve(arr[i]).then(resolve, reject); } - }], + }); +}; // Use polyfill for setImmediate for performance gains - deepClone: function deepClone() { - var collection = this.clone(); - collection.reset(collection.map(function (model) { - var cloned = model.clone(); - cloned.typeView = model.typeView; - return cloned; - })); - return collection; - }, +Promise._immediateFn = // @ts-ignore +typeof setImmediate === 'function' && function (fn) { + // @ts-ignore + setImmediate(fn); +} || function (fn) { + setTimeoutFunc(fn, 0); +}; - /** - * Parse a value and return an array splitted by properties - * @param {string} value - * @return {Array} - * @return - */ - parseValue: function parseValue(value) { - var _this = this; +Promise._unhandledRejectionFn = function _unhandledRejectionFn(err) { + if (typeof console !== 'undefined' && console) { + console.warn('Possible Unhandled Promise Rejection:', err); // eslint-disable-line no-console + } +}; - var properties = []; - var values = value.split(' '); - values.forEach(function (value, i) { - var property = _this.at(i); - properties.push(_extends({}, property.attributes, { value: value })); - }); - return properties; - }, - getFullValue: function getFullValue() { - var result = ''; - this.each(function (model) { - return result += model.getFullValue() + ' '; - }); - return result.trim(); - } -}); +/* harmony default export */ __webpack_exports__["default"] = (Promise); +/* WEBPACK VAR INJECTION */}.call(this, __webpack_require__(/*! ./../../timers-browserify/main.js */ "./node_modules/timers-browserify/main.js").setImmediate)) /***/ }), -/* 12 */ + +/***/ "./node_modules/setimmediate/setImmediate.js": +/*!***************************************************!*\ + !*** ./node_modules/setimmediate/setImmediate.js ***! + \***************************************************/ +/*! no static exports found */ /***/ (function(module, exports, __webpack_require__) { -"use strict"; +/* WEBPACK VAR INJECTION */(function(global, process) {(function (global, undefined) { + "use strict"; + if (global.setImmediate) { + return; + } -var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; + var nextHandle = 1; // Spec says greater than zero + var tasksByHandle = {}; + var currentlyRunningATask = false; + var doc = global.document; + var registerImmediate; -module.exports = __webpack_require__(0).Model.extend({ + function setImmediate(callback) { + // Callback can either be a function or a string + if (typeof callback !== "function") { + callback = new Function("" + callback); + } + // Copy function arguments + var args = new Array(arguments.length - 1); + for (var i = 0; i < args.length; i++) { + args[i] = arguments[i + 1]; + } + // Store and register the task + var task = { callback: callback, args: args }; + tasksByHandle[nextHandle] = task; + registerImmediate(nextHandle); + return nextHandle++; + } - defaults: { - name: '', - property: '', - type: '', - defaults: '', - info: '', - value: '', - icon: '', - functionName: '', - status: '', - visible: true, - fixedValues: ['initial', 'inherit'], + function clearImmediate(handle) { + delete tasksByHandle[handle]; + } - // If true, will be hidden by default and will show up only for targets - // which require this property (via `stylable-require`) - // Use case: - // you can add all SVG CSS properties with toRequire as true - // and then require them on SVG Components - toRequire: 0 - }, + function run(task) { + var callback = task.callback; + var args = task.args; + switch (args.length) { + case 0: + callback(); + break; + case 1: + callback(args[0]); + break; + case 2: + callback(args[0], args[1]); + break; + case 3: + callback(args[0], args[1], args[2]); + break; + default: + callback.apply(undefined, args); + break; + } + } - initialize: function initialize(opt) { - var o = opt || {}; - var name = this.get('name'); - var prop = this.get('property'); + function runIfPresent(handle) { + // From the spec: "Wait until any invocations of this algorithm started before this one have completed." + // So if we're currently running a task, we'll need to delay this invocation. + if (currentlyRunningATask) { + // Delay by doing a setTimeout. setImmediate was tried instead, but in Firefox 7 it generated a + // "too much recursion" error. + setTimeout(runIfPresent, 0, handle); + } else { + var task = tasksByHandle[handle]; + if (task) { + currentlyRunningATask = true; + try { + run(task); + } finally { + clearImmediate(handle); + currentlyRunningATask = false; + } + } + } + } - if (!name) { - this.set('name', prop.charAt(0).toUpperCase() + prop.slice(1).replace(/-/g, ' ')); + function installNextTickImplementation() { + registerImmediate = function(handle) { + process.nextTick(function () { runIfPresent(handle); }); + }; } - var init = this.init && this.init.bind(this); - init && init(); - }, + function canUsePostMessage() { + // The test against `importScripts` prevents this implementation from being installed inside a web worker, + // where `global.postMessage` means something completely different and can't be used for this purpose. + if (global.postMessage && !global.importScripts) { + var postMessageIsAsynchronous = true; + var oldOnMessage = global.onmessage; + global.onmessage = function() { + postMessageIsAsynchronous = false; + }; + global.postMessage("", "*"); + global.onmessage = oldOnMessage; + return postMessageIsAsynchronous; + } + } + + function installPostMessageImplementation() { + // Installs an event handler on `global` for the `message` event: see + // * https://developer.mozilla.org/en/DOM/window.postMessage + // * http://www.whatwg.org/specs/web-apps/current-work/multipage/comms.html#crossDocumentMessages + var messagePrefix = "setImmediate$" + Math.random() + "$"; + var onGlobalMessage = function(event) { + if (event.source === global && + typeof event.data === "string" && + event.data.indexOf(messagePrefix) === 0) { + runIfPresent(+event.data.slice(messagePrefix.length)); + } + }; - /** - * Update value - * @param {any} value - * @param {Boolen} [complete=true] Indicates if it's a final state - * @param {Object} [opts={}] Options - */ - setValue: function setValue(value) { - var complete = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1; - var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + if (global.addEventListener) { + global.addEventListener("message", onGlobalMessage, false); + } else { + global.attachEvent("onmessage", onGlobalMessage); + } - var parsed = this.parseValue(value); - this.set(parsed, _extends({}, opts, { avoidStore: 1 })); + registerImmediate = function(handle) { + global.postMessage(messagePrefix + handle, "*"); + }; + } - // It's important to set an empty value, otherwise the - // UndoManager won't see the change - if (complete) { - this.set('value', '', opts); - this.set(parsed, opts); + function installMessageChannelImplementation() { + var channel = new MessageChannel(); + channel.port1.onmessage = function(event) { + var handle = event.data; + runIfPresent(handle); + }; + + registerImmediate = function(handle) { + channel.port2.postMessage(handle); + }; } - }, + function installReadyStateChangeImplementation() { + var html = doc.documentElement; + registerImmediate = function(handle) { + // Create a ' : ''; - return html; - }, +/* harmony default export */ __webpack_exports__["default"] = (function () { + var c = {}; + var devices, view; + return { + /** + * Name of the module + * @type {String} + * @private + */ + name: 'DeviceManager', + /** + * Initialize module. Automatically called with a new instance of the editor + * @param {Object} config Configurations + * @param {Array} [config.devices=[]] Default devices + * @example + * ... + * { + * devices: [ + * {name: 'Desktop', width: ''} + * {name: 'Tablet', width: '991px'} + * ], + * } + * ... + * @return {this} + * @private + */ + init: function init(config) { + c = config || {}; - /** - * Returns CSS built inside canvas - * @param {Object} [opts={}] Options - * @return {string} CSS string - * @private - */ - getCss: function getCss() { - var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + for (var name in _config_config__WEBPACK_IMPORTED_MODULE_0__["default"]) { + if (!(name in c)) c[name] = _config_config__WEBPACK_IMPORTED_MODULE_0__["default"][name]; + } - var config = this.config; - var wrappesIsBody = config.wrappesIsBody; - var avoidProt = opts.avoidProtected; - var cssc = this.get('CssComposer'); - var wrp = this.get('DomComponents').getComponent(); - var protCss = !avoidProt ? config.protectedCss : ''; + devices = new _model_Devices__WEBPACK_IMPORTED_MODULE_1__["default"](c.devices); + view = new _view_DevicesView__WEBPACK_IMPORTED_MODULE_2__["default"]({ + collection: devices, + config: c + }); + return this; + }, - return protCss + this.get('CodeManager').getCode(wrp, 'css', { - cssc: cssc, wrappesIsBody: wrappesIsBody - }); - }, + /** + * Add new device to the collection. URLs are supposed to be unique + * @param {string} name Device name + * @param {string} width Width of the device + * @param {Object} opts Custom options + * @return {Device} Added device + * @example + * deviceManager.add('Tablet', '900px'); + * deviceManager.add('Tablet2', '900px', { + * height: '300px', + * widthMedia: '810px', // the width that will be used for the CSS media + * }); + */ + add: function add(name, width, opts) { + var obj = opts || {}; + obj.name = name; + obj.width = width; + return devices.add(obj); + }, + + /** + * Return device by name + * @param {string} name Name of the device + * @example + * var device = deviceManager.get('Tablet'); + * console.log(JSON.stringify(device)); + * // {name: 'Tablet', width: '900px'} + */ + get: function get(name) { + return devices.get(name); + }, + /** + * Return all devices + * @return {Collection} + * @example + * var devices = deviceManager.getAll(); + * console.log(JSON.stringify(devices)); + * // [{name: 'Desktop', width: ''}, ...] + */ + getAll: function getAll() { + return devices; + }, - /** - * Returns JS of all components - * @return {string} JS string - * @private - */ - getJs: function getJs() { - var wrp = this.get('DomComponents').getWrapper(); - return this.get('CodeManager').getCode(wrp, 'js').trim(); - }, + /** + * Render devices + * @return {string} HTML string + * @private + */ + render: function render() { + return view.render().el; + } + }; +}); +/***/ }), - /** - * Store data to the current storage - * @param {Function} clb Callback function - * @return {Object} Stored data - * @private - */ - store: function store(clb) { - var _this4 = this; +/***/ "./src/device_manager/model/Device.js": +/*!********************************************!*\ + !*** ./src/device_manager/model/Device.js ***! + \********************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - var sm = this.get('StorageManager'); - var store = {}; - if (!sm) return; +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); - // Fetch what to store - this.get('storables').forEach(function (m) { - var obj = m.store(1); - for (var el in obj) { - store[el] = obj[el]; - } - }); +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_0___default.a.Model.extend({ + idAttribute: 'name', + defaults: { + name: '', + // Width to set for the editor iframe + width: null, + // Height to set for the editor iframe + height: '', + // The width which will be used in media queries, + // If empty the width will be used + widthMedia: null, + // Setup the order of media queries + priority: null + }, + initialize: function initialize() { + var _this = this; - sm.store(store, function () { - clb && clb(); - _this4.set('changesCount', 0); - _this4.trigger('storage:store', store); + this.get('widthMedia') === null && this.set('widthMedia', this.get('width')); + this.get('width') === null && this.set('width', this.get('widthMedia')); + !this.get('priority') && this.set('priority', parseFloat(this.get('widthMedia')) || 0); + var toCheck = ['width', 'height', 'widthMedia']; + toCheck.forEach(function (prop) { + return _this.checkUnit(prop); }); - - return store; }, + checkUnit: function checkUnit(prop) { + var pr = this.get(prop) || ''; + var noUnit = (parseFloat(pr) || 0).toString() === pr.toString(); + noUnit && this.set(prop, "".concat(pr, "px")); + } +})); +/***/ }), - /** - * Load data from the current storage - * @param {Function} clb Callback function - * @private - */ - load: function load() { - var _this5 = this; +/***/ "./src/device_manager/model/Devices.js": +/*!*********************************************!*\ + !*** ./src/device_manager/model/Devices.js ***! + \*********************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - var clb = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null; +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _Device__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Device */ "./src/device_manager/model/Device.js"); - this.getCacheLoad(1, function (res) { - _this5.get('storables').forEach(function (module) { - return module.load(res); - }); - clb && clb(res); - }); - }, +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_0___default.a.Collection.extend({ + model: _Device__WEBPACK_IMPORTED_MODULE_1__["default"], + comparator: function comparator(left, right) { + var max = Number.MAX_VALUE; + return (right.get('priority') || max) - (left.get('priority') || max); + }, + getSorted: function getSorted() { + return this.sort(); + } +})); - /** - * Returns cached load - * @param {Boolean} force Force to reload - * @param {Function} clb Callback function - * @return {Object} - * @private - */ - getCacheLoad: function getCacheLoad(force, clb) { - var _this6 = this; +/***/ }), - var f = force ? 1 : 0; - if (this.cacheLoad && !f) return this.cacheLoad; - var sm = this.get('StorageManager'); - var load = []; +/***/ "./src/device_manager/view/DevicesView.js": +/*!************************************************!*\ + !*** ./src/device_manager/view/DevicesView.js ***! + \************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - if (!sm) return {}; +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_1__); - this.get('storables').forEach(function (m) { - var key = m.storageKey; - key = typeof key === 'function' ? key() : key; - var keys = key instanceof Array ? key : [key]; - keys.forEach(function (k) { - load.push(k); - }); - }); - sm.load(load, function (res) { - _this6.cacheLoad = res; - clb && clb(res); - _this6.trigger('storage:load', res); - }); +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_1___default.a.View.extend({ + template: Object(underscore__WEBPACK_IMPORTED_MODULE_0__["template"])("\n
device-label\"><%= deviceLabel %>
\n
field <%= ppfx %>select\">\n input-holder\">\n \n \n
sel-arrow\">\n
d-s-arrow\">
\n
\n
\n "), + events: { + change: 'updateDevice' + }, + initialize: function initialize(o) { + this.config = o.config || {}; + this.em = this.config.em; + this.ppfx = this.config.pStylePrefix || ''; + this.events['click .' + this.ppfx + 'add-trasp'] = this.startAdd; + this.listenTo(this.em, 'change:device', this.updateSelect); + this.delegateEvents(); }, - /** - * Returns device model by name - * @return {Device|null} + * Start adding new device + * @return {[type]} [description] * @private */ - getDeviceModel: function getDeviceModel() { - var name = this.get('device'); - return this.get('DeviceManager').get(name); - }, - + startAdd: function startAdd() {}, /** - * Run default command if setted - * @param {Object} [opts={}] Options + * Update device of the editor * @private */ - runDefault: function runDefault() { - var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + updateDevice: function updateDevice() { + var em = this.em; - var command = this.get('Commands').get(this.config.defaultCommand); - if (!command || this.defaultRunning) return; - command.stop(this, this, opts); - command.run(this, this, opts); - this.defaultRunning = 1; + if (em) { + var devEl = this.devicesEl; + var val = devEl ? devEl.val() : ''; + em.set('device', val); + } }, - /** - * Stop default command - * @param {Object} [opts={}] Options + * Update select value on device update * @private */ - stopDefault: function stopDefault() { - var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + updateSelect: function updateSelect() { + var em = this.em; + var devEl = this.devicesEl; - var command = this.get('Commands').get(this.config.defaultCommand); - if (!command) return; - command.stop(this, this, opts); - this.defaultRunning = 0; + if (em && em.getDeviceModel && devEl) { + var device = em.getDeviceModel(); + var name = device ? device.get('name') : ''; + devEl.val(name); + } }, - /** - * Update canvas dimensions and refresh data useful for tools positioning + * Return devices options + * @return {string} String of options * @private */ - refreshCanvas: function refreshCanvas() { - this.set('canvasOffset', this.get('Canvas').getOffset()); + getOptions: function getOptions() { + var result = ''; + this.collection.each(function (device) { + var name = device.get('name'); + result += ''; + }); + return result; }, + render: function render() { + var pfx = this.ppfx; + this.$el.html(this.template({ + ppfx: pfx, + deviceLabel: this.config.deviceLabel + })); + this.devicesEl = this.$el.find('.' + pfx + 'devices'); + this.devicesEl.append(this.getOptions()); + this.el.className = pfx + 'devices-c'; + return this; + } +})); + +/***/ }), + +/***/ "./src/dom_components/config/config.js": +/*!*********************************************!*\ + !*** ./src/dom_components/config/config.js ***! + \*********************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony default export */ __webpack_exports__["default"] = ({ + stylePrefix: 'comp-', + wrapperId: 'wrapper', + wrapperName: 'Body', + // Default wrapper configuration + wrapper: { + removable: false, + copyable: false, + draggable: false, + components: [], + traits: [], + stylable: ['background', 'background-color', 'background-image', 'background-repeat', 'background-attachment', 'background-position', 'background-size'] + }, + // Could be used for default components + components: [], + // If the component is draggable you can drag the component itself (not only from the toolbar) + draggableComponents: 1, + // Generally, if you don't edit the wrapper in the editor, like + // custom attributes, you don't need the wrapper stored in your JSON + // structure, but in case you need it you can use this option. + // If you have `config.avoidInlineStyle` disabled the wrapper will be stored + // as we need to store inlined style. + storeWrapper: 0, /** - * Clear all selected stuf inside the window, sometimes is useful to call before - * doing some dragging opearation - * @param {Window} win If not passed the current one will be used - * @private + * You can setup a custom component definiton processor before adding it into the editor. + * It might be useful to transform custom objects (es. some framework specific JSX) to GrapesJS component one. + * This custom function will be executed on ANY new added component to the editor so make smart checks/conditions + * to avoid doing useless executions + * By default, GrapesJS supports already elements generated from React JSX preset + * @example + * processor: (obj) => { + * if (obj.$$typeof) { // eg. this is a React Element + * const gjsComponent = { + * type: obj.type, + * components: obj.props.children, + * ... + * }; + * ... + * return gjsComponent; + * } + * } */ - clearSelection: function clearSelection(win) { - var w = win || window; - w.getSelection().removeAllRanges(); - }, - - - /** - * Get the current media text - * @return {string} - */ - getCurrentMedia: function getCurrentMedia() { - var config = this.config; - var device = this.getDeviceModel(); - var condition = config.mediaCondition; - var preview = config.devicePreviewMode; - var width = device && device.get('widthMedia'); - return device && width && !preview ? '(' + condition + ': ' + width + ')' : ''; - }, - - - /** - * Set/get data from the HTMLElement - * @param {HTMLElement} el - * @param {string} name Data name - * @param {any} value Date value - * @return {any} - * @private - */ - data: function data(el, name, value) { - var varName = '_gjs-data'; - - if (!el[varName]) { - el[varName] = {}; - } - - if ((0, _underscore.isUndefined)(value)) { - return el[varName][name]; - } else { - el[varName][name] = value; - } - } + processor: 0, + // List of void elements + voidElements: ['area', 'base', 'br', 'col', 'embed', 'hr', 'img', 'input', 'keygen', 'link', 'menuitem', 'meta', 'param', 'source', 'track', 'wbr'] }); /***/ }), -/* 65 */ -/***/ (function(module, exports, __webpack_require__) { -"use strict"; +/***/ "./src/dom_components/index.js": +/*!*************************************!*\ + !*** ./src/dom_components/index.js ***! + \*************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/typeof */ "./node_modules/@babel/runtime/helpers/typeof.js"); +/* harmony import */ var _babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_2__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_3__); +/* harmony import */ var _config_config__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./config/config */ "./src/dom_components/config/config.js"); +/* harmony import */ var _model_Component__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./model/Component */ "./src/dom_components/model/Component.js"); +/* harmony import */ var _model_Components__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./model/Components */ "./src/dom_components/model/Components.js"); +/* harmony import */ var _view_ComponentView__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./view/ComponentView */ "./src/dom_components/view/ComponentView.js"); +/* harmony import */ var _view_ComponentsView__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./view/ComponentsView */ "./src/dom_components/view/ComponentsView.js"); +/* harmony import */ var _model_ComponentTableCell__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./model/ComponentTableCell */ "./src/dom_components/model/ComponentTableCell.js"); +/* harmony import */ var _view_ComponentTableCellView__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./view/ComponentTableCellView */ "./src/dom_components/view/ComponentTableCellView.js"); +/* harmony import */ var _model_ComponentTableRow__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./model/ComponentTableRow */ "./src/dom_components/model/ComponentTableRow.js"); +/* harmony import */ var _view_ComponentTableRowView__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ./view/ComponentTableRowView */ "./src/dom_components/view/ComponentTableRowView.js"); +/* harmony import */ var _model_ComponentTable__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! ./model/ComponentTable */ "./src/dom_components/model/ComponentTable.js"); +/* harmony import */ var _view_ComponentTableView__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(/*! ./view/ComponentTableView */ "./src/dom_components/view/ComponentTableView.js"); +/* harmony import */ var _model_ComponentTableHead__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(/*! ./model/ComponentTableHead */ "./src/dom_components/model/ComponentTableHead.js"); +/* harmony import */ var _view_ComponentTableHeadView__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(/*! ./view/ComponentTableHeadView */ "./src/dom_components/view/ComponentTableHeadView.js"); +/* harmony import */ var _model_ComponentTableBody__WEBPACK_IMPORTED_MODULE_17__ = __webpack_require__(/*! ./model/ComponentTableBody */ "./src/dom_components/model/ComponentTableBody.js"); +/* harmony import */ var _view_ComponentTableBodyView__WEBPACK_IMPORTED_MODULE_18__ = __webpack_require__(/*! ./view/ComponentTableBodyView */ "./src/dom_components/view/ComponentTableBodyView.js"); +/* harmony import */ var _model_ComponentTableFoot__WEBPACK_IMPORTED_MODULE_19__ = __webpack_require__(/*! ./model/ComponentTableFoot */ "./src/dom_components/model/ComponentTableFoot.js"); +/* harmony import */ var _view_ComponentTableFootView__WEBPACK_IMPORTED_MODULE_20__ = __webpack_require__(/*! ./view/ComponentTableFootView */ "./src/dom_components/view/ComponentTableFootView.js"); +/* harmony import */ var _model_ComponentMap__WEBPACK_IMPORTED_MODULE_21__ = __webpack_require__(/*! ./model/ComponentMap */ "./src/dom_components/model/ComponentMap.js"); +/* harmony import */ var _view_ComponentMapView__WEBPACK_IMPORTED_MODULE_22__ = __webpack_require__(/*! ./view/ComponentMapView */ "./src/dom_components/view/ComponentMapView.js"); +/* harmony import */ var _model_ComponentLink__WEBPACK_IMPORTED_MODULE_23__ = __webpack_require__(/*! ./model/ComponentLink */ "./src/dom_components/model/ComponentLink.js"); +/* harmony import */ var _view_ComponentLinkView__WEBPACK_IMPORTED_MODULE_24__ = __webpack_require__(/*! ./view/ComponentLinkView */ "./src/dom_components/view/ComponentLinkView.js"); +/* harmony import */ var _model_ComponentLabel__WEBPACK_IMPORTED_MODULE_25__ = __webpack_require__(/*! ./model/ComponentLabel */ "./src/dom_components/model/ComponentLabel.js"); +/* harmony import */ var _view_ComponentLabelView__WEBPACK_IMPORTED_MODULE_26__ = __webpack_require__(/*! ./view/ComponentLabelView */ "./src/dom_components/view/ComponentLabelView.js"); +/* harmony import */ var _model_ComponentVideo__WEBPACK_IMPORTED_MODULE_27__ = __webpack_require__(/*! ./model/ComponentVideo */ "./src/dom_components/model/ComponentVideo.js"); +/* harmony import */ var _view_ComponentVideoView__WEBPACK_IMPORTED_MODULE_28__ = __webpack_require__(/*! ./view/ComponentVideoView */ "./src/dom_components/view/ComponentVideoView.js"); +/* harmony import */ var _model_ComponentImage__WEBPACK_IMPORTED_MODULE_29__ = __webpack_require__(/*! ./model/ComponentImage */ "./src/dom_components/model/ComponentImage.js"); +/* harmony import */ var _view_ComponentImageView__WEBPACK_IMPORTED_MODULE_30__ = __webpack_require__(/*! ./view/ComponentImageView */ "./src/dom_components/view/ComponentImageView.js"); +/* harmony import */ var _model_ComponentScript__WEBPACK_IMPORTED_MODULE_31__ = __webpack_require__(/*! ./model/ComponentScript */ "./src/dom_components/model/ComponentScript.js"); +/* harmony import */ var _view_ComponentScriptView__WEBPACK_IMPORTED_MODULE_32__ = __webpack_require__(/*! ./view/ComponentScriptView */ "./src/dom_components/view/ComponentScriptView.js"); +/* harmony import */ var _model_ComponentSvg__WEBPACK_IMPORTED_MODULE_33__ = __webpack_require__(/*! ./model/ComponentSvg */ "./src/dom_components/model/ComponentSvg.js"); +/* harmony import */ var _view_ComponentSvgView__WEBPACK_IMPORTED_MODULE_34__ = __webpack_require__(/*! ./view/ComponentSvgView */ "./src/dom_components/view/ComponentSvgView.js"); +/* harmony import */ var _model_ComponentComment__WEBPACK_IMPORTED_MODULE_35__ = __webpack_require__(/*! ./model/ComponentComment */ "./src/dom_components/model/ComponentComment.js"); +/* harmony import */ var _view_ComponentCommentView__WEBPACK_IMPORTED_MODULE_36__ = __webpack_require__(/*! ./view/ComponentCommentView */ "./src/dom_components/view/ComponentCommentView.js"); +/* harmony import */ var _model_ComponentTextNode__WEBPACK_IMPORTED_MODULE_37__ = __webpack_require__(/*! ./model/ComponentTextNode */ "./src/dom_components/model/ComponentTextNode.js"); +/* harmony import */ var _view_ComponentTextNodeView__WEBPACK_IMPORTED_MODULE_38__ = __webpack_require__(/*! ./view/ComponentTextNodeView */ "./src/dom_components/view/ComponentTextNodeView.js"); +/* harmony import */ var _model_ComponentText__WEBPACK_IMPORTED_MODULE_39__ = __webpack_require__(/*! ./model/ComponentText */ "./src/dom_components/model/ComponentText.js"); +/* harmony import */ var _view_ComponentTextView__WEBPACK_IMPORTED_MODULE_40__ = __webpack_require__(/*! ./view/ComponentTextView */ "./src/dom_components/view/ComponentTextView.js"); +/* harmony import */ var _model_ComponentWrapper__WEBPACK_IMPORTED_MODULE_41__ = __webpack_require__(/*! ./model/ComponentWrapper */ "./src/dom_components/model/ComponentWrapper.js"); + + + +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } + +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } -module.exports = function () { +/** + * With this module is possible to manage components inside the canvas. You can customize the initial state of the module from the editor initialization, by passing the following [Configuration Object](https://github.com/artf/grapesjs/blob/master/src/dom_components/config/config.js) + * ```js + * const editor = grapesjs.init({ + * domComponents: { + * // options + * } + * }) + * ``` + * + * Once the editor is instantiated you can use its API. Before using these methods you should get the module from the instance + * + * ```js + * const domComponents = editor.DomComponents; + * ``` + * + * * [getWrapper](#getwrapper) + * * [getComponents](#getcomponents) + * * [addComponent](#addcomponent) + * * [clear](#clear) + * * [load](#load) + * * [store](#store) + * * [addType](#addtype) + * * [getType](#gettype) + * * [getTypes](#gettypes) + * * [render](#render) + * + * @module DomComponents + */ - var Sorter = __webpack_require__(66); - var Resizer = __webpack_require__(67); - var Dragger = __webpack_require__(68); - return { - /** - * Name of the module - * @type {String} - * @private - */ - name: 'Utils', - /** - * Initialize module - */ - init: function init() { - return this; - }, - Sorter: Sorter, - Resizer: Resizer, - Dragger: Dragger - }; -}; -/***/ }), -/* 66 */ -/***/ (function(module, exports, __webpack_require__) { -"use strict"; -/* WEBPACK VAR INJECTION */(function(Backbone, _) { -var _underscore = __webpack_require__(1); -var _mixins = __webpack_require__(2); -var $ = Backbone.$; -module.exports = Backbone.View.extend({ - initialize: function initialize(opt) { - this.opt = opt || {}; - _.bindAll(this, 'startSort', 'onMove', 'endMove', 'rollback', 'udpateOffset', 'moveDragHelper'); - var o = opt || {}; - this.elT = 0; - this.elL = 0; - this.borderOffset = o.borderOffset || 10; - var el = o.container; - this.el = typeof el === 'string' ? document.querySelector(el) : el; - this.$el = $(this.el); - this.containerSel = o.containerSel || 'div'; - this.itemSel = o.itemSel || 'div'; - this.draggable = o.draggable || true; - this.nested = o.nested || 0; - this.pfx = o.pfx || ''; - this.ppfx = o.ppfx || ''; - this.freezeClass = o.freezeClass || this.pfx + 'freezed'; - this.onStart = o.onStart || ''; - this.onEndMove = o.onEndMove || ''; - this.direction = o.direction || 'v'; // v (vertical), h (horizontal), a (auto) - this.onMoveClb = o.onMove || ''; - this.relative = o.relative || 0; - this.ignoreViewChildren = o.ignoreViewChildren || 0; - this.ignoreModels = o.ignoreModels || 0; - this.plh = o.placer || ''; - // Frame offset - this.wmargin = o.wmargin || 0; - this.offTop = o.offsetTop || 0; - this.offLeft = o.offsetLeft || 0; - this.document = o.document || document; - this.$document = $(this.document); - this.dropContent = null; - this.em = o.em || ''; - this.dragHelper = null; - this.canvasRelative = o.canvasRelative || 0; - this.selectOnEnd = !o.avoidSelectOnEnd; - if (this.em && this.em.on) { - this.em.on('change:canvasOffset', this.udpateOffset); - this.udpateOffset(); - } - }, - getContainerEl: function getContainerEl() { - if (!this.el) { - var el = this.opt.container; - this.el = typeof el === 'string' ? document.querySelector(el) : el; - this.$el = $(this.el); - } - return this.el; - }, - getDocuments: function getDocuments() { - var em = this.em; - var canvasDoc = em && em.get('Canvas').getBody().ownerDocument; - var docs = [document]; - canvasDoc && docs.push(canvasDoc); - return docs; - }, - /** - * Triggered when the offset of the editro is changed - */ - udpateOffset: function udpateOffset() { - var offset = this.em.get('canvasOffset'); - this.offTop = offset.top; - this.offLeft = offset.left; - }, - /** - * Set content to drop - * @param {String|Object} content - */ - setDropContent: function setDropContent(content) { - this.dropContent = content; - }, - /** - * Toggle cursor while sorting - * @param {Boolean} active - */ - toggleSortCursor: function toggleSortCursor(active) { - var em = this.em; - var body = document.body; - var pfx = this.ppfx || this.pfx; - var sortCls = pfx + 'grabbing'; - var emBody = em ? em.get('Canvas').getBody() : ''; - // Avoid updating body className as it causes a huge repaint - // Noticeable with "fast" drag of blocks - if (active) { - em && em.get('Canvas').startAutoscroll(); - //body.className += ' ' + sortCls; - //if (em) emBody.className += ' ' + sortCls; - } else { - em && em.get('Canvas').stopAutoscroll(); - //body.className = body.className.replace(sortCls, '').trim(); - //if(em) emBody.className = emBody.className.replace(sortCls, '').trim(); - } - }, - /** - * Set drag helper - * @param {HTMLElement} el - * @param {Event} event - */ - setDragHelper: function setDragHelper(el, event) { - var ev = event || ''; - var clonedEl = el.cloneNode(1); - var rect = el.getBoundingClientRect(); - var computed = getComputedStyle(el); - var style = ''; - for (var i = 0; i < computed.length; i++) { - var prop = computed[i]; - style += prop + ':' + computed.getPropertyValue(prop) + ';'; - } - document.body.appendChild(clonedEl); - clonedEl.className += ' ' + this.pfx + 'bdrag'; - clonedEl.setAttribute('style', style); - this.dragHelper = clonedEl; - clonedEl.style.width = rect.width + 'px'; - clonedEl.style.height = rect.height + 'px'; - ev && this.moveDragHelper(ev); - // Listen mouse move events - if (this.em) { - $(this.em.get('Canvas').getBody().ownerDocument).off('mousemove', this.moveDragHelper).on('mousemove', this.moveDragHelper); - } - $(document).off('mousemove', this.moveDragHelper).on('mousemove', this.moveDragHelper); - }, - /** - * Update the position of the helper - * @param {Event} e - */ - moveDragHelper: function moveDragHelper(e) { - var doc = e.target.ownerDocument; - if (!this.dragHelper || !doc) { - return; - } - var posY = e.pageY; - var posX = e.pageX; - var addTop = 0; - var addLeft = 0; - var window = doc.defaultView || doc.parentWindow; - var frame = window.frameElement; - var dragHelperStyle = this.dragHelper.style; - // If frame is present that means mouse has moved over the editor's canvas, - // which is rendered inside the iframe and the mouse move event comes from - // the iframe, not the parent window. Mouse position relative to the frame's - // parent window needs to account for the frame's position relative to the - // parent window. - if (frame) { - var frameRect = frame.getBoundingClientRect(); - addTop = frameRect.top + document.documentElement.scrollTop; - addLeft = frameRect.left + document.documentElement.scrollLeft; - posY = e.clientY; - posX = e.clientX; - } - dragHelperStyle.top = posY + addTop + 'px'; - dragHelperStyle.left = posX + addLeft + 'px'; - }, - /** - * Returns true if the element matches with selector - * @param {Element} el - * @param {String} selector - * @return {Boolean} - */ - matches: function matches(el, selector, useBody) { - return _mixins.matches.call(el, selector); - }, - /** - * Closest parent - * @param {Element} el - * @param {String} selector - * @return {Element|null} - */ - closest: function closest(el, selector) { - if (!el) return; - var elem = el.parentNode; - while (elem && elem.nodeType === 1) { - if (this.matches(elem, selector)) return elem; - elem = elem.parentNode; - } - return null; - }, - /** - * Get the offset of the element - * @param {HTMLElement} el - * @return {Object} - */ - offset: function offset(el) { - var rect = el.getBoundingClientRect(); - return { - top: rect.top + document.body.scrollTop, - left: rect.left + document.body.scrollLeft - }; - }, - /** - * Create placeholder - * @return {HTMLElement} - */ - createPlaceholder: function createPlaceholder() { - var pfx = this.pfx; - var el = document.createElement('div'); - var ins = document.createElement('div'); - el.className = pfx + 'placeholder'; - el.style.display = 'none'; - el.style['pointer-events'] = 'none'; - ins.className = pfx + "placeholder-int"; - el.appendChild(ins); - return el; - }, - - - /** - * Picking component to move - * @param {HTMLElement} src - * */ - startSort: function startSort(src) { - var em = this.em; - var itemSel = this.itemSel; - var contSel = this.containerSel; - var container = this.getContainerEl(); - var docs = this.getDocuments(); - var onStart = this.onStart; - var srcModel = void 0; - var plh = this.plh; - this.dropModel = null; - this.moved = 0; - - // Check if the start element is a valid one, if not get the - // closest valid one - if (src && !this.matches(src, itemSel + ', ' + contSel)) { - src = this.closest(src, itemSel); - } - - this.eV = src; - - // Create placeholder if not yet exists - if (!plh) { - plh = this.createPlaceholder(); - container.appendChild(plh); - this.plh = plh; - } - - if (src) { - srcModel = this.getSourceModel(src); - srcModel && srcModel.set && srcModel.set('status', 'freezed'); - } - - (0, _mixins.on)(container, 'mousemove', this.onMove); - (0, _mixins.on)(docs, 'mouseup', this.endMove); - (0, _mixins.on)(docs, 'keydown', this.rollback); - onStart && onStart(); +/* harmony default export */ __webpack_exports__["default"] = (function () { + var c = {}; + var em; + var componentsById = {}; + var component, componentView; + var componentTypes = [{ + id: 'cell', + model: _model_ComponentTableCell__WEBPACK_IMPORTED_MODULE_9__["default"], + view: _view_ComponentTableCellView__WEBPACK_IMPORTED_MODULE_10__["default"] + }, { + id: 'row', + model: _model_ComponentTableRow__WEBPACK_IMPORTED_MODULE_11__["default"], + view: _view_ComponentTableRowView__WEBPACK_IMPORTED_MODULE_12__["default"] + }, { + id: 'table', + model: _model_ComponentTable__WEBPACK_IMPORTED_MODULE_13__["default"], + view: _view_ComponentTableView__WEBPACK_IMPORTED_MODULE_14__["default"] + }, { + id: 'thead', + model: _model_ComponentTableHead__WEBPACK_IMPORTED_MODULE_15__["default"], + view: _view_ComponentTableHeadView__WEBPACK_IMPORTED_MODULE_16__["default"] + }, { + id: 'tbody', + model: _model_ComponentTableBody__WEBPACK_IMPORTED_MODULE_17__["default"], + view: _view_ComponentTableBodyView__WEBPACK_IMPORTED_MODULE_18__["default"] + }, { + id: 'tfoot', + model: _model_ComponentTableFoot__WEBPACK_IMPORTED_MODULE_19__["default"], + view: _view_ComponentTableFootView__WEBPACK_IMPORTED_MODULE_20__["default"] + }, { + id: 'map', + model: _model_ComponentMap__WEBPACK_IMPORTED_MODULE_21__["default"], + view: _view_ComponentMapView__WEBPACK_IMPORTED_MODULE_22__["default"] + }, { + id: 'link', + model: _model_ComponentLink__WEBPACK_IMPORTED_MODULE_23__["default"], + view: _view_ComponentLinkView__WEBPACK_IMPORTED_MODULE_24__["default"] + }, { + id: 'label', + model: _model_ComponentLabel__WEBPACK_IMPORTED_MODULE_25__["default"], + view: _view_ComponentLabelView__WEBPACK_IMPORTED_MODULE_26__["default"] + }, { + id: 'video', + model: _model_ComponentVideo__WEBPACK_IMPORTED_MODULE_27__["default"], + view: _view_ComponentVideoView__WEBPACK_IMPORTED_MODULE_28__["default"] + }, { + id: 'image', + model: _model_ComponentImage__WEBPACK_IMPORTED_MODULE_29__["default"], + view: _view_ComponentImageView__WEBPACK_IMPORTED_MODULE_30__["default"] + }, { + id: 'script', + model: _model_ComponentScript__WEBPACK_IMPORTED_MODULE_31__["default"], + view: _view_ComponentScriptView__WEBPACK_IMPORTED_MODULE_32__["default"] + }, { + id: 'svg', + model: _model_ComponentSvg__WEBPACK_IMPORTED_MODULE_33__["default"], + view: _view_ComponentSvgView__WEBPACK_IMPORTED_MODULE_34__["default"] + }, { + id: 'comment', + model: _model_ComponentComment__WEBPACK_IMPORTED_MODULE_35__["default"], + view: _view_ComponentCommentView__WEBPACK_IMPORTED_MODULE_36__["default"] + }, { + id: 'textnode', + model: _model_ComponentTextNode__WEBPACK_IMPORTED_MODULE_37__["default"], + view: _view_ComponentTextNodeView__WEBPACK_IMPORTED_MODULE_38__["default"] + }, { + id: 'text', + model: _model_ComponentText__WEBPACK_IMPORTED_MODULE_39__["default"], + view: _view_ComponentTextView__WEBPACK_IMPORTED_MODULE_40__["default"] + }, { + id: 'wrapper', + model: _model_ComponentWrapper__WEBPACK_IMPORTED_MODULE_41__["default"], + view: _view_ComponentView__WEBPACK_IMPORTED_MODULE_7__["default"] + }, { + id: 'default', + model: _model_Component__WEBPACK_IMPORTED_MODULE_5__["default"], + view: _view_ComponentView__WEBPACK_IMPORTED_MODULE_7__["default"] + }]; + return { + Component: _model_Component__WEBPACK_IMPORTED_MODULE_5__["default"], + Components: _model_Components__WEBPACK_IMPORTED_MODULE_6__["default"], + ComponentsView: _view_ComponentsView__WEBPACK_IMPORTED_MODULE_8__["default"], + componentTypes: componentTypes, + componentsById: componentsById, - // Avoid strange effects on dragging - em && em.clearSelection(); - this.toggleSortCursor(1); + /** + * Name of the module + * @type {String} + * @private + */ + name: 'DomComponents', - em && em.trigger('sorter:drag:start', src, srcModel); - }, + /** + * Returns config + * @return {Object} Config object + * @private + */ + getConfig: function getConfig() { + return c; + }, + /** + * Mandatory for the storage manager + * @type {String} + * @private + */ + storageKey: function storageKey() { + var keys = []; + var smc = c.stm && c.stm.getConfig() || {}; + if (smc.storeHtml) keys.push('html'); + if (smc.storeComponents) keys.push('components'); + return keys; + }, - /** - * Get the model from HTMLElement target - * @return {Model|null} - */ - getTargetModel: function getTargetModel(el) { - var elem = el || this.target; - return $(elem).data('model'); - }, + /** + * Initialize module. Called on a new instance of the editor with configurations passed + * inside 'domComponents' field + * @param {Object} config Configurations + * @private + */ + init: function init(config) { + var _this = this; + c = config || {}; + em = c.em; + this.em = em; - /** - * Get the model of the current source element (element to drag) - * @return {Model} - */ - getSourceModel: function getSourceModel(source) { - var src = source || this.eV; - var dropContent = this.dropContent; - var dropModel = this.dropModel; - var em = this.em; + if (em) { + c.components = em.config.components || c.components; + } - if (dropContent && em) { - if (!dropModel) { - var comps = em.get('DomComponents').getComponents(); - var tempModel = comps.add(dropContent, { avoidUpdateStyle: 1, temporary: 1 }); - dropModel = comps.remove(tempModel, { temporary: 1 }); - this.dropModel = dropModel instanceof Array ? dropModel[0] : dropModel; + for (var name in _config_config__WEBPACK_IMPORTED_MODULE_4__["default"]) { + if (!(name in c)) c[name] = _config_config__WEBPACK_IMPORTED_MODULE_4__["default"][name]; } - return dropModel; - } - if (src) { - return $(src).data('model'); - } - }, + var ppfx = c.pStylePrefix; + if (ppfx) c.stylePrefix = ppfx + c.stylePrefix; // Load dependencies + if (em) { + c.modal = em.get('Modal') || ''; + c.am = em.get('AssetManager') || ''; + em.get('Parser').compTypes = componentTypes; + em.on('change:componentHovered', this.componentHovered, this); + var selected = em.get('selected'); + em.listenTo(selected, 'add', function (sel, c, opts) { + return _this.selectAdd(sel, opts); + }); + em.listenTo(selected, 'remove', function (sel, c, opts) { + return _this.selectRemove(sel, opts); + }); + } // Build wrapper - /** - * Highlight target - * @param {Model|null} model - */ - selectTargetModel: function selectTargetModel(model) { - if (model instanceof Backbone.Collection) { - return; - } - var prevModel = this.targetModel; - if (prevModel) { - prevModel.set('status', ''); - } + var components = c.components; - if (model && model.set) { - model.set('status', 'selected-parent'); - this.targetModel = model; - } - }, + var wrapper = _objectSpread({}, c.wrapper); + wrapper['custom-name'] = c.wrapperName; + wrapper.wrapper = 1; + wrapper.type = 'wrapper'; // Components might be a wrapper - /** - * During move - * @param {Event} e - * */ - onMove: function onMove(e) { - var em = this.em; - this.moved = 1; + if (components && components.constructor === Object && components.wrapper) { + wrapper = _objectSpread({}, components); + components = components.components || []; + wrapper.components = []; // Have to put back the real object of components - // Turn placeholder visibile - var plh = this.plh; - var dsp = plh.style.display; - if (!dsp || dsp === 'none') plh.style.display = 'block'; + if (em) { + em.config.components = components; + c.components = components; + } + } - // Cache all necessary positions - var eO = this.offset(this.el); - this.elT = this.wmargin ? Math.abs(eO.top) : eO.top; - this.elL = this.wmargin ? Math.abs(eO.left) : eO.left; - var rY = e.pageY - this.elT + this.el.scrollTop; - var rX = e.pageX - this.elL + this.el.scrollLeft; + component = new _model_Component__WEBPACK_IMPORTED_MODULE_5__["default"](wrapper, { + em: em, + config: c, + componentTypes: componentTypes, + domc: this + }); + component.set({ + attributes: { + id: 'wrapper' + } + }); + componentView = new _view_ComponentView__WEBPACK_IMPORTED_MODULE_7__["default"]({ + model: component, + config: c, + componentTypes: componentTypes + }); + return this; + }, - if (this.canvasRelative && em) { - var mousePos = em.get('Canvas').getMouseRelativeCanvas(e); - rX = mousePos.x; - rY = mousePos.y; - } + /** + * On load callback + * @private + */ + onLoad: function onLoad() { + this.setComponents(c.components); + }, - this.rX = rX; - this.rY = rY; - this.eventMove = e; + /** + * Do stuff after load + * @param {Editor} em + * @private + */ + postLoad: function postLoad(em) { + this.handleChanges(this.getWrapper(), null, { + avoidStore: 1 + }); + }, - //var targetNew = this.getTargetFromEl(e.target); - var dims = this.dimsFromTarget(e.target, rX, rY); - var target = this.target; - var targetModel = this.getTargetModel(target); - this.selectTargetModel(targetModel); + /** + * Handle component changes + * @private + */ + handleChanges: function handleChanges(model, value) { + var _this2 = this; - this.lastDims = dims; - var pos = this.findPosition(dims, rX, rY); - // If there is a significant changes with the pointer - if (!this.lastPos || this.lastPos.index != pos.index || this.lastPos.method != pos.method) { - this.movePlaceholder(this.plh, dims, pos, this.prevTargetDim); - if (!this.$plh) this.$plh = $(this.plh); + var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + var comps = model.components(); + var um = em.get('UndoManager'); + var handleUpdates = em.handleUpdates.bind(em); + var handleChanges = this.handleChanges.bind(this); + var handleChangesColl = this.handleChangesColl.bind(this); + var handleRemoves = this.handleRemoves.bind(this); + um && um.add(model); + um && comps && um.add(comps); + var evn = 'change:style change:content change:attributes change:src'; + [[model, evn, handleUpdates], [model, 'change:components', handleChangesColl], [comps, 'add', handleChanges], [comps, 'remove', handleRemoves], [model.get('classes'), 'add remove', handleUpdates]].forEach(function (els) { + em.stopListening(els[0], els[1], els[2]); + em.listenTo(els[0], els[1], els[2]); + }); + !opts.avoidStore && handleUpdates('', '', opts); + comps.each(function (model) { + return _this2.handleChanges(model, value, opts); + }); + }, + handleChangesColl: function handleChangesColl(model, coll) { + var um = em.get('UndoManager'); - // With canvasRelative the offset is calculated automatically for - // each element - if (!this.canvasRelative) { - if (this.offTop) this.$plh.css('top', '+=' + this.offTop + 'px'); - if (this.offLeft) this.$plh.css('left', '+=' + this.offLeft + 'px'); + if (um && coll instanceof backbone__WEBPACK_IMPORTED_MODULE_2___default.a.Collection) { + var handleChanges = this.handleChanges.bind(this); + var handleRemoves = this.handleRemoves.bind(this); + um.add(coll); + [[coll, 'add', handleChanges], [coll, 'remove', handleRemoves]].forEach(function (els) { + em.stopListening(els[0], els[1], els[2]); + em.listenTo(els[0], els[1], els[2]); + }); } + }, - this.lastPos = pos; - } - - if (typeof this.onMoveClb === 'function') this.onMoveClb(e); - - em && em.trigger('sorter:drag', { - target: target, - targetModel: targetModel, - dims: dims, - pos: pos, - x: rX, - y: rY - }); - }, + /** + * Triggered when some component is removed + * @private + * */ + handleRemoves: function handleRemoves(model, value) { + var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + !opts.avoidStore && em.handleUpdates(model, value, opts); + }, + /** + * Load components from the passed object, if the object is empty will try to fetch them + * autonomously from the selected storage + * The fetched data will be added to the collection + * @param {Object} data Object of data to load + * @return {Object} Loaded data + */ + load: function load() { + var data = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ''; + var em = this.em; + var result = ''; - /** - * Returns true if the elements is in flow, so is not in flow where - * for example the component is with float:left - * @param {HTMLElement} el - * @param {HTMLElement} parent - * @return {Boolean} - * @private - * */ - isInFlow: function isInFlow(el, parent) { - if (!el) return false; + if (!data && c.stm) { + data = c.em.getCacheLoad(); + } - parent = parent || document.body; - var ch = -1, - h; - var elem = el; - h = elem.offsetHeight; - if ( /*h < ch || */!this.styleInFlow(elem, parent)) return false;else return true; - }, + var _data = data, + components = _data.components, + html = _data.html; + if (components) { + if (Object(underscore__WEBPACK_IMPORTED_MODULE_3__["isObject"])(components) || Object(underscore__WEBPACK_IMPORTED_MODULE_3__["isArray"])(components)) { + result = components; + } else { + try { + result = JSON.parse(components); + } catch (err) { + em && em.logError(err); + } + } + } else if (html) { + result = html; + } - /** - * Check if el has style to be in flow - * @param {HTMLElement} el - * @param {HTMLElement} parent - * @return {Boolean} - * @private - */ - styleInFlow: function styleInFlow(el, parent) { - var style = el.style; - var $el = $(el); - if (style.overflow && style.overflow !== 'visible') return; - if ($el.css('float') !== 'none') return; - if (parent && $(parent).css('display') == 'flex') return; - switch (style.position) { - case 'static':case 'relative':case '': - break; - default: - return; - } - switch (el.tagName) { - case 'TR':case 'TBODY':case 'THEAD':case 'TFOOT': - return true; - } - switch ($el.css('display')) { - case 'block': - case 'list-item': - case 'table': - case 'flex': - return true; - } - return; - }, + var isObj = result && result.constructor === Object; + if (result && result.length || isObj) { + this.clear(); // If the result is an object I consider it the wrapper - /** - * Check if the target is valid with the actual source - * @param {HTMLElement} trg - * @return {Boolean} - */ - validTarget: function validTarget(trg) { - var srcModel = this.getSourceModel(); - var src = srcModel && srcModel.view && srcModel.view.el; - var trgModel = this.getTargetModel(trg); - trg = trgModel && trgModel.view && trgModel.view.el; - var result = { - valid: true, - src: src, - srcModel: srcModel, - trg: trg, - trgModel: trgModel - }; + if (isObj) { + this.getWrapper().set(result); + } else { + this.getComponents().add(result); + } + } - if (!src || !trg) { - result.valid = false; return result; - } - - // Check if the target could accept the source - var droppable = trgModel.get('droppable'); - droppable = droppable instanceof Backbone.Collection ? 1 : droppable; - droppable = droppable instanceof Array ? droppable.join(', ') : droppable; - result.dropInfo = droppable; - droppable = (0, _underscore.isString)(droppable) ? this.matches(src, droppable) : droppable; - result.droppable = droppable; - - // check if the source is draggable in target - var draggable = srcModel.get('draggable'); - draggable = draggable instanceof Array ? draggable.join(', ') : draggable; - result.dragInfo = draggable; - draggable = (0, _underscore.isString)(draggable) ? this.matches(trg, draggable) : draggable; - result.draggable = draggable; - - if (!droppable || !draggable) { - result.valid = false; - } - - return result; - }, - - - /** - * Get dimensions of nodes relative to the coordinates - * @param {HTMLElement} target - * @param {number} rX Relative X position - * @param {number} rY Relative Y position - * @return {Array} - */ - dimsFromTarget: function dimsFromTarget(target, rX, rY) { - var em = this.em; - var dims = []; - - if (!target) { - return dims; - } - - // Select the first valuable target - if (!this.matches(target, this.itemSel + ', ' + this.containerSel)) { - target = this.closest(target, this.itemSel); - } - - // If draggable is an array the target will be one of those - if (this.draggable instanceof Array) { - target = this.closest(target, this.draggable.join(',')); - } - - if (!target) { - return dims; - } - - // Check if the target is different from the previous one - if (this.prevTarget && this.prevTarget != target) { - this.prevTarget = null; - } - - // New target found - if (!this.prevTarget) { - this.targetP = this.closest(target, this.containerSel); - - // Check if the source is valid with the target - var validResult = this.validTarget(target); - em && em.trigger('sorter:drag:validation', validResult); + }, - if (!validResult.valid && this.targetP) { - return this.dimsFromTarget(this.targetP, rX, rY); + /** + * Store components on the selected storage + * @param {Boolean} noStore If true, won't store + * @return {Object} Data to store + */ + store: function store(noStore) { + if (!c.stm) { + return; } - this.prevTarget = target; - this.prevTargetDim = this.getDim(target); - this.cacheDimsP = this.getChildrenDim(this.targetP); - this.cacheDims = this.getChildrenDim(target); - } - - // If the target is the previous one will return the cached dims - if (this.prevTarget == target) dims = this.cacheDims; - - // Target when I will drop element to sort - this.target = this.prevTarget; - - // Generally, on any new target the poiner enters inside its area and - // triggers nearBorders(), so have to take care of this - if (this.nearBorders(this.prevTargetDim, rX, rY) || !this.nested && !this.cacheDims.length) { - var targetParent = this.targetP; + var obj = {}; + var keys = this.storageKey(); - if (targetParent && this.validTarget(targetParent).valid) { - dims = this.cacheDimsP; - this.target = targetParent; + if (keys.indexOf('html') >= 0) { + obj.html = c.em.getHtml(); } - } - - this.lastPos = null; - return dims; - }, - - /** - * Get valid target from element - * This method should replace dimsFromTarget() - * @param {HTMLElement} el - * @return {HTMLElement} - */ - getTargetFromEl: function getTargetFromEl(el) { - var target = el; - var targetParent = void 0; - var targetPrev = this.targetPrev; - var em = this.em; - var containerSel = this.containerSel; - var itemSel = this.itemSel; - - // Select the first valuable target - if (!this.matches(target, itemSel + ', ' + containerSel)) { - target = this.closest(target, itemSel); - } - - // If draggable is an array the target will be one of those - // TODO check if this options is used somewhere - if (this.draggable instanceof Array) { - target = this.closest(target, this.draggable.join(',')); - } - - // Check if the target is different from the previous one - if (targetPrev && targetPrev != target) { - this.targetPrev = ''; - } - - // New target found - if (!this.targetPrev) { - targetParent = this.closest(target, containerSel); - - // If the current target is not valid (src/trg reasons) try with - // the parent one (if exists) - var validResult = this.validTarget(target); - em && em.trigger('sorter:drag:validation', validResult); + if (keys.indexOf('components') >= 0) { + var _em = this.em; // const storeWrap = (em && !em.getConfig('avoidInlineStyle')) || c.storeWrapper; - if (!validResult.valid && targetParent) { - return this.getTargetFromEl(targetParent); + var storeWrap = c.storeWrapper; + var toStore = storeWrap ? this.getWrapper() : this.getComponents(); + obj.components = JSON.stringify(toStore); } - this.targetPrev = target; - } - - // Generally, on any new target the poiner enters inside its area and - // triggers nearBorders(), so have to take care of this - if (this.nearElBorders(target)) { - targetParent = this.closest(target, containerSel); - - if (targetParent && this.validTarget(targetParent).valid) { - target = targetParent; + if (!noStore) { + c.stm.store(obj); } - } - return target; - }, + return obj; + }, + /** + * Returns privately the main wrapper + * @return {Object} + * @private + */ + getComponent: function getComponent() { + return component; + }, - /** - * Check if the current pointer is neare to element borders - * @return {Boolen} - */ - nearElBorders: function nearElBorders(el) { - var off = 10; - var rect = el.getBoundingClientRect(); - var body = el.ownerDocument.body; + /** + * Returns root component inside the canvas. Something like `` inside HTML page + * The wrapper doesn't differ from the original Component Model + * @return {Component} Root Component + * @example + * // Change background of the wrapper and set some attribute + * var wrapper = domComponents.getWrapper(); + * wrapper.set('style', {'background-color': 'red'}); + * wrapper.set('attributes', {'title': 'Hello!'}); + */ + getWrapper: function getWrapper() { + return this.getComponent(); + }, - var _getCurrentPos = this.getCurrentPos(), - x = _getCurrentPos.x, - y = _getCurrentPos.y; + /** + * Returns wrapper's children collection. Once you have the collection you can + * add other Components(Models) inside. Each component can have several nested + * components inside and you can nest them as more as you wish. + * @return {Components} Collection of components + * @example + * // Let's add some component + * var wrapperChildren = domComponents.getComponents(); + * var comp1 = wrapperChildren.add({ + * style: { 'background-color': 'red'} + * }); + * var comp2 = wrapperChildren.add({ + * tagName: 'span', + * attributes: { title: 'Hello!'} + * }); + * // Now let's add an other one inside first component + * // First we have to get the collection inside. Each + * // component has 'components' property + * var comp1Children = comp1.get('components'); + * // Procede as before. You could also add multiple objects + * comp1Children.add([ + * { style: { 'background-color': 'blue'}}, + * { style: { height: '100px', width: '100px'}} + * ]); + * // Remove comp2 + * wrapperChildren.remove(comp2); + */ + getComponents: function getComponents() { + return this.getWrapper().get('components'); + }, - var top = rect.top + body.scrollTop; - var left = rect.left + body.scrollLeft; - var width = rect.width; - var height = rect.height; + /** + * Add new components to the wrapper's children. It's the same + * as 'domComponents.getComponents().add(...)' + * @param {Object|Component|Array} component Component/s to add + * @param {string} [component.tagName='div'] Tag name + * @param {string} [component.type=''] Type of the component. Available: ''(default), 'text', 'image' + * @param {boolean} [component.removable=true] If component is removable + * @param {boolean} [component.draggable=true] If is possible to move the component around the structure + * @param {boolean} [component.droppable=true] If is possible to drop inside other components + * @param {boolean} [component.badgable=true] If the badge is visible when the component is selected + * @param {boolean} [component.stylable=true] If is possible to style component + * @param {boolean} [component.copyable=true] If is possible to copy&paste the component + * @param {string} [component.content=''] String inside component + * @param {Object} [component.style={}] Style object + * @param {Object} [component.attributes={}] Attribute object + * @return {Component|Array} Component/s added + * @example + * // Example of a new component with some extra property + * var comp1 = domComponents.addComponent({ + * tagName: 'div', + * removable: true, // Can't remove it + * draggable: true, // Can't move it + * copyable: true, // Disable copy/past + * content: 'Content text', // Text inside component + * style: { color: 'red'}, + * attributes: { title: 'here' } + * }); + */ + addComponent: function addComponent(component) { + return this.getComponents().add(component); + }, - //console.log(pos, {top, left}); - if (y < top + off || // near top edge - y > top + height - off || // near bottom edge - x < left + off || // near left edge - x > left + width - off // near right edge - ) { - return 1; + /** + * Render and returns wrapper element with all components inside. + * Once the wrapper is rendered, and it's what happens when you init the editor, + * the all new components will be added automatically and property changes are all + * updated immediately + * @return {HTMLElement} + */ + render: function render() { + return componentView.render().el; + }, + + /** + * Remove all components + * @return {this} + */ + clear: function clear() { + this.getComponents().map(function (i) { + return i; + }).forEach(function (i) { + return i.remove(); + }); + return this; + }, + + /** + * Set components + * @param {Object|string} components HTML string or components model + * @return {this} + * @private + */ + setComponents: function setComponents(components) { + this.clear().addComponent(components); + }, + + /** + * Add new component type. + * Read more about this in [Define New Component](https://grapesjs.com/docs/modules/Components.html#define-new-component) + * @param {string} type Component ID + * @param {Object} methods Component methods + * @return {this} + */ + addType: function addType(type, methods) { + var em = this.em; + var _methods$model = methods.model, + model = _methods$model === void 0 ? {} : _methods$model, + _methods$view = methods.view, + view = _methods$view === void 0 ? {} : _methods$view, + isComponent = methods.isComponent, + extend = methods.extend, + extendView = methods.extendView, + _methods$extendFn = methods.extendFn, + extendFn = _methods$extendFn === void 0 ? [] : _methods$extendFn, + _methods$extendFnView = methods.extendFnView, + extendFnView = _methods$extendFnView === void 0 ? [] : _methods$extendFnView; + var compType = this.getType(type); + var extendType = this.getType(extend); + var extendViewType = this.getType(extendView); + var typeToExtend = extendType ? extendType : compType ? compType : this.getType('default'); + var modelToExt = typeToExtend.model; + var viewToExt = extendViewType ? extendViewType.view : typeToExtend.view; // Function for extending source object methods + + var getExtendedObj = function getExtendedObj(fns, target, srcToExt) { + return fns.reduce(function (res, next) { + var fn = target[next]; + var parentFn = srcToExt.prototype[next]; + + if (fn && parentFn) { + res[next] = function () { + parentFn.bind(this).apply(void 0, arguments); + fn.bind(this).apply(void 0, arguments); + }; + } + + return res; + }, {}); + }; // If the model/view is a simple object I need to extend it + + + if (_babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0___default()(model) === 'object') { + methods.model = modelToExt.extend(_objectSpread({}, model, {}, getExtendedObj(extendFn, model, modelToExt), { + defaults: _objectSpread({}, modelToExt.prototype.defaults, {}, Object(underscore__WEBPACK_IMPORTED_MODULE_3__["result"])(model, 'defaults') || {}) + }), { + isComponent: compType && !extendType && !isComponent ? modelToExt.isComponent : isComponent || function () { + return 0; + } + }); } - }, - getCurrentPos: function getCurrentPos() { - var ev = this.eventMove; - var x = ev.pageX || 0; - var y = ev.pageY || 0; - return { x: x, y: y }; - }, + if (_babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0___default()(view) === 'object') { + methods.view = viewToExt.extend(_objectSpread({}, view, {}, getExtendedObj(extendFnView, view, viewToExt))); + } - /** - * Returns dimensions and positions about the element - * @param {HTMLElement} el - * @return {Array} - */ - getDim: function getDim(el) { - var top, left, height, width; + if (compType) { + compType.model = methods.model; + compType.view = methods.view; + } else { + methods.id = type; + componentTypes.unshift(methods); + } - if (this.canvasRelative && this.em) { - var pos = this.em.get('Canvas').getElementPos(el); - var styles = window.getComputedStyle(el); - var marginTop = parseFloat(styles['marginTop']); - var marginBottom = parseFloat(styles['marginBottom']); - var marginRight = parseFloat(styles['marginRight']); - var marginLeft = parseFloat(styles['marginLeft']); - top = pos.top - marginTop; - left = pos.left - marginLeft; - height = pos.height + marginTop + marginBottom; - width = pos.width + marginLeft + marginRight; - } else { - var o = this.offset(el); - top = this.relative ? el.offsetTop : o.top - (this.wmargin ? -1 : 1) * this.elT; - left = this.relative ? el.offsetLeft : o.left - (this.wmargin ? -1 : 1) * this.elL; - height = el.offsetHeight; - width = el.offsetWidth; - } + var event = "component:type:".concat(compType ? 'update' : 'add'); + em && em.trigger(event, compType || methods); + return this; + }, - //console.log('get dim', top, left, this.canvasRelative); + /** + * Get component type. + * Read more about this in [Define New Component](https://grapesjs.com/docs/modules/Components.html#define-new-component) + * @param {string} type Component ID + * @return {Object} Component type defintion, eg. `{ model: ..., view: ... }` + */ + getType: function getType(type) { + var df = componentTypes; - return [top, left, height, width]; - }, + for (var it = 0; it < df.length; it++) { + var dfId = df[it].id; + if (dfId == type) { + return df[it]; + } + } - /** - * Get children dimensions - * @param {HTMLELement} el Element root - * @retun {Array} - * */ - getChildrenDim: function getChildrenDim(trg) { - var dims = []; - if (!trg) return dims; + return; + }, - // Get children based on getChildrenContainer - var trgModel = this.getTargetModel(trg); - if (trgModel && trgModel.view && !this.ignoreViewChildren) { - trg = trgModel.view.getChildrenContainer(); - } + /** + * Remove component type + * @param {string} type Component ID + * @returns {Object|undefined} Removed component type, undefined otherwise + */ + removeType: function removeType(id) { + var df = componentTypes; + var type = this.getType(id); + if (!type) return; + var index = df.indexOf(type); + df.splice(index, 1); + return type; + }, - var ch = trg.children; + /** + * Return the array of all types + * @return {Array} + */ + getTypes: function getTypes() { + return componentTypes; + }, + selectAdd: function selectAdd(component) { + var _this3 = this; - for (var i = 0, len = ch.length; i < len; i++) { - var el = ch[i]; + var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; - if (!this.matches(el, this.itemSel)) { - continue; + if (component) { + component.set({ + status: 'selected' + }); + ['component:selected', 'component:toggled'].forEach(function (event) { + return _this3.em.trigger(event, component, opts); + }); } + }, + selectRemove: function selectRemove(component) { + var _this4 = this; + + var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; - var dim = this.getDim(el); - var dir = this.direction; + if (component) { + var _em2 = this.em; + component.set({ + status: '', + state: '' + }); + ['component:deselected', 'component:toggled'].forEach(function (event) { + return _this4.em.trigger(event, component, opts); + }); + } + }, - if (dir == 'v') dir = true;else if (dir == 'h') dir = false;else dir = this.isInFlow(el, trg); + /** + * Triggered when the component is hovered + * @private + */ + componentHovered: function componentHovered() { + var em = c.em; + var model = em.get('componentHovered'); + var previous = em.previous('componentHovered'); + var state = 'hovered'; // Deselect the previous component - dim.push(dir); - dim.push(el); - dims.push(dim); + previous && previous.get('status') == state && previous.set({ + status: '', + state: '' + }); + model && Object(underscore__WEBPACK_IMPORTED_MODULE_3__["isEmpty"])(model.get('status')) && model.set('status', state); } + }; +}); - return dims; - }, +/***/ }), +/***/ "./src/dom_components/model/Component.js": +/*!***********************************************!*\ + !*** ./src/dom_components/model/Component.js ***! + \***********************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - /** - * Check if the coordinates are near to the borders - * @param {Array} dim - * @param {number} rX Relative X position - * @param {number} rY Relative Y position - * @return {Boolean} - * */ - nearBorders: function nearBorders(dim, rX, rY) { - var result = 0; - var off = this.borderOffset; - var x = rX || 0; - var y = rY || 0; - var t = dim[0]; - var l = dim[1]; - var h = dim[2]; - var w = dim[3]; - if (t + off > y || y > t + h - off || l + off > x || x > l + w - off) result = 1; +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/typeof */ "./node_modules/@babel/runtime/helpers/typeof.js"); +/* harmony import */ var _babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_2__); +/* harmony import */ var utils_mixins__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! utils/mixins */ "./src/utils/mixins.js"); +/* harmony import */ var domain_abstract_model_Styleable__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! domain_abstract/model/Styleable */ "./src/domain_abstract/model/Styleable.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_5___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_5__); +/* harmony import */ var _Components__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./Components */ "./src/dom_components/model/Components.js"); +/* harmony import */ var selector_manager_model_Selector__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! selector_manager/model/Selector */ "./src/selector_manager/model/Selector.js"); +/* harmony import */ var selector_manager_model_Selectors__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! selector_manager/model/Selectors */ "./src/selector_manager/model/Selectors.js"); +/* harmony import */ var trait_manager_model_Traits__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! trait_manager/model/Traits */ "./src/trait_manager/model/Traits.js"); - return !!result; - }, - /** - * Find the position based on passed dimensions and coordinates - * @param {Array} dims Dimensions of nodes to parse - * @param {number} posX X coordindate - * @param {number} posY Y coordindate - * @retun {Object} - * */ - findPosition: function findPosition(dims, posX, posY) { - var result = { index: 0, method: 'before' }; - var leftLimit = 0, - xLimit = 0, - dimRight = 0, - yLimit = 0, - xCenter = 0, - yCenter = 0, - dimDown = 0, - dim = 0; - // Each dim is: Top, Left, Height, Width - for (var i = 0, len = dims.length; i < len; i++) { - dim = dims[i]; - // Right position of the element. Left + Width - dimRight = dim[1] + dim[3]; - // Bottom position of the element. Top + Height - dimDown = dim[0] + dim[2]; - // X center position of the element. Left + (Width / 2) - xCenter = dim[1] + dim[3] / 2; - // Y center position of the element. Top + (Height / 2) - yCenter = dim[0] + dim[2] / 2; - // Skip if over the limits - if (xLimit && dim[1] > xLimit || yLimit && yCenter >= yLimit || // >= avoid issue with clearfixes - leftLimit && dimRight < leftLimit) continue; - result.index = i; - // If it's not in flow (like 'float' element) - if (!dim[4]) { - if (posY < dimDown) yLimit = dimDown; - //If x lefter than center - if (posX < xCenter) { - xLimit = xCenter; - result.method = "before"; - } else { - leftLimit = xCenter; - result.method = "after"; - } - } else { - // If y upper than center - if (posY < yCenter) { - result.method = "before"; - break; - } else result.method = "after"; // After last element - } - } - return result; - }, +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - /** - * Updates the position of the placeholder - * @param {HTMLElement} phl - * @param {Array} dims - * @param {Object} pos Position object - * @param {Array} trgDim target dimensions - * */ - movePlaceholder: function movePlaceholder(plh, dims, pos, trgDim) { - var marg = 0, - t = 0, - l = 0, - w = 0, - h = 0, - un = 'px', - margI = 5, - brdCol = '#62c462', - brd = 3, - method = pos.method; - var elDim = dims[pos.index]; - plh.style.borderColor = 'transparent ' + brdCol; - plh.style.borderWidth = brd + un + ' ' + (brd + 2) + un; - plh.style.margin = '-' + brd + 'px 0 0'; - if (elDim) { - // If it's not in flow (like 'float' element) - if (!elDim[4]) { - w = 'auto'; - h = elDim[2] - marg * 2 + un; - t = elDim[0] + marg; - l = method == 'before' ? elDim[1] - marg : elDim[1] + elDim[3] - marg; - plh.style.borderColor = brdCol + ' transparent'; - plh.style.borderWidth = brd + 2 + un + ' ' + brd + un; - plh.style.margin = '0 0 0 -' + brd + 'px'; - } else { - w = elDim[3] + un; - h = 'auto'; - t = method == 'before' ? elDim[0] - marg : elDim[0] + elDim[2] - marg; - l = elDim[1]; - } - } else { - if (!this.nested) { - plh.style.display = 'none'; - return; - } - if (trgDim) { - t = trgDim[0] + margI; - l = trgDim[1] + margI; - w = parseInt(trgDim[3]) - margI * 2 + un; - h = 'auto'; - } - } - plh.style.top = t + un; - plh.style.left = l + un; - if (w) plh.style.width = w; - if (h) plh.style.height = h; - }, - /** - * Leave item - * @param event - * - * @return void - * */ - endMove: function endMove(e) { - var created; - var docs = this.getDocuments(); - var container = this.getContainerEl(); - (0, _mixins.off)(container, 'mousemove', this.onMove); - (0, _mixins.off)(docs, 'mouseup', this.endMove); - (0, _mixins.off)(docs, 'keydown', this.rollback); - //this.$document.off('mouseup', this.endMove); - //this.$document.off('keydown', this.rollback); - this.plh.style.display = 'none'; - var clsReg = new RegExp('(?:^|\\s)' + this.freezeClass + '(?!\\S)', 'gi'); - var src = this.eV; - if (src) { - var srcModel = this.getSourceModel(); - if (srcModel && srcModel.set) { - srcModel.set('status', ''); - srcModel.set('status', 'selected'); - //this.selectOnEnd && srcModel.set('status', 'selected'); - } - } - if (this.moved) { - created = this.move(this.target, src, this.lastPos); - } - if (this.plh) this.plh.style.display = 'none'; - if (typeof this.onEndMove === 'function') this.onEndMove(created); - var dragHelper = this.dragHelper; - if (dragHelper) { - dragHelper.parentNode.removeChild(dragHelper); - this.dragHelper = null; - } +var componentList = {}; +var componentIndex = 0; - this.selectTargetModel(); - this.toggleSortCursor(); +var escapeRegExp = function escapeRegExp(str) { + return str.replace(/[|\\{}()[\]^$+*?.]/g, '\\$&'); +}; + +var avoidInline = function avoidInline(em) { + return em && em.getConfig('avoidInlineStyle'); +}; +/** + * The Component object represents a single node of our template structure, so when you update its properties the changes are + * immediately reflected on the canvas and in the code to export (indeed, when you ask to export the code we just go through all + * the tree of nodes). + * An example on how to update properties: + * ```js + * component.set({ + * tagName: 'span', + * attributes: { ... }, + * removable: false, + * }); + * component.get('tagName'); + * // -> 'span' + * ``` + * + * @typedef Component + * @property {String} [type=''] Component type, eg. `text`, `image`, `video`, etc. + * @property {String} [tagName='div'] HTML tag of the component, eg. `span`. Default: `div` + * @property {Object} [attributes={}] Key-value object of the component's attributes, eg. `{ title: 'Hello' }` Default: `{}` + * @property {String} [name=''] Name of the component. Will be used, for example, in Layers and badges + * @property {Boolean} [removable=true] When `true` the component is removable from the canvas, default: `true` + * @property {Boolean|String} [draggable=true] Indicates if it's possible to drag the component inside others. + * You can also specify a query string to indentify elements, + * eg. `'.some-class[title=Hello], [data-gjs-type=column]'` means you can drag the component only inside elements + * containing `some-class` class and `Hello` title, and `column` components. Default: `true` + * @property {Boolean|String} [droppable=true] Indicates if it's possible to drop other components inside. You can use + * a query string as with `draggable`. Default: `true` + * @property {Boolean} [badgable=true] Set to false if you don't want to see the badge (with the name) over the component. Default: `true` + * @property {Boolean|Array} [stylable=true] True if it's possible to style the component. + * You can also indicate an array of CSS properties which is possible to style, eg. `['color', 'width']`, all other properties + * will be hidden from the style manager. Default: `true` + * @property {Array} [stylable-require=[]] Indicate an array of style properties to show up which has been marked as `toRequire`. Default: `[]` + * @property {Array} [unstylable=[]] Indicate an array of style properties which should be hidden from the style manager. Default: `[]` + * @property {Array} [style-signature=''] This option comes handy when you need to remove or export strictly component-specific rules. Be default, if this option is not empty, the editor will remove rules when there are no components, of that type, in the canvas. Eg. '['.navbar', '[navbar-']'. Default: `''` + * @property {Boolean} [highlightable=true] It can be highlighted with 'dotted' borders if true. Default: `true` + * @property {Boolean} [copyable=true] True if it's possible to clone the component. Default: `true` + * @property {Boolean} [resizable=false] Indicates if it's possible to resize the component. It's also possible to pass an object as [options for the Resizer](https://github.com/artf/grapesjs/blob/master/src/utils/Resizer.js). Default: `false` + * @property {Boolean} [editable=false] Allow to edit the content of the component (used on Text components). Default: `false` + * @property {Boolean} [layerable=true] Set to `false` if you need to hide the component inside Layers. Default: `true` + * @property {Boolean} [selectable=true] Allow component to be selected when clicked. Default: `true` + * @property {Boolean} [hoverable=true] Shows a highlight outline when hovering on the element if `true`. Default: `true` + * @property {Boolean} [void=false] This property is used by the HTML exporter as void elements don't have closing tags, eg. `
`, `
`, etc. Default: `false` + * @property {String} [content=''] Content of the component (not escaped) which will be appended before children rendering. Default: `''` + * @property {String} [icon=''] Component's icon, this string will be inserted before the name (in Layers and badge), eg. it can be an HTML string ''. Default: `''` + * @property {String|Function} [script=''] Component's javascript. More about it [here](/modules/Components-js.html). Default: `''` + * @property {String|Function} [script-export=''] You can specify javascript available only in export functions (eg. when you get the HTML). + * If this property is defined it will overwrite the `script` one (in export functions). Default: `''` + * @property {Array} [traits=''] Component's traits. More about it [here](/modules/Traits.html). Default: `['id', 'title']` + * @property {Array} [propagate=[]] Indicates an array of properties which will be inhereted by all NEW appended children. + * For example if you create a component likes this: `{ removable: false, draggable: false, propagate: ['removable', 'draggable'] }` + * and append some new component inside, the new added component will get the exact same properties indicated in the `propagate` array (and the `propagate` property itself). Default: `[]` + * @property {Array} [toolbar=null] Set an array of items to show up inside the toolbar when the component is selected (move, clone, delete). + * Eg. `toolbar: [ { attributes: {class: 'fa fa-arrows'}, command: 'tlb-move' }, ... ]`. + * By default, when `toolbar` property is falsy the editor will add automatically commands like `move`, `delete`, etc. based on its properties. + * @property {Collection} [components=null] Children components. Default: `null` + */ + + +var Component = backbone__WEBPACK_IMPORTED_MODULE_5___default.a.Model.extend(domain_abstract_model_Styleable__WEBPACK_IMPORTED_MODULE_4__["default"]).extend({ + defaults: { + tagName: 'div', + type: '', + name: '', + removable: true, + draggable: true, + droppable: true, + badgable: true, + stylable: true, + 'stylable-require': '', + 'style-signature': '', + unstylable: '', + highlightable: true, + copyable: true, + resizable: false, + editable: false, + layerable: true, + selectable: true, + hoverable: true, + void: false, + state: '', + // Indicates if the component is in some CSS state like ':hover', ':active', etc. + status: '', + // State, eg. 'selected' + content: '', + icon: '', + style: '', + // Component related style + classes: '', + // Array of classes + script: '', + 'script-export': '', + attributes: '', + traits: ['id', 'title'], + propagate: '', + dmode: '', + toolbar: null }, + /** + * Hook method, called once the model is created + */ + init: function init() {}, /** - * Move component to new position - * @param {HTMLElement} dst Destination target - * @param {HTMLElement} src Element to move - * @param {Object} pos Object with position coordinates - * */ - move: function move(dst, src, pos) { - var em = this.em; - em && em.trigger('component:dragEnd:before', dst, src, pos); // @depricated - var warns = []; - var index = pos.index; - var modelToDrop, modelTemp, created; - var validResult = this.validTarget(dst); - var targetCollection = $(dst).data('collection'); - var model = validResult.srcModel; - var droppable = validResult.droppable; - var draggable = validResult.draggable; - var dropInfo = validResult.dropInfo; - var dragInfo = validResult.dragInfo; - var dropContent = this.dropContent; - droppable = validResult.trgModel instanceof Backbone.Collection ? 1 : droppable; + * Hook method, called when the model has been updated (eg. updated some model's property) + * @param {String} property Property name, if triggered after some property update + * @param {*} value Property value, if triggered after some property update + * @param {*} previous Property previous value, if triggered after some property update + */ + updated: function updated(property, value, previous) {}, - if (targetCollection && droppable && draggable) { - index = pos.method === 'after' ? index + 1 : index; - var opts = { at: index, noIncrement: 1 }; + /** + * Hook method, called once the model has been removed + */ + removed: function removed() {}, + initialize: function initialize() { + var _this = this; - if (!dropContent) { - modelTemp = targetCollection.add({}, opts); + var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var opt = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + var em = opt.em; // Propagate properties from parent if indicated - if (model) { - modelToDrop = model.collection.remove(model); - } - } else { - modelToDrop = dropContent; - opts.silent = false; - opts.avoidUpdateStyle = 1; - } + var parent = this.parent(); + var parentAttr = parent && parent.attributes; + + if (parentAttr && parentAttr.propagate) { + var newAttr = {}; + var toPropagate = parentAttr.propagate; + toPropagate.forEach(function (prop) { + return newAttr[prop] = parent.get(prop); + }); + newAttr.propagate = toPropagate; + newAttr = _objectSpread({}, newAttr, {}, props); + this.set(newAttr); + } - created = targetCollection.add(modelToDrop, opts); + var propagate = this.get('propagate'); + propagate && this.set('propagate', Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isArray"])(propagate) ? propagate : [propagate]); // Check void elements - if (!dropContent) { - targetCollection.remove(modelTemp); - } else { - this.dropContent = null; - } + if (opt && opt.config && opt.config.voidElements.indexOf(this.get('tagName')) >= 0) { + this.set('void', true); + } - // This will cause to recalculate children dimensions - this.prevTarget = null; - } else { - if (!targetCollection) { - warns.push('Target collection not found'); - } + opt.em = em; + this.opt = opt; + this.em = em; + this.config = opt.config || {}; + this.set('attributes', _objectSpread({}, this.defaults.attributes || {}, {}, this.get('attributes') || {})); + this.ccid = Component.createId(this); + this.initClasses(); + this.initTraits(); + this.initComponents(); + this.initToolbar(); + this.listenTo(this, 'change:script', this.scriptUpdated); + this.listenTo(this, 'change:tagName', this.tagUpdated); + this.listenTo(this, 'change:attributes', this.attrUpdated); + this.listenTo(this, 'change:attributes:id', this._idUpdated); + this.set('status', ''); // Register global updates for collection properties - if (!droppable) { - warns.push('Target is not droppable, accepts [' + dropInfo + ']'); - } + ['classes', 'traits', 'components'].forEach(function (name) { + var events = "add remove ".concat(name !== 'components' ? 'change' : ''); - if (!draggable) { - warns.push('Component not draggable, acceptable by [' + dragInfo + ']'); - } + _this.listenTo(_this.get(name), events.trim(), function () { + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; + } - console.warn('Invalid target position: ' + warns.join(', ')); + return _this.emitUpdate.apply(_this, [name].concat(args)); + }); + }); + + if (!opt.temporary) { + this.init(); + em && em.trigger('component:create', this); } + }, - em && em.trigger('component:dragEnd', targetCollection, modelToDrop, warns); // @depricated - em && em.trigger('sorter:drag:end', targetCollection, modelToDrop, warns); + /** + * Check component's type + * @param {string} type Component type + * @return {Boolean} + * @example + * component.is('image') + * // -> false + */ + is: function is(type) { + return !!(this.get('type') == type); + }, - return created; + /** + * Return all the propeties + * @returns {Object} + */ + props: function props() { + return this.attributes; }, + /** + * Get the index of the component in the parent collection. + * @return {Number} + */ + index: function index() { + var collection = this.collection; + return collection && collection.indexOf(this); + }, /** - * Rollback to previous situation - * @param {Event} - * @param {Bool} Indicates if rollback in anycase - * */ - rollback: function rollback(e) { - (0, _mixins.off)(this.getDocuments(), 'keydown', this.rollback); - var key = e.which || e.keyCode; + * Change the drag mode of the component. + * To get more about this feature read: https://github.com/artf/grapesjs/issues/1936 + * @param {String} value Drag mode, options: 'absolute' | 'translate' + * @returns {this} + */ + setDragMode: function setDragMode(value) { + return this.set('dmode', value); + }, - if (key == 27) { - this.moved = 0; - this.endMove(); - } - } -}); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(0), __webpack_require__(1))) - -/***/ }), -/* 67 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); - -var _underscore = __webpack_require__(1); - -var _mixins = __webpack_require__(2); - -function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } - -var defaultOpts = { - // Function which returns custom X and Y coordinates of the mouse - mousePosFetcher: null, - // Indicates custom target updating strategy - updateTarget: null, - // Function which gets HTMLElement as an arg and returns it relative position - ratioDefault: 0, - posFetcher: null, - onStart: null, - onMove: null, - onEnd: null, + /** + * Find inner components by query string. + * **ATTENTION**: this method works only with already rendered component + * @param {String} query Query string + * @return {Array} Array of components + * @example + * component.find('div > .class'); + * // -> [Component, Component, ...] + */ + find: function find(query) { + var result = []; + this.view.$el.find(query).each(function (el, i, $els) { + var $el = $els.eq(i); + var model = $el.data('model'); + model && result.push(model); + }); + return result; + }, - // Resize unit step - step: 1, + /** + * Find all inner components by component id. + * The advantage of this method over `find` is that you can use it + * also before rendering the component + * @param {String} id Component id + * @returns {Array} + * @example + * const allImages = component.findType('image'); + * console.log(allImages[0]) // prints the first found component + */ + findType: function findType(id) { + var result = []; - // Minimum dimension - minDim: 32, + var find = function find(components) { + return components.forEach(function (item) { + item.is(id) && result.push(item); + find(item.components()); + }); + }; - // Maximum dimension - maxDim: '', + find(this.components()); + return result; + }, - // Unit used for height resizing - unitHeight: 'px', + /** + * Find the closest parent component by query string. + * **ATTENTION**: this method works only with already rendered component + * @param {string} query Query string + * @return {Component} + * @example + * component.closest('div.some-class'); + * // -> Component + */ + closest: function closest(query) { + var result = this.view.$el.closest(query); + return result.length && result.data('model'); + }, - // Unit used for width resizing - unitWidth: 'px', + /** + * Once the tag is updated I have to remove the node and replace it + * @private + */ + tagUpdated: function tagUpdated() { + var coll = this.collection; + var at = coll.indexOf(this); + coll.remove(this); + coll.add(this, { + at: at + }); + }, - // The key used for height resizing - keyHeight: 'height', + /** + * Replace a component with another one + * @param {String|Component} el Component or HTML string + * @return {Component|Array} New added component/s + * @example + * component.replaceWith('
Some new content
'); + * // -> Component + */ + replaceWith: function replaceWith(el) { + var coll = this.collection; + var at = coll.indexOf(this); + coll.remove(this); + return coll.add(el, { + at: at + }); + }, - // The key used for width resizing - keyWidth: 'width', + /** + * Emit changes for each updated attribute + * @private + */ + attrUpdated: function attrUpdated(m, v) { + var _this2 = this; - // If true, will override unitHeight and unitWidth, on start, with units - // from the current focused element (currently used only in SelectComponent) - currentUnit: 1, + var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + var attrs = this.get('attributes'); // Handle classes - // Handlers - tl: 1, // Top left - tc: 1, // Top center - tr: 1, // Top right - cl: 1, // Center left - cr: 1, // Center right - bl: 1, // Bottom left - bc: 1, // Bottom center - br: 1 // Bottom right -}; + var classes = attrs.class; + classes && this.setClass(classes); + delete attrs.class; // Handle style -var createHandler = function createHandler(name, opts) { - var pfx = opts.prefix || ''; - var el = document.createElement('i'); - el.className = pfx + 'resizer-h ' + pfx + 'resizer-h-' + name; - el.setAttribute('data-' + pfx + 'handler', name); - return el; -}; + var style = attrs.style; + style && this.setStyle(style); + delete attrs.style; -var getBoundingRect = function getBoundingRect(el, win) { - var w = win || window; - var rect = el.getBoundingClientRect(); - return { - left: rect.left + w.pageXOffset, - top: rect.top + w.pageYOffset, - width: rect.width, - height: rect.height - }; -}; + var attrPrev = _objectSpread({}, this.previous('attributes')); -var Resizer = function () { + var diff = Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["shallowDiff"])(attrPrev, this.get('attributes')); + Object(underscore__WEBPACK_IMPORTED_MODULE_2__["keys"])(diff).forEach(function (pr) { + return _this2.trigger("change:attributes:".concat(pr), _this2, diff[pr], opts); + }); + }, /** - * Init the Resizer with options - * @param {Object} options + * Update attributes of the component + * @param {Object} attrs Key value attributes + * @return {this} + * @example + * component.setAttributes({ id: 'test', 'data-key': 'value' }); */ - function Resizer() { - var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + setAttributes: function setAttributes(attrs) { + var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + this.set('attributes', _objectSpread({}, attrs), opts); + return this; + }, - _classCallCheck(this, Resizer); + /** + * Add attributes to the component + * @param {Object} attrs Key value attributes + * @return {this} + * @example + * component.addAttributes({ 'data-key': 'value' }); + */ + addAttributes: function addAttributes(attrs) { + var newAttrs = _objectSpread({}, this.getAttributes(), {}, attrs); - this.setOptions(opts); - (0, _underscore.bindAll)(this, 'handleKeyDown', 'handleMouseDown', 'move', 'stop'); + this.setAttributes(newAttrs); return this; - } + }, /** - * Get current connfiguration options + * Get the style of the component * @return {Object} */ + getStyle: function getStyle() { + var em = this.em; + if (em && em.getConfig('avoidInlineStyle')) { + var state = this.get('state'); + var cc = em.get('CssComposer'); + var rule = cc.getIdRule(this.getId(), { + state: state + }); + this.rule = rule; - _createClass(Resizer, [{ - key: 'getConfig', - value: function getConfig() { - return this.opts; - } - - /** - * Setup options - * @param {Object} options - */ - - }, { - key: 'setOptions', - value: function setOptions() { - var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; - - this.opts = (0, _underscore.defaults)(options, defaultOpts); - this.setup(); + if (rule) { + return rule.getStyle(); + } } - /** - * Setup resizer - */ - - }, { - key: 'setup', - value: function setup() { - var opts = this.opts; - var pfx = opts.prefix || ''; - var appendTo = opts.appendTo || document.body; - var container = this.container; + return domain_abstract_model_Styleable__WEBPACK_IMPORTED_MODULE_4__["default"].getStyle.call(this); + }, - // Create container if not yet exist - if (!container) { - container = document.createElement('div'); - container.className = pfx + 'resizer-c'; - appendTo.appendChild(container); - this.container = container; - } + /** + * Set the style on the component + * @param {Object} prop Key value style object + * @return {Object} + * @example + * component.setStyle({ color: 'red' }); + */ + setStyle: function setStyle() { + var _this3 = this; - while (container.firstChild) { - container.removeChild(container.firstChild); - } + var prop = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + var em = this.em; + var opt = this.opt; - // Create handlers - var handlers = {}; - ['tl', 'tc', 'tr', 'cl', 'cr', 'bl', 'bc', 'br'].forEach(function (hdl) { - return handlers[hdl] = opts[hdl] ? createHandler(hdl, opts) : ''; + if (em && em.getConfig('avoidInlineStyle') && !opt.temporary) { + var style = this.get('style') || {}; + prop = Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isString"])(prop) ? this.parseStyle(prop) : prop; + prop = _objectSpread({}, prop, {}, style); + var state = this.get('state'); + var cc = em.get('CssComposer'); + var propOrig = this.getStyle(); + this.rule = cc.setIdRule(this.getId(), prop, _objectSpread({}, opts, { + state: state + })); + var diff = Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["shallowDiff"])(propOrig, prop); + this.set('style', {}, { + silent: 1 }); - - for (var n in handlers) { - var handler = handlers[n]; - handler && container.appendChild(handler); - } - - this.handlers = handlers; - this.mousePosFetcher = opts.mousePosFetcher; - this.updateTarget = opts.updateTarget; - this.posFetcher = opts.posFetcher; - this.onStart = opts.onStart; - this.onMove = opts.onMove; - this.onEnd = opts.onEnd; + Object(underscore__WEBPACK_IMPORTED_MODULE_2__["keys"])(diff).forEach(function (pr) { + return _this3.trigger("change:style:".concat(pr)); + }); + } else { + prop = domain_abstract_model_Styleable__WEBPACK_IMPORTED_MODULE_4__["default"].setStyle.apply(this, arguments); } - /** - * Detects if the passed element is a resize handler - * @param {HTMLElement} el - * @return {Boolean} - */ + return prop; + }, - }, { - key: 'isHandler', - value: function isHandler(el) { - var handlers = this.handlers; + /** + * Return all component's attributes + * @return {Object} + */ + getAttributes: function getAttributes() { + var em = this.em; + var classes = []; - for (var n in handlers) { - if (handlers[n] === el) return true; - } + var attributes = _objectSpread({}, this.get('attributes')); - return false; - } + var sm = em && em.get('SelectorManager'); + var id = this.getId(); // Add classes - /** - * Returns the focused element - * @return {HTMLElement} - */ + this.get('classes').forEach(function (cls) { + return classes.push(Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isString"])(cls) ? cls : cls.get('name')); + }); + classes.length && (attributes.class = classes.join(' ')); // Check if we need an ID on the component - }, { - key: 'getFocusedEl', - value: function getFocusedEl() { - return this.el; - } + if (!Object(underscore__WEBPACK_IMPORTED_MODULE_2__["has"])(attributes, 'id')) { + var hasStyle; // If we don't rely on inline styling we have to check + // for the ID selector - /** - * Returns documents - */ + if (avoidInline(em)) { + hasStyle = sm && sm.get(id, sm.Selector.TYPE_ID); + } else if (!Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isEmpty"])(this.getStyle())) { + hasStyle = 1; + } - }, { - key: 'getDocumentEl', - value: function getDocumentEl() { - return [this.el.ownerDocument, document]; + if (hasStyle) { + attributes.id = this.getId(); + } } - /** - * Return element position - * @param {HTMLElement} el - * @return {Object} - */ - - }, { - key: 'getElementPos', - value: function getElementPos(el) { - var posFetcher = this.posFetcher || ''; - return posFetcher ? posFetcher(el) : getBoundingRect(el); - } + return attributes; + }, - /** - * Focus resizer on the element, attaches handlers to it - * @param {HTMLElement} el - */ + /** + * Add classes + * @param {Array|String} classes Array or string of classes + * @return {Array} Array of added selectors + * @example + * model.addClass('class1'); + * model.addClass('class1 class2'); + * model.addClass(['class1', 'class2']); + * // -> [SelectorObject, ...] + */ + addClass: function addClass(classes) { + var added = this.em.get('SelectorManager').addClass(classes); + return this.get('classes').add(added); + }, - }, { - key: 'focus', - value: function focus(el) { - // Avoid focusing on already focused element - if (el && el === this.el) { - return; - } + /** + * Set classes (resets current collection) + * @param {Array|String} classes Array or string of classes + * @return {Array} Array of added selectors + * @example + * model.setClass('class1'); + * model.setClass('class1 class2'); + * model.setClass(['class1', 'class2']); + * // -> [SelectorObject, ...] + */ + setClass: function setClass(classes) { + this.get('classes').reset(); + return this.addClass(classes); + }, - // Show the handlers - this.el = el; - var unit = 'px'; - var rect = this.getElementPos(el); - var container = this.container; - var contStyle = container.style; - contStyle.left = rect.left + unit; - contStyle.top = rect.top + unit; - contStyle.width = rect.width + unit; - contStyle.height = rect.height + unit; - container.style.display = 'block'; + /** + * Remove classes + * @param {Array|String} classes Array or string of classes + * @return {Array} Array of removed selectors + * @example + * model.removeClass('class1'); + * model.removeClass('class1 class2'); + * model.removeClass(['class1', 'class2']); + * // -> [SelectorObject, ...] + */ + removeClass: function removeClass(classes) { + var removed = []; + classes = Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isArray"])(classes) ? classes : [classes]; + var selectors = this.get('classes'); + var type = selector_manager_model_Selector__WEBPACK_IMPORTED_MODULE_7__["default"].TYPE_CLASS; + classes.forEach(function (classe) { + var classes = classe.split(' '); + classes.forEach(function (name) { + var selector = selectors.where({ + name: name, + type: type + })[0]; + selector && removed.push(selectors.remove(selector)); + }); + }); + return removed; + }, - (0, _mixins.on)(this.getDocumentEl(), 'mousedown', this.handleMouseDown); - } + /** + * Returns component's classes as an array of strings + * @return {Array} + */ + getClasses: function getClasses() { + var attr = this.getAttributes(); + var classStr = attr.class; + return classStr ? classStr.split(' ') : []; + }, + initClasses: function initClasses() { + var event = 'change:classes'; + var toListen = [this, event, this.initClasses]; + var cls = this.get('classes') || []; + var clsArr = Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isString"])(cls) ? cls.split(' ') : cls; + this.stopListening.apply(this, toListen); + var classes = this.normalizeClasses(clsArr); + var selectors = new selector_manager_model_Selectors__WEBPACK_IMPORTED_MODULE_8__["default"]([]); + this.set('classes', selectors); + selectors.add(classes); + this.listenTo.apply(this, toListen); + return this; + }, + initComponents: function initComponents() { + var event = 'change:components'; + var toListen = [this, event, this.initComponents]; + this.stopListening.apply(this, toListen); // Have to add components after the init, otherwise the parent + // is not visible - /** - * Blur from element - */ + var comps = new _Components__WEBPACK_IMPORTED_MODULE_6__["default"](null, this.opt); + comps.parent = this; + var components = this.get('components'); + var addChild = !this.opt.avoidChildren; + this.set('components', comps); + addChild && comps.add(Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isFunction"])(components) ? components(this) : components); + this.listenTo.apply(this, toListen); + return this; + }, + initTraits: function initTraits(changed) { + var em = this.em; + var event = 'change:traits'; + var toListen = [this, event, this.initTraits]; + this.stopListening.apply(this, toListen); + this.loadTraits(); - }, { - key: 'blur', - value: function blur() { - this.container.style.display = 'none'; + var attrs = _objectSpread({}, this.get('attributes')); - if (this.el) { - (0, _mixins.off)(this.getDocumentEl(), 'mousedown', this.handleMouseDown); - this.el = null; + var traits = this.get('traits'); + traits.each(function (trait) { + if (!trait.get('changeProp')) { + var name = trait.get('name'); + var value = trait.getInitValue(); + if (name && value) attrs[name] = value; } - } + }); + traits.length && this.set('attributes', attrs); + this.listenTo.apply(this, toListen); + changed && em && em.trigger('component:toggled'); + return this; + }, - /** - * Start resizing - * @param {Event} e - */ + /** + * Add new component children + * @param {Component|String} components Component to add + * @param {Object} [opts={}] Options, same as in `model.add()`(from backbone) + * @return {Array} Array of appended components + * @example + * someComponent.get('components').length // -> 0 + * const videoComponent = someComponent.append('
')[0]; + * // This will add 2 components (`video` and `div`) to your `someComponent` + * someComponent.get('components').length // -> 2 + * // You can pass components directly + * otherComponent.append(otherComponent2); + * otherComponent.append([otherComponent3, otherComponent4]); + */ + append: function append(components) { + var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + var result = this.components().add(components, opts); + return Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isArray"])(result) ? result : [result]; + }, - }, { - key: 'start', - value: function start(e) { - //Right or middel click - if (e.button !== 0) { - return; - } - e.preventDefault(); - e.stopPropagation(); - var el = this.el; - var resizer = this; - var config = this.opts || {}; - var attrName = 'data-' + config.prefix + 'handler'; - var rect = this.getElementPos(el); - this.handlerAttr = e.target.getAttribute(attrName); - this.clickedHandler = e.target; - this.startDim = { - t: rect.top, - l: rect.left, - w: rect.width, - h: rect.height - }; - this.rectDim = { - t: rect.top, - l: rect.left, - w: rect.width, - h: rect.height - }; - this.startPos = { - x: e.clientX, - y: e.clientY - }; + /** + * Set new collection if `components` are provided, otherwise the + * current collection is returned + * @param {Component|String} [components] Components to set + * @return {Collection|Array} + * @example + * // Set new collection + * component.components('
'); + * // Get current collection + * const collection = component.components(); + * console.log(collection.length); + * // -> 2 + */ + components: function components(_components) { + var coll = this.get('components'); - // Listen events - var doc = this.getDocumentEl(); - (0, _mixins.on)(doc, 'mousemove', this.move); - (0, _mixins.on)(doc, 'keydown', this.handleKeyDown); - (0, _mixins.on)(doc, 'mouseup', this.stop); - (0, _underscore.isFunction)(this.onStart) && this.onStart(e, { docs: doc, config: config, el: el, resizer: resizer }); - this.move(e); + if (Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isUndefined"])(_components)) { + return coll; + } else { + coll.reset(); + return _components && this.append(_components); } + }, - /** - * While resizing - * @param {Event} e - */ + /** + * Get the parent component, if exists + * @return {Component} + * @example + * component.parent(); + * // -> Component + */ + parent: function parent() { + var coll = this.collection; + return coll && coll.parent; + }, - }, { - key: 'move', - value: function move(e) { - var onMove = this.onMove; - var mouseFetch = this.mousePosFetcher; - var currentPos = mouseFetch ? mouseFetch(e) : { - x: e.clientX, - y: e.clientY - }; + /** + * Script updated + * @private + */ + scriptUpdated: function scriptUpdated() { + this.set('scriptUpdated', 1); + }, - this.currentPos = currentPos; - this.delta = { - x: currentPos.x - this.startPos.x, - y: currentPos.y - this.startPos.y - }; - this.keys = { - shift: e.shiftKey, - ctrl: e.ctrlKey, - alt: e.altKey - }; + /** + * Init toolbar + * @private + */ + initToolbar: function initToolbar() { + var em = this.em; + var model = this; + var ppfx = em && em.getConfig('stylePrefix') || ''; - this.rectDim = this.calc(this); - this.updateRect(0); + if (!model.get('toolbar')) { + var tb = []; - // Move callback - onMove && onMove(e); + if (model.collection) { + tb.push({ + attributes: { + class: 'fa fa-arrow-up' + }, + command: function command(ed) { + return ed.runCommand('core:component-exit', { + force: 1 + }); + } + }); + } - // In case the mouse button was released outside of the window - if (e.which === 0) { - this.stop(e); + if (model.get('draggable')) { + tb.push({ + attributes: { + class: "fa fa-arrows ".concat(ppfx, "no-touch-actions"), + draggable: true + }, + //events: hasDnd(this.em) ? { dragstart: 'execCommand' } : '', + command: 'tlb-move' + }); } - } - /** - * Stop resizing - * @param {Event} e - */ + if (model.get('copyable')) { + tb.push({ + attributes: { + class: 'fa fa-clone' + }, + command: 'tlb-clone' + }); + } - }, { - key: 'stop', - value: function stop(e) { - var config = this.opts; - var doc = this.getDocumentEl(); - (0, _mixins.off)(doc, 'mousemove', this.move); - (0, _mixins.off)(doc, 'keydown', this.handleKeyDown); - (0, _mixins.off)(doc, 'mouseup', this.stop); - this.updateRect(1); - (0, _underscore.isFunction)(this.onEnd) && this.onEnd(e, { docs: doc, config: config }); + if (model.get('removable')) { + tb.push({ + attributes: { + class: 'fa fa-trash-o' + }, + command: 'tlb-delete' + }); + } + + model.set('toolbar', tb); } + }, - /** - * Update rect - */ + /** + * Load traits + * @param {Array} traits + * @private + */ + loadTraits: function loadTraits(traits) { + var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + traits = traits || this.get('traits'); + traits = Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isFunction"])(traits) ? traits(this) : traits; - }, { - key: 'updateRect', - value: function updateRect(store) { - var el = this.el; - var resizer = this; - var config = this.opts; - var rect = this.rectDim; - var conStyle = this.container.style; - var updateTarget = this.updateTarget; - var selectedHandler = this.getSelectedHandler(); - var unitHeight = config.unitHeight, - unitWidth = config.unitWidth; - - // Use custom updating strategy if requested + if (!(traits instanceof trait_manager_model_Traits__WEBPACK_IMPORTED_MODULE_9__["default"])) { + var trt = new trait_manager_model_Traits__WEBPACK_IMPORTED_MODULE_9__["default"]([], this.opt); + trt.setTarget(this); - if ((0, _underscore.isFunction)(updateTarget)) { - updateTarget(el, rect, { - store: store, - selectedHandler: selectedHandler, - resizer: resizer, - config: config + if (traits.length) { + traits.forEach(function (tr) { + return tr.attributes && delete tr.attributes.value; }); - } else { - var elStyle = el.style; - elStyle.width = rect.w + unitWidth; - elStyle.height = rect.h + unitHeight; - } - - var unitRect = 'px'; - var rectEl = this.getElementPos(el); - conStyle.left = rectEl.left + unitRect; - conStyle.top = rectEl.top + unitRect; - conStyle.width = rectEl.width + unitRect; - conStyle.height = rectEl.height + unitRect; - } - - /** - * Get selected handler name - * @return {string} - */ - - }, { - key: 'getSelectedHandler', - value: function getSelectedHandler() { - var handlers = this.handlers; - - if (!this.selectedHandler) { - return; - } - - for (var n in handlers) { - if (handlers[n] === this.selectedHandler) return n; - } - } - - /** - * Handle ESC key - * @param {Event} e - */ - - }, { - key: 'handleKeyDown', - value: function handleKeyDown(e) { - if (e.keyCode === 27) { - // Rollback to initial dimensions - this.rectDim = this.startDim; - this.stop(e); - } - } - - /** - * Handle mousedown to check if it's possible to start resizing - * @param {Event} e - */ - - }, { - key: 'handleMouseDown', - value: function handleMouseDown(e) { - var el = e.target; - if (this.isHandler(el)) { - this.selectedHandler = el; - this.start(e); - } else if (el !== this.el) { - this.selectedHandler = ''; - this.blur(); - } - } - - /** - * All positioning logic - * @return {Object} - */ - - }, { - key: 'calc', - value: function calc(data) { - var value = void 0; - var opts = this.opts || {}; - var step = opts.step; - var startDim = this.startDim; - var minDim = opts.minDim; - var maxDim = opts.maxDim; - var deltaX = data.delta.x; - var deltaY = data.delta.y; - var startW = startDim.w; - var startH = startDim.h; - var box = { - t: 0, - l: 0, - w: startW, - h: startH - }; - - if (!data) return; - - var attr = data.handlerAttr; - if (~attr.indexOf('r')) { - value = (0, _mixins.normalizeFloat)(startW + deltaX * step, step); - value = Math.max(minDim, value); - maxDim && (value = Math.min(maxDim, value)); - box.w = value; - } - if (~attr.indexOf('b')) { - value = (0, _mixins.normalizeFloat)(startH + deltaY * step, step); - value = Math.max(minDim, value); - maxDim && (value = Math.min(maxDim, value)); - box.h = value; - } - if (~attr.indexOf('l')) { - value = (0, _mixins.normalizeFloat)(startW - deltaX * step, step); - value = Math.max(minDim, value); - maxDim && (value = Math.min(maxDim, value)); - box.w = value; - } - if (~attr.indexOf('t')) { - value = (0, _mixins.normalizeFloat)(startH - deltaY * step, step); - value = Math.max(minDim, value); - maxDim && (value = Math.min(maxDim, value)); - box.h = value; - } - - // Enforce aspect ratio (unless shift key is being held) - var ratioActive = opts.ratioDefault ? !data.keys.shift : data.keys.shift; - if (attr.indexOf('c') < 0 && ratioActive) { - var ratio = startDim.w / startDim.h; - if (box.w / box.h > ratio) { - box.h = Math.round(box.w / ratio); - } else { - box.w = Math.round(box.h * ratio); - } - } - - if (~attr.indexOf('l')) { - box.l = startDim.w - box.w; - } - if (~attr.indexOf('t')) { - box.t = startDim.h - box.h; + trt.add(traits); } - return box; + this.set('traits', trt, opts); } - }]); - - return Resizer; -}(); - -module.exports = { - init: function init(opts) { - return new Resizer(opts); - } -}; - -/***/ }), -/* 68 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; -/* WEBPACK VAR INJECTION */(function(Backbone) { - -var $ = Backbone.$; - -var getBoundingRect = function getBoundingRect(el, win) { - var w = win || window; - var rect = el.getBoundingClientRect(); - return { - left: rect.left + w.pageXOffset, - top: rect.top + w.pageYOffset, - width: rect.width, - height: rect.height - }; -}; - -module.exports = { - // TODO move to opts - setKey: function setKey(keys, command) { - //key(keys, command); + return this; }, - /** - * Return element position - * @param {HTMLElement} el - * @return {Object} + * Get the trait by id/name + * @param {String} id The `id` or `name` of the trait + * @return {Trait} Trait model + * @example + * const traitTitle = component.getTrait('title'); + * traitTitle && traitTitle.set('label', 'New label'); */ - getElementRect: function getElementRect(el) { - var posFetcher = this.opts.posFetcher || ''; - return posFetcher ? posFetcher(el, { - avoidFrameOffset: 1 - }) : getBoundingRect(el); + getTrait: function getTrait(id) { + return this.get('traits').filter(function (trait) { + return trait.get('id') === id || trait.get('name') === id; + })[0]; }, - /** - * Init the resizer - * @param {Object} opts + * Update a trait + * @param {String} id The `id` or `name` of the trait + * @param {Object} props Object with the props to update + * @return {this} + * @example + * component.updateTrait('title', { + * type: 'select', + * options: [ 'Option 1', 'Option 2' ], + * }); */ - init: function init(opts) { - this.setOptions(opts); - this.handleMouseDown = this.handleMouseDown.bind(this); - this.drag = this.drag.bind(this); - this.move = this.move.bind(this); - this.stop = this.stop.bind(this); - this.setKey('up, right, down, left', this.handleKey); + updateTrait: function updateTrait(id, props) { + var em = this.em; + var trait = this.getTrait(id); + trait && trait.set(props); + em && em.trigger('component:toggled'); return this; }, - /** - * Update options - * @param {Object} options + * Get the trait position index by id/name. Useful in case you want to + * replace some trait, at runtime, with something else. + * @param {String} id The `id` or `name` of the trait + * @return {Number} Index position of the current trait + * @example + * const traitTitle = component.getTraitIndex('title'); + * console.log(traitTitle); // 1 */ - setOptions: function setOptions(opts) { - this.opts = opts || {}; + getTraitIndex: function getTraitIndex(id) { + var trait = this.getTrait(id); + return trait ? this.get('traits').indexOf(trait) : trait; }, - /** - * Focus dragger on the element - * @param {HTMLElement} el + * Remove trait/s by id/s. + * @param {String|Array} id The `id`/`name` of the trait (or an array) + * @return {Array} Array of removed traits + * @example + * component.removeTrait('title'); + * component.removeTrait(['title', 'id']); */ - focus: function focus(el) { - // Avoid focusing on already focused element - if (el && el === this.el) { - return; - } - - this.getDocumentEl(el); - this.blur(); - this.el = el; - this.handlers = this.opts.dragHandlers || [el]; - - var elRect = this.getElementRect(el); //<-- TODO have wrong top:left - this.elRect = elRect; - this.startTop = elRect.top; - this.startLeft = elRect.left; - - // TODO init snapper + removeTrait: function removeTrait(id) { + var _this4 = this; - this.getDocumentEl().on('mousedown', this.handleMouseDown); + var em = this.em; + var ids = Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isArray"])(id) ? id : [id]; + var toRemove = ids.map(function (id) { + return _this4.getTrait(id); + }); + var removed = this.get('traits').remove(toRemove); + em && em.trigger('component:toggled'); + return removed; }, + /** + * Add trait/s by id/s. + * @param {String|Object|Array} trait Trait to add (or an array of traits) + * @param {Options} opts Options for the add + * @return {Array} Array of added traits + * @example + * component.addTrait('title', { at: 1 }); // Add title trait (`at` option is the position index) + * component.addTrait({ + * type: 'checkbox', + * name: 'disabled', + * }); + * component.addTrait(['title', {...}, ...]); + */ + addTrait: function addTrait(trait) { + var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + var em = this.em; + var added = this.get('traits').add(trait, opts); + em && em.trigger('component:toggled'); + return added; + }, /** - * Blur from the focused element + * Normalize input classes from array to array of objects + * @param {Array} arr + * @return {Array} + * @private */ - blur: function blur() { - this.getDocumentEl().off('mousedown', this.handleMouseDown); - this.el = null; + normalizeClasses: function normalizeClasses(arr) { + var res = []; + var em = this.em; + if (!em) return; + var clm = em.get('SelectorManager'); + if (!clm) return; + arr.forEach(function (val) { + var name = ''; + if (typeof val === 'string') name = val;else name = val.name; + var model = clm.add(name); + res.push(model); + }); + return res; }, - /** - * Start dragging - * @param {Event} e + * Override original clone method + * @private */ - start: function start(e) { - this.startPos = this.getMousePos(e); - var docs = this.getDocumentEl(); - docs.on('mousemove', this.drag); - docs.on('mouseup', this.stop); - - // Start callback - var onStart = this.opts.onStart; - if (typeof onStart === 'function') { - onStart(e, { - docs: docs, - el: this.el, - start: this.startPos, - elRect: this.elRect - }); - } + clone: function clone() { + var em = this.em; + var style = this.getStyle(); - this.drag(e); - }, + var attr = _objectSpread({}, this.attributes); + var opts = _objectSpread({}, this.opt); - /** - * Stop dragging - */ - stop: function stop(e) { - var docs = this.getDocumentEl(); - docs.off('mousemove', this.drag); - docs.off('mouseup', this.stop); - this.lockedAxis = null; + attr.attributes = _objectSpread({}, attr.attributes); + delete attr.attributes.id; + attr.components = []; + attr.classes = []; + attr.traits = []; + this.get('components').each(function (md, i) { + attr.components[i] = md.clone(); + }); + this.get('traits').each(function (md, i) { + attr.traits[i] = md.clone(); + }); + this.get('classes').each(function (md, i) { + attr.classes[i] = md.get('name'); + }); + attr.status = ''; + attr.view = ''; + opts.collection = null; - // Stop callback - var onEnd = this.opts.onEnd; - if (typeof onEnd === 'function') { - onEnd(e, { - docs: docs, - delta: this.delta, - end: { - x: this.startLeft + this.delta.x, - y: this.startTop + this.delta.y - } - }); + if (em && em.getConfig('avoidInlineStyle') && !Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isEmpty"])(style)) { + attr.style = style; } + + var cloned = new this.constructor(attr, opts); + var event = 'component:clone'; + em && em.trigger(event, cloned); + this.trigger(event, cloned); + return cloned; }, + /** + * Get the name of the component + * @return {String} + * */ + getName: function getName() { + var customName = this.get('name') || this.get('custom-name'); + var tag = this.get('tagName'); + tag = tag == 'div' ? 'box' : tag; + var name = this.get('type') || tag; + name = name.charAt(0).toUpperCase() + name.slice(1); + return customName || name; + }, /** - * Handle mousedown to check if it's possible to drag - * @param {Event} e + * Get the icon string + * @return {String} */ - handleMouseDown: function handleMouseDown(e) { - var el = e.target; - if (this.isHandler(el)) { - this.start(e); - } + getIcon: function getIcon() { + var icon = this.get('icon'); + return icon ? icon + ' ' : ''; }, - /** - * Detects if the clicked element is a valid handler - * @param {HTMLElement} el - * @return {Boolean} + * Return HTML string of the component + * @param {Object} [opts={}] Options + * @param {Object|Function} [opts.attributes=null] You can pass an object of custom attributes to replace + * with the current one or you can even pass a function to generate attributes dynamically + * @return {String} HTML string + * @example + * // Simple HTML return + * component.set({ tagName: 'span' }); + * component.setAttributes({ title: 'Hello' }); + * component.toHTML(); + * // -> + * + * // Custom attributes + * component.toHTML({ attributes: { 'data-test': 'Hello' } }); + * // -> + * + * // Custom dynamic attributes + * component.toHTML({ + * attributes(component, attributes) { + * if (component.get('tagName') == 'span') { + * attributes.title = 'Custom attribute'; + * } + * return attributes; + * }, + * }); + * // -> */ - isHandler: function isHandler(el) { - var handlers = this.handlers; + toHTML: function toHTML() { + var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var model = this; + var attrs = []; + var classes = []; + var tag = model.get('tagName'); + var sTag = model.get('void'); + var customAttr = opts.attributes; + var attributes = this.getAttrToHTML(); // Get custom attributes if requested - for (var n in handlers) { - if (handlers[n] === el) return true; + if (customAttr) { + if (Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isFunction"])(customAttr)) { + attributes = customAttr(model, attributes) || {}; + } else if (Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isObject"])(customAttr)) { + attributes = customAttr; + } } - return false; - }, + for (var attr in attributes) { + var val = attributes[attr]; + var value = Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isString"])(val) ? val.replace(/"/g, '"') : val; + + if (!Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isUndefined"])(value)) { + if (Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isBoolean"])(value)) { + value && attrs.push(attr); + } else { + attrs.push("".concat(attr, "=\"").concat(value, "\"")); + } + } + } + var attrString = attrs.length ? " ".concat(attrs.join(' ')) : ''; + var code = "<".concat(tag).concat(attrString).concat(sTag ? '/' : '', ">").concat(model.get('content')); + model.get('components').each(function (comp) { + return code += comp.toHTML(opts); + }); + !sTag && (code += "")); + return code; + }, /** - * Handle key press - * @param {Event} e - * @param {Object} handler + * Returns object of attributes for HTML + * @return {Object} + * @private */ - handleKey: function handleKey(e, handler) { - switch (handler.shortcut) { - case 'up': - this.move(0, -1); - break; - case 'right': - this.move(1, 0); - break; - case 'down': - this.move(0, 1); - break; - case 'left': - this.move(-1, 0); - break; - } + getAttrToHTML: function getAttrToHTML() { + var attr = this.getAttributes(); + delete attr.style; + return attr; }, - /** - * Returns documents + * Return a shallow copy of the model's attributes for JSON + * stringification. + * @return {Object} + * @private */ - getDocumentEl: function getDocumentEl(el) { - var el = el || this.el; - if (!this.$doc) { - var docs = [document]; - if (el) { - docs.push(el.ownerDocument); + toJSON: function toJSON() { + for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) { + args[_key2] = arguments[_key2]; + } + + var obj = backbone__WEBPACK_IMPORTED_MODULE_5___default.a.Model.prototype.toJSON.apply(this, args); + obj.attributes = this.getAttributes(); + delete obj.attributes.class; + delete obj.toolbar; + delete obj.traits; + + if (this.em.getConfig('avoidDefaults')) { + var defaults = Object(underscore__WEBPACK_IMPORTED_MODULE_2__["result"])(this, 'defaults'); + Object(underscore__WEBPACK_IMPORTED_MODULE_2__["forEach"])(defaults, function (value, key) { + if (['type', 'content'].indexOf(key) === -1 && obj[key] === value) { + delete obj[key]; + } + }); + + if (Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isEmpty"])(obj.type)) { + delete obj.type; } - this.$doc = $(docs); + + Object(underscore__WEBPACK_IMPORTED_MODULE_2__["forEach"])(['attributes', 'style'], function (prop) { + if (Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isEmpty"])(defaults[prop]) && Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isEmpty"])(obj[prop])) { + delete obj[prop]; + } + }); + Object(underscore__WEBPACK_IMPORTED_MODULE_2__["forEach"])(['classes', 'components'], function (prop) { + if (Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isEmpty"])(defaults[prop]) && !obj[prop].length) { + delete obj[prop]; + } + }); } - return this.$doc; + + return obj; + }, + + /** + * Return the component id + * @return {String} + */ + getId: function getId() { + var attrs = this.get('attributes') || {}; + return attrs.id || this.ccid || this.cid; }, + /** + * Set new id on the component + * @param {String} id + * @return {this} + */ + setId: function setId(id, opts) { + var attrs = _objectSpread({}, this.get('attributes')); + + attrs.id = id; + this.set('attributes', attrs, opts); + return this; + }, /** - * Get mouse coordinates - * @param {Event} event - * @return {Object} + * Get the DOM element of the component. + * This works only if the component is already rendered + * @return {HTMLElement} */ - getMousePos: function getMousePos(e) { - var mouseFetch = this.opts.mousePosFetcher; - return mouseFetch ? mouseFetch(e) : { - x: e.clientX, - y: e.clientY - }; + getEl: function getEl() { + return this.view && this.view.el; }, + /** + * Get the View of the component. + * This works only if the component is already rendered + * @return {ComponentView} + */ + getView: function getView() { + return this.view; + }, /** - * Drag event - * @param {Event} event + * Return script in string format, cleans 'function() {..' from scripts + * if it's a function + * @param {string|Function} script + * @return {string} + * @private */ - drag: function drag(e) { - var lockedAxis = this.lockedAxis; - var currentPos = this.getMousePos(e); - var delta = { - x: currentPos.x - this.startPos.x, - y: currentPos.y - this.startPos.y - }; - // Lock one axis - if (e.shiftKey) { - if (!lockedAxis) { - var relX = delta.x; - var relY = delta.y; - var absX = Math.abs(relX); - var absY = Math.abs(relY); + getScriptString: function getScriptString(script) { + var _this5 = this; - // Vertical or Horizontal lock - if (relY >= absX || relY <= -absX) { - lockedAxis = 'x'; - } else if (relX > absY || relX < -absY) { - lockedAxis = 'y'; - } - } - } else { - lockedAxis = null; - } + var scr = script || this.get('script'); - if (lockedAxis === 'x') { - delta.x = this.startPos.x; + if (!scr) { + return scr; + } // Need to convert script functions to strings + + + if (typeof scr == 'function') { + var scrStr = scr.toString().trim(); + scrStr = scrStr.replace(/^function[\s\w]*\(\)\s?\{/, '').replace(/\}$/, ''); + scr = scrStr.trim(); } - if (lockedAxis === 'y') { - delta.y = this.startPos.y; + var config = this.em.getConfig(); + var tagVarStart = escapeRegExp(config.tagVarStart || '{[ '); + var tagVarEnd = escapeRegExp(config.tagVarEnd || ' ]}'); + var reg = new RegExp("".concat(tagVarStart, "([\\w\\d-]*)").concat(tagVarEnd), 'g'); + scr = scr.replace(reg, function (match, v) { + // If at least one match is found I have to track this change for a + // better optimization inside JS generator + _this5.scriptUpdated(); + + var result = _this5.attributes[v] || ''; + return Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isArray"])(result) || _babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0___default()(result) == 'object' ? JSON.stringify(result) : result; + }); + return scr; + }, + emitUpdate: function emitUpdate(property) { + var em = this.em; + var event = 'component:update' + (property ? ":".concat(property) : ''); + + for (var _len3 = arguments.length, args = new Array(_len3 > 1 ? _len3 - 1 : 0), _key3 = 1; _key3 < _len3; _key3++) { + args[_key3 - 1] = arguments[_key3]; } - this.lockedAxis = lockedAxis; - this.delta = delta; - this.move(delta.x, delta.y); + property && this.updated.apply(this, [property, property && this.get(property), property && this.previous(property)].concat(args)); + this.trigger.apply(this, [event].concat(args)); + em && em.trigger.apply(em, [event, this].concat(args)); + }, - // Drag callback - var onDrag = this.opts.onDrag; - if (typeof onDrag === 'function') { - onDrag(e, { - delta: delta, - current: { - x: this.startLeft + delta.x, - y: this.startTop + delta.y - }, - lockedAxis: lockedAxis + /** + * Execute callback function on itself and all inner components + * @param {Function} clb Callback function, the model is passed as an argument + * @return {this} + * @example + * component.onAll(component => { + * // do something with component + * }) + */ + onAll: function onAll(clb) { + if (Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isFunction"])(clb)) { + clb(this); + this.components().forEach(function (model) { + return model.onAll(clb); }); } - // In case the mouse button was released outside of the window - if (e.which === 0) { - this.stop(e); - } + return this; }, - /** - * Move the element - * @param {integer} x - * @param {integer} y + * Remove the component + * @return {this} */ - move: function move(x, y) { - this.moveX(x); - this.moveY(y); + remove: function remove() { + var coll = this.collection; + return coll && coll.remove(this); }, /** - * Move in x direction - * @param {integer} x + * Reset id of the component and any of its style rule + * @param {Object} [opts={}] Options + * @return {this} + * @private */ - moveX: function moveX(x) { - var el = this.el; - var opts = this.opts; - var xPos = this.startLeft + x; - var setX = this.opts.setX; + resetId: function resetId() { + var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var em = this.em; + var oldId = this.getId(); + if (!oldId) return; + var newId = Component.createId(this); + this.setId(newId); + var rule = em && em.get('CssComposer').getIdRule(oldId); + var selector = rule && rule.get('selectors').at(0); + selector && selector.set('name', newId); + return this; + }, + _getStyleRule: function _getStyleRule() { + var _ref = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}, + id = _ref.id; - if (typeof setX === 'function') { - setX(xPos, { - el: el, - start: this.startLeft, - delta: x - }); - } else { - el.style.left = xPos + 'px'; - } + var em = this.em; + var idS = id || this.getId(); + return em && em.get('CssComposer').getIdRule(idS); + }, + _getStyleSelector: function _getStyleSelector(opts) { + var rule = this._getStyleRule(opts); + + return rule && rule.get('selectors').at(0); }, + _idUpdated: function _idUpdated(m, v) { + var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + if (opts.idUpdate) return; + var ccid = this.ccid; + + var _ref2 = this.get('attributes') || {}, + id = _ref2.id; + + var idPrev = (this.previous('attributes') || {}).id || ccid; + var list = Component.getList(this); // If the ID already exists I need to rollback to the old one + + if (list[id]) { + return this.setId(idPrev, { + idUpdate: 1 + }); + } // Remove the old ID reference and add the new one + + + delete list[idPrev]; + list[id] = this; + this.ccid = id; // Update the style selector name + + var selector = this._getStyleSelector({ + id: idPrev + }); + selector && selector.set({ + name: id, + label: id + }); + } +}, { + /** + * Detect if the passed element is a valid component. + * In case the element is valid an object abstracted + * from the element will be returned + * @param {HTMLElement} + * @return {Object} + * @private + */ + isComponent: function isComponent(el) { + return { + tagName: el.tagName ? el.tagName.toLowerCase() : '' + }; + }, /** - * Move in y direction - * @param {integer} y + * Relying simply on the number of components becomes a problem when you + * store and load them back, you might hit collisions with new components + * @param {Model} model + * @return {string} + * @private */ - moveY: function moveY(y) { - var el = this.el; - var opts = this.opts; - var yPos = this.startTop + y; - var setY = this.opts.setY; + createId: function createId(model) { + var list = Component.getList(model); - if (typeof setY === 'function') { - setY(yPos, { - el: el, - start: this.startTop, - delta: y - }); + var _model$get = model.get('attributes'), + id = _model$get.id; + + var nextId; + + if (id) { + nextId = Component.getIncrementId(id, list); + model.setId(nextId); } else { - el.style.top = yPos + 'px'; + nextId = Component.getNewId(list); } - } -}; -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(0))) -/***/ }), -/* 69 */ -/***/ (function(module, exports, __webpack_require__) { + list[nextId] = model; + return nextId; + }, + getNewId: function getNewId(list) { + var count = Object.keys(list).length; // Testing 1000000 components with `+ 2` returns 0 collisions -"use strict"; + var ilen = count.toString().length + 2; + var uid = (Math.random() + 1.1).toString(36).slice(-ilen); + var newId = "i".concat(uid); + while (list[newId]) { + newId = Component.getNewId(list); + } -var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; + return newId; + }, + getIncrementId: function getIncrementId(id, list) { + var counter = 1; + var newId = id; -var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; /** - * This module allows to create shortcuts for functions and commands (via command id) - * - * You can access the module in this way - * ```js - * const keymaps = editor.Keymaps; - * ``` - * - */ + while (list[newId]) { + counter++; + newId = "".concat(id, "-").concat(counter); + } + return newId; + }, -var _underscore = __webpack_require__(1); + /** + * The list of components is taken from the Components module. + * Initially, the list, was set statically on the Component object but it was + * not ok, as it was shared between multiple editor instances + */ + getList: function getList(model) { + var domc = model.opt && model.opt.domc; + return domc ? domc.componentsById : {}; + }, -var keymaster = __webpack_require__(23); + /** + * This method checks, for each parsed component and style object + * (are not Components/CSSRules yet), for duplicated id and fixes them + * This method is used in Components.js just after the parsing + */ + checkId: function checkId(components) { + var styles = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : []; + var list = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + var comps = Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isArray"])(components) ? components : [components]; + comps.forEach(function (comp) { + var _comp$attributes = comp.attributes, + attributes = _comp$attributes === void 0 ? {} : _comp$attributes, + components = comp.components; + var id = attributes.id; // Check if we have collisions with current components -module.exports = function () { - var em = void 0; - var config = void 0; - var keymaps = {}; - var configDef = { - defaults: { - 'core:undo': { - keys: '⌘+z, ctrl+z', - handler: 'core:undo' - }, - 'core:redo': { - keys: '⌘+shift+z, ctrl+shift+z', - handler: 'core:redo' - }, - 'core:copy': { - keys: '⌘+c, ctrl+c', - handler: 'core:copy' - }, - 'core:paste': { - keys: '⌘+v, ctrl+v', - handler: 'core:paste' + if (id && list[id]) { + var newId = Component.getIncrementId(id, list); + attributes.id = newId; // Update passed styles + + Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isArray"])(styles) && styles.forEach(function (style) { + var selectors = style.selectors; + selectors.forEach(function (sel, idx) { + if (sel === "#".concat(id)) selectors[idx] = "#".concat(newId); + }); + }); } - } - }; - return { + components && Component.checkId(components, styles, list); + }); + } +}); +/* harmony default export */ __webpack_exports__["default"] = (Component); - keymaster: keymaster, +/***/ }), - name: 'Keymaps', +/***/ "./src/dom_components/model/ComponentComment.js": +/*!******************************************************!*\ + !*** ./src/dom_components/model/ComponentComment.js ***! + \******************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - /** - * Get module configurations - * @return {Object} Configuration object - */ - getConfig: function getConfig() { - return config; - }, +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _ComponentTextNode__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./ComponentTextNode */ "./src/dom_components/model/ComponentTextNode.js"); - /** - * Initialize module - * @param {Object} config Configurations - * @private - */ - init: function init() { - var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - config = _extends({}, configDef, opts); - em = config.em; - this.em = em; - return this; - }, - onLoad: function onLoad() { - var defKeys = config.defaults; +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - for (var id in defKeys) { - var value = defKeys[id]; - this.add(id, value.keys, value.handler); - } - }, +/* harmony default export */ __webpack_exports__["default"] = (_ComponentTextNode__WEBPACK_IMPORTED_MODULE_1__["default"].extend({ + defaults: _objectSpread({}, _ComponentTextNode__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.defaults), + toHTML: function toHTML() { + return ""); + } +}, { + isComponent: function isComponent(el) { + if (el.nodeType == 8) { + return { + tagName: 'NULL', + type: 'comment', + content: el.textContent + }; + } + } +})); - /** - * Add new keymap - * @param {string} id Keymap id - * @param {string} keys Keymap keys, eg. `ctrl+a`, `⌘+z, ctrl+z` - * @param {Function|string} handler Keymap handler, might be a function - * @return {Object} Added keymap - * or just a command id as a string - * @example - * // 'ns' is just a custom namespace - * keymaps.add('ns:my-keymap', '⌘+j, ⌘+u, ctrl+j, alt+u', editor => { - * console.log('do stuff'); - * }); - * // or - * keymaps.add('ns:my-keymap', '⌘+s, ctrl+s', 'some-gjs-command'); - * - * // listen to events - * editor.on('keymap:emit', (id, shortcut, e) => { - * // ... - * }) - */ - add: function add(id, keys, handler) { - var em = this.em; - var cmd = em.get('Commands'); - var editor = em.getEditor(); - var keymap = { id: id, keys: keys, handler: handler }; - var pk = keymaps[id]; - pk && this.remove(id); - keymaps[id] = keymap; - keymaster(keys, function (e, h) { - // It's safer putting handlers resolution inside the callback - handler = (0, _underscore.isString)(handler) ? cmd.get(handler) : handler; - (typeof handler === 'undefined' ? 'undefined' : _typeof(handler)) == 'object' ? handler.run(editor) : handler(editor); - var args = [id, h.shortcut, e]; - em.trigger.apply(em, ['keymap:emit'].concat(args)); - em.trigger.apply(em, ['keymap:emit:' + id].concat(args)); - }); - em.trigger('keymap:add', keymap); - return keymap; - }, +/***/ }), +/***/ "./src/dom_components/model/ComponentImage.js": +/*!****************************************************!*\ + !*** ./src/dom_components/model/ComponentImage.js ***! + \****************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - /** - * Get the keymap by id - * @param {string} id Keymap id - * @return {Object} Keymap object - * @example - * keymaps.get('ns:my-keymap'); - * // -> {keys, handler}; - */ - get: function get(id) { - return keymaps[id]; - }, +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var _Component__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./Component */ "./src/dom_components/model/Component.js"); - /** - * Get all keymaps - * @return {Object} - * @example - * keymaps.getAll(); - * // -> {id1: {}, id2: {}}; - */ - getAll: function getAll() { - return keymaps; - }, +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - /** - * Remove the keymap by id - * @param {string} id Keymap id - * @return {Object} Removed keymap - * @example - * keymaps.remove('ns:my-keymap'); - * // -> {keys, handler}; - */ - remove: function remove(id) { - var em = this.em; - var keymap = this.get(id); - if (keymap) { - delete keymaps[id]; - keymaster.unbind(keymap.keys); - em && em.trigger('keymap:remove', keymap); - return keymap; - } + +var svgAttrs = 'xmlns="http://www.w3.org/2000/svg" width="100" viewBox="0 0 24 24" style="fill: rgba(0,0,0,0.15); transform: scale(0.75)"'; +/* harmony default export */ __webpack_exports__["default"] = (_Component__WEBPACK_IMPORTED_MODULE_2__["default"].extend({ + defaults: _objectSpread({}, _Component__WEBPACK_IMPORTED_MODULE_2__["default"].prototype.defaults, { + type: 'image', + tagName: 'img', + void: 1, + droppable: 0, + editable: 1, + highlightable: 0, + resizable: { + ratioDefault: 1 + }, + traits: ['alt'], + src: "\n \n "), + // Fallback image in case the src can't be loaded + // If you use SVG, xmlns="http://www.w3.org/2000/svg" is required + fallback: "\n \n "), + // File to load asynchronously once the model is rendered + file: '' + }), + initialize: function initialize(o, opt) { + _Component__WEBPACK_IMPORTED_MODULE_2__["default"].prototype.initialize.apply(this, arguments); + var attr = this.get('attributes'); + if (attr.src) this.set('src', attr.src); + }, + initToolbar: function initToolbar() { + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; } - }; -}; -/***/ }), -/* 70 */ -/***/ (function(module, exports, __webpack_require__) { + _Component__WEBPACK_IMPORTED_MODULE_2__["default"].prototype.initToolbar.apply(this, args); + var em = this.em; -"use strict"; + if (em) { + var cmd = em.get('Commands'); + var cmdName = 'image-editor'; // Add Image Editor button only if the default command exists + if (cmd.has(cmdName)) { + var hasButtonBool = false; + var tb = this.get('toolbar'); -var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; /** - * This module allows to manage the stack of changes applied in canvas - * - * You can access the module in this way - * ```js - * const um = editor.UndoManager; - * ``` - * - */ + for (var i = 0; i < tb.length; i++) { + if (tb[i].command === 'image-editor') { + hasButtonBool = true; + break; + } + } + if (!hasButtonBool) { + tb.push({ + attributes: { + class: 'fa fa-pencil' + }, + command: cmdName + }); + this.set('toolbar', tb); + } + } + } + }, -var _backboneUndo = __webpack_require__(71); + /** + * Returns object of attributes for HTML + * @return {Object} + * @private + */ + getAttrToHTML: function getAttrToHTML() { + for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) { + args[_key2] = arguments[_key2]; + } -var _backboneUndo2 = _interopRequireDefault(_backboneUndo); + var attr = _Component__WEBPACK_IMPORTED_MODULE_2__["default"].prototype.getAttrToHTML.apply(this, args); + var src = this.get('src'); + if (src) attr.src = src; + return attr; + }, + getSrcResult: function getSrcResult() { + var opt = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var src = this.get(opt.fallback ? 'fallback' : 'src') || ''; + var result = src; -function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } + if (src && src.substr(0, 4) === ' 0 && arguments[0] !== undefined ? arguments[0] : {}; + return { + hostname: el.hostname, + pathname: el.pathname, + protocol: el.protocol, + search: el.search, + hash: el.hash, + port: el.port, + query: query + }; + } +}, { + /** + * Detect if the passed element is a valid component. + * In case the element is valid an object abstracted + * from the element will be returned + * @param {HTMLElement} + * @return {Object} + * @private + */ + isComponent: function isComponent(el) { + var result = ''; - config = _extends({}, opts, configDef); - em = config.em; - this.em = em; - um = new _backboneUndo2.default({ track: true, register: [] }); - um.changeUndoType('change', { condition: false }); - var customUndoType = { - on: function on(object, value) { - var opt = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + if (el.tagName == 'IMG') { + result = { + type: 'image' + }; + } - !beforeCache && (beforeCache = object.previousAttributes()); + return result; + } +})); - if (opt.avoidStore) { - return; - } else { - var result = { - object: object, - before: beforeCache, - after: object.toJSON() - }; - beforeCache = null; - return result; - } - }, - undo: function undo(model, bf, af, opt) { - model.set(bf); - }, - redo: function redo(model, bf, af, opt) { - model.set(af); - } - }; +/***/ }), - var events = ['style', 'attributes', 'content', 'src']; - events.forEach(function (ev) { - return um.addUndoType('change:' + ev, customUndoType); - }); - um.on('undo redo', function () { - return em.trigger('change:selectedComponent change:canvasOffset'); - }); - ['undo', 'redo'].forEach(function (ev) { - return um.on(ev, function () { - return em.trigger(ev); - }); - }); +/***/ "./src/dom_components/model/ComponentLabel.js": +/*!****************************************************!*\ + !*** ./src/dom_components/model/ComponentLabel.js ***! + \****************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - return this; - }, +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _ComponentText__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./ComponentText */ "./src/dom_components/model/ComponentText.js"); - /** - * Get module configurations - * @return {Object} Configuration object - * @example - * const config = um.getConfig(); - * // { ... } - */ - getConfig: function getConfig() { - return config; - }, +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - /** - * Add an entity (Model/Collection) to track - * Note: New Components and CSSRules will be added automatically - * @param {Model|Collection} entity Entity to track - * @return {this} - * @example - * um.add(someModelOrCollection); - */ - add: function add(entity) { - um.register(entity); - return this; - }, +/* harmony default export */ __webpack_exports__["default"] = (_ComponentText__WEBPACK_IMPORTED_MODULE_1__["default"].extend({ + defaults: _objectSpread({}, _ComponentText__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.defaults, { + tagName: 'label', + traits: ['id', 'title', 'for'] + }) +}, { + isComponent: function isComponent(el) { + if (el.tagName == 'LABEL') { + return { + type: 'label' + }; + } + } +})); - /** - * Remove and stop tracking the entity (Model/Collection) - * @param {Model|Collection} entity Entity to remove - * @return {this} - * @example - * um.remove(someModelOrCollection); - */ - remove: function remove(entity) { - um.unregister(entity); - return this; - }, +/***/ }), +/***/ "./src/dom_components/model/ComponentLink.js": +/*!***************************************************!*\ + !*** ./src/dom_components/model/ComponentLink.js ***! + \***************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - /** - * Remove all entities - * @return {this} - * @example - * um.removeAll(); - */ - removeAll: function removeAll() { - um.unregisterAll(); - return this; - }, +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _ComponentText__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./ComponentText */ "./src/dom_components/model/ComponentText.js"); - /** - * Start/resume tracking changes - * @return {this} - * @example - * um.start(); - */ - start: function start() { - um.startTracking(); - return this; - }, +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - /** - * Stop tracking changes - * @return {this} - * @example - * um.stop(); - */ - stop: function stop() { - um.stopTracking(); - return this; - }, +/* harmony default export */ __webpack_exports__["default"] = (_ComponentText__WEBPACK_IMPORTED_MODULE_1__["default"].extend({ + defaults: _objectSpread({}, _ComponentText__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.defaults, { + type: 'link', + tagName: 'a', + traits: ['title', 'href', 'target'] + }), - /** - * Undo last change - * @return {this} - * @example - * um.undo(); - */ - undo: function undo() { - if (!em.get('Canvas').isInputFocused()) um.undo(1); - return this; - }, + /** + * Returns object of attributes for HTML + * @return {Object} + * @private + */ + getAttrToHTML: function getAttrToHTML() { + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; + } + var attr = _ComponentText__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.getAttrToHTML.apply(this, args); + delete attr.onmousedown; + return attr; + } +}, { + isComponent: function isComponent(el) { + var result; + var avoidEdit; - /** - * Undo all changes - * @return {this} - * @example - * um.undoAll(); - */ - undoAll: function undoAll() { - um.undoAll(); - return this; - }, + if (el.tagName == 'A') { + result = { + type: 'link', + editable: 0 + }; // The link is editable only if, at least, one of its + // children is a text node (not empty one) + var children = el.childNodes; + var len = children.length; + if (!len) delete result.editable; - /** - * Redo last change - * @return {this} - * @example - * um.redo(); - */ - redo: function redo() { - if (!em.get('Canvas').isInputFocused()) um.redo(1); - return this; - }, + for (var i = 0; i < len; i++) { + var child = children[i]; + if (child.nodeType == 3 && child.textContent.trim() != '') { + delete result.editable; + break; + } + } + } - /** - * Redo all changes - * @return {this} - * @example - * um.redoAll(); - */ - redoAll: function redoAll() { - um.redoAll(); - return this; - }, + return result; + } +})); +/***/ }), - /** - * Checks if exists an available undo - * @return {Boolean} - * @example - * um.hasUndo(); - */ - hasUndo: function hasUndo() { - return um.isAvailable('undo'); - }, +/***/ "./src/dom_components/model/ComponentMap.js": +/*!**************************************************!*\ + !*** ./src/dom_components/model/ComponentMap.js ***! + \**************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _ComponentImage__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./ComponentImage */ "./src/dom_components/model/ComponentImage.js"); +/* harmony import */ var _Component__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./Component */ "./src/dom_components/model/Component.js"); - /** - * Checks if exists an available redo - * @return {Boolean} - * @example - * um.hasRedo(); - */ - hasRedo: function hasRedo() { - return um.isAvailable('redo'); - }, +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - /** - * Get stack of changes - * @return {Collection} - * @example - * const stack = um.getStack(); - * stack.each(item => ...); - */ - getStack: function getStack() { - return um.stack; - }, +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - /** - * Clear the stack - * @return {this} - * @example - * um.clear(); - */ - clear: function clear() { - um.clear(); - return this; + +/* harmony default export */ __webpack_exports__["default"] = (_ComponentImage__WEBPACK_IMPORTED_MODULE_1__["default"].extend({ + defaults: _objectSpread({}, _ComponentImage__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.defaults, { + type: 'map', + src: '', + void: 0, + mapUrl: 'https://maps.google.com/maps', + tagName: 'iframe', + mapType: 'q', + address: '', + zoom: '1', + attributes: { + frameborder: 0 }, - getInstance: function getInstance() { - return um; + toolbar: _Component__WEBPACK_IMPORTED_MODULE_2__["default"].prototype.defaults.toolbar, + traits: [{ + label: 'Address', + name: 'address', + placeholder: 'eg. London, UK', + changeProp: 1 + }, { + type: 'select', + label: 'Map type', + name: 'mapType', + changeProp: 1, + options: [{ + value: 'q', + name: 'Roadmap' + }, { + value: 'w', + name: 'Satellite' + }] + }, { + label: 'Zoom', + name: 'zoom', + type: 'range', + min: '1', + max: '20', + changeProp: 1 + }] + }), + initialize: function initialize(o, opt) { + if (this.get('src')) this.parseFromSrc();else this.updateSrc(); + _ComponentImage__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.initialize.apply(this, arguments); + this.listenTo(this, 'change:address change:zoom change:mapType', this.updateSrc); + }, + updateSrc: function updateSrc() { + this.set('src', this.getMapUrl()); + }, + + /** + * Returns url of the map + * @return {string} + * @private + */ + getMapUrl: function getMapUrl() { + var md = this; + var addr = md.get('address'); + var zoom = md.get('zoom'); + var type = md.get('mapType'); + var size = ''; + addr = addr ? '&q=' + addr : ''; + zoom = zoom ? '&z=' + zoom : ''; + type = type ? '&t=' + type : ''; + var result = md.get('mapUrl') + '?' + addr + zoom + type; + result += '&output=embed'; + return result; + }, + + /** + * Set attributes by src string + * @private + */ + parseFromSrc: function parseFromSrc() { + var uri = this.parseUri(this.get('src')); + var qr = uri.query; + if (qr.q) this.set('address', qr.q); + if (qr.z) this.set('zoom', qr.z); + if (qr.t) this.set('mapType', qr.t); + } +}, { + /** + * Detect if the passed element is a valid component. + * In case the element is valid an object abstracted + * from the element will be returned + * @param {HTMLElement} + * @return {Object} + * @private + */ + isComponent: function isComponent(el) { + var result = ''; + + if (el.tagName == 'IFRAME' && /maps\.google\.com/.test(el.src)) { + result = { + type: 'map', + src: el.src + }; } - }; -}; + + return result; + } +})); /***/ }), -/* 71 */ -/***/ (function(module, exports, __webpack_require__) { -var __WEBPACK_AMD_DEFINE_FACTORY__, __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;/*! - * Backbone.Undo.js v0.2 - * - * Copyright (c)2013 Oliver Sartun - * Released under the MIT License - * - * Documentation and full license available at - * https://github.com/osartun/Backbone.Undo.js - */ +/***/ "./src/dom_components/model/ComponentScript.js": +/*!*****************************************************!*\ + !*** ./src/dom_components/model/ComponentScript.js ***! + \*****************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _Component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Component */ "./src/dom_components/model/Component.js"); -(function (factory) { - if (true) { - // AMD support - !(__WEBPACK_AMD_DEFINE_ARRAY__ = [__webpack_require__(1), __webpack_require__(72)], __WEBPACK_AMD_DEFINE_FACTORY__ = (factory), - __WEBPACK_AMD_DEFINE_RESULT__ = (typeof __WEBPACK_AMD_DEFINE_FACTORY__ === 'function' ? - (__WEBPACK_AMD_DEFINE_FACTORY__.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__)) : __WEBPACK_AMD_DEFINE_FACTORY__), - __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)); - } else if (typeof exports !== 'undefined') { - // CommonJS support - module.exports = factory( - require("underscore"), - require("backbone") - ); - } else { - // Non-modular execution - factory(_, Backbone); - } -})(function (_, Backbone) { - var core_slice = Array.prototype.slice; +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - /** - * As call is faster than apply, this is a faster version of apply as it uses call. - * - * @param {Function} fn The function to execute - * @param {Object} ctx The context the function should be called in - * @param {Array} args The array of arguments that should be applied to the function - * @return Forwards whatever the called function returns - */ - function apply (fn, ctx, args) { - return args.length <= 4 ? - fn.call(ctx, args[0], args[1], args[2], args[3]) : - fn.apply(ctx, args); - } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - /** - * Uses slice on an array or an array-like object. - * - * @param {Array|Object} arr The array or array-like object. - * @param {Number} [index] The index from where the array should be sliced. Default is 0. - * @return {Array} The sliced array - */ - function slice (arr, index) { - return core_slice.call(arr, index); - } - /** - * Checks if an object has one or more specific keys. The keys - * don't have to be an owned property. - * You can call this function either this way: - * hasKeys(obj, ["a", "b", "c"]) - * or this way: - * hasKeys(obj, "a", "b", "c") - * - * @param {Object} obj The object to check on - * @param {Array} keys The keys to check for - * @return {Boolean} True, if the object has all those keys - */ - function hasKeys (obj, keys) { - if (obj == null) return false; - if (!_.isArray(keys)) { - keys = slice(arguments, 1); - } - return _.all(keys, function (key) { - return key in obj; - }); - } +/* harmony default export */ __webpack_exports__["default"] = (_Component__WEBPACK_IMPORTED_MODULE_1__["default"].extend({ + defaults: _objectSpread({}, _Component__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.defaults, { + type: 'script', + droppable: false, + draggable: false, + layerable: false + }) +}, { + isComponent: function isComponent(el) { + if (el.tagName == 'SCRIPT') { + var result = { + type: 'script' + }; - /** - * Returns a number that is unique per call stack. The number gets - * changed after the call stack has been completely processed. - * - * @return {number} MagicFusionIndex - */ - var getMagicFusionIndex = (function () { - // If you add several models to a collection or set several - // attributes on a model all in sequence and yet all for - // example in one function, then several Undo-Actions are - // generated. - // If you want to undo your last action only the last model - // would be removed from the collection or the last set - // attribute would be changed back to its previous value. - // To prevent that we have to figure out a way to combine - // all those actions that happened "at the same time". - // Timestamps aren't exact enough. A complex routine could - // run several milliseconds and in that time produce a lot - // of actions with different timestamps. - // Instead we take advantage of the single-threadedness of - // JavaScript: + if (el.src) { + result.src = el.src; + result.onload = el.onload; + } - var callstackWasIndexed = false, magicFusionIndex = -1; - function indexCycle() { - magicFusionIndex++; - callstackWasIndexed = true; - _.defer(function () { - // Here comes the magic. With a Timeout of 0 - // milliseconds this function gets called whenever - // the current callstack is completed - callstackWasIndexed = false; - }) - } - return function () { - if (!callstackWasIndexed) { - indexCycle(); - } - return magicFusionIndex; - } - })(); + return result; + } + } +})); - /** - * To prevent binding a listener several times to one - * object, we register the objects in an ObjectRegistry - * - * @constructor - */ - function ObjectRegistry () { - // This uses two different ways of storing - // objects: In case the object has a cid - // (which Backbone objects typically have) - // it uses this cid as an index. That way - // the Array's length attribute doesn't - // change and the object isn't an item - // in the array, but an object-property. - // Otherwise it's added to the Array as an - // item. - // That way we can use the fast property- - // lookup and only have to fall back to - // iterating over the array in case - // non-Backbone-objects are registered. - this.registeredObjects = []; - // To return a list of all registered - // objects in the 'get' method we have to - // store the objects that have a cid in - // an additional array. - this.cidIndexes = []; - } - ObjectRegistry.prototype = { - /** - * Returns whether the object is already registered in this ObjectRegistry or not. - * - * @this {ObjectRegistry} - * @param {Object} obj The object to check - * @return {Boolean} True if the object is already registered - */ - isRegistered: function (obj) { - // This is where we get a performance boost - // by using the two different ways of storing - // objects. - return obj && obj.cid ? this.registeredObjects[obj.cid] : _.contains(this.registeredObjects, obj); - }, - /** - * Registers an object in this ObjectRegistry. - * - * @this {ObjectRegistry} - * @param {Object} obj The object to register - * @return {undefined} - */ - register: function (obj) { - if (!this.isRegistered(obj)) { - if (obj && obj.cid) { - this.registeredObjects[obj.cid] = obj; - this.cidIndexes.push(obj.cid); - } else { - this.registeredObjects.push(obj); - } - return true; - } - return false; - }, - /** - * Unregisters an object from this ObjectRegistry. - * - * @this {ObjectRegistry} - * @param {Object} obj The object to unregister - * @return {undefined} - */ - unregister: function (obj) { - if (this.isRegistered(obj)) { - if (obj && obj.cid) { - delete this.registeredObjects[obj.cid]; - this.cidIndexes.splice(_.indexOf(this.cidIndexes, obj.cid), 1); - } else { - var i = _.indexOf(this.registeredObjects, obj); - this.registeredObjects.splice(i, 1); - } - return true; - } - return false; - }, - /** - * Returns an array of all objects that are currently in this ObjectRegistry. - * - * @return {Array} An array of all the objects which are currently in the ObjectRegistry - */ - get: function () { - return (_.map(this.cidIndexes, function (cid) {return this.registeredObjects[cid];}, this)).concat(this.registeredObjects); - } - } +/***/ }), - /** - * Binds or unbinds the "all"-listener for one or more objects. - * - * @param {String} which Either "on" or "off" - * @param {Object[]} objects Array of the objects on which the "all"-listener should be bound / unbound to - * @param {Function} [fn] The function that should be bound / unbound. Optional in case of "off" - * @param {Object} [ctx] The context the function should be called in - * @return {undefined} - */ - function onoff(which, objects, fn, ctx) { - for (var i = 0, l = objects.length, obj; i < l; i++) { - obj = objects[i]; - if (!obj) continue; - if (which === "on") { - if (!ctx.objectRegistry.register(obj)) { - // register returned false, so obj was already registered - continue; - } - } else { - if (!ctx.objectRegistry.unregister(obj)) { - // unregister returned false, so obj wasn't registered - continue; - } - } - if (_.isFunction(obj[which])) { - obj[which]("all", fn, ctx); - } - } - } +/***/ "./src/dom_components/model/ComponentSvg.js": +/*!**************************************************!*\ + !*** ./src/dom_components/model/ComponentSvg.js ***! + \**************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - /** - * Calls the undo/redo-function for a specific action. - * - * @param {String} which Either "undo" or "redo" - * @param {Object} action The Action's attributes - * @return {undefined} - */ - function actionUndoRedo (which, action) { - var type = action.type, undoTypes = action.undoTypes, fn = !undoTypes[type] || undoTypes[type][which]; - if (_.isFunction(fn)) { - fn(action.object, action.before, action.after, action.options); - } - } +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _Component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Component */ "./src/dom_components/model/Component.js"); - /** - * The main undo/redo function. - * - * @param {String} which Either "undo" or "redo" - * @param {UndoManager} manager The UndoManager-instance on which an "undo"/"redo"-Event is triggered afterwards - * @param {UndoStack} stack The UndoStack on which we perform - * @param {Boolean} magic If true, undoes / redoes all actions with the same magicFusionIndex - * @param {Boolean} everything If true, undoes / redoes every action that had been tracked - * @return {undefined} - */ - function managerUndoRedo (which, manager, stack, magic, everything) { - if (stack.isCurrentlyUndoRedoing || - (which === "undo" && stack.pointer === -1) || - (which === "redo" && stack.pointer === stack.length - 1)) { - // We're either currently in an undo- / redo-process or - // we reached the end of the stack - return; - } - stack.isCurrentlyUndoRedoing = true; - var action, actions, isUndo = which === "undo"; - if (everything) { - // Undo / Redo all steps until you reach the stack's beginning / end - actions = isUndo && stack.pointer === stack.length - 1 || // If at the stack's end calling undo - !isUndo && stack.pointer === -1 ? // or at the stack's beginning calling redo - _.clone(stack.models) : // => Take all the models. Otherwise: - core_slice.apply(stack.models, isUndo ? [0, stack.pointer] : [stack.pointer, stack.length - 1]); - } else { - // Undo / Redo only one step - action = stack.at(isUndo ? stack.pointer : stack.pointer + 1); - actions = magic ? stack.where({"magicFusionIndex": action.get("magicFusionIndex")}) : [action]; - } - - stack.pointer += (isUndo ? -1 : 1) * actions.length; - while (action = isUndo ? actions.pop() : actions.shift()) { - // Here we're calling the Action's undo / redo method - action[which](); - } - stack.isCurrentlyUndoRedoing = false; - manager.trigger(which, manager); - } +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - /** - * Checks whether an UndoAction should be created or not. Therefore it checks - * whether a "condition" property is set in the undoTypes-object of the specific - * event type. If not, it returns true. If it's set and a boolean, it returns it. - * If it's a function, it returns its result, converting it into a boolean. - * Otherwise it returns true. - * - * @param {Object} undoTypesType The object within the UndoTypes that holds the function for this event type (i.e. "change") - * @param {Arguments} args The arguments the "condition" function is called with - * @return {Boolean} True, if an UndoAction should be created - */ - function validateUndoActionCreation (undoTypesType, args) { - var condition = undoTypesType.condition, type = typeof condition; - return type === "function" ? !!apply(condition, undoTypesType, args) : - type === "boolean" ? condition : true; - } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - /** - * Adds an Undo-Action to the stack. - * - * @param {UndoStack} stack The undostack the action should be added to. - * @param {String} type The event type (i.e. "change") - * @param {Arguments} args The arguments passed to the undoTypes' "on"-handler - * @param {OwnedUndoTypes} undoTypes The undoTypes-object which has the "on"-handler - * @return {undefined} - */ - function addToStack(stack, type, args, undoTypes) { - if (stack.track && !stack.isCurrentlyUndoRedoing && type in undoTypes && - validateUndoActionCreation(undoTypes[type], args)) { - // An UndoAction should be created - var res = apply(undoTypes[type]["on"], undoTypes[type], args), diff; - if (hasKeys(res, "object", "before", "after")) { - res.type = type; - res.magicFusionIndex = getMagicFusionIndex(); - res.undoTypes = undoTypes; - if (stack.pointer < stack.length - 1) { - // New Actions must always be added to the end of the stack. - // If the pointer is not pointed to the last action in the - // stack, presumably because actions were undone before, then - // all following actions must be discarded - var diff = stack.length - stack.pointer - 1; - while (diff--) { - stack.pop(); - } - } - stack.pointer = stack.length; - stack.add(res); - if (stack.length > stack.maximumStackLength) { - stack.shift(); - stack.pointer--; - } - } - } - } +/* harmony default export */ __webpack_exports__["default"] = (_Component__WEBPACK_IMPORTED_MODULE_1__["default"].extend({ + defaults: _objectSpread({}, _Component__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.defaults, { + highlightable: 0 + }), + getName: function getName() { + var name = this.get('tagName'); + var customName = this.get('custom-name'); + name = name.charAt(0).toUpperCase() + name.slice(1); + return customName || name; + } +}, { + isComponent: function isComponent(el) { + if (SVGElement && el instanceof SVGElement) { + // Some SVG elements require uppercase letters (eg. ) + var tagName = el.tagName; // Make the root resizable - /** - * Predefined UndoTypes object with default handlers for the most common events. - * @type {Object} - */ - var UndoTypes = { - "add": { - "undo": function (collection, ignore, model, options) { - // Undo add = remove - collection.remove(model, options); - }, - "redo": function (collection, ignore, model, options) { - // Redo add = add - if (options.index) { - options.at = options.index; - } - collection.add(model, options); - }, - "on": function (model, collection, options) { - return { - object: collection, - before: undefined, - after: model, - options: _.clone(options) - }; - } - }, - "remove": { - "undo": function (collection, model, ignore, options) { - if ("index" in options) { - options.at = options.index; - } - collection.add(model, options); - }, - "redo": function (collection, model, ignore, options) { - collection.remove(model, options); - }, - "on": function (model, collection, options) { - return { - object: collection, - before: model, - after: undefined, - options: _.clone(options) - }; - } - }, - "change": { - "undo": function (model, before, after, options) { - if (_.isEmpty(before)) { - _.each(_.keys(after), model.unset, model); - } else { - model.set(before); - if (options && options.unsetData && options.unsetData.before && options.unsetData.before.length) { - _.each(options.unsetData.before, model.unset, model); - } - } - }, - "redo": function (model, before, after, options) { - if (_.isEmpty(after)) { - _.each(_.keys(before), model.unset, model); - } else { - model.set(after); - if (options && options.unsetData && options.unsetData.after && options.unsetData.after.length) { - _.each(options.unsetData.after, model.unset, model); - } - } - }, - "on": function (model, options) { - var - afterAttributes = model.changedAttributes(), - keysAfter = _.keys(afterAttributes), - previousAttributes = _.pick(model.previousAttributes(), keysAfter), - keysPrevious = _.keys(previousAttributes), - unsetData = (options || (options = {})).unsetData = { - after: [], - before: [] - }; + var resizable = tagName == 'svg' ? true : false; + return { + tagName: tagName, + type: 'svg', + resizable: resizable + }; + } + } +})); - if (keysAfter.length != keysPrevious.length) { - // There are new attributes or old attributes have been unset - if (keysAfter.length > keysPrevious.length) { - // New attributes have been added - _.each(keysAfter, function (val) { - if (!(val in previousAttributes)) { - unsetData.before.push(val); - } - }, this); - } else { - // Old attributes have been unset - _.each(keysPrevious, function (val) { - if (!(val in afterAttributes)) { - unsetData.after.push(val); - } - }) - } - } - return { - object: model, - before: previousAttributes, - after: afterAttributes, - options: _.clone(options) - }; - } - }, - "reset": { - "undo": function (collection, before, after) { - collection.reset(before); - }, - "redo": function (collection, before, after) { - collection.reset(after); - }, - "on": function (collection, options) { - return { - object: collection, - before: options.previousModels, - after: _.clone(collection.models) - }; - } - } - }; +/***/ }), - /** - * Every UndoManager instance has an own undoTypes object - * which is an instance of OwnedUndoTypes. OwnedUndoTypes' - * prototype is the global UndoTypes object. Changes to the - * global UndoTypes object take effect on every instance of - * UndoManager as the object is its prototype. And yet every - * local UndoTypes object can be changed individually. - * - * @constructor - */ - function OwnedUndoTypes () {} - OwnedUndoTypes.prototype = UndoTypes; +/***/ "./src/dom_components/model/ComponentTable.js": +/*!****************************************************!*\ + !*** ./src/dom_components/model/ComponentTable.js ***! + \****************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - /** - * Adds, changes or removes an undo-type from an UndoTypes-object. - * You can call it this way: - * manipulateUndoType (1, "reset", {"on": function () {}}, undoTypes) - * or this way to perform bulk actions: - * manipulateUndoType (1, {"reset": {"on": function () {}}}, undoTypes) - * In case of removing undo-types you can pass an Array for performing - * bulk actions: - * manipulateUndoType(2, ["reset", "change"], undoTypes) - * - * @param {Number} manipType Indicates the kind of action to execute: 0 for add, 1 for change, 2 for remove - * @param {String|Object|Array} undoType The type of undoType that should be added/changed/removed. Can be an object / array to perform bulk actions - * @param {Object} [fns] Object with the functions to add / change. Is optional in case you passed an object as undoType that contains these functions - * @param {OwnedUndoTypes|UndoTypes} undoTypesInstance The undoTypes object to act on - * @return {undefined} - */ - function manipulateUndoType (manipType, undoType, fns, undoTypesInstance) { - // manipType, passed by the calling function - // 0: add - // 1: change - // 2: remove - if (typeof undoType === "object") { - // bulk action. Iterate over this data. - return _.each(undoType, function (val, key) { - if (manipType === 2) { // remove - // undoType is an array - manipulateUndoType (manipType, val, fns, undoTypesInstance); - } else { - // undoType is an object - manipulateUndoType (manipType, key, val, fns); - } - }) - } +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _Component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Component */ "./src/dom_components/model/Component.js"); - switch (manipType) { - case 0: // add - if (hasKeys(fns, "undo", "redo", "on") && _.all(_.pick(fns, "undo", "redo", "on"), _.isFunction)) { - undoTypesInstance[undoType] = fns; - } - break; - case 1: // change - if (undoTypesInstance[undoType] && _.isObject(fns)) { - // undoTypeInstance[undoType] may be a prototype's property - // So, if we did this _.extend(undoTypeInstance[undoType], fns) - // we would extend the object on the prototype which means - // that this change would have a global effect - // Instead we just want to manipulate this instance. That's why - // we're doing this: - undoTypesInstance[undoType] = _.extend({}, undoTypesInstance[undoType], fns); - } - break; - case 2: // remove - delete undoTypesInstance[undoType]; - break; - } - return this; - } - /** - * Instantiating "Action" creates the UndoActions that - * are collected in an UndoStack. It holds all relevant - * data to undo / redo an action and has an undo / redo - * method. - */ - var Action = Backbone.Model.extend({ - defaults: { - type: null, // "add", "change", "reset", etc. - object: null, // The object on which the action occurred - before: null, // The previous values which were changed with this action - after: null, // The values after this action - magicFusionIndex: null // The magicFusionIndex helps to combine - // all actions that occurred "at the same time" to undo/redo them altogether - }, - /** - * Undoes this action. - * @param {OwnedUndoTypes|UndoTypes} undoTypes The undoTypes object which contains the "undo"-handler that should be used - * @return {undefined} - */ - undo: function (undoTypes) { - actionUndoRedo("undo", this.attributes); - }, - /** - * Redoes this action. - * @param {OwnedUndoTypes|UndoTypes} undoTypes The undoTypes object which contains the "redo"-handler that should be used - * @return {undefined} - */ - redo: function (undoTypes) { - actionUndoRedo("redo", this.attributes); - } - }), - /** - * An UndoStack is a collection of UndoActions in - * chronological order. - */ - UndoStack = Backbone.Collection.extend({ - model: Action, - pointer: -1, // The pointer indicates the index where we are located within the stack. We start at -1 - track: false, - isCurrentlyUndoRedoing: false, - maximumStackLength: Infinity, - setMaxLength: function (val) { - this.maximumStackLength = val; - } - }), - /** - * An instance of UndoManager can keep track of - * changes to objects and helps to undo them. - */ - UndoManager = Backbone.Model.extend({ - defaults: { - maximumStackLength: Infinity, - track: false - }, - /** - * The constructor function. - * @param {attr} [attr] Object with parameters. The available parameters are: - * - maximumStackLength {number} Set the undo-stack's maximum size - * - track {boolean} Start tracking changes right away - * @return {undefined} - */ - initialize: function (attr) { - this.stack = new UndoStack; - this.objectRegistry = new ObjectRegistry(); - this.undoTypes = new OwnedUndoTypes(); +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - // sync the maximumStackLength attribute with our stack - this.stack.setMaxLength(this.get("maximumStackLength")); - this.on("change:maximumStackLength", function (model, value) { - this.stack.setMaxLength(value); - }, this); +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - // Start tracking, if attr.track == true - if (attr && attr.track) { - this.startTracking(); - } - // Register objects passed in the "register" attribute - if (attr && attr.register) { - if (_.isArray(attr.register) || _.isArguments(attr.register)) { - apply(this.register, this, attr.register); - } else { - this.register(attr.register); - } - } - }, - /** - * Starts tracking. Changes of registered objects won't be processed until you've called this function - * @return {undefined} - */ - startTracking: function () { - this.set("track", true); - this.stack.track = true; - }, - /** - * Stops tracking. Afterwards changes of registered objects won't be processed. - * @return {undefined} - */ - stopTracking: function () { - this.set("track", false); - this.stack.track = false; - }, - /** - * Return the state of the tracking - * @return {boolean} - */ - isTracking: function () { - return this.get("track"); - }, - /** - * This is the "all"-handler which is bound to registered - * objects. It creates an UndoAction from the event and adds - * it to the stack. - * - * @param {String} type The event type - * @return {undefined} - */ - _addToStack: function (type) { - addToStack(this.stack, type, slice(arguments, 1), this.undoTypes); - }, - /** - * Registers one or more objects to track their changes. - * @param {...Object} obj The object or objects of which changes should be tracked - * @return {undefined} - */ - register: function () { - onoff("on", arguments, this._addToStack, this); - }, - /** - * Unregisters one or more objects. - * @param {...Object} obj The object or objects of which changes shouldn't be tracked any longer - * @return {undefined} - */ - unregister: function () { - onoff("off", arguments, this._addToStack, this); - }, - /** - * Unregisters all previously registered objects. - * @return {undefined} - */ - unregisterAll: function () { - apply(this.unregister, this, this.objectRegistry.get()); - }, - /** - * Undoes the last action or the last set of actions in case 'magic' is true. - * @param {Boolean} [magic] If true, all actions that happened basically at the same time are undone together - * @return {undefined} - */ - undo: function (magic) { - managerUndoRedo("undo", this, this.stack, magic); - }, +/* harmony default export */ __webpack_exports__["default"] = (_Component__WEBPACK_IMPORTED_MODULE_1__["default"].extend({ + defaults: _objectSpread({}, _Component__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.defaults, { + type: 'table', + tagName: 'table', + droppable: ['tbody', 'thead', 'tfoot'] + }), + initialize: function initialize(o, opt) { + _Component__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.initialize.apply(this, arguments); + var components = this.get('components'); + !components.length && components.add({ + type: 'tbody' + }); + } +}, { + isComponent: function isComponent(el) { + var result = ''; - /** - * Undoes all actions ever tracked by the undo manager - * @return {undefined} - */ - undoAll: function () { - managerUndoRedo("undo", this, this.stack, false, true); - }, + if (el.tagName == 'TABLE') { + result = { + type: 'table' + }; + } - /** - * Redoes a previously undone action or a set of actions. - * @param {Boolean} [magic] If true, all actions that happened basically at the same time are redone together - * @return {undefined} - */ - redo: function (magic) { - managerUndoRedo("redo", this, this.stack, magic); - }, + return result; + } +})); - /** - * Redoes all actions ever tracked by the undo manager - * @return {undefined} - */ - redoAll: function () { - managerUndoRedo("redo", this, this.stack, false, true); - }, - /** - * Checks if there's an action in the stack that can be undone / redone - * @param {String} type Either "undo" or "redo" - * @return {Boolean} True if there is a set of actions which can be undone / redone - */ - isAvailable: function (type) { - var s = this.stack, l = s.length; +/***/ }), - switch (type) { - case "undo": return l > 0 && s.pointer > -1; - case "redo": return l > 0 && s.pointer < l - 1; - default: return false; - } - }, - /** - * Sets the stack-reference to the stack of another undoManager. - * @param {UndoManager} undoManager The undoManager whose stack-reference is set to this stack - * @return {undefined} - */ - merge: function (undoManager) { - // This sets the stack-reference to the stack of another - // undoManager so that the stack of this other undoManager - // is used by two different managers. - // This enables to set up a main-undoManager and besides it - // several others for special, exceptional cases (by using - // instance-based custom UndoTypes). Models / collections - // which need this special treatment are only registered at - // those special undoManagers. Those special ones are then - // merged into the main-undoManager to write on its stack. - // That way it's easier to manage exceptional cases. - var args = _.isArray(undoManager) ? undoManager : slice(arguments), manager; - while (manager = args.pop()) { - if (manager instanceof UndoManager && - manager.stack instanceof UndoStack) { - // set the stack reference to our stack - manager.stack = this.stack; - } - } - }, - /** - * Add an UndoType to this specific UndoManager-instance. - * @param {String} type The event this UndoType is made for - * @param {Object} fns An object of functions that are called to generate the data for an UndoAction or to process it. Must have the properties "undo", "redo" and "on". Can have the property "condition". - * @return {undefined} - */ - addUndoType: function (type, fns) { - manipulateUndoType(0, type, fns, this.undoTypes); - }, - /** - * Overwrite properties of an existing UndoType for this specific UndoManager-instance. - * @param {String} type The event the UndoType is made for - * @param {Object} fns An object of functions that are called to generate the data for an UndoAction or to process it. It extends the existing object. - * @return {undefined} - */ - changeUndoType: function (type, fns) { - manipulateUndoType(1, type, fns, this.undoTypes); - }, - /** - * Remove one or more UndoTypes of this specific UndoManager-instance to fall back to the global UndoTypes. - * @param {String|Array} type The event the UndoType that should be removed is made for. You can also pass an array of events. - * @return {undefined} - */ - removeUndoType: function (type) { - manipulateUndoType(2, type, undefined, this.undoTypes); - }, +/***/ "./src/dom_components/model/ComponentTableBody.js": +/*!********************************************************!*\ + !*** ./src/dom_components/model/ComponentTableBody.js ***! + \********************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - /** - * Removes all actions from the stack. - * @return {undefined} - */ - clear: function() { - this.stack.reset(); - this.stack.pointer = -1; - } - }); +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _Component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Component */ "./src/dom_components/model/Component.js"); - _.extend(UndoManager, { - /** - * Change the UndoManager's default attributes - * @param {Object} defaultAttributes An object with the new default values. - * @return {undefined} - */ - defaults: function (defaultAttributes) { - _.extend(UndoManager.prototype.defaults, defaultAttributes); - }, - /** - * Add an UndoType to the global UndoTypes-object. - * @param {String} type The event this UndoType is made for - * @param {Object} fns An object of functions that are called to generate the data for an UndoAction or to process it. Must have the properties "undo", "redo" and "on". Can have the property "condition". - * @return {undefined} - */ - "addUndoType": function (type, fns) { - manipulateUndoType(0, type, fns, UndoTypes); - }, - /** - * Overwrite properties of an existing UndoType in the global UndoTypes-object. - * @param {String} type The event the UndoType is made for - * @param {Object} fns An object of functions that are called to generate the data for an UndoAction or to process it. It extends the existing object. - * @return {undefined} - */ - "changeUndoType": function (type, fns) { - manipulateUndoType(1, type, fns, UndoTypes) - }, - /** - * Remove one or more UndoTypes of this specific UndoManager-instance to fall back to the global UndoTypes. - * @param {String|Array} type The event the UndoType that should be removed is made for. You can also pass an array of events. - * @return {undefined} - */ - "removeUndoType": function (type) { - manipulateUndoType(2, type, undefined, UndoTypes); - } - }) - return Backbone.UndoManager = UndoManager; +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } -}); +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } -/***/ }), -/* 72 */ -/***/ (function(module, exports, __webpack_require__) { +/* harmony default export */ __webpack_exports__["default"] = (_Component__WEBPACK_IMPORTED_MODULE_1__["default"].extend({ + defaults: _objectSpread({}, _Component__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.defaults, { + type: 'tbody', + tagName: 'tbody', + draggable: ['table'], + droppable: ['tr'], + columns: 1, + rows: 1 + }), + initialize: function initialize(o, opt) { + _Component__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.initialize.apply(this, arguments); + var components = this.get('components'); + var columns = this.get('columns'); + var rows = this.get('rows'); // Init components if empty -/* WEBPACK VAR INJECTION */(function(global) {var __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;// Backbone.js 1.2.1 + if (!components.length) { + var rowsToAdd = []; -// (c) 2010-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors -// Backbone may be freely distributed under the MIT license. -// For all details and documentation: -// http://backbonejs.org + while (rows--) { + var columnsToAdd = []; + var clm = columns; -(function(factory) { + while (clm--) { + columnsToAdd.push({ + type: 'cell', + classes: ['cell'] + }); + } - // Establish the root object, `window` (`self`) in the browser, or `global` on the server. - // We use `self` instead of `window` for `WebWorker` support. - var root = (typeof self == 'object' && self.self == self && self) || - (typeof global == 'object' && global.global == global && global); + rowsToAdd.push({ + type: 'row', + classes: ['row'], + components: columnsToAdd + }); + } - // Set up Backbone appropriately for the environment. Start with AMD. - if (true) { - !(__WEBPACK_AMD_DEFINE_ARRAY__ = [__webpack_require__(1), __webpack_require__(9), exports], __WEBPACK_AMD_DEFINE_RESULT__ = function(_, $, exports) { - // Export global even in AMD case in case this script is loaded with - // others that may still expect a global Backbone. - root.Backbone = factory(root, exports, _, $); - }.apply(exports, __WEBPACK_AMD_DEFINE_ARRAY__), - __WEBPACK_AMD_DEFINE_RESULT__ !== undefined && (module.exports = __WEBPACK_AMD_DEFINE_RESULT__)); + components.add(rowsToAdd); + } + } +}, { + isComponent: function isComponent(el) { + var result = ''; - // Next for Node.js or CommonJS. jQuery may not be needed as a module. - } else if (typeof exports !== 'undefined') { - var _ = require('underscore'), $; - try { $ = require('jquery'); } catch(e) {} - factory(root, exports, _, $); + if (el.tagName == 'TBODY') { + result = { + type: 'tbody' + }; + } - // Finally, as a browser global. - } else { - root.Backbone = factory(root, {}, root._, (root.jQuery || root.Zepto || root.ender || root.$)); + return result; } +})); -}(function(root, Backbone, _, $) { - - // Initial Setup - // ------------- +/***/ }), - // Save the previous value of the `Backbone` variable, so that it can be - // restored later on, if `noConflict` is used. - var previousBackbone = root.Backbone; +/***/ "./src/dom_components/model/ComponentTableCell.js": +/*!********************************************************!*\ + !*** ./src/dom_components/model/ComponentTableCell.js ***! + \********************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // Create a local reference to a common array method we'll want to use later. - var slice = [].slice; +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _Component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Component */ "./src/dom_components/model/Component.js"); - // Current version of the library. Keep in sync with `package.json`. - Backbone.VERSION = '1.2.1'; - // For Backbone's purposes, jQuery, Zepto, Ender, or My Library (kidding) owns - // the `$` variable. - Backbone.$ = $; +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - // Runs Backbone.js in *noConflict* mode, returning the `Backbone` variable - // to its previous owner. Returns a reference to this Backbone object. - Backbone.noConflict = function() { - root.Backbone = previousBackbone; - return this; - }; +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - // Turn on `emulateHTTP` to support legacy HTTP servers. Setting this option - // will fake `"PATCH"`, `"PUT"` and `"DELETE"` requests via the `_method` parameter and - // set a `X-Http-Method-Override` header. - Backbone.emulateHTTP = false; - // Turn on `emulateJSON` to support legacy servers that can't deal with direct - // `application/json` requests ... this will encode the body as - // `application/x-www-form-urlencoded` instead and will send the model in a - // form param named `model`. - Backbone.emulateJSON = false; +/* harmony default export */ __webpack_exports__["default"] = (_Component__WEBPACK_IMPORTED_MODULE_1__["default"].extend({ + defaults: _objectSpread({}, _Component__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.defaults, { + type: 'cell', + tagName: 'td', + draggable: ['tr'] + }) +}, { + isComponent: function isComponent(el) { + var result = ''; + var tag = el.tagName; - // Proxy Underscore methods to a Backbone class' prototype using a - // particular attribute as the data argument - var addMethod = function(length, method, attribute) { - switch (length) { - case 1: return function() { - return _[method](this[attribute]); - }; - case 2: return function(value) { - return _[method](this[attribute], value); - }; - case 3: return function(iteratee, context) { - return _[method](this[attribute], iteratee, context); - }; - case 4: return function(iteratee, defaultVal, context) { - return _[method](this[attribute], iteratee, defaultVal, context); - }; - default: return function() { - var args = slice.call(arguments); - args.unshift(this[attribute]); - return _[method].apply(_, args); + if (tag == 'TD' || tag == 'TH') { + result = { + type: 'cell', + tagName: tag.toLowerCase() }; } - }; - var addUnderscoreMethods = function(Class, methods, attribute) { - _.each(methods, function(length, method) { - if (_[method]) Class.prototype[method] = addMethod(length, method, attribute); - }); - }; - // Backbone.Events - // --------------- + return result; + } +})); - // A module that can be mixed in to *any object* in order to provide it with - // custom events. You may bind with `on` or remove with `off` callback - // functions to an event; `trigger`-ing an event fires all callbacks in - // succession. - // - // var object = {}; - // _.extend(object, Backbone.Events); - // object.on('expand', function(){ alert('expanded'); }); - // object.trigger('expand'); - // - var Events = Backbone.Events = {}; +/***/ }), - // Regular expression used to split event strings. - var eventSplitter = /\s+/; +/***/ "./src/dom_components/model/ComponentTableFoot.js": +/*!********************************************************!*\ + !*** ./src/dom_components/model/ComponentTableFoot.js ***! + \********************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // Iterates over the standard `event, callback` (as well as the fancy multiple - // space-separated events `"change blur", callback` and jQuery-style event - // maps `{event: callback}`), reducing them by manipulating `memo`. - // Passes a normalized single event name and callback, as well as any - // optional `opts`. - var eventsApi = function(iteratee, memo, name, callback, opts) { - var i = 0, names; - if (name && typeof name === 'object') { - // Handle event maps. - if (callback !== void 0 && 'context' in opts && opts.context === void 0) opts.context = callback; - for (names = _.keys(name); i < names.length ; i++) { - memo = iteratee(memo, names[i], name[names[i]], opts); - } - } else if (name && eventSplitter.test(name)) { - // Handle space separated event names. - for (names = name.split(eventSplitter); i < names.length; i++) { - memo = iteratee(memo, names[i], callback, opts); - } - } else { - memo = iteratee(memo, name, callback, opts); - } - return memo; - }; +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _ComponentTableBody__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./ComponentTableBody */ "./src/dom_components/model/ComponentTableBody.js"); - // Bind an event to a `callback` function. Passing `"all"` will bind - // the callback to all events fired. - Events.on = function(name, callback, context) { - return internalOn(this, name, callback, context); - }; - // An internal use `on` function, used to guard the `listening` argument from - // the public API. - var internalOn = function(obj, name, callback, context, listening) { - obj._events = eventsApi(onApi, obj._events || {}, name, callback, { - context: context, - ctx: obj, - listening: listening - }); +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - if (listening) { - var listeners = obj._listeners || (obj._listeners = {}); - listeners[listening.id] = listening; - } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - return obj; - }; - // Inversion-of-control versions of `on`. Tell *this* object to listen to - // an event in another object... keeping track of what it's listening to. - Events.listenTo = function(obj, name, callback) { - if (!obj) return this; - var id = obj._listenId || (obj._listenId = _.uniqueId('l')); - var listeningTo = this._listeningTo || (this._listeningTo = {}); - var listening = listeningTo[id]; +/* harmony default export */ __webpack_exports__["default"] = (_ComponentTableBody__WEBPACK_IMPORTED_MODULE_1__["default"].extend({ + defaults: _objectSpread({}, _ComponentTableBody__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.defaults, { + type: 'tfoot', + tagName: 'tfoot' + }) +}, { + isComponent: function isComponent(el) { + var result = ''; - // This object is not listening to any other events on `obj` yet. - // Setup the necessary references to track the listening callbacks. - if (!listening) { - var thisId = this._listenId || (this._listenId = _.uniqueId('l')); - listening = listeningTo[id] = {obj: obj, objId: id, id: thisId, listeningTo: listeningTo, count: 0}; + if (el.tagName == 'TFOOT') { + result = { + type: 'tfoot' + }; } - // Bind callbacks on obj, and keep track of them on listening. - internalOn(obj, name, callback, this, listening); - return this; - }; - - // The reducing API that adds a callback to the `events` object. - var onApi = function(events, name, callback, options) { - if (callback) { - var handlers = events[name] || (events[name] = []); - var context = options.context, ctx = options.ctx, listening = options.listening; - if (listening) listening.count++; - - handlers.push({ callback: callback, context: context, ctx: context || ctx, listening: listening }); - } - return events; - }; - - // Remove one or many callbacks. If `context` is null, removes all - // callbacks with that function. If `callback` is null, removes all - // callbacks for the event. If `name` is null, removes all bound - // callbacks for all events. - Events.off = function(name, callback, context) { - if (!this._events) return this; - this._events = eventsApi(offApi, this._events, name, callback, { - context: context, - listeners: this._listeners - }); - return this; - }; + return result; + } +})); - // Tell this object to stop listening to either specific events ... or - // to every object it's currently listening to. - Events.stopListening = function(obj, name, callback) { - var listeningTo = this._listeningTo; - if (!listeningTo) return this; +/***/ }), - var ids = obj ? [obj._listenId] : _.keys(listeningTo); +/***/ "./src/dom_components/model/ComponentTableHead.js": +/*!********************************************************!*\ + !*** ./src/dom_components/model/ComponentTableHead.js ***! + \********************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - for (var i = 0; i < ids.length; i++) { - var listening = listeningTo[ids[i]]; +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _ComponentTableBody__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./ComponentTableBody */ "./src/dom_components/model/ComponentTableBody.js"); - // If listening doesn't exist, this object is not currently - // listening to obj. Break out early. - if (!listening) break; - listening.obj.off(name, callback, this); - } - if (_.isEmpty(listeningTo)) this._listeningTo = void 0; +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - return this; - }; +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - // The reducing API that removes a callback from the `events` object. - var offApi = function(events, name, callback, options) { - // No events to consider. - if (!events) return; - var i = 0, listening; - var context = options.context, listeners = options.listeners; +/* harmony default export */ __webpack_exports__["default"] = (_ComponentTableBody__WEBPACK_IMPORTED_MODULE_1__["default"].extend({ + defaults: _objectSpread({}, _ComponentTableBody__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.defaults, { + type: 'thead', + tagName: 'thead' + }) +}, { + isComponent: function isComponent(el) { + var result = ''; - // Delete all events listeners and "drop" events. - if (!name && !callback && !context) { - var ids = _.keys(listeners); - for (; i < ids.length; i++) { - listening = listeners[ids[i]]; - delete listeners[listening.id]; - delete listening.listeningTo[listening.objId]; - } - return; + if (el.tagName == 'THEAD') { + result = { + type: 'thead' + }; } - var names = name ? [name] : _.keys(events); - for (; i < names.length; i++) { - name = names[i]; - var handlers = events[name]; - - // Bail out if there are no events stored. - if (!handlers) break; + return result; + } +})); - // Replace events if there are any remaining. Otherwise, clean up. - var remaining = []; - for (var j = 0; j < handlers.length; j++) { - var handler = handlers[j]; - if ( - callback && callback !== handler.callback && - callback !== handler.callback._callback || - context && context !== handler.context - ) { - remaining.push(handler); - } else { - listening = handler.listening; - if (listening && --listening.count === 0) { - delete listeners[listening.id]; - delete listening.listeningTo[listening.objId]; - } - } - } +/***/ }), - // Update tail event if the list has any events. Otherwise, clean up. - if (remaining.length) { - events[name] = remaining; - } else { - delete events[name]; - } - } - if (_.size(events)) return events; - }; +/***/ "./src/dom_components/model/ComponentTableRow.js": +/*!*******************************************************!*\ + !*** ./src/dom_components/model/ComponentTableRow.js ***! + \*******************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // Bind an event to only be triggered a single time. After the first time - // the callback is invoked, it will be removed. When multiple events are - // passed in using the space-separated syntax, the event will fire once for every - // event you passed in, not once for a combination of all events - Events.once = function(name, callback, context) { - // Map the event into a `{event: once}` object. - var events = eventsApi(onceMap, {}, name, callback, _.bind(this.off, this)); - return this.on(events, void 0, context); - }; +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _Component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Component */ "./src/dom_components/model/Component.js"); - // Inversion-of-control versions of `once`. - Events.listenToOnce = function(obj, name, callback) { - // Map the event into a `{event: once}` object. - var events = eventsApi(onceMap, {}, name, callback, _.bind(this.stopListening, this, obj)); - return this.listenTo(obj, events); - }; - // Reduces the event callbacks into a map of `{event: onceWrapper}`. - // `offer` unbinds the `onceWrapper` after it has been called. - var onceMap = function(map, name, callback, offer) { - if (callback) { - var once = map[name] = _.once(function() { - offer(name, once); - callback.apply(this, arguments); - }); - once._callback = callback; - } - return map; - }; +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - // Trigger one or many events, firing all bound callbacks. Callbacks are - // passed the same arguments as `trigger` is, apart from the event name - // (unless you're listening on `"all"`, which will cause your callback to - // receive the true name of the event as the first argument). - Events.trigger = function(name) { - if (!this._events) return this; +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - var length = Math.max(0, arguments.length - 1); - var args = Array(length); - for (var i = 0; i < length; i++) args[i] = arguments[i + 1]; - eventsApi(triggerApi, this._events, name, void 0, args); - return this; - }; +/* harmony default export */ __webpack_exports__["default"] = (_Component__WEBPACK_IMPORTED_MODULE_1__["default"].extend({ + defaults: _objectSpread({}, _Component__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.defaults, { + type: 'row', + tagName: 'tr', + draggable: ['thead', 'tbody', 'tfoot'], + droppable: ['th', 'td'] + }), + initialize: function initialize(o, opt) { + _Component__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.initialize.apply(this, arguments); // Clean the row from non cell components - // Handles triggering the appropriate event callbacks. - var triggerApi = function(objEvents, name, cb, args) { - if (objEvents) { - var events = objEvents[name]; - var allEvents = objEvents.all; - if (events && allEvents) allEvents = allEvents.slice(); - if (events) triggerEvents(events, args); - if (allEvents) triggerEvents(allEvents, [name].concat(args)); - } - return objEvents; - }; + var cells = []; + var components = this.get('components'); + components.each(function (model) { + return model.is('cell') && cells.push(model); + }); + components.reset(cells); + } +}, { + isComponent: function isComponent(el) { + var result = ''; - // A difficult-to-believe, but optimized internal dispatch function for - // triggering events. Tries to keep the usual cases speedy (most internal - // Backbone events have 3 arguments). - var triggerEvents = function(events, args) { - var ev, i = -1, l = events.length, a1 = args[0], a2 = args[1], a3 = args[2]; - switch (args.length) { - case 0: while (++i < l) (ev = events[i]).callback.call(ev.ctx); return; - case 1: while (++i < l) (ev = events[i]).callback.call(ev.ctx, a1); return; - case 2: while (++i < l) (ev = events[i]).callback.call(ev.ctx, a1, a2); return; - case 3: while (++i < l) (ev = events[i]).callback.call(ev.ctx, a1, a2, a3); return; - default: while (++i < l) (ev = events[i]).callback.apply(ev.ctx, args); return; + if (el.tagName == 'TR') { + result = { + type: 'row' + }; } - }; - - // Aliases for backwards compatibility. - Events.bind = Events.on; - Events.unbind = Events.off; - // Allow the `Backbone` object to serve as a global event bus, for folks who - // want global "pubsub" in a convenient place. - _.extend(Backbone, Events); + return result; + } +})); - // Backbone.Model - // -------------- +/***/ }), - // Backbone **Models** are the basic data object in the framework -- - // frequently representing a row in a table in a database on your server. - // A discrete chunk of data and a bunch of useful, related methods for - // performing computations and transformations on that data. +/***/ "./src/dom_components/model/ComponentText.js": +/*!***************************************************!*\ + !*** ./src/dom_components/model/ComponentText.js ***! + \***************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // Create a new model with the specified attributes. A client id (`cid`) - // is automatically generated and assigned for you. - var Model = Backbone.Model = function(attributes, options) { - var attrs = attributes || {}; - options || (options = {}); - this.cid = _.uniqueId(this.cidPrefix); - this.attributes = {}; - if (options.collection) this.collection = options.collection; - if (options.parse) attrs = this.parse(attrs, options) || {}; - attrs = _.defaults({}, attrs, _.result(this, 'defaults')); - this.set(attrs, options); - this.changed = {}; - this.initialize.apply(this, arguments); - }; +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _Component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Component */ "./src/dom_components/model/Component.js"); - // Attach all inheritable methods to the Model prototype. - _.extend(Model.prototype, Events, { - // A hash of attributes whose current and previous value differ. - changed: null, +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - // The value returned during the last failed validation. - validationError: null, +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - // The default name for the JSON `id` attribute is `"id"`. MongoDB and - // CouchDB users may want to set this to `"_id"`. - idAttribute: 'id', - // The prefix is used to create the client id which is used to identify models locally. - // You may want to override this if you're experiencing name clashes with model ids. - cidPrefix: 'c', +/* harmony default export */ __webpack_exports__["default"] = (_Component__WEBPACK_IMPORTED_MODULE_1__["default"].extend({ + defaults: _objectSpread({}, _Component__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.defaults, { + type: 'text', + droppable: false, + editable: true + }), + toHTML: function toHTML() { + this.trigger('sync:content', { + silent: 1 + }); + return _Component__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.toHTML.apply(this, arguments); + } +})); - // Initialize is an empty function by default. Override it with your own - // initialization logic. - initialize: function(){}, +/***/ }), - // Return a copy of the model's `attributes` object. - toJSON: function(options) { - return _.clone(this.attributes); - }, +/***/ "./src/dom_components/model/ComponentTextNode.js": +/*!*******************************************************!*\ + !*** ./src/dom_components/model/ComponentTextNode.js ***! + \*******************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // Proxy `Backbone.sync` by default -- but override this if you need - // custom syncing semantics for *this* particular model. - sync: function() { - return Backbone.sync.apply(this, arguments); - }, +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _Component__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Component */ "./src/dom_components/model/Component.js"); - // Get the value of an attribute. - get: function(attr) { - return this.attributes[attr]; - }, - // Get the HTML-escaped value of an attribute. - escape: function(attr) { - return _.escape(this.get(attr)); - }, +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - // Returns `true` if the attribute contains a value that is not null - // or undefined. - has: function(attr) { - return this.get(attr) != null; - }, +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - // Special-cased proxy to underscore's `_.matches` method. - matches: function(attrs) { - return !!_.iteratee(attrs, this)(this.attributes); - }, - // Set a hash of model attributes on the object, firing `"change"`. This is - // the core primitive operation of a model, updating the data and notifying - // anyone who needs to know about the change in state. The heart of the beast. - set: function(key, val, options) { - if (key == null) return this; - - // Handle both `"key", value` and `{key: value}` -style arguments. - var attrs; - if (typeof key === 'object') { - attrs = key; - options = val; - } else { - (attrs = {})[key] = val; - } +/* harmony default export */ __webpack_exports__["default"] = (_Component__WEBPACK_IMPORTED_MODULE_1__["default"].extend({ + defaults: _objectSpread({}, _Component__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.defaults, { + droppable: false, + layerable: false, + editable: true + }), + toHTML: function toHTML() { + return this.get('content'); + } +}, { + isComponent: function isComponent(el) { + var result = ''; - options || (options = {}); + if (el.nodeType === 3) { + result = { + type: 'textnode', + content: el.textContent + }; + } - // Run validation. - if (!this._validate(attrs, options)) return false; + return result; + } +})); - // Extract attributes and options. - var unset = options.unset; - var silent = options.silent; - var changes = []; - var changing = this._changing; - this._changing = true; +/***/ }), - if (!changing) { - this._previousAttributes = _.clone(this.attributes); - this.changed = {}; - } +/***/ "./src/dom_components/model/ComponentVideo.js": +/*!****************************************************!*\ + !*** ./src/dom_components/model/ComponentVideo.js ***! + \****************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - var current = this.attributes; - var changed = this.changed; - var prev = this._previousAttributes; +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _ComponentImage__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./ComponentImage */ "./src/dom_components/model/ComponentImage.js"); +/* harmony import */ var _Component__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./Component */ "./src/dom_components/model/Component.js"); - // Check for changes of `id`. - if (this.idAttribute in attrs) this.id = attrs[this.idAttribute]; - // For each `set` attribute, update or delete the current value. - for (var attr in attrs) { - val = attrs[attr]; - if (!_.isEqual(current[attr], val)) changes.push(attr); - if (!_.isEqual(prev[attr], val)) { - changed[attr] = val; - } else { - delete changed[attr]; - } - unset ? delete current[attr] : current[attr] = val; - } +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - // Trigger all relevant attribute changes. - if (!silent) { - if (changes.length) this._pending = options; - for (var i = 0; i < changes.length; i++) { - this.trigger('change:' + changes[i], this, current[changes[i]], options); - } - } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - // You might be wondering why there's a `while` loop here. Changes can - // be recursively nested within `"change"` events. - if (changing) return this; - if (!silent) { - while (this._pending) { - options = this._pending; - this._pending = false; - this.trigger('change', this, options); - } - } - this._pending = false; - this._changing = false; - return this; - }, - // Remove an attribute from the model, firing `"change"`. `unset` is a noop - // if the attribute doesn't exist. - unset: function(attr, options) { - return this.set(attr, void 0, _.extend({}, options, {unset: true})); - }, - // Clear all attributes on the model, firing `"change"`. - clear: function(options) { - var attrs = {}; - for (var key in this.attributes) attrs[key] = void 0; - return this.set(attrs, _.extend({}, options, {unset: true})); +var yt = 'yt'; +var vi = 'vi'; +var ytnc = 'ytnc'; +/* harmony default export */ __webpack_exports__["default"] = (_ComponentImage__WEBPACK_IMPORTED_MODULE_1__["default"].extend({ + defaults: _objectSpread({}, _ComponentImage__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.defaults, { + type: 'video', + tagName: 'video', + videoId: '', + void: 0, + provider: 'so', + // on change of provider, traits are switched + ytUrl: 'https://www.youtube.com/embed/', + ytncUrl: 'https://www.youtube-nocookie.com/embed/', + viUrl: 'https://player.vimeo.com/video/', + loop: 0, + poster: '', + muted: 0, + autoplay: 0, + controls: 1, + color: '', + rel: 1, + // YT related videos + modestbranding: 0, + // YT modest branding + sources: [], + attributes: { + allowfullscreen: 'allowfullscreen' }, + toolbar: _Component__WEBPACK_IMPORTED_MODULE_2__["default"].prototype.defaults.toolbar + }), + initialize: function initialize(o, opt) { + var traits = []; + var prov = this.get('provider'); - // Determine if the model has changed since the last `"change"` event. - // If you specify an attribute name, determine if that attribute has changed. - hasChanged: function(attr) { - if (attr == null) return !_.isEmpty(this.changed); - return _.has(this.changed, attr); - }, + switch (prov) { + case yt: + case ytnc: + traits = this.getYoutubeTraits(); + break; - // Return an object containing all the attributes that have changed, or - // false if there are no changed attributes. Useful for determining what - // parts of a view need to be updated and/or what attributes need to be - // persisted to the server. Unset attributes will be set to undefined. - // You can also pass an attributes object to diff against the model, - // determining if there *would be* a change. - changedAttributes: function(diff) { - if (!diff) return this.hasChanged() ? _.clone(this.changed) : false; - var old = this._changing ? this._previousAttributes : this.attributes; - var changed = {}; - for (var attr in diff) { - var val = diff[attr]; - if (_.isEqual(old[attr], val)) continue; - changed[attr] = val; - } - return _.size(changed) ? changed : false; - }, + case vi: + traits = this.getVimeoTraits(); + break; - // Get the previous value of an attribute, recorded at the time the last - // `"change"` event was fired. - previous: function(attr) { - if (attr == null || !this._previousAttributes) return null; - return this._previousAttributes[attr]; - }, + default: + traits = this.getSourceTraits(); + } - // Get all of the attributes of the model at the time of the previous - // `"change"` event. - previousAttributes: function() { - return _.clone(this._previousAttributes); - }, + if (this.get('src')) this.parseFromSrc(); + this.set('traits', traits); + _ComponentImage__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.initialize.apply(this, arguments); + this.listenTo(this, 'change:provider', this.updateTraits); + this.listenTo(this, 'change:videoId change:provider', this.updateSrc); + }, + initToolbar: function initToolbar() { + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; + } - // Fetch the model from the server, merging the response with the model's - // local attributes. Any changed attributes will trigger a "change" event. - fetch: function(options) { - options = _.extend({parse: true}, options); - var model = this; - var success = options.success; - options.success = function(resp) { - var serverAttrs = options.parse ? model.parse(resp, options) : resp; - if (!model.set(serverAttrs, options)) return false; - if (success) success.call(options.context, model, resp, options); - model.trigger('sync', model, resp, options); - }; - wrapError(this, options); - return this.sync('read', this, options); - }, + _Component__WEBPACK_IMPORTED_MODULE_2__["default"].prototype.initToolbar.apply(this, args); + }, - // Set a hash of model attributes, and sync the model to the server. - // If the server returns an attributes hash that differs, the model's - // state will be `set` again. - save: function(key, val, options) { - // Handle both `"key", value` and `{key: value}` -style arguments. - var attrs; - if (key == null || typeof key === 'object') { - attrs = key; - options = val; - } else { - (attrs = {})[key] = val; - } + /** + * Set attributes by src string + */ + parseFromSrc: function parseFromSrc() { + var prov = this.get('provider'); + var uri = this.parseUri(this.get('src')); + var qr = uri.query; - options = _.extend({validate: true, parse: true}, options); - var wait = options.wait; + switch (prov) { + case yt: + case ytnc: + case vi: + var videoId = uri.pathname.split('/').pop(); + this.set('videoId', videoId); + if (qr.autoplay) this.set('autoplay', 1); + if (qr.loop) this.set('loop', 1); + if (parseInt(qr.controls) === 0) this.set('controls', 0); + if (qr.color) this.set('color', qr.color); + if (qr.rel === '0') this.set('rel', 0); + if (qr.modestbranding === '1') this.set('modestbranding', 1); + break; - // If we're not waiting and attributes exist, save acts as - // `set(attr).save(null, opts)` with validation. Otherwise, check if - // the model will be valid when the attributes, if any, are set. - if (attrs && !wait) { - if (!this.set(attrs, options)) return false; - } else { - if (!this._validate(attrs, options)) return false; - } + default: + } + }, - // After a successful server-side save, the client is (optionally) - // updated with the server-side state. - var model = this; - var success = options.success; - var attributes = this.attributes; - options.success = function(resp) { - // Ensure attributes are restored during synchronous saves. - model.attributes = attributes; - var serverAttrs = options.parse ? model.parse(resp, options) : resp; - if (wait) serverAttrs = _.extend({}, attrs, serverAttrs); - if (serverAttrs && !model.set(serverAttrs, options)) return false; - if (success) success.call(options.context, model, resp, options); - model.trigger('sync', model, resp, options); - }; - wrapError(this, options); + /** + * Update src on change of video ID + * @private + */ + updateSrc: function updateSrc() { + var prov = this.get('provider'); - // Set temporary attributes if `{wait: true}` to properly find new ids. - if (attrs && wait) this.attributes = _.extend({}, attributes, attrs); + switch (prov) { + case yt: + this.set('src', this.getYoutubeSrc()); + break; - var method = this.isNew() ? 'create' : (options.patch ? 'patch' : 'update'); - if (method === 'patch' && !options.attrs) options.attrs = attrs; - var xhr = this.sync(method, this, options); + case ytnc: + this.set('src', this.getYoutubeNoCookieSrc()); + break; - // Restore attributes. - this.attributes = attributes; + case vi: + this.set('src', this.getVimeoSrc()); + break; + } + }, - return xhr; - }, - - // Destroy this model on the server if it was already persisted. - // Optimistically removes the model from its collection, if it has one. - // If `wait: true` is passed, waits for the server to respond before removal. - destroy: function(options) { - options = options ? _.clone(options) : {}; - var model = this; - var success = options.success; - var wait = options.wait; - - var destroy = function() { - model.stopListening(); - model.trigger('destroy', model, model.collection, options); - }; + /** + * Returns object of attributes for HTML + * @return {Object} + * @private + */ + getAttrToHTML: function getAttrToHTML() { + for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) { + args[_key2] = arguments[_key2]; + } - options.success = function(resp) { - if (wait) destroy(); - if (success) success.call(options.context, model, resp, options); - if (!model.isNew()) model.trigger('sync', model, resp, options); - }; + var attr = _ComponentImage__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.getAttrToHTML.apply(this, args); + var prov = this.get('provider'); - var xhr = false; - if (this.isNew()) { - _.defer(options.success); - } else { - wrapError(this, options); - xhr = this.sync('delete', this, options); - } - if (!wait) destroy(); - return xhr; - }, + switch (prov) { + case yt: + case ytnc: + case vi: + break; - // Default URL for the model's representation on the server -- if you're - // using Backbone's restful methods, override this to change the endpoint - // that will be called. - url: function() { - var base = - _.result(this, 'urlRoot') || - _.result(this.collection, 'url') || - urlError(); - if (this.isNew()) return base; - var id = this.get(this.idAttribute); - return base.replace(/[^\/]$/, '$&/') + encodeURIComponent(id); - }, + default: + if (this.get('loop')) attr.loop = 'loop'; + if (this.get('autoplay')) attr.autoplay = 'autoplay'; + if (this.get('controls')) attr.controls = 'controls'; + } - // **parse** converts a response into the hash of attributes to be `set` on - // the model. The default implementation is just to pass the response along. - parse: function(resp, options) { - return resp; - }, + return attr; + }, - // Create a new model with identical attributes to this one. - clone: function() { - return new this.constructor(this.attributes); - }, + /** + * Update traits by provider + * @private + */ + updateTraits: function updateTraits() { + var prov = this.get('provider'); + var traits = this.getSourceTraits(); - // A model is new if it has never been saved to the server, and lacks an id. - isNew: function() { - return !this.has(this.idAttribute); - }, + switch (prov) { + case yt: + case ytnc: + this.set('tagName', 'iframe'); + traits = this.getYoutubeTraits(); + break; - // Check if the model is currently in a valid state. - isValid: function(options) { - return this._validate({}, _.defaults({validate: true}, options)); - }, + case vi: + this.set('tagName', 'iframe'); + traits = this.getVimeoTraits(); + break; - // Run validation against the next complete set of model attributes, - // returning `true` if all is well. Otherwise, fire an `"invalid"` event. - _validate: function(attrs, options) { - if (!options.validate || !this.validate) return true; - attrs = _.extend({}, this.attributes, attrs); - var error = this.validationError = this.validate(attrs, options) || null; - if (!error) return true; - this.trigger('invalid', this, error, _.extend(options, {validationError: error})); - return false; + default: + this.set('tagName', 'video'); } - }); + this.loadTraits(traits); + this.em.trigger('component:toggled'); + }, + // Listen provider change and switch traits, in TraitView listen traits change - // Underscore methods that we want to implement on the Model. - var modelMethods = { keys: 1, values: 1, pairs: 1, invert: 1, pick: 0, - omit: 0, chain: 1, isEmpty: 1 }; + /** + * Return the provider trait + * @return {Object} + * @private + */ + getProviderTrait: function getProviderTrait() { + return { + type: 'select', + label: 'Provider', + name: 'provider', + changeProp: 1, + options: [{ + value: 'so', + name: 'HTML5 Source' + }, { + value: yt, + name: 'Youtube' + }, { + value: ytnc, + name: 'Youtube (no cookie)' + }, { + value: vi, + name: 'Vimeo' + }] + }; + }, - // Mix in each Underscore method as a proxy to `Model#attributes`. - addUnderscoreMethods(Model, modelMethods, 'attributes'); + /** + * Return traits for the source provider + * @return {Array} + * @private + */ + getSourceTraits: function getSourceTraits() { + return [this.getProviderTrait(), { + label: 'Source', + name: 'src', + placeholder: 'eg. ./media/video.mp4', + changeProp: 1 + }, { + label: 'Poster', + name: 'poster', + placeholder: 'eg. ./media/image.jpg', + changeProp: 1 + }, this.getAutoplayTrait(), this.getLoopTrait(), this.getControlsTrait()]; + }, - // Backbone.Collection - // ------------------- + /** + * Return traits for the source provider + * @return {Array} + * @private + */ + getYoutubeTraits: function getYoutubeTraits() { + return [this.getProviderTrait(), { + label: 'Video ID', + name: 'videoId', + placeholder: 'eg. jNQXAC9IVRw', + changeProp: 1 + }, this.getAutoplayTrait(), this.getLoopTrait(), this.getControlsTrait(), { + type: 'checkbox', + label: 'Related', + name: 'rel', + changeProp: 1 + }, { + type: 'checkbox', + label: 'Modest', + name: 'modestbranding', + changeProp: 1 + }]; + }, - // If models tend to represent a single row of data, a Backbone Collection is - // more analogous to a table full of data ... or a small slice or page of that - // table, or a collection of rows that belong together for a particular reason - // -- all of the messages in this particular folder, all of the documents - // belonging to this particular author, and so on. Collections maintain - // indexes of their models, both in order, and for lookup by `id`. + /** + * Return traits for the source provider + * @return {Array} + * @private + */ + getVimeoTraits: function getVimeoTraits() { + return [this.getProviderTrait(), { + label: 'Video ID', + name: 'videoId', + placeholder: 'eg. 123456789', + changeProp: 1 + }, { + label: 'Color', + name: 'color', + placeholder: 'eg. FF0000', + changeProp: 1 + }, this.getAutoplayTrait(), this.getLoopTrait()]; + }, - // Create a new **Collection**, perhaps to contain a specific type of `model`. - // If a `comparator` is specified, the Collection will maintain - // its models in sort order, as they're added and removed. - var Collection = Backbone.Collection = function(models, options) { - options || (options = {}); - if (options.model) this.model = options.model; - if (options.comparator !== void 0) this.comparator = options.comparator; - this._reset(); - this.initialize.apply(this, arguments); - if (models) this.reset(models, _.extend({silent: true}, options)); - }; + /** + * Return object trait + * @return {Object} + * @private + */ + getAutoplayTrait: function getAutoplayTrait() { + return { + type: 'checkbox', + label: 'Autoplay', + name: 'autoplay', + changeProp: 1 + }; + }, - // Default options for `Collection#set`. - var setOptions = {add: true, remove: true, merge: true}; - var addOptions = {add: true, remove: false}; + /** + * Return object trait + * @return {Object} + * @private + */ + getLoopTrait: function getLoopTrait() { + return { + type: 'checkbox', + label: 'Loop', + name: 'loop', + changeProp: 1 + }; + }, - // Define the Collection's inheritable methods. - _.extend(Collection.prototype, Events, { + /** + * Return object trait + * @return {Object} + * @private + */ + getControlsTrait: function getControlsTrait() { + return { + type: 'checkbox', + label: 'Controls', + name: 'controls', + changeProp: 1 + }; + }, - // The default model for a collection is just a **Backbone.Model**. - // This should be overridden in most cases. - model: Model, + /** + * Returns url to youtube video + * @return {string} + * @private + */ + getYoutubeSrc: function getYoutubeSrc() { + var id = this.get('videoId'); + var url = this.get('ytUrl'); + url += id + '?'; + url += this.get('autoplay') ? '&autoplay=1' : ''; + url += !this.get('controls') ? '&controls=0&showinfo=0' : ''; // Loop works only with playlist enabled + // https://stackoverflow.com/questions/25779966/youtube-iframe-loop-doesnt-work - // Initialize is an empty function by default. Override it with your own - // initialization logic. - initialize: function(){}, + url += this.get('loop') ? "&loop=1&playlist=".concat(id) : ''; + url += this.get('rel') ? '' : '&rel=0'; + url += this.get('modestbranding') ? '&modestbranding=1' : ''; + return url; + }, - // The JSON representation of a Collection is an array of the - // models' attributes. - toJSON: function(options) { - return this.map(function(model) { return model.toJSON(options); }); - }, + /** + * Returns url to youtube no cookie video + * @return {string} + * @private + */ + getYoutubeNoCookieSrc: function getYoutubeNoCookieSrc() { + var url = this.getYoutubeSrc(); + url = url.replace(this.get('ytUrl'), this.get('ytncUrl')); + return url; + }, - // Proxy `Backbone.sync` by default. - sync: function() { - return Backbone.sync.apply(this, arguments); - }, + /** + * Returns url to vimeo video + * @return {string} + * @private + */ + getVimeoSrc: function getVimeoSrc() { + var url = this.get('viUrl'); + url += this.get('videoId') + '?'; + url += this.get('autoplay') ? '&autoplay=1' : ''; + url += this.get('loop') ? '&loop=1' : ''; + url += !this.get('controls') ? '&title=0&portrait=0&badge=0' : ''; + url += this.get('color') ? '&color=' + this.get('color') : ''; + return url; + } +}, { + /** + * Detect if the passed element is a valid component. + * In case the element is valid an object abstracted + * from the element will be returned + * @param {HTMLElement} + * @return {Object} + * @private + */ + isComponent: function isComponent(el) { + var result = ''; + var isYtProv = /youtube\.com\/embed/.test(el.src); + var isYtncProv = /youtube-nocookie\.com\/embed/.test(el.src); + var isViProv = /player\.vimeo\.com\/video/.test(el.src); + var isExtProv = isYtProv || isYtncProv || isViProv; - // Add a model, or list of models to the set. - add: function(models, options) { - return this.set(models, _.extend({merge: false}, options, addOptions)); - }, + if (el.tagName == 'VIDEO' || el.tagName == 'IFRAME' && isExtProv) { + result = { + type: 'video' + }; + if (el.src) result.src = el.src; - // Remove a model, or a list of models from the set. - remove: function(models, options) { - options = _.extend({}, options); - var singular = !_.isArray(models); - models = singular ? [models] : _.clone(models); - var removed = this._removeModels(models, options); - if (!options.silent && removed) this.trigger('update', this, options); - return singular ? removed[0] : removed; - }, + if (isExtProv) { + if (isYtProv) result.provider = yt;else if (isYtncProv) result.provider = ytnc;else if (isViProv) result.provider = vi; + } + } - // Update a collection by `set`-ing a new list of models, adding new ones, - // removing models that are no longer present, and merging models that - // already exist in the collection, as necessary. Similar to **Model#set**, - // the core operation for updating the data contained by the collection. - set: function(models, options) { - options = _.defaults({}, options, setOptions); - if (options.parse && !this._isModel(models)) models = this.parse(models, options); - var singular = !_.isArray(models); - models = singular ? (models ? [models] : []) : models.slice(); - var id, model, attrs, existing, sort; - var at = options.at; - if (at != null) at = +at; - if (at < 0) at += this.length + 1; - var sortable = this.comparator && (at == null) && options.sort !== false; - var sortAttr = _.isString(this.comparator) ? this.comparator : null; - var toAdd = [], toRemove = [], modelMap = {}; - var add = options.add, merge = options.merge, remove = options.remove; - var order = !sortable && add && remove ? [] : false; - var orderChanged = false; + return result; + } +})); - // Turn bare objects into model references, and prevent invalid models - // from being added. - for (var i = 0; i < models.length; i++) { - attrs = models[i]; +/***/ }), - // If a duplicate is found, prevent it from being added and - // optionally merge it into the existing model. - if (existing = this.get(attrs)) { - if (remove) modelMap[existing.cid] = true; - if (merge && attrs !== existing) { - attrs = this._isModel(attrs) ? attrs.attributes : attrs; - if (options.parse) attrs = existing.parse(attrs, options); - existing.set(attrs, options); - if (sortable && !sort && existing.hasChanged(sortAttr)) sort = true; - } - models[i] = existing; +/***/ "./src/dom_components/model/ComponentWrapper.js": +/*!******************************************************!*\ + !*** ./src/dom_components/model/ComponentWrapper.js ***! + \******************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // If this is a new, valid model, push it to the `toAdd` list. - } else if (add) { - model = models[i] = this._prepareModel(attrs, options); - if (!model) continue; - toAdd.push(model); - this._addReference(model, options); - } +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _Component__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./Component */ "./src/dom_components/model/Component.js"); +// We need this one just to identify better the wrapper type - // Do not add multiple models with the same `id`. - model = existing || model; - if (!model) continue; - id = this.modelId(model.attributes); - if (order && (model.isNew() || !modelMap[id])) { - order.push(model); +/* harmony default export */ __webpack_exports__["default"] = (_Component__WEBPACK_IMPORTED_MODULE_0__["default"].extend({}, { + isComponent: function isComponent() { + return false; + } +})); - // Check to see if this is actually a new model at this index. - orderChanged = orderChanged || !this.models[i] || model.cid !== this.models[i].cid; - } +/***/ }), - modelMap[id] = true; - } +/***/ "./src/dom_components/model/Components.js": +/*!************************************************!*\ + !*** ./src/dom_components/model/Components.js ***! + \************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // Remove nonexistent models if appropriate. - if (remove) { - for (var i = 0; i < this.length; i++) { - if (!modelMap[(model = this.models[i]).cid]) toRemove.push(model); +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/typeof */ "./node_modules/@babel/runtime/helpers/typeof.js"); +/* harmony import */ var _babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_2__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_3__); + + + +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } + +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } + + + +var Component; +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_2___default.a.Collection.extend({ + initialize: function initialize(models) { + var opt = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + this.opt = opt; + this.listenTo(this, 'add', this.onAdd); + this.config = opt.config; + this.em = opt.em; + var em = this.em; + + this.model = function (attrs, options) { + var model; + var df = opt.componentTypes; + options.em = opt.em; + options.config = opt.config; + options.componentTypes = df; + options.domc = opt.domc; + + for (var it = 0; it < df.length; it++) { + var dfId = df[it].id; + + if (dfId == attrs.type) { + model = df[it].model; + break; } - if (toRemove.length) this._removeModels(toRemove, options); } - // See if sorting is needed, update `length` and splice in new models. - if (toAdd.length || orderChanged) { - if (sortable) sort = true; - this.length += toAdd.length; - if (at != null) { - for (var i = 0; i < toAdd.length; i++) { - this.models.splice(at + i, 0, toAdd[i]); - } - } else { - if (order) this.models.length = 0; - var orderedModels = order || toAdd; - for (var i = 0; i < orderedModels.length; i++) { - this.models.push(orderedModels[i]); - } - } + if (!model) { + // get the last one + model = df[df.length - 1].model; + em && attrs.type && em.logWarning("Component type '".concat(attrs.type, "' not found"), { + attrs: attrs, + options: options + }); } - // Silently sort the collection if appropriate. - if (sort) this.sort({silent: true}); + return new model(attrs, options); + }; + }, + parseString: function parseString(value) { + var opt = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + var em = this.em; + var cssc = em.get('CssComposer'); + var parsed = em.get('Parser').parseHtml(value); // We need this to avoid duplicate IDs - // Unless silenced, it's time to fire all appropriate add/sort events. - if (!options.silent) { - var addOpts = at != null ? _.clone(options) : options; - for (var i = 0; i < toAdd.length; i++) { - if (at != null) addOpts.index = at + i; - (model = toAdd[i]).trigger('add', model, this, addOpts); + if (!Component) Component = __webpack_require__(/*! ./Component */ "./src/dom_components/model/Component.js").default; + Component.checkId(parsed.html, parsed.css, this.opt.domc.componentsById); + + if (parsed.css && cssc && !opt.temporary) { + cssc.addCollection(parsed.css, _objectSpread({}, opt, { + extend: 1 + })); + } + + return parsed.html; + }, + add: function add(models) { + var _this = this; + + var opt = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + + if (Object(underscore__WEBPACK_IMPORTED_MODULE_3__["isString"])(models)) { + models = this.parseString(models, opt); + } else if (Object(underscore__WEBPACK_IMPORTED_MODULE_3__["isArray"])(models)) { + models.forEach(function (item, index) { + if (Object(underscore__WEBPACK_IMPORTED_MODULE_3__["isString"])(item)) { + models[index] = _this.parseString(item, opt); } - if (sort || orderChanged) this.trigger('sort', this, options); - if (toAdd.length || toRemove.length) this.trigger('update', this, options); + }); + } + + var isMult = Object(underscore__WEBPACK_IMPORTED_MODULE_3__["isArray"])(models); + models = (isMult ? models : [models]).filter(function (i) { + return i; + }).map(function (model) { + return _this.processDef(model); + }); + models = isMult ? models : models[0]; + return backbone__WEBPACK_IMPORTED_MODULE_2___default.a.Collection.prototype.add.apply(this, [models, opt]); + }, + + /** + * Process component definition. + */ + processDef: function processDef(mdl) { + // Avoid processing Models + if (mdl.cid && mdl.ccid) return mdl; + var em = this.em, + _this$config = this.config, + config = _this$config === void 0 ? {} : _this$config; + var processor = config.processor; + var model = mdl; + + if (processor) { + model = _objectSpread({}, model); // Avoid 'Cannot delete property ...' + + var modelPr = processor(model); + + if (modelPr) { + Object(underscore__WEBPACK_IMPORTED_MODULE_3__["each"])(model, function (val, key) { + return delete model[key]; + }); + Object(underscore__WEBPACK_IMPORTED_MODULE_3__["extend"])(model, modelPr); } + } // React JSX preset - // Return the added (or merged) model (or models). - return singular ? models[0] : models; - }, - // When you have more items than you want to add or remove individually, - // you can reset the entire set with a new list of models, without firing - // any granular `add` or `remove` events. Fires `reset` when finished. - // Useful for bulk operations and optimizations. - reset: function(models, options) { - options = options ? _.clone(options) : {}; - for (var i = 0; i < this.models.length; i++) { - this._removeReference(this.models[i], options); + if (model.$$typeof && _babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0___default()(model.props) == 'object') { + model = _objectSpread({}, model); + model.props = _objectSpread({}, model.props); + var domc = em.get('DomComponents'); + var parser = em.get('Parser'); + var parserHtml = parser.parserHtml; + Object(underscore__WEBPACK_IMPORTED_MODULE_3__["each"])(model, function (value, key) { + if (!Object(underscore__WEBPACK_IMPORTED_MODULE_3__["includes"])(['props', 'type'], key)) delete model[key]; + }); + var _model = model, + props = _model.props; + var comps = props.children; + delete props.children; + delete model.props; + var res = parserHtml.splitPropsFromAttr(props); + model.attributes = res.attrs; + + if (comps) { + model.components = comps; } - options.previousModels = this.models; - this._reset(); - models = this.add(models, _.extend({silent: true}, options)); - if (!options.silent) this.trigger('reset', this, options); - return models; - }, - // Add a model to the end of the collection. - push: function(model, options) { - return this.add(model, _.extend({at: this.length}, options)); - }, + if (!model.type) { + model.type = 'textnode'; + } else if (!domc.getType(model.type)) { + model.tagName = model.type; + delete model.type; + } - // Remove a model from the end of the collection. - pop: function(options) { - var model = this.at(this.length - 1); - return this.remove(model, options); - }, + Object(underscore__WEBPACK_IMPORTED_MODULE_3__["extend"])(model, res.props); + } - // Add a model to the beginning of the collection. - unshift: function(model, options) { - return this.add(model, _.extend({at: 0}, options)); - }, + return model; + }, + onAdd: function onAdd(model, c) { + var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + var em = this.em; + var style = model.getStyle(); + var avoidInline = em && em.getConfig('avoidInlineStyle'); - // Remove a model from the beginning of the collection. - shift: function(options) { - var model = this.at(0); - return this.remove(model, options); - }, + if (!Object(underscore__WEBPACK_IMPORTED_MODULE_3__["isEmpty"])(style) && !avoidInline && em && em.get && em.getConfig('forceClass') && !opts.temporary) { + var name = model.cid; + var rule = em.get('CssComposer').setClassRule(name, style); + model.setStyle({}); + model.addClass(name); + } + } +})); - // Slice out a sub-array of models from the collection. - slice: function() { - return slice.apply(this.models, arguments); - }, +/***/ }), - // Get a model from the set by id. - get: function(obj) { - if (obj == null) return void 0; - var id = this.modelId(this._isModel(obj) ? obj.attributes : obj); - return this._byId[obj] || this._byId[id] || this._byId[obj.cid]; - }, +/***/ "./src/dom_components/model/Toolbar.js": +/*!*********************************************!*\ + !*** ./src/dom_components/model/Toolbar.js ***! + \*********************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // Get the model at the given index. - at: function(index) { - if (index < 0) index += this.length; - return this.models[index]; - }, +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _ToolbarButton__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./ToolbarButton */ "./src/dom_components/model/ToolbarButton.js"); - // Return models with matching attributes. Useful for simple cases of - // `filter`. - where: function(attrs, first) { - var matches = _.matches(attrs); - return this[first ? 'find' : 'filter'](function(model) { - return matches(model.attributes); - }); - }, - // Return the first model with matching attributes. Useful for simple cases - // of `find`. - findWhere: function(attrs) { - return this.where(attrs, true); - }, +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_0___default.a.Collection.extend({ + model: _ToolbarButton__WEBPACK_IMPORTED_MODULE_1__["default"] +})); - // Force the collection to re-sort itself. You don't need to call this under - // normal circumstances, as the set will maintain sort order as each item - // is added. - sort: function(options) { - if (!this.comparator) throw new Error('Cannot sort a set without a comparator'); - options || (options = {}); +/***/ }), - // Run sort based on type of `comparator`. - if (_.isString(this.comparator) || this.comparator.length === 1) { - this.models = this.sortBy(this.comparator, this); - } else { - this.models.sort(_.bind(this.comparator, this)); - } +/***/ "./src/dom_components/model/ToolbarButton.js": +/*!***************************************************!*\ + !*** ./src/dom_components/model/ToolbarButton.js ***! + \***************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - if (!options.silent) this.trigger('sort', this, options); - return this; - }, +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); - // Pluck an attribute from each model in the collection. - pluck: function(attr) { - return _.invoke(this.models, 'get', attr); - }, +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_0___default.a.Model.extend({ + defaults: { + command: '', + attributes: {} + } +})); - // Fetch the default set of models for this collection, resetting the - // collection when they arrive. If `reset: true` is passed, the response - // data will be passed through the `reset` method instead of `set`. - fetch: function(options) { - options = _.extend({parse: true}, options); - var success = options.success; - var collection = this; - options.success = function(resp) { - var method = options.reset ? 'reset' : 'set'; - collection[method](resp, options); - if (success) success.call(options.context, collection, resp, options); - collection.trigger('sync', collection, resp, options); - }; - wrapError(this, options); - return this.sync('read', this, options); - }, - - // Create a new instance of a model in this collection. Add the model to the - // collection immediately, unless `wait: true` is passed, in which case we - // wait for the server to agree. - create: function(model, options) { - options = options ? _.clone(options) : {}; - var wait = options.wait; - model = this._prepareModel(model, options); - if (!model) return false; - if (!wait) this.add(model, options); - var collection = this; - var success = options.success; - options.success = function(model, resp, callbackOpts) { - if (wait) collection.add(model, callbackOpts); - if (success) success.call(callbackOpts.context, model, resp, callbackOpts); - }; - model.save(null, options); - return model; - }, - - // **parse** converts a response into a list of models to be added to the - // collection. The default implementation is just to pass it through. - parse: function(resp, options) { - return resp; - }, +/***/ }), - // Create a new collection with an identical list of models as this one. - clone: function() { - return new this.constructor(this.models, { - model: this.model, - comparator: this.comparator - }); - }, +/***/ "./src/dom_components/view/ComponentCommentView.js": +/*!*********************************************************!*\ + !*** ./src/dom_components/view/ComponentCommentView.js ***! + \*********************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // Define how to uniquely identify models in the collection. - modelId: function (attrs) { - return attrs[this.model.prototype.idAttribute || 'id']; - }, +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _ComponentTextNodeView__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./ComponentTextNodeView */ "./src/dom_components/view/ComponentTextNodeView.js"); - // Private method to reset all internal state. Called when the collection - // is first initialized or reset. - _reset: function() { - this.length = 0; - this.models = []; - this._byId = {}; - }, +/* harmony default export */ __webpack_exports__["default"] = (_ComponentTextNodeView__WEBPACK_IMPORTED_MODULE_0__["default"].extend({ + _createElement: function _createElement() { + return document.createComment(this.model.get('content')); + } +})); - // Prepare a hash of attributes (or other model) to be added to this - // collection. - _prepareModel: function(attrs, options) { - if (this._isModel(attrs)) { - if (!attrs.collection) attrs.collection = this; - return attrs; - } - options = options ? _.clone(options) : {}; - options.collection = this; - var model = new this.model(attrs, options); - if (!model.validationError) return model; - this.trigger('invalid', this, model.validationError, options); - return false; - }, +/***/ }), - // Internal method called by both remove and set. - // Returns removed models, or false if nothing is removed. - _removeModels: function(models, options) { - var removed = []; - for (var i = 0; i < models.length; i++) { - var model = this.get(models[i]); - if (!model) continue; +/***/ "./src/dom_components/view/ComponentImageView.js": +/*!*******************************************************!*\ + !*** ./src/dom_components/view/ComponentImageView.js ***! + \*******************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - var index = this.indexOf(model); - this.models.splice(index, 1); - this.length--; +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _ComponentView__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./ComponentView */ "./src/dom_components/view/ComponentView.js"); - if (!options.silent) { - options.index = index; - model.trigger('remove', model, this, options); - } - removed.push(model); - this._removeReference(model, options); - } - return removed.length ? removed : false; - }, +/* harmony default export */ __webpack_exports__["default"] = (_ComponentView__WEBPACK_IMPORTED_MODULE_1__["default"].extend({ + tagName: 'img', + events: { + dblclick: 'onActive', + click: 'initResize', + error: 'onError', + dragstart: 'noDrag' + }, + initialize: function initialize(o) { + var model = this.model; + _ComponentView__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.initialize.apply(this, arguments); + this.listenTo(model, 'change:src', this.updateSrc); + this.classEmpty = "".concat(this.ppfx, "plh-image"); + var config = this.config; + config.modal && (this.modal = config.modal); + config.am && (this.am = config.am); + this.fetchFile(); + }, - // Method for checking whether an object should be considered a model for - // the purposes of adding to the collection. - _isModel: function (model) { - return model instanceof Model; - }, + /** + * Fetch file if exists + */ + fetchFile: function fetchFile() { + if (this.modelOpt.temporary) return; + var model = this.model; + var file = model.get('file'); + + if (file) { + var fu = this.em.get('AssetManager').FileUploader(); + fu.uploadFile({ + dataTransfer: { + files: [file] + } + }, function (res) { + var obj = res && res.data && res.data[0]; + var src = obj && (Object(underscore__WEBPACK_IMPORTED_MODULE_0__["isString"])(obj) ? obj : obj.src); + src && model.set({ + src: src + }); + }); + model.set('file', ''); + } + }, - // Internal method to create a model's ties to a collection. - _addReference: function(model, options) { - this._byId[model.cid] = model; - var id = this.modelId(model.attributes); - if (id != null) this._byId[id] = model; - model.on('all', this._onModelEvent, this); - }, + /** + * Update src attribute + * @private + * */ + updateSrc: function updateSrc() { + var model = this.model, + classEmpty = this.classEmpty, + $el = this.$el; + var src = model.getSrcResult(); + var srcExists = src && !model.isDefaultSrc(); + model.addAttributes({ + src: src + }); + $el[srcExists ? 'removeClass' : 'addClass'](classEmpty); + }, - // Internal method to sever a model's ties to a collection. - _removeReference: function(model, options) { - delete this._byId[model.cid]; - var id = this.modelId(model.attributes); - if (id != null) delete this._byId[id]; - if (this === model.collection) delete model.collection; - model.off('all', this._onModelEvent, this); - }, + /** + * Open dialog for image changing + * @param {Object} e Event + * @private + * */ + onActive: function onActive(ev) { + ev && ev.stopPropagation(); + var em = this.opts.config.em; + var editor = em ? em.get('Editor') : ''; - // Internal method called every time a model in the set fires an event. - // Sets need to update their indexes when models change ids. All other - // events simply proxy through. "add" and "remove" events that originate - // in other collections are ignored. - _onModelEvent: function(event, model, collection, options) { - if ((event === 'add' || event === 'remove') && collection !== this) return; - if (event === 'destroy') this.remove(model, options); - if (event === 'change') { - var prevId = this.modelId(model.previousAttributes()); - var id = this.modelId(model.attributes); - if (prevId !== id) { - if (prevId != null) delete this._byId[prevId]; - if (id != null) this._byId[id] = model; + if (editor && this.model.get('editable')) { + editor.runCommand('open-assets', { + target: this.model, + types: ['image'], + accept: 'image/*', + onSelect: function onSelect() { + editor.Modal.close(); + editor.AssetManager.setTarget(null); } - } - this.trigger.apply(this, arguments); + }); } + }, + onError: function onError() { + var fallback = this.model.getSrcResult({ + fallback: 1 + }); + if (fallback) this.el.src = fallback; + }, + noDrag: function noDrag(ev) { + ev.preventDefault(); + return false; + }, + render: function render() { + this.renderAttributes(); + this.updateSrc(); + var $el = this.$el, + model = this.model; + var cls = $el.attr('class') || ''; + !model.get('src') && $el.attr('class', "".concat(cls, " ").concat(this.classEmpty).trim()); + this.postRender(); + return this; + } +})); - }); +/***/ }), - // Underscore methods that we want to implement on the Collection. - // 90% of the core usefulness of Backbone Collections is actually implemented - // right here: - var collectionMethods = { forEach: 3, each: 3, map: 3, collect: 3, reduce: 4, - foldl: 4, inject: 4, reduceRight: 4, foldr: 4, find: 3, detect: 3, filter: 3, - select: 3, reject: 3, every: 3, all: 3, some: 3, any: 3, include: 2, - contains: 2, invoke: 0, max: 3, min: 3, toArray: 1, size: 1, first: 3, - head: 3, take: 3, initial: 3, rest: 3, tail: 3, drop: 3, last: 3, - without: 0, difference: 0, indexOf: 3, shuffle: 1, lastIndexOf: 3, - isEmpty: 1, chain: 1, sample: 3, partition: 3 }; +/***/ "./src/dom_components/view/ComponentLabelView.js": +/*!*******************************************************!*\ + !*** ./src/dom_components/view/ComponentLabelView.js ***! + \*******************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // Mix in each Underscore method as a proxy to `Collection#models`. - addUnderscoreMethods(Collection, collectionMethods, 'models'); +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _ComponentLinkView__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./ComponentLinkView */ "./src/dom_components/view/ComponentLinkView.js"); - // Underscore methods that take a property name as an argument. - var attributeMethods = ['groupBy', 'countBy', 'sortBy', 'indexBy']; +/* harmony default export */ __webpack_exports__["default"] = (_ComponentLinkView__WEBPACK_IMPORTED_MODULE_0__["default"].extend({})); - // Use attributes instead of properties. - _.each(attributeMethods, function(method) { - if (!_[method]) return; - Collection.prototype[method] = function(value, context) { - var iterator = _.isFunction(value) ? value : function(model) { - return model.get(value); - }; - return _[method](this.models, iterator, context); - }; - }); +/***/ }), - // Backbone.View - // ------------- +/***/ "./src/dom_components/view/ComponentLinkView.js": +/*!******************************************************!*\ + !*** ./src/dom_components/view/ComponentLinkView.js ***! + \******************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // Backbone Views are almost more convention than they are actual code. A View - // is simply a JavaScript object that represents a logical chunk of UI in the - // DOM. This might be a single item, an entire list, a sidebar or panel, or - // even the surrounding frame which wraps your whole app. Defining a chunk of - // UI as a **View** allows you to define your DOM events declaratively, without - // having to worry about render order ... and makes it easy for the view to - // react to specific changes in the state of your models. +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _ComponentTextView__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./ComponentTextView */ "./src/dom_components/view/ComponentTextView.js"); - // Creating a Backbone.View creates its initial element outside of the DOM, - // if an existing element is not provided... - var View = Backbone.View = function(options) { - this.cid = _.uniqueId('view'); - _.extend(this, _.pick(options, viewOptions)); - this._ensureElement(); - this.initialize.apply(this, arguments); - }; +/* harmony default export */ __webpack_exports__["default"] = (_ComponentTextView__WEBPACK_IMPORTED_MODULE_0__["default"].extend({ + render: function render() { + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; + } - // Cached regex to split keys for `delegate`. - var delegateEventSplitter = /^(\S+)\s*(.*)$/; + _ComponentTextView__WEBPACK_IMPORTED_MODULE_0__["default"].prototype.render.apply(this, args); // I need capturing instead of bubbling as bubbled clicks from other + // children will execute the link event - // List of view options to be merged as properties. - var viewOptions = ['model', 'collection', 'el', 'id', 'attributes', 'className', 'tagName', 'events']; + this.el.addEventListener('click', this.prevDef, true); + return this; + } +})); - // Set up all inheritable **Backbone.View** properties and methods. - _.extend(View.prototype, Events, { +/***/ }), - // The default `tagName` of a View's element is `"div"`. - tagName: 'div', +/***/ "./src/dom_components/view/ComponentMapView.js": +/*!*****************************************************!*\ + !*** ./src/dom_components/view/ComponentMapView.js ***! + \*****************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // jQuery delegate for element lookup, scoped to DOM elements within the - // current view. This should be preferred to global lookups where possible. - $: function(selector) { - return this.$el.find(selector); - }, +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _ComponentImageView__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./ComponentImageView */ "./src/dom_components/view/ComponentImageView.js"); - // Initialize is an empty function by default. Override it with your own - // initialization logic. - initialize: function(){}, - // **render** is the core function that your view should override, in order - // to populate its element (`this.el`), with the appropriate HTML. The - // convention is for **render** to always return `this`. - render: function() { - return this; - }, +/* harmony default export */ __webpack_exports__["default"] = (_ComponentImageView__WEBPACK_IMPORTED_MODULE_1__["default"].extend({ + tagName: 'div', + events: {}, + initialize: function initialize(o) { + _ComponentImageView__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.initialize.apply(this, arguments); + this.classEmpty = this.ppfx + 'plh-map'; + }, - // Remove this view by taking the element out of the DOM, and removing any - // applicable Backbone.Events listeners. - remove: function() { - this._removeElement(); - this.stopListening(); - return this; - }, + /** + * Update the map on the canvas + * @private + */ + updateSrc: function updateSrc() { + this.getIframe().src = this.model.get('src'); + }, + getIframe: function getIframe() { + if (!this.iframe) { + var ifrm = document.createElement('iframe'); + ifrm.src = this.model.get('src'); + ifrm.frameBorder = 0; + ifrm.style.height = '100%'; + ifrm.style.width = '100%'; + ifrm.className = this.ppfx + 'no-pointer'; + this.iframe = ifrm; + } - // Remove this view's element from the document and all event listeners - // attached to it. Exposed for subclasses using an alternative DOM - // manipulation API. - _removeElement: function() { - this.$el.remove(); - }, + return this.iframe; + }, + render: function render() { + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; + } - // Change the view's element (`this.el` property) and re-delegate the - // view's events on the new element. - setElement: function(element) { - this.undelegateEvents(); - this._setElement(element); - this.delegateEvents(); - return this; - }, + _ComponentImageView__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.render.apply(this, args); + this.updateClasses(); + this.el.appendChild(this.getIframe()); + return this; + } +})); - // Creates the `this.el` and `this.$el` references for this view using the - // given `el`. `el` can be a CSS selector or an HTML string, a jQuery - // context or an element. Subclasses can override this to utilize an - // alternative DOM manipulation API and are only required to set the - // `this.el` property. - _setElement: function(el) { - this.$el = el instanceof Backbone.$ ? el : Backbone.$(el); - this.el = this.$el[0]; - }, +/***/ }), - // Set callbacks, where `this.events` is a hash of - // - // *{"event selector": "callback"}* - // - // { - // 'mousedown .title': 'edit', - // 'click .button': 'save', - // 'click .open': function(e) { ... } - // } - // - // pairs. Callbacks will be bound to the view, with `this` set properly. - // Uses event delegation for efficiency. - // Omitting the selector binds the event to `this.el`. - delegateEvents: function(events) { - events || (events = _.result(this, 'events')); - if (!events) return this; - this.undelegateEvents(); - for (var key in events) { - var method = events[key]; - if (!_.isFunction(method)) method = this[method]; - if (!method) continue; - var match = key.match(delegateEventSplitter); - this.delegate(match[1], match[2], _.bind(method, this)); - } - return this; - }, +/***/ "./src/dom_components/view/ComponentScriptView.js": +/*!********************************************************!*\ + !*** ./src/dom_components/view/ComponentScriptView.js ***! + \********************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // Add a single event listener to the view's element (or a child element - // using `selector`). This only works for delegate-able events: not `focus`, - // `blur`, and not `change`, `submit`, and `reset` in Internet Explorer. - delegate: function(eventName, selector, listener) { - this.$el.on(eventName + '.delegateEvents' + this.cid, selector, listener); - return this; - }, +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _ComponentImageView__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./ComponentImageView */ "./src/dom_components/view/ComponentImageView.js"); - // Clears all callbacks previously bound to the view by `delegateEvents`. - // You usually don't need to use this, but may wish to if you have multiple - // Backbone views attached to the same DOM element. - undelegateEvents: function() { - if (this.$el) this.$el.off('.delegateEvents' + this.cid); - return this; - }, - // A finer-grained `undelegateEvents` for removing a single delegated event. - // `selector` and `listener` are both optional. - undelegate: function(eventName, selector, listener) { - this.$el.off(eventName + '.delegateEvents' + this.cid, selector, listener); - return this; - }, +/* harmony default export */ __webpack_exports__["default"] = (_ComponentImageView__WEBPACK_IMPORTED_MODULE_1__["default"].extend({ + tagName: 'script', + events: {}, + render: function render() { + var model = this.model; + var src = model.get('src'); + var em = this.em; + var scriptCount = em && em.get('scriptCount') ? em.get('scriptCount') : 0; + var content = ''; // If it's an external script - // Produces a DOM element to be assigned to your view. Exposed for - // subclasses using an alternative DOM manipulation API. - _createElement: function(tagName) { - return document.createElement(tagName); - }, + if (src) { + var onload = model.get('onload'); + var svar = 'script' + scriptCount; + var svarNext = 'script' + (scriptCount + 1); + content = 'var ' + svar + " = document.createElement('script');\n" + svar + '.onload = function(){\n' + (onload ? onload + '();\n' : '') + 'typeof ' + svarNext + "Start == 'function' && " + svarNext + 'Start();\n' + '};\n' + svar + ".src = '" + src + "';\n" + 'function ' + svar + 'Start() { document.body.appendChild(' + svar + '); };\n' + (!scriptCount ? svar + 'Start();' : ''); - // Ensure that the View has a DOM element to render into. - // If `this.el` is a string, pass it through `$()`, take the first - // matching element, and re-assign it to `el`. Otherwise, create - // an element from the `id`, `className` and `tagName` properties. - _ensureElement: function() { - if (!this.el) { - var attrs = _.extend({}, _.result(this, 'attributes')); - if (this.id) attrs.id = _.result(this, 'id'); - if (this.className) attrs['class'] = _.result(this, 'className'); - this.setElement(this._createElement(_.result(this, 'tagName'))); - this._setAttributes(attrs); - } else { - this.setElement(_.result(this, 'el')); + if (em) { + em.set('scriptCount', scriptCount + 1); } - }, - - // Set attributes from a hash on this view's element. Exposed for - // subclasses using an alternative DOM manipulation API. - _setAttributes: function(attributes) { - this.$el.attr(attributes); + } else { + content = model.get('content'); } - }); + this.el.innerHTML = content; + return this; + } +})); - // Backbone.sync - // ------------- +/***/ }), - // Override this function to change the manner in which Backbone persists - // models to the server. You will be passed the type of request, and the - // model in question. By default, makes a RESTful Ajax request - // to the model's `url()`. Some possible customizations could be: - // - // * Use `setTimeout` to batch rapid-fire updates into a single request. - // * Send up the models as XML instead of JSON. - // * Persist models via WebSockets instead of Ajax. - // - // Turn on `Backbone.emulateHTTP` in order to send `PUT` and `DELETE` requests - // as `POST`, with a `_method` parameter containing the true HTTP method, - // as well as all requests with the body as `application/x-www-form-urlencoded` - // instead of `application/json` with the model in a param named `model`. - // Useful when interfacing with server-side languages like **PHP** that make - // it difficult to read the body of `PUT` requests. - Backbone.sync = function(method, model, options) { - var type = methodMap[method]; +/***/ "./src/dom_components/view/ComponentSvgView.js": +/*!*****************************************************!*\ + !*** ./src/dom_components/view/ComponentSvgView.js ***! + \*****************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // Default options, unless specified. - _.defaults(options || (options = {}), { - emulateHTTP: Backbone.emulateHTTP, - emulateJSON: Backbone.emulateJSON - }); +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _ComponentView__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./ComponentView */ "./src/dom_components/view/ComponentView.js"); - // Default JSON-request options. - var params = {type: type, dataType: 'json'}; +/* harmony default export */ __webpack_exports__["default"] = (_ComponentView__WEBPACK_IMPORTED_MODULE_0__["default"].extend({ + _createElement: function _createElement(tagName) { + return document.createElementNS('http://www.w3.org/2000/svg', tagName); + } +})); - // Ensure that we have a URL. - if (!options.url) { - params.url = _.result(model, 'url') || urlError(); - } +/***/ }), - // Ensure that we have the appropriate request data. - if (options.data == null && model && (method === 'create' || method === 'update' || method === 'patch')) { - params.contentType = 'application/json'; - params.data = JSON.stringify(options.attrs || model.toJSON(options)); - } +/***/ "./src/dom_components/view/ComponentTableBodyView.js": +/*!***********************************************************!*\ + !*** ./src/dom_components/view/ComponentTableBodyView.js ***! + \***********************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // For older servers, emulate JSON by encoding the request into an HTML-form. - if (options.emulateJSON) { - params.contentType = 'application/x-www-form-urlencoded'; - params.data = params.data ? {model: params.data} : {}; - } +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _ComponentView__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./ComponentView */ "./src/dom_components/view/ComponentView.js"); - // For older servers, emulate HTTP by mimicking the HTTP method with `_method` - // And an `X-HTTP-Method-Override` header. - if (options.emulateHTTP && (type === 'PUT' || type === 'DELETE' || type === 'PATCH')) { - params.type = 'POST'; - if (options.emulateJSON) params.data._method = type; - var beforeSend = options.beforeSend; - options.beforeSend = function(xhr) { - xhr.setRequestHeader('X-HTTP-Method-Override', type); - if (beforeSend) return beforeSend.apply(this, arguments); - }; - } +/* harmony default export */ __webpack_exports__["default"] = (_ComponentView__WEBPACK_IMPORTED_MODULE_0__["default"].extend({})); - // Don't process data on a non-GET request. - if (params.type !== 'GET' && !options.emulateJSON) { - params.processData = false; - } +/***/ }), - // Pass along `textStatus` and `errorThrown` from jQuery. - var error = options.error; - options.error = function(xhr, textStatus, errorThrown) { - options.textStatus = textStatus; - options.errorThrown = errorThrown; - if (error) error.call(options.context, xhr, textStatus, errorThrown); - }; +/***/ "./src/dom_components/view/ComponentTableCellView.js": +/*!***********************************************************!*\ + !*** ./src/dom_components/view/ComponentTableCellView.js ***! + \***********************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // Make the request, allowing the user to override any Ajax options. - var xhr = options.xhr = Backbone.ajax(_.extend(params, options)); - model.trigger('request', model, xhr, options); - return xhr; - }; +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _ComponentView__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./ComponentView */ "./src/dom_components/view/ComponentView.js"); - // Map from CRUD to HTTP for our default `Backbone.sync` implementation. - var methodMap = { - 'create': 'POST', - 'update': 'PUT', - 'patch': 'PATCH', - 'delete': 'DELETE', - 'read': 'GET' - }; +/* harmony default export */ __webpack_exports__["default"] = (_ComponentView__WEBPACK_IMPORTED_MODULE_0__["default"].extend({})); - // Set the default implementation of `Backbone.ajax` to proxy through to `$`. - // Override this if you'd like to use a different library. - Backbone.ajax = function() { - return Backbone.$.ajax.apply(Backbone.$, arguments); - }; +/***/ }), - // Backbone.Router - // --------------- +/***/ "./src/dom_components/view/ComponentTableFootView.js": +/*!***********************************************************!*\ + !*** ./src/dom_components/view/ComponentTableFootView.js ***! + \***********************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // Routers map faux-URLs to actions, and fire events when routes are - // matched. Creating a new one sets its `routes` hash, if not set statically. - var Router = Backbone.Router = function(options) { - options || (options = {}); - if (options.routes) this.routes = options.routes; - this._bindRoutes(); - this.initialize.apply(this, arguments); - }; +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _ComponentView__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./ComponentView */ "./src/dom_components/view/ComponentView.js"); - // Cached regular expressions for matching named param parts and splatted - // parts of route strings. - var optionalParam = /\((.*?)\)/g; - var namedParam = /(\(\?)?:\w+/g; - var splatParam = /\*\w+/g; - var escapeRegExp = /[\-{}\[\]+?.,\\\^$|#\s]/g; +/* harmony default export */ __webpack_exports__["default"] = (_ComponentView__WEBPACK_IMPORTED_MODULE_0__["default"].extend({})); - // Set up all inheritable **Backbone.Router** properties and methods. - _.extend(Router.prototype, Events, { +/***/ }), - // Initialize is an empty function by default. Override it with your own - // initialization logic. - initialize: function(){}, +/***/ "./src/dom_components/view/ComponentTableHeadView.js": +/*!***********************************************************!*\ + !*** ./src/dom_components/view/ComponentTableHeadView.js ***! + \***********************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // Manually bind a single named route to a callback. For example: - // - // this.route('search/:query/p:num', 'search', function(query, num) { - // ... - // }); - // - route: function(route, name, callback) { - if (!_.isRegExp(route)) route = this._routeToRegExp(route); - if (_.isFunction(name)) { - callback = name; - name = ''; - } - if (!callback) callback = this[name]; - var router = this; - Backbone.history.route(route, function(fragment) { - var args = router._extractParameters(route, fragment); - if (router.execute(callback, args, name) !== false) { - router.trigger.apply(router, ['route:' + name].concat(args)); - router.trigger('route', name, args); - Backbone.history.trigger('route', router, name, args); - } - }); - return this; - }, - - // Execute a route handler with the provided parameters. This is an - // excellent place to do pre-route setup or post-route cleanup. - execute: function(callback, args, name) { - if (callback) callback.apply(this, args); - }, +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _ComponentView__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./ComponentView */ "./src/dom_components/view/ComponentView.js"); - // Simple proxy to `Backbone.history` to save a fragment into the history. - navigate: function(fragment, options) { - Backbone.history.navigate(fragment, options); - return this; - }, +/* harmony default export */ __webpack_exports__["default"] = (_ComponentView__WEBPACK_IMPORTED_MODULE_0__["default"].extend({})); - // Bind all defined routes to `Backbone.history`. We have to reverse the - // order of the routes here to support behavior where the most general - // routes can be defined at the bottom of the route map. - _bindRoutes: function() { - if (!this.routes) return; - this.routes = _.result(this, 'routes'); - var route, routes = _.keys(this.routes); - while ((route = routes.pop()) != null) { - this.route(route, this.routes[route]); - } - }, +/***/ }), - // Convert a route string into a regular expression, suitable for matching - // against the current location hash. - _routeToRegExp: function(route) { - route = route.replace(escapeRegExp, '\\$&') - .replace(optionalParam, '(?:$1)?') - .replace(namedParam, function(match, optional) { - return optional ? match : '([^/?]+)'; - }) - .replace(splatParam, '([^?]*?)'); - return new RegExp('^' + route + '(?:\\?([\\s\\S]*))?$'); - }, +/***/ "./src/dom_components/view/ComponentTableRowView.js": +/*!**********************************************************!*\ + !*** ./src/dom_components/view/ComponentTableRowView.js ***! + \**********************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // Given a route, and a URL fragment that it matches, return the array of - // extracted decoded parameters. Empty or unmatched parameters will be - // treated as `null` to normalize cross-browser behavior. - _extractParameters: function(route, fragment) { - var params = route.exec(fragment).slice(1); - return _.map(params, function(param, i) { - // Don't decode the search params. - if (i === params.length - 1) return param || null; - return param ? decodeURIComponent(param) : null; - }); - } +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _ComponentView__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./ComponentView */ "./src/dom_components/view/ComponentView.js"); - }); +/* harmony default export */ __webpack_exports__["default"] = (_ComponentView__WEBPACK_IMPORTED_MODULE_0__["default"].extend({})); - // Backbone.History - // ---------------- +/***/ }), - // Handles cross-browser history management, based on either - // [pushState](http://diveintohtml5.info/history.html) and real URLs, or - // [onhashchange](https://developer.mozilla.org/en-US/docs/DOM/window.onhashchange) - // and URL fragments. If the browser supports neither (old IE, natch), - // falls back to polling. - var History = Backbone.History = function() { - this.handlers = []; - _.bindAll(this, 'checkUrl'); +/***/ "./src/dom_components/view/ComponentTableView.js": +/*!*******************************************************!*\ + !*** ./src/dom_components/view/ComponentTableView.js ***! + \*******************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // Ensure that `History` can be used outside of the browser. - if (typeof window !== 'undefined') { - this.location = window.location; - this.history = window.history; - } - }; +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _ComponentView__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./ComponentView */ "./src/dom_components/view/ComponentView.js"); - // Cached regex for stripping a leading hash/slash and trailing space. - var routeStripper = /^[#\/]|\s+$/g; +/* harmony default export */ __webpack_exports__["default"] = (_ComponentView__WEBPACK_IMPORTED_MODULE_0__["default"].extend({ + events: {} +})); - // Cached regex for stripping leading and trailing slashes. - var rootStripper = /^\/+|\/+$/g; +/***/ }), - // Cached regex for stripping urls of hash. - var pathStripper = /#.*$/; +/***/ "./src/dom_components/view/ComponentTextNodeView.js": +/*!**********************************************************!*\ + !*** ./src/dom_components/view/ComponentTextNodeView.js ***! + \**********************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // Has the history handling already been started? - History.started = false; +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); - // Set up all inheritable **Backbone.History** properties and methods. - _.extend(History.prototype, Events, { +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_0___default.a.View.extend({ + initialize: function initialize() { + var $el = this.$el, + model = this.model; + $el.data('model', model); + model.view = this; + }, + _createElement: function _createElement() { + return document.createTextNode(this.model.get('content')); + } +})); - // The default interval to poll for hash changes, if necessary, is - // twenty times a second. - interval: 50, +/***/ }), - // Are we at the app root? - atRoot: function() { - var path = this.location.pathname.replace(/[^\/]$/, '$&/'); - return path === this.root && !this.getSearch(); - }, +/***/ "./src/dom_components/view/ComponentTextView.js": +/*!******************************************************!*\ + !*** ./src/dom_components/view/ComponentTextView.js ***! + \******************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // Does the pathname match the root? - matchRoot: function() { - var path = this.decodeFragment(this.location.pathname); - var root = path.slice(0, this.root.length - 1) + '/'; - return root === this.root; - }, +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var utils_mixins__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! utils/mixins */ "./src/utils/mixins.js"); +/* harmony import */ var _ComponentView__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./ComponentView */ "./src/dom_components/view/ComponentView.js"); - // Unicode characters in `location.pathname` are percent encoded so they're - // decoded for comparison. `%25` should not be decoded since it may be part - // of an encoded parameter. - decodeFragment: function(fragment) { - return decodeURI(fragment.replace(/%25/g, '%2525')); - }, - // In IE6, the hash fragment and search params are incorrect if the - // fragment contains `?`. - getSearch: function() { - var match = this.location.href.replace(/#.*/, '').match(/\?.+/); - return match ? match[0] : ''; - }, +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - // Gets the true hash value. Cannot use location.hash directly due to bug - // in Firefox where location.hash will always be decoded. - getHash: function(window) { - var match = (window || this).location.href.match(/#(.*)$/); - return match ? match[1] : ''; - }, +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - // Get the pathname and search params, without the root. - getPath: function() { - var path = this.decodeFragment( - this.location.pathname + this.getSearch() - ).slice(this.root.length - 1); - return path.charAt(0) === '/' ? path.slice(1) : path; - }, - // Get the cross-browser normalized URL fragment from the path or hash. - getFragment: function(fragment) { - if (fragment == null) { - if (this._usePushState || !this._wantsHashChange) { - fragment = this.getPath(); - } else { - fragment = this.getHash(); - } - } - return fragment.replace(routeStripper, ''); - }, - // Start the hash change handling, returning `true` if the current URL matches - // an existing route, and `false` otherwise. - start: function(options) { - if (History.started) throw new Error('Backbone.history has already been started'); - History.started = true; +var compProt = _ComponentView__WEBPACK_IMPORTED_MODULE_2__["default"].prototype; +/* harmony default export */ __webpack_exports__["default"] = (_ComponentView__WEBPACK_IMPORTED_MODULE_2__["default"].extend({ + events: { + dblclick: 'onActive', + input: 'onInput' + }, + initialize: function initialize(o) { + compProt.initialize.apply(this, arguments); + this.disableEditing = this.disableEditing.bind(this); + var model = this.model; + var em = this.em; + this.listenTo(model, 'focus', this.onActive); + this.listenTo(model, 'change:content', this.updateContentText); + this.listenTo(model, 'sync:content', this.syncContent); + this.rte = em && em.get('RichTextEditor'); + }, + updateContentText: function updateContentText(m, v) { + var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + !opts.fromDisable && this.disableEditing(); + }, - // Figure out the initial configuration. Do we need an iframe? - // Is pushState desired ... is it available? - this.options = _.extend({root: '/'}, this.options, options); - this.root = this.options.root; - this._wantsHashChange = this.options.hashChange !== false; - this._hasHashChange = 'onhashchange' in window; - this._useHashChange = this._wantsHashChange && this._hasHashChange; - this._wantsPushState = !!this.options.pushState; - this._hasPushState = !!(this.history && this.history.pushState); - this._usePushState = this._wantsPushState && this._hasPushState; - this.fragment = this.getFragment(); + /** + * Enable element content editing + * @private + * */ + onActive: function onActive(e) { + // We place this before stopPropagation in case of nested + // text components will not block the editing (#1394) + if (this.rteEnabled || !this.model.get('editable')) { + return; + } - // Normalize root to always include a leading and trailing slash. - this.root = ('/' + this.root + '/').replace(rootStripper, '/'); + e && e.stopPropagation && e.stopPropagation(); + var rte = this.rte; - // Transition from hashChange to pushState or vice versa if both are - // requested. - if (this._wantsHashChange && this._wantsPushState) { + if (rte) { + try { + this.activeRte = rte.enable(this, this.activeRte); + } catch (err) { + console.error(err); + } + } - // If we've started off with a route from a `pushState`-enabled - // browser, but we're currently in a browser that doesn't support it... - if (!this._hasPushState && !this.atRoot()) { - var root = this.root.slice(0, -1) || '/'; - this.location.replace(root + '#' + this.getPath()); - // Return immediately as browser will do redirect to new url - return true; + this.rteEnabled = 1; + this.toggleEvents(1); + }, - // Or if we've started out with a hash-based route, but we're currently - // in a browser where it could be `pushState`-based instead... - } else if (this._hasPushState && this.atRoot()) { - this.navigate(this.getHash(), {replace: true}); - } + /** + * Disable element content editing + * @private + * */ + disableEditing: function disableEditing() { + var model = this.model, + rte = this.rte, + activeRte = this.activeRte; + var editable = model.get('editable'); + if (rte && editable) { + try { + rte.disable(this, activeRte); + } catch (err) { + console.error(err); } - // Proxy an iframe to handle location events if the browser doesn't - // support the `hashchange` event, HTML5 history, or the user wants - // `hashChange` but not `pushState`. - if (!this._hasHashChange && this._wantsHashChange && !this._usePushState) { - this.iframe = document.createElement('iframe'); - this.iframe.src = 'javascript:0'; - this.iframe.style.display = 'none'; - this.iframe.tabIndex = -1; - var body = document.body; - // Using `appendChild` will throw on IE < 9 if the document is not ready. - var iWindow = body.insertBefore(this.iframe, body.firstChild).contentWindow; - iWindow.document.open(); - iWindow.document.close(); - iWindow.location.hash = '#' + this.fragment; - } + this.syncContent(); + } - // Add a cross-platform `addEventListener` shim for older browsers. - var addEventListener = window.addEventListener || function (eventName, listener) { - return attachEvent('on' + eventName, listener); - }; + this.rteEnabled = 0; + this.toggleEvents(); + }, - // Depending on whether we're using pushState or hashes, and whether - // 'onhashchange' is supported, determine how we check the URL state. - if (this._usePushState) { - addEventListener('popstate', this.checkUrl, false); - } else if (this._useHashChange && !this.iframe) { - addEventListener('hashchange', this.checkUrl, false); - } else if (this._wantsHashChange) { - this._checkUrlInterval = setInterval(this.checkUrl, this.interval); - } + /** + * Merge content from the DOM to the model + */ + syncContent: function syncContent() { + var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var model = this.model, + rte = this.rte, + rteEnabled = this.rteEnabled; + if (!rteEnabled && !opts.force) return; + var content = this.getChildrenContainer().innerHTML; + var comps = model.components(); + + var contentOpt = _objectSpread({ + fromDisable: 1 + }, opts); + + comps.length && comps.reset(null, opts); + model.set('content', '', contentOpt); // If there is a custom RTE the content is just baked staticly + // inside 'content' + + if (rte.customRte) { + model.set('content', content, contentOpt); + } else { + var clean = function clean(model) { + var textable = !!model.get('textable'); + var selectable = !['text', 'default', ''].some(function (type) { + return model.is(type); + }) || textable; + model.set(_objectSpread({ + editable: selectable && model.get('editable'), + selectable: selectable, + hoverable: selectable, + removable: textable, + draggable: textable, + highlightable: 0, + copyable: textable + }, !textable && { + toolbar: '' + }), opts); + model.get('components').each(function (model) { + return clean(model); + }); + }; // Avoid re-render on reset with silent option - if (!this.options.silent) return this.loadUrl(); - }, - // Disable Backbone.history, perhaps temporarily. Not useful in a real app, - // but possibly useful for unit testing Routers. - stop: function() { - // Add a cross-platform `removeEventListener` shim for older browsers. - var removeEventListener = window.removeEventListener || function (eventName, listener) { - return detachEvent('on' + eventName, listener); - }; + !opts.silent && model.trigger('change:content', model, '', contentOpt); + comps.add(content, opts); + comps.each(function (model) { + return clean(model); + }); + comps.trigger('resetNavigator'); + } + }, - // Remove window listeners. - if (this._usePushState) { - removeEventListener('popstate', this.checkUrl, false); - } else if (this._useHashChange && !this.iframe) { - removeEventListener('hashchange', this.checkUrl, false); - } + /** + * Callback on input event + * @param {Event} e + */ + onInput: function onInput() { + var em = this.em; // Update toolbars - // Clean up the iframe if necessary. - if (this.iframe) { - document.body.removeChild(this.iframe); - this.iframe = null; - } + em && em.trigger('change:canvasOffset'); + }, - // Some environments will throw when clearing an undefined interval. - if (this._checkUrlInterval) clearInterval(this._checkUrlInterval); - History.started = false; - }, + /** + * Isolate disable propagation method + * @param {Event} + * @private + * */ + disablePropagation: function disablePropagation(e) { + e.stopPropagation(); + }, - // Add a route to be tested when the fragment changes. Routes added later - // may override previous routes. - route: function(route, callback) { - this.handlers.unshift({route: route, callback: callback}); - }, + /** + * Enable/Disable events + * @param {Boolean} enable + */ + toggleEvents: function toggleEvents(enable) { + var method = enable ? 'on' : 'off'; + var mixins = { + on: utils_mixins__WEBPACK_IMPORTED_MODULE_1__["on"], + off: utils_mixins__WEBPACK_IMPORTED_MODULE_1__["off"] + }; + this.em.setEditing(enable); // The ownerDocument is from the frame - // Checks the current URL to see if it has changed, and if it has, - // calls `loadUrl`, normalizing across the hidden iframe. - checkUrl: function(e) { - var current = this.getFragment(); + var elDocs = [this.el.ownerDocument, document]; + mixins.off(elDocs, 'mousedown', this.disableEditing); + mixins[method](elDocs, 'mousedown', this.disableEditing); // Avoid closing edit mode on component click - // If the user pressed the back button, the iframe's hash will have - // changed and we should use that for comparison. - if (current === this.fragment && this.iframe) { - current = this.getHash(this.iframe.contentWindow); + this.$el.off('mousedown', this.disablePropagation); + this.$el[method]('mousedown', this.disablePropagation); // Fixes #2210 but use this also as a replacement + // of this fix: bd7b804f3b46eb45b4398304b2345ce870f232d2 + + if (this.config.draggableComponents) { + var el = this.el; + + while (el) { + el.draggable = enable ? !1 : !0; + el = el.parentNode; + el.tagName == 'BODY' && (el = 0); } + } + } +})); - if (current === this.fragment) return false; - if (this.iframe) this.navigate(current); - this.loadUrl(); - }, +/***/ }), - // Attempt to load the current URL fragment. If a route succeeds with a - // match, returns `true`. If no defined routes matches the fragment, - // returns `false`. - loadUrl: function(fragment) { - // If the root doesn't match, no routes can match either. - if (!this.matchRoot()) return false; - fragment = this.fragment = this.getFragment(fragment); - return _.any(this.handlers, function(handler) { - if (handler.route.test(fragment)) { - handler.callback(fragment); - return true; - } - }); - }, +/***/ "./src/dom_components/view/ComponentVideoView.js": +/*!*******************************************************!*\ + !*** ./src/dom_components/view/ComponentVideoView.js ***! + \*******************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // Save a fragment into the hash history, or replace the URL state if the - // 'replace' option is passed. You are responsible for properly URL-encoding - // the fragment in advance. - // - // The options object can contain `trigger: true` if you wish to have the - // route callback be fired (not usually desirable), or `replace: true`, if - // you wish to modify the current URL without adding an entry to the history. - navigate: function(fragment, options) { - if (!History.started) return false; - if (!options || options === true) options = {trigger: !!options}; +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _ComponentImageView__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./ComponentImageView */ "./src/dom_components/view/ComponentImageView.js"); +/* harmony import */ var _ComponentView__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./ComponentView */ "./src/dom_components/view/ComponentView.js"); - // Normalize the fragment. - fragment = this.getFragment(fragment || ''); - // Don't include a trailing slash on the root. - var root = this.root; - if (fragment === '' || fragment.charAt(0) === '?') { - root = root.slice(0, -1) || '/'; - } - var url = root + fragment; +/* harmony default export */ __webpack_exports__["default"] = (_ComponentImageView__WEBPACK_IMPORTED_MODULE_0__["default"].extend({ + tagName: 'div', + events: {}, + initialize: function initialize(o) { + _ComponentView__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.initialize.apply(this, arguments); + this.listenTo(this.model, 'change:src', this.updateSrc); + this.listenTo(this.model, 'change:loop change:autoplay change:controls change:color change:rel change:modestbranding change:poster', this.updateVideo); + this.listenTo(this.model, 'change:provider', this.updateProvider); + }, - // Strip the hash and decode for matching. - fragment = this.decodeFragment(fragment.replace(pathStripper, '')); + /** + * Rerender on update of the provider + * @private + */ + updateProvider: function updateProvider() { + var prov = this.model.get('provider'); + this.el.innerHTML = ''; + this.el.appendChild(this.renderByProvider(prov)); + }, - if (this.fragment === fragment) return; - this.fragment = fragment; + /** + * Update the source of the video + * @private + */ + updateSrc: function updateSrc() { + var model = this.model, + videoEl = this.videoEl; + if (!videoEl) return; + var prov = model.get('provider'); + var src = model.get('src'); - // If pushState is available, we use it to set the fragment as a real URL. - if (this._usePushState) { - this.history[options.replace ? 'replaceState' : 'pushState']({}, document.title, url); + switch (prov) { + case 'yt': + src = model.getYoutubeSrc(); + break; - // If hash changes haven't been explicitly disabled, update the hash - // fragment to store history. - } else if (this._wantsHashChange) { - this._updateHash(this.location, fragment, options.replace); - if (this.iframe && (fragment !== this.getHash(this.iframe.contentWindow))) { - var iWindow = this.iframe.contentWindow; + case 'ytnc': + src = model.getYoutubeNoCookieSrc(); + break; - // Opening and closing the iframe tricks IE7 and earlier to push a - // history entry on hash-tag change. When replace is true, we don't - // want this. - if (!options.replace) { - iWindow.document.open(); - iWindow.document.close(); - } + case 'vi': + src = model.getVimeoSrc(); + break; + } - this._updateHash(iWindow.location, fragment, options.replace); - } + videoEl.src = src; + }, - // If you've told us that you explicitly don't want fallback hashchange- - // based history, then `navigate` becomes a page refresh. - } else { - return this.location.assign(url); - } - if (options.trigger) return this.loadUrl(fragment); - }, + /** + * Update video parameters + * @private + */ + updateVideo: function updateVideo() { + var prov = this.model.get('provider'); + var videoEl = this.videoEl; + var md = this.model; - // Update the hash location, either replacing the current entry, or adding - // a new one to the browser history. - _updateHash: function(location, fragment, replace) { - if (replace) { - var href = location.href.replace(/(javascript:|#).*$/, ''); - location.replace(href + '#' + fragment); - } else { - // Some browsers require that `hash` contains a leading #. - location.hash = '#' + fragment; - } + switch (prov) { + case 'yt': + case 'ytnc': + case 'vi': + this.model.trigger('change:videoId'); + break; + + default: + videoEl.loop = md.get('loop'); + videoEl.autoplay = md.get('autoplay'); + videoEl.controls = md.get('controls'); + videoEl.poster = md.get('poster'); } + }, + renderByProvider: function renderByProvider(prov) { + var videoEl; - }); + switch (prov) { + case 'yt': + videoEl = this.renderYoutube(); + break; - // Create the default Backbone.history. - Backbone.history = new History; + case 'ytnc': + videoEl = this.renderYoutubeNoCookie(); + break; - // Helpers - // ------- + case 'vi': + videoEl = this.renderVimeo(); + break; - // Helper function to correctly set up the prototype chain for subclasses. - // Similar to `goog.inherits`, but uses a hash of prototype properties and - // class properties to be extended. - var extend = function(protoProps, staticProps) { - var parent = this; - var child; + default: + videoEl = this.renderSource(); + } - // The constructor function for the new subclass is either defined by you - // (the "constructor" property in your `extend` definition), or defaulted - // by us to simply call the parent constructor. - if (protoProps && _.has(protoProps, 'constructor')) { - child = protoProps.constructor; - } else { - child = function(){ return parent.apply(this, arguments); }; + this.videoEl = videoEl; + return videoEl; + }, + renderSource: function renderSource() { + var el = document.createElement('video'); + el.src = this.model.get('src'); + this.initVideoEl(el); + return el; + }, + renderYoutube: function renderYoutube() { + var el = document.createElement('iframe'); + el.src = this.model.getYoutubeSrc(); + el.frameBorder = 0; + el.setAttribute('allowfullscreen', true); + this.initVideoEl(el); + return el; + }, + renderYoutubeNoCookie: function renderYoutubeNoCookie() { + var el = document.createElement('iframe'); + el.src = this.model.getYoutubeNoCookieSrc(); + el.frameBorder = 0; + el.setAttribute('allowfullscreen', true); + this.initVideoEl(el); + return el; + }, + renderVimeo: function renderVimeo() { + var el = document.createElement('iframe'); + el.src = this.model.getVimeoSrc(); + el.frameBorder = 0; + el.setAttribute('allowfullscreen', true); + this.initVideoEl(el); + return el; + }, + initVideoEl: function initVideoEl(el) { + el.className = this.ppfx + 'no-pointer'; + el.style.height = '100%'; + el.style.width = '100%'; + }, + render: function render() { + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; } - // Add static properties to the constructor function, if supplied. - _.extend(child, parent, staticProps); + _ComponentImageView__WEBPACK_IMPORTED_MODULE_0__["default"].prototype.render.apply(this, args); + this.updateClasses(); + var prov = this.model.get('provider'); + this.el.appendChild(this.renderByProvider(prov)); + return this; + } +})); - // Set the prototype chain to inherit from `parent`, without calling - // `parent` constructor function. - var Surrogate = function(){ this.constructor = child; }; - Surrogate.prototype = parent.prototype; - child.prototype = new Surrogate; +/***/ }), - // Add prototype properties (instance properties) to the subclass, - // if supplied. - if (protoProps) _.extend(child.prototype, protoProps); +/***/ "./src/dom_components/view/ComponentView.js": +/*!**************************************************!*\ + !*** ./src/dom_components/view/ComponentView.js ***! + \**************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // Set a convenience property in case the parent's prototype is needed - // later. - child.__super__ = parent.prototype; +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_2__); +/* harmony import */ var _model_Components__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../model/Components */ "./src/dom_components/model/Components.js"); +/* harmony import */ var _ComponentsView__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./ComponentsView */ "./src/dom_components/view/ComponentsView.js"); +/* harmony import */ var selector_manager_model_Selectors__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! selector_manager/model/Selectors */ "./src/selector_manager/model/Selectors.js"); +/* harmony import */ var utils_dom__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! utils/dom */ "./src/utils/dom.js"); - return child; - }; - - // Set up inheritance for the model, collection, router, view and history. - Model.extend = Collection.extend = Router.extend = View.extend = History.extend = extend; - - // Throw an error when a URL is needed, and none is supplied. - var urlError = function() { - throw new Error('A "url" property or function must be specified'); - }; - // Wrap an optional error callback with a fallback error event. - var wrapError = function(model, options) { - var error = options.error; - options.error = function(resp) { - if (error) error.call(options.context, model, resp, options); - model.trigger('error', model, resp, options); - }; - }; +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - return Backbone; +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } -})); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(16))) -/***/ }), -/* 73 */ -/***/ (function(module, exports, __webpack_require__) { -"use strict"; -/** - * Before using methods you should get first the module from the editor instance, in this way: - * - * ```js - * var storageManager = editor.StorageManager; - * ``` - */ -module.exports = function () { - var c = {}, - defaults = __webpack_require__(74), - LocalStorage = __webpack_require__(75), - RemoteStorage = __webpack_require__(76); - var storages = {}; - var defaultStorages = {}; +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_1___default.a.View.extend({ + className: function className() { + return this.getClasses(); + }, + tagName: function tagName() { + return this.model.get('tagName'); + }, + initialize: function initialize() { + var opt = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var model = this.model; + var config = opt.config || {}; + var em = config.em; + var modelOpt = model.opt || {}; + var $el = this.$el; + var draggableComponents = config.draggableComponents; + this.opts = opt; + this.modelOpt = modelOpt; + this.config = config; + this.em = em || ''; + this.pfx = config.stylePrefix || ''; + this.ppfx = config.pStylePrefix || ''; + this.attr = model.get('attributes'); + this.classe = this.attr.class || []; + this.listenTo(model, 'change:style', this.updateStyle); + this.listenTo(model, 'change:attributes', this.renderAttributes); + this.listenTo(model, 'change:highlightable', this.updateHighlight); + this.listenTo(model, 'change:status', this.updateStatus); + this.listenTo(model, 'change:state', this.updateState); + this.listenTo(model, 'change:script', this.reset); + this.listenTo(model, 'change:content', this.updateContent); + this.listenTo(model, 'change', this.handleChange); + this.listenTo(model, 'active', this.onActive); + $el.data('model', model); + model.view = this; + this.initClasses(); + this.initComponents({ + avoidRender: 1 + }); + this.events = _objectSpread({}, this.events, {}, draggableComponents && { + dragstart: 'handleDragStart' + }); + this.delegateEvents(); + !modelOpt.temporary && this.init(this._clbObj()); + }, + _clbObj: function _clbObj() { + var em = this.em, + model = this.model, + el = this.el; + return { + editor: em && em.getEditor(), + model: model, + el: el + }; + }, - return { + /** + * Initialize callback + */ + init: function init() {}, - /** - * Name of the module - * @type {String} - * @private - */ - name: 'StorageManager', + /** + * Remove callback + */ + removed: function removed() {}, - /** - * Initialize module. Automatically called with a new instance of the editor - * @param {Object} config Configurations - * @param {string} [config.id='gjs-'] The prefix for the fields, useful to differentiate storing/loading - * with multiple editors on the same page. For example, in local storage, the item of HTML will be saved like 'gjs-html' - * @param {Boolean} [config.autosave=true] Indicates if autosave mode is enabled, works in conjunction with stepsBeforeSave - * @param {number} [config.stepsBeforeSave=1] If autosave enabled, indicates how many steps/changes are necessary - * before autosave is triggered - * @param {string} [config.type='local'] Default storage type. Available: 'local' | 'remote' | ''(do not store) - * @private - * @example - * ... - * { - * autosave: false, - * type: 'remote', - * } - * ... - */ - init: function init(config) { - c = config || {}; + /** + * Callback executed when the `active` event is triggered on component + */ + onActive: function onActive() {}, + remove: function remove() { + backbone__WEBPACK_IMPORTED_MODULE_1___default.a.View.prototype.remove.apply(this, arguments); + this.removed(this._clbObj()); + return this; + }, + handleDragStart: function handleDragStart(event) { + event.preventDefault(); + event.stopPropagation(); + this.em.get('Commands').run('tlb-move', { + target: this.model, + event: event + }); + }, + initClasses: function initClasses() { + var model = this.model; + var event = 'change:classes'; + var classes = model.get('classes'); - for (var name in defaults) { - if (!(name in c)) c[name] = defaults[name]; - } + if (classes instanceof selector_manager_model_Selectors__WEBPACK_IMPORTED_MODULE_5__["default"]) { + this.stopListening(model, event, this.initClasses); + this.listenTo(model, event, this.initClasses); + this.listenTo(classes, 'add remove change', this.updateClasses); + classes.length && this.importClasses(); + } + }, + initComponents: function initComponents() { + var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var model = this.model, + $el = this.$el, + childrenView = this.childrenView; + var event = 'change:components'; + var comps = model.get('components'); + var toListen = [model, event, this.initComponents]; - defaultStorages.remote = new RemoteStorage(c); - defaultStorages.local = new LocalStorage(c); - c.currentStorage = c.type; - this.loadDefaultProviders().setCurrent(c.type); - return this; - }, + if (comps instanceof _model_Components__WEBPACK_IMPORTED_MODULE_3__["default"]) { + $el.data('collection', comps); + childrenView && childrenView.remove(); + this.stopListening.apply(this, toListen); + !opts.avoidRender && this.renderChildren(); + this.listenTo.apply(this, toListen); + } + }, + /** + * Handle any property change + * @private + */ + handleChange: function handleChange() { + var model = this.model; + model.emitUpdate(); - /** - * Checks if autosave is enabled - * @return {Boolean} - * */ - isAutosave: function isAutosave() { - return !!c.autosave; - }, + for (var prop in model.changed) { + model.emitUpdate(prop); + } + }, + /** + * Import, if possible, classes inside main container + * @private + * */ + importClasses: function importClasses() { + var clm = this.config.em.get('SelectorManager'); - /** - * Set autosave value - * @param {Boolean} v - * @return {this} - * */ - setAutosave: function setAutosave(v) { - c.autosave = !!v; - return this; - }, + if (clm) { + this.model.get('classes').each(function (m) { + clm.add(m.get('name')); + }); + } + }, + /** + * Fires on state update. If the state is not empty will add a helper class + * @param {Event} e + * @private + * */ + updateState: function updateState(e) { + var cl = 'hc-state'; + var state = this.model.get('state'); - /** - * Returns number of steps required before trigger autosave - * @return {number} - * */ - getStepsBeforeSave: function getStepsBeforeSave() { - return c.stepsBeforeSave; - }, + if (state) { + this.$el.addClass(cl); + } else { + this.$el.removeClass(cl); + } + }, + /** + * Update item on status change + * @param {Event} e + * @private + * */ + updateStatus: function updateStatus() { + var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var em = this.em; + var el = this.el; + var status = this.model.get('status'); + var pfx = this.pfx; + var ppfx = this.ppfx; + var selectedCls = "".concat(pfx, "selected"); + var selectedParentCls = "".concat(selectedCls, "-parent"); + var freezedCls = "".concat(ppfx, "freezed"); + var hoveredCls = "".concat(ppfx, "hovered"); + var toRemove = [selectedCls, selectedParentCls, freezedCls, hoveredCls]; + this.$el.removeClass(toRemove.join(' ')); + var actualCls = el.getAttribute('class') || ''; + var cls = ''; - /** - * Set steps required before trigger autosave - * @param {number} v - * @return {this} - * */ - setStepsBeforeSave: function setStepsBeforeSave(v) { - c.stepsBeforeSave = v; - return this; - }, + switch (status) { + case 'selected': + cls = "".concat(actualCls, " ").concat(selectedCls); + break; + case 'selected-parent': + cls = "".concat(actualCls, " ").concat(selectedParentCls); + break; - /** - * Add new storage - * @param {string} id Storage ID - * @param {Object} storage Storage wrapper - * @param {Function} storage.load Load method - * @param {Function} storage.store Store method - * @return {this} - * @example - * storageManager.add('local2', { - * load: function(keys, clb) { - * var res = {}; - * for (var i = 0, len = keys.length; i < len; i++){ - * var v = localStorage.getItem(keys[i]); - * if(v) res[keys[i]] = v; - * } - * clb(res); // might be called inside some async method - * }, - * store: function(data, clb) { - * for(var key in data) - * localStorage.setItem(key, data[key]); - * clb(); // might be called inside some async method - * } - * }); - * */ - add: function add(id, storage) { - storages[id] = storage; - return this; - }, + case 'freezed': + cls = "".concat(actualCls, " ").concat(freezedCls); + break; + case 'freezed-selected': + cls = "".concat(actualCls, " ").concat(freezedCls, " ").concat(selectedCls); + break; - /** - * Returns storage by id - * @param {string} id Storage ID - * @return {Object|null} - * */ - get: function get(id) { - return storages[id] || null; - }, + case 'hovered': + cls = !opts.avoidHover ? "".concat(actualCls, " ").concat(hoveredCls) : ''; + break; + } + cls = cls.trim(); + cls && el.setAttribute('class', cls); + }, - /** - * Returns all storages - * @return {Array} - * */ - getStorages: function getStorages() { - return storages; - }, - + /** + * Update highlight attribute + * @private + * */ + updateHighlight: function updateHighlight() { + var hl = this.model.get('highlightable'); + this.setAttribute('data-highlightable', hl ? 1 : ''); + }, - /** - * Returns current storage type - * @return {string} - * */ - getCurrent: function getCurrent() { - return c.currentStorage; - }, + /** + * Update style attribute + * @private + * */ + updateStyle: function updateStyle() { + var em = this.em; + var model = this.model; + if (em && em.get('avoidInlineStyle')) { + this.el.id = model.getId(); + var style = model.getStyle(); + !Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isEmpty"])(style) && model.setStyle(style); + } else { + this.setAttribute('style', model.styleToString()); + } + }, - /** - * Set current storage type - * @param {string} id Storage ID - * @return {this} - * */ - setCurrent: function setCurrent(id) { - c.currentStorage = id; - return this; - }, + /** + * Update classe attribute + * @private + * */ + updateClasses: function updateClasses() { + var str = this.model.get('classes').pluck('name').join(' '); + this.setAttribute('class', str); // Regenerate status class + this.updateStatus(); + }, - /** - * Store key-value resources in the current storage - * @param {Object} data Data in key-value format, eg. {item1: value1, item2: value2} - * @param {Function} clb Callback function - * @return {Object|null} - * @example - * storageManager.store({item1: value1, item2: value2}); - * */ - store: function store(data, clb) { - var st = this.get(this.getCurrent()); - var dataF = {}; + /** + * Update single attribute + * @param {[type]} name [description] + * @param {[type]} value [description] + */ + setAttribute: function setAttribute(name, value) { + var el = this.$el; + value ? el.attr(name, value) : el.removeAttr(name); + }, - for (var key in data) { - dataF[c.id + key] = data[key]; - }return st ? st.store(dataF, clb) : null; - }, + /** + * Get classes from attributes. + * This method is called before initialize + * + * @return {Array}|null + * @private + * */ + getClasses: function getClasses() { + return this.model.getClasses().join(' '); + }, + /** + * Update attributes + * @private + * */ + updateAttributes: function updateAttributes() { + var attrs = []; + var model = this.model, + $el = this.$el, + el = this.el, + config = this.config; + var _model$attributes = model.attributes, + highlightable = _model$attributes.highlightable, + textable = _model$attributes.textable, + type = _model$attributes.type; + var draggableComponents = config.draggableComponents; + + var defaultAttr = _objectSpread({ + 'data-gjs-type': type || 'default' + }, draggableComponents ? { + draggable: true + } : {}, {}, highlightable ? { + 'data-highlightable': 1 + } : {}, {}, textable ? { + contenteditable: 'false', + 'data-gjs-textable': 'true' + } : {}); // Remove all current attributes + + + Object(underscore__WEBPACK_IMPORTED_MODULE_2__["each"])(el.attributes, function (attr) { + return attrs.push(attr.nodeName); + }); + attrs.forEach(function (attr) { + return $el.removeAttr(attr); + }); - /** - * Load resource from the current storage by keys - * @param {string|Array} keys Keys to load - * @param {Function} clb Callback function - * @example - * storageManager.load(['item1', 'item2'], res => { - * // res -> {item1: value1, item2: value2} - * }); - * storageManager.load('item1', res => { - * // res -> {item1: value1} - * }); - * */ - load: function load(keys, clb) { - var st = this.get(this.getCurrent()); - var keysF = []; - var result = {}; + var attr = _objectSpread({}, defaultAttr, {}, model.getAttributes()); // Remove all `false` attributes - if (typeof keys === 'string') keys = [keys]; - for (var i = 0, len = keys.length; i < len; i++) { - keysF.push(c.id + keys[i]); - }st && st.load(keysF, function (res) { - // Restore keys name - var reg = new RegExp('^' + c.id + ''); - for (var itemKey in res) { - var itemKeyR = itemKey.replace(reg, ''); - result[itemKeyR] = res[itemKey]; - } + Object(underscore__WEBPACK_IMPORTED_MODULE_2__["keys"])(attr).forEach(function (key) { + return attr[key] === false && delete attr[key]; + }); + $el.attr(attr); + this.updateStyle(); + }, - clb && clb(result); - }); - }, + /** + * Update component content + * @private + * */ + updateContent: function updateContent() { + this.getChildrenContainer().innerHTML = this.model.get('content'); + }, + /** + * Prevent default helper + * @param {Event} e + * @private + */ + prevDef: function prevDef(e) { + e.preventDefault(); + }, - /** - * Load default storages - * @return {this} - * @private - * */ - loadDefaultProviders: function loadDefaultProviders() { - for (var id in defaultStorages) { - this.add(id, defaultStorages[id]); - }return this; - }, + /** + * Render component's script + * @private + */ + updateScript: function updateScript() { + var model = this.model, + em = this.em; + if (!model.get('script')) return; + em && em.get('Canvas').getCanvasView().updateScript(this); + }, + /** + * Return children container + * Differently from a simple component where children container is the + * component itself + * + * + * + * You could have the children container more deeper + * + *
+ *
+ *
+ *
+ * + *
+ *
+ *
+ * @return HTMLElement + * @private + */ + getChildrenContainer: function getChildrenContainer() { + var container = this.el; - /** - * Get configuration object - * @return {Object} - * @private - * */ - getConfig: function getConfig() { - return c; + if (typeof this.getChildrenSelector == 'function') { + container = this.el.querySelector(this.getChildrenSelector()); + } else if (typeof this.getTemplate == 'function') {// Need to find deepest first child } - }; -}; -/***/ }), -/* 74 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; + return container; + }, + /** + * Recreate the element of the view + */ + reset: function reset() { + var el = this.el, + model = this.model; + var collection = model.components(); + this.el = ''; -module.exports = { - // Prefix identifier that will be used inside storing and loading - id: 'gjs-', + this._ensureElement(); - // Enable/Disable autosaving - autosave: 1, + this.$el.data({ + model: model, + collection: collection + }); + Object(utils_dom__WEBPACK_IMPORTED_MODULE_6__["replaceWith"])(el, this.el); + this.render(); + }, - // Indicates if load data inside editor after init - autoload: 1, + /** + * Render children components + * @private + */ + renderChildren: function renderChildren() { + this.updateContent(); + var container = this.getChildrenContainer(); + var view = new _ComponentsView__WEBPACK_IMPORTED_MODULE_4__["default"]({ + collection: this.model.get('components'), + config: this.config, + componentTypes: this.opts.componentTypes + }); + view.render(container); + this.childrenView = view; + var childNodes = Array.prototype.slice.call(view.el.childNodes); - // Indicates which storage to use. Available: local | remote - type: 'local', + for (var i = 0, len = childNodes.length; i < len; i++) { + container.appendChild(childNodes.shift()); + } + }, + renderAttributes: function renderAttributes() { + this.updateAttributes(); + this.updateClasses(); + }, + render: function render() { + this.renderAttributes(); + if (this.modelOpt.temporary) return this; + this.renderChildren(); + this.updateScript(); + this.postRender(); + return this; + }, + postRender: function postRender() { + var em = this.em, + model = this.model, + modelOpt = this.modelOpt; - // If autosave enabled, indicates how many steps (general changes to structure) - // need to be done before save. Useful with remoteStorage to reduce remote calls - stepsBeforeSave: 1, + if (!modelOpt.temporary) { + this.onRender(this._clbObj()); + em && em.trigger('component:mount', model); + } + }, + onRender: function onRender() {} +})); - //Enable/Disable components model (JSON format) - storeComponents: 1, +/***/ }), - //Enable/Disable styles model (JSON format) - storeStyles: 1, +/***/ "./src/dom_components/view/ComponentsView.js": +/*!***************************************************!*\ + !*** ./src/dom_components/view/ComponentsView.js ***! + \***************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - //Enable/Disable saving HTML template - storeHtml: 1, +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_1__); - //Enable/Disable saving CSS template - storeCss: 1, - // ONLY FOR LOCAL STORAGE - // If enabled, checks if browser supports Local Storage - checkLocal: 1, +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_0___default.a.View.extend({ + initialize: function initialize(o) { + this.opts = o || {}; + this.config = o.config || {}; + var coll = this.collection; + this.listenTo(coll, 'add', this.addTo); + this.listenTo(coll, 'reset', this.resetChildren); + this.listenTo(coll, 'remove', this.removeChildren); + }, + removeChildren: function removeChildren(removed, coll) { + var _this = this; - // ONLY FOR REMOTE STORAGE - // Custom parameters to pass with the remote storage request, eg. csrf token - params: {}, + var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + var em = this.config.em; + var view = removed.view; + var tempComp = removed.opt.temporary; + var tempRemove = opts.temporary; + if (!view) return; + view.remove.apply(view); + var childrenView = view.childrenView, + scriptContainer = view.scriptContainer; + childrenView && childrenView.stopListening(); + scriptContainer && scriptContainer.remove(); + removed.components().forEach(function (it) { + return _this.removeChildren(it, coll, opts); + }); - // Custom headers for the remote storage request - headers: {}, + if (em && !tempRemove) { + // Remove the component from the global list + var id = removed.getId(); + var domc = em.get('DomComponents'); + delete domc.componentsById[id]; // Remove all related CSS rules - // Endpoint where to save all stuff - urlStore: '', + var allRules = em.get('CssComposer').getAll(); + allRules.remove(allRules.filter(function (rule) { + return rule.getSelectors().getFullString() === "#".concat(id); + })); - // Endpoint where to fetch data - urlLoad: '', + if (!tempComp) { + var cm = em.get('Commands'); + var hasSign = removed.get('style-signature'); + var optStyle = { + target: removed + }; + hasSign && cm.run('core:component-style-clear', optStyle); + removed.removed(); + em.trigger('component:remove', removed); + } + } + }, - //Callback before request - beforeSend: function beforeSend(jqXHR, settings) {}, + /** + * Add to collection + * @param {Model} model + * @param {Collection} coll + * @param {Object} opts + * @private + * */ + addTo: function addTo(model) { + var coll = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + var em = this.config.em; + var i = this.collection.indexOf(model); + this.addToCollection(model, null, i); + if (em && !opts.temporary) { + var triggerAdd = function triggerAdd(model) { + em.trigger('component:add', model); + model.components().forEach(function (comp) { + return triggerAdd(comp); + }); + }; - //Callback after request - onComplete: function onComplete(jqXHR, status) {}, + triggerAdd(model); + } + }, + /** + * Add new object to collection + * @param {Object} Model + * @param {Object} Fragment collection + * @param {Integer} Index of append + * + * @return {Object} Object rendered + * @private + * */ + addToCollection: function addToCollection(model, fragmentEl, index) { + if (!this.compView) this.compView = __webpack_require__(/*! ./ComponentView */ "./src/dom_components/view/ComponentView.js").default; + var config = this.config, + opts = this.opts; + var fragment = fragmentEl || null; + var dt = opts.componentTypes; + var type = model.get('type'); + var viewObject = this.compView; - // set contentType paramater of $.ajax - // true: application/json; charset=utf-8' - // false: 'x-www-form-urlencoded' - contentTypeJson: false + for (var it = 0; it < dt.length; it++) { + if (dt[it].id == type) { + viewObject = dt[it].view; + break; + } + } -}; + var view = new viewObject({ + model: model, + config: config, + componentTypes: dt + }); + var rendered = view.render().el; -/***/ }), -/* 75 */ -/***/ (function(module, exports, __webpack_require__) { + if (fragment) { + fragment.appendChild(rendered); + } else { + var parent = this.parentEl; + var children = parent.childNodes; -"use strict"; + if (!Object(underscore__WEBPACK_IMPORTED_MODULE_1__["isUndefined"])(index)) { + var lastIndex = children.length == index; // If the added model is the last of collection + // need to change the logic of append + if (lastIndex) { + index--; + } // In case the added is new in the collection index will be -1 -var Backbone = __webpack_require__(0); -module.exports = Backbone.Model.extend({ + if (lastIndex || !children.length) { + parent.appendChild(rendered); + } else { + parent.insertBefore(rendered, children[index]); + } + } else { + parent.appendChild(rendered); + } + } - defaults: { - checkLocal: true + return rendered; }, + resetChildren: function resetChildren() { + var _this2 = this; - /** - * @private - */ - store: function store(data, clb) { - this.checkStorageEnvironment(); - - for (var key in data) { - localStorage.setItem(key, data[key]); - }if (typeof clb == 'function') { - clb(); - } + this.parentEl.innerHTML = ''; + this.collection.each(function (model) { + return _this2.addToCollection(model); + }); }, + render: function render(parent) { + var _this3 = this; + var el = this.el; + var frag = document.createDocumentFragment(); + this.parentEl = parent || this.el; + this.collection.each(function (model) { + return _this3.addToCollection(model, frag); + }); + el.innerHTML = ''; + el.appendChild(frag); + return this; + } +})); - /** - * @private - */ - load: function load(keys, clb) { - this.checkStorageEnvironment(); - var result = {}; - - for (var i = 0, len = keys.length; i < len; i++) { - var value = localStorage.getItem(keys[i]); - if (value) result[keys[i]] = value; - } +/***/ }), - if (typeof clb == 'function') { - clb(result); - } +/***/ "./src/dom_components/view/ToolbarButtonView.js": +/*!******************************************************!*\ + !*** ./src/dom_components/view/ToolbarButtonView.js ***! + \******************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - return result; +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); + +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_0___default.a.View.extend({ + events: function events() { + return this.model.get('events') || { + mousedown: 'handleClick' + }; }, + attributes: function attributes() { + return this.model.get('attributes'); + }, + initialize: function initialize(opts) { + this.editor = opts.config.editor; + }, + handleClick: function handleClick(event) { + event.preventDefault(); + event.stopPropagation(); + this.execCommand(event); + }, + execCommand: function execCommand(event) { + var opts = { + event: event + }; + var command = this.model.get('command'); + var editor = this.editor; + if (typeof command === 'function') { + command(editor, null, opts); + } - /** - * @private - */ - remove: function remove(keys) { - this.checkStorageEnvironment(); - - for (var i = 0, len = keys.length; i < len; i++) { - localStorage.removeItem(keys[i]); + if (typeof command === 'string') { + editor.runCommand(command, opts); } }, - - - /** - * Check storage environment - * @private - * */ - checkStorageEnvironment: function checkStorageEnvironment() { - if (this.get('checkLocal') && !localStorage) console.warn("Your browser doesn't support localStorage"); + render: function render() { + var editor = this.editor, + $el = this.$el, + model = this.model; + var id = model.get('id'); + var label = model.get('label'); + var pfx = editor.getConfig('stylePrefix'); + $el.addClass("".concat(pfx, "toolbar-item")); + id && $el.addClass("".concat(pfx, "toolbar-item__").concat(id)); + label && $el.append(label); + return this; } -}); +})); /***/ }), -/* 76 */ -/***/ (function(module, exports, __webpack_require__) { -"use strict"; +/***/ "./src/dom_components/view/ToolbarView.js": +/*!************************************************!*\ + !*** ./src/dom_components/view/ToolbarView.js ***! + \************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var domain_abstract_view_DomainViews__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! domain_abstract/view/DomainViews */ "./src/domain_abstract/view/DomainViews.js"); +/* harmony import */ var _ToolbarButtonView__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./ToolbarButtonView */ "./src/dom_components/view/ToolbarButtonView.js"); -var _fetch = __webpack_require__(24); -var _fetch2 = _interopRequireDefault(_fetch); +/* harmony default export */ __webpack_exports__["default"] = (domain_abstract_view_DomainViews__WEBPACK_IMPORTED_MODULE_0__["default"].extend({ + itemView: _ToolbarButtonView__WEBPACK_IMPORTED_MODULE_1__["default"], + initialize: function initialize(opts) { + this.config = { + editor: opts.editor || '' + }; + this.listenTo(this.collection, 'reset', this.render); + } +})); -var _underscore = __webpack_require__(1); +/***/ }), -function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } +/***/ "./src/domain_abstract/model/Styleable.js": +/*!************************************************!*\ + !*** ./src/domain_abstract/model/Styleable.js ***! + \************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { -module.exports = __webpack_require__(0).Model.extend({ +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var utils_mixins__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! utils/mixins */ "./src/utils/mixins.js"); +/* harmony import */ var parser_model_ParserHtml__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! parser/model/ParserHtml */ "./src/parser/model/ParserHtml.js"); - fetch: _fetch2.default, - defaults: { - urlStore: '', - urlLoad: '', - params: {}, - beforeSend: function beforeSend() {}, - onComplete: function onComplete() {}, +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - contentTypeJson: false - }, +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - /** - * Triggered before the request is started - * @private - */ - onStart: function onStart() { - var em = this.get('em'); - var before = this.get('beforeSend'); - before && before(); - em && em.trigger('storage:start'); - }, - /** - * Triggered on request error - * @param {Object} err Error - * @private - */ - onError: function onError(err) { - var em = this.get('em'); - console.error(err); - em && em.trigger('storage:error', err); - this.onEnd(err); - }, +var parseStyle = Object(parser_model_ParserHtml__WEBPACK_IMPORTED_MODULE_3__["default"])().parseStyle; +/* harmony default export */ __webpack_exports__["default"] = ({ + parseStyle: parseStyle, /** - * Triggered after the request is ended - * @param {Object|string} res End result - * @private + * To trigger the style change event on models I have to + * pass a new object instance + * @param {Object} prop + * @return {Object} */ - onEnd: function onEnd(res) { - var em = this.get('em'); - em && em.trigger('storage:end', res); + extendStyle: function extendStyle(prop) { + return _objectSpread({}, this.getStyle(), {}, prop); }, - /** - * Triggered on request response - * @param {string} text Response text - * @private + * Get style object + * @return {Object} */ - onResponse: function onResponse(text, clb) { - var em = this.get('em'); - var complete = this.get('onComplete'); - var typeJson = this.get('contentTypeJson'); - var res = typeJson && typeof text === 'string' ? JSON.parse(text) : text; - complete && complete(res); - clb && clb(res); - em && em.trigger('storage:response', res); - this.onEnd(text); - }, - store: function store(data, clb) { - var body = {}; - - for (var key in data) { - body[key] = data[key]; - } - - this.request(this.get('urlStore'), { body: body }, clb); - }, - load: function load(keys, clb) { - this.request(this.get('urlLoad'), { method: 'get' }, clb); + getStyle: function getStyle() { + var style = this.get('style') || {}; + return _objectSpread({}, style); }, - /** - * Execute remote request - * @param {string} url Url - * @param {Object} [opts={}] Options - * @param {[type]} [clb=null] Callback - * @private + * Set new style object + * @param {Object|string} prop + * @param {Object} opts + * @return {Object} Applied properties */ - request: function request(url) { + setStyle: function setStyle() { var _this = this; + var prop = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; - var clb = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null; - - var typeJson = this.get('contentTypeJson'); - var headers = this.get('headers') || {}; - var params = this.get('params'); - var reqHead = 'X-Requested-With'; - var typeHead = 'Content-Type'; - var bodyObj = opts.body || {}; - var fetchOptions = void 0; - var body = void 0; - for (var param in params) { - bodyObj[param] = params[param]; + if (Object(underscore__WEBPACK_IMPORTED_MODULE_1__["isString"])(prop)) { + prop = parseStyle(prop); } - if ((0, _underscore.isUndefined)(headers[reqHead])) { - headers[reqHead] = 'XMLHttpRequest'; - } + var propOrig = this.getStyle(); - // With `fetch`, have to send FormData without any 'Content-Type' - // https://stackoverflow.com/questions/39280438/fetch-missing-boundary-in-multipart-form-data-post + var propNew = _objectSpread({}, prop); - if ((0, _underscore.isUndefined)(headers[typeHead]) && typeJson) { - headers[typeHead] = 'application/json; charset=utf-8'; - } + this.set('style', propNew, opts); + var diff = Object(utils_mixins__WEBPACK_IMPORTED_MODULE_2__["shallowDiff"])(propOrig, propNew); + Object(underscore__WEBPACK_IMPORTED_MODULE_1__["keys"])(diff).forEach(function (pr) { + var em = _this.em; - if (typeJson) { - body = JSON.stringify(bodyObj); - } else { - body = new FormData(); + _this.trigger("change:style:".concat(pr)); - for (var bodyKey in bodyObj) { - body.append(bodyKey, bodyObj[bodyKey]); + if (em) { + em.trigger("styleable:change", _this, pr); + em.trigger("styleable:change:".concat(pr), _this, pr); } - } - fetchOptions = { - method: opts.method || 'post', - credentials: 'include', - headers: headers - }; - - // Body should only be included on POST method - if (fetchOptions.method === 'post') { - fetchOptions.body = body; - } - - this.onStart(); - this.fetch(url, fetchOptions).then(function (res) { - return (res.status / 200 | 0) == 1 ? res.text() : res.text().then(function (text) { - return Promise.reject(text); - }); - }).then(function (text) { - return _this.onResponse(text, clb); - }).catch(function (err) { - return _this.onError(err); }); - } -}); - -/***/ }), -/* 77 */ -/***/ (function(module, exports, __webpack_require__) { - -/* WEBPACK VAR INJECTION */(function(setImmediate) {(function (root) { + return propNew; + }, - // Store setTimeout reference so promise-polyfill will be unaffected by - // other code modifying setTimeout (like sinon.useFakeTimers()) - var setTimeoutFunc = setTimeout; + /** + * Add style property + * @param {Object|string} prop + * @param {string} value + * @example + * this.addStyle({color: 'red'}); + * this.addStyle('color', 'blue'); + */ + addStyle: function addStyle(prop) { + var value = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : ''; + var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; - function noop() {} - - // Polyfill for Function.prototype.bind - function bind(fn, thisArg) { - return function () { - fn.apply(thisArg, arguments); - }; - } + if (typeof prop == 'string') { + prop = { + prop: value + }; + } else { + opts = value || {}; + } - function Promise(fn) { - if (typeof this !== 'object') throw new TypeError('Promises must be constructed via new'); - if (typeof fn !== 'function') throw new TypeError('not a function'); - this._state = 0; - this._handled = false; - this._value = undefined; - this._deferreds = []; + prop = this.extendStyle(prop); + this.setStyle(prop, opts); + }, - doResolve(fn, this); - } + /** + * Remove style property + * @param {string} prop + */ + removeStyle: function removeStyle(prop) { + var style = this.getStyle(); + delete style[prop]; + this.setStyle(style); + }, - function handle(self, deferred) { - while (self._state === 3) { - self = self._value; - } - if (self._state === 0) { - self._deferreds.push(deferred); - return; - } - self._handled = true; - Promise._immediateFn(function () { - var cb = self._state === 1 ? deferred.onFulfilled : deferred.onRejected; - if (cb === null) { - (self._state === 1 ? resolve : reject)(deferred.promise, self._value); - return; - } - var ret; - try { - ret = cb(self._value); - } catch (e) { - reject(deferred.promise, e); - return; - } - resolve(deferred.promise, ret); - }); - } + /** + * Returns string of style properties + * @param {Object} [opts={}] Options + * @return {String} + */ + styleToString: function styleToString() { + var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var result = []; + var style = this.getStyle(); - function resolve(self, newValue) { - try { - // Promise Resolution Procedure: https://github.com/promises-aplus/promises-spec#the-promise-resolution-procedure - if (newValue === self) throw new TypeError('A promise cannot be resolved with itself.'); - if (newValue && (typeof newValue === 'object' || typeof newValue === 'function')) { - var then = newValue.then; - if (newValue instanceof Promise) { - self._state = 3; - self._value = newValue; - finale(self); - return; - } else if (typeof then === 'function') { - doResolve(bind(then, newValue), self); - return; - } - } - self._state = 1; - self._value = newValue; - finale(self); - } catch (e) { - reject(self, e); + for (var prop in style) { + var imp = opts.important; + var important = Object(underscore__WEBPACK_IMPORTED_MODULE_1__["isArray"])(imp) ? imp.indexOf(prop) >= 0 : imp; + var value = "".concat(style[prop]).concat(important ? ' !important' : ''); + value && result.push("".concat(prop, ":").concat(value, ";")); } - } - function reject(self, newValue) { - self._state = 2; - self._value = newValue; - finale(self); + return result.join(''); + }, + getSelectors: function getSelectors() { + return this.get('selectors') || this.get('classes'); } +}); - function finale(self) { - if (self._state === 2 && self._deferreds.length === 0) { - Promise._immediateFn(function() { - if (!self._handled) { - Promise._unhandledRejectionFn(self._value); - } - }); - } - - for (var i = 0, len = self._deferreds.length; i < len; i++) { - handle(self, self._deferreds[i]); - } - self._deferreds = null; - } +/***/ }), - function Handler(onFulfilled, onRejected, promise) { - this.onFulfilled = typeof onFulfilled === 'function' ? onFulfilled : null; - this.onRejected = typeof onRejected === 'function' ? onRejected : null; - this.promise = promise; - } +/***/ "./src/domain_abstract/model/TypeableCollection.js": +/*!*********************************************************!*\ + !*** ./src/domain_abstract/model/TypeableCollection.js ***! + \*********************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - /** - * Take a potentially misbehaving resolver function and make sure - * onFulfilled and onRejected are only called once. - * - * Makes no guarantees about asynchrony. - */ - function doResolve(fn, self) { - var done = false; - try { - fn(function (value) { - if (done) return; - done = true; - resolve(self, value); - }, function (reason) { - if (done) return; - done = true; - reject(self, reason); - }); - } catch (ex) { - if (done) return; - done = true; - reject(self, ex); - } - } +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_1__); - Promise.prototype['catch'] = function (onRejected) { - return this.then(null, onRejected); - }; - Promise.prototype.then = function (onFulfilled, onRejected) { - var prom = new (this.constructor)(noop); +var Model = backbone__WEBPACK_IMPORTED_MODULE_1___default.a.Model; +var View = backbone__WEBPACK_IMPORTED_MODULE_1___default.a.View; +/* harmony default export */ __webpack_exports__["default"] = ({ + types: [], + initialize: function initialize(models, opts) { + var _this = this; - handle(this, new Handler(onFulfilled, onRejected, prom)); - return prom; - }; + this.model = function () { + var attrs = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + var Model, View, type; - Promise.all = function (arr) { - var args = Array.prototype.slice.call(arr); + if (attrs && attrs.type) { + var baseType = _this.getBaseType(); - return new Promise(function (resolve, reject) { - if (args.length === 0) return resolve([]); - var remaining = args.length; + type = _this.getType(attrs.type); + Model = type ? type.model : baseType.model; + View = type ? type.view : baseType.view; + } else { + var typeFound = _this.recognizeType(attrs); - function res(i, val) { - try { - if (val && (typeof val === 'object' || typeof val === 'function')) { - var then = val.then; - if (typeof then === 'function') { - then.call(val, function (val) { - res(i, val); - }, reject); - return; - } - } - args[i] = val; - if (--remaining === 0) { - resolve(args); - } - } catch (ex) { - reject(ex); - } + type = typeFound.type; + Model = type.model; + View = type.view; + attrs = typeFound.attributes; } - for (var i = 0; i < args.length; i++) { - res(i, args[i]); - } - }); - }; + var model = new Model(attrs, options); + model.typeView = View; + return model; + }; - Promise.resolve = function (value) { - if (value && typeof value === 'object' && value.constructor === Promise) { - return value; - } + var init = this.init && this.init.bind(this); + init && init(); + }, - return new Promise(function (resolve) { - resolve(value); - }); - }; + /** + * Recognize type by any value + * @param {mixed} value + * @return {Object} Found type + */ + recognizeType: function recognizeType(value) { + var types = this.getTypes(); - Promise.reject = function (value) { - return new Promise(function (resolve, reject) { - reject(value); - }); - }; + for (var i = 0; i < types.length; i++) { + var type = types[i]; + var typeFound = type.isType(value); + typeFound = typeof typeFound == 'boolean' && typeFound ? { + type: type.id + } : typeFound; - Promise.race = function (values) { - return new Promise(function (resolve, reject) { - for (var i = 0, len = values.length; i < len; i++) { - values[i].then(resolve, reject); + if (typeFound) { + return { + type: type, + attributes: typeFound + }; } - }); - }; + } // If, for any reason, the type is not found it'll return the base one - // Use polyfill for setImmediate for performance gains - Promise._immediateFn = (typeof setImmediate === 'function' && function (fn) { setImmediate(fn); }) || - function (fn) { - setTimeoutFunc(fn, 0); - }; - Promise._unhandledRejectionFn = function _unhandledRejectionFn(err) { - if (typeof console !== 'undefined' && console) { - console.warn('Possible Unhandled Promise Rejection:', err); // eslint-disable-line no-console - } - }; + return { + type: this.getBaseType(), + attributes: value + }; + }, /** - * Set the immediate function to execute callbacks - * @param fn {function} Function to execute - * @deprecated + * Returns the base type (last object in the stack) + * @return {Object} */ - Promise._setImmediateFn = function _setImmediateFn(fn) { - Promise._immediateFn = fn; - }; + getBaseType: function getBaseType() { + var types = this.getTypes(); + return types[types.length - 1]; + }, /** - * Change the function to execute on unhandled rejection - * @param {function} fn Function to execute on unhandled rejection - * @deprecated + * Get types + * @return {Array} */ - Promise._setUnhandledRejectionFn = function _setUnhandledRejectionFn(fn) { - Promise._unhandledRejectionFn = fn; - }; - - if (typeof module !== 'undefined' && module.exports) { - module.exports = Promise; - } else if (!root.Promise) { - root.Promise = Promise; - } + getTypes: function getTypes() { + return this.types; + }, -})(this); + /** + * Get type + * @param {string} id Type ID + * @return {Object} Type definition + */ + getType: function getType(id) { + var types = this.getTypes(); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(78).setImmediate)) + for (var i = 0; i < types.length; i++) { + var type = types[i]; -/***/ }), -/* 78 */ -/***/ (function(module, exports, __webpack_require__) { + if (type.id === id) { + return type; + } + } + }, -var apply = Function.prototype.apply; + /** + * Add new type + * @param {string} id Type ID + * @param {Object} definition Definition of the type. Each definition contains + * `model` (business logic), `view` (presentation logic) + * and `isType` function which recognize the type of the + * passed entity + * addType('my-type', { + * model: {}, + * view: {}, + * isType: (value) => {}, + * }) + */ + addType: function addType(id, definition) { + var type = this.getType(id); + var baseType = this.getBaseType(); + var ModelInst = type ? type.model : baseType.model; + var ViewInst = type ? type.view : baseType.view; + var model = definition.model, + view = definition.view, + isType = definition.isType; + model = model instanceof Model || Object(underscore__WEBPACK_IMPORTED_MODULE_0__["isFunction"])(model) ? model : ModelInst.extend(model || {}); + view = view instanceof View || Object(underscore__WEBPACK_IMPORTED_MODULE_0__["isFunction"])(view) ? view : ViewInst.extend(view || {}); -// DOM APIs, for completeness + if (type) { + type.model = model; + type.view = view; + type.isType = isType || type.isType; + } else { + definition.id = id; + definition.model = model; + definition.view = view; -exports.setTimeout = function() { - return new Timeout(apply.call(setTimeout, window, arguments), clearTimeout); -}; -exports.setInterval = function() { - return new Timeout(apply.call(setInterval, window, arguments), clearInterval); -}; -exports.clearTimeout = -exports.clearInterval = function(timeout) { - if (timeout) { - timeout.close(); - } -}; + definition.isType = isType || function (value) { + if (value && value.type == id) { + return true; + } + }; -function Timeout(id, clearFn) { - this._id = id; - this._clearFn = clearFn; -} -Timeout.prototype.unref = Timeout.prototype.ref = function() {}; -Timeout.prototype.close = function() { - this._clearFn.call(window, this._id); -}; + this.getTypes().unshift(definition); + } + } +}); -// Does not start the time, just sets up the members needed. -exports.enroll = function(item, msecs) { - clearTimeout(item._idleTimeoutId); - item._idleTimeout = msecs; -}; +/***/ }), -exports.unenroll = function(item) { - clearTimeout(item._idleTimeoutId); - item._idleTimeout = -1; -}; +/***/ "./src/domain_abstract/ui/Input.js": +/*!*****************************************!*\ + !*** ./src/domain_abstract/ui/Input.js ***! + \*****************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { -exports._unrefActive = exports.active = function(item) { - clearTimeout(item._idleTimeoutId); +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); - var msecs = item._idleTimeout; - if (msecs >= 0) { - item._idleTimeoutId = setTimeout(function onTimeout() { - if (item._onTimeout) - item._onTimeout(); - }, msecs); - } -}; +var $ = backbone__WEBPACK_IMPORTED_MODULE_0___default.a.$; +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_0___default.a.View.extend({ + events: { + change: 'handleChange' + }, + template: function template() { + return ""); + }, + inputClass: function inputClass() { + return "".concat(this.ppfx, "field"); + }, + holderClass: function holderClass() { + return "".concat(this.ppfx, "input-holder"); + }, + initialize: function initialize() { + var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var ppfx = opts.ppfx || ''; + this.opts = opts; + this.ppfx = ppfx; + this.em = opts.target || {}; + this.listenTo(this.model, 'change:value', this.handleModelChange); + }, -// setimmediate attaches itself to the global object -__webpack_require__(79); -exports.setImmediate = setImmediate; -exports.clearImmediate = clearImmediate; + /** + * Fired when the element of the property is updated + */ + elementUpdated: function elementUpdated() { + this.model.trigger('el:change'); + }, + /** + * Set value to the input element + * @param {string} value + */ + setValue: function setValue(value) { + var model = this.model; + var val = value || model.get('defaults'); + var input = this.getInputEl(); + input && (input.value = val); + }, -/***/ }), -/* 79 */ -/***/ (function(module, exports, __webpack_require__) { + /** + * Updates the view when the model is changed + * */ + handleModelChange: function handleModelChange(model, value, opts) { + this.setValue(value, opts); + }, -/* WEBPACK VAR INJECTION */(function(global, process) {(function (global, undefined) { - "use strict"; + /** + * Handled when the view is changed + */ + handleChange: function handleChange(e) { + e.stopPropagation(); + var value = this.getInputEl().value; + this.model.set({ + value: value + }, { + fromInput: 1 + }); + this.elementUpdated(); + }, - if (global.setImmediate) { - return; + /** + * Get the input element + * @return {HTMLElement} + */ + getInputEl: function getInputEl() { + if (!this.inputEl) { + var model = this.model; + var plh = model.get('placeholder') || model.get('defaults') || ''; + this.inputEl = $("")); } - var nextHandle = 1; // Spec says greater than zero - var tasksByHandle = {}; - var currentlyRunningATask = false; - var doc = global.document; - var registerImmediate; + return this.inputEl.get(0); + }, + render: function render() { + this.inputEl = null; + var el = this.$el; + el.addClass(this.inputClass()); + el.html(this.template()); + el.find(".".concat(this.holderClass())).append(this.getInputEl()); + return this; + } +})); - function setImmediate(callback) { - // Callback can either be a function or a string - if (typeof callback !== "function") { - callback = new Function("" + callback); - } - // Copy function arguments - var args = new Array(arguments.length - 1); - for (var i = 0; i < args.length; i++) { - args[i] = arguments[i + 1]; - } - // Store and register the task - var task = { callback: callback, args: args }; - tasksByHandle[nextHandle] = task; - registerImmediate(nextHandle); - return nextHandle++; - } +/***/ }), - function clearImmediate(handle) { - delete tasksByHandle[handle]; - } +/***/ "./src/domain_abstract/ui/InputColor.js": +/*!**********************************************!*\ + !*** ./src/domain_abstract/ui/InputColor.js ***! + \**********************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - function run(task) { - var callback = task.callback; - var args = task.args; - switch (args.length) { - case 0: - callback(); - break; - case 1: - callback(args[0]); - break; - case 2: - callback(args[0], args[1]); - break; - case 3: - callback(args[0], args[1], args[2]); - break; - default: - callback.apply(undefined, args); - break; - } - } +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_2__); +/* harmony import */ var utils_ColorPicker__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! utils/ColorPicker */ "./src/utils/ColorPicker.js"); +/* harmony import */ var _Input__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./Input */ "./src/domain_abstract/ui/Input.js"); - function runIfPresent(handle) { - // From the spec: "Wait until any invocations of this algorithm started before this one have completed." - // So if we're currently running a task, we'll need to delay this invocation. - if (currentlyRunningATask) { - // Delay by doing a setTimeout. setImmediate was tried instead, but in Firefox 7 it generated a - // "too much recursion" error. - setTimeout(runIfPresent, 0, handle); - } else { - var task = tasksByHandle[handle]; - if (task) { - currentlyRunningATask = true; - try { - run(task); - } finally { - clearImmediate(handle); - currentlyRunningATask = false; - } - } - } - } - function installNextTickImplementation() { - registerImmediate = function(handle) { - process.nextTick(function () { runIfPresent(handle); }); - }; - } +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - function canUsePostMessage() { - // The test against `importScripts` prevents this implementation from being installed inside a web worker, - // where `global.postMessage` means something completely different and can't be used for this purpose. - if (global.postMessage && !global.importScripts) { - var postMessageIsAsynchronous = true; - var oldOnMessage = global.onmessage; - global.onmessage = function() { - postMessageIsAsynchronous = false; - }; - global.postMessage("", "*"); - global.onmessage = oldOnMessage; - return postMessageIsAsynchronous; - } - } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - function installPostMessageImplementation() { - // Installs an event handler on `global` for the `message` event: see - // * https://developer.mozilla.org/en/DOM/window.postMessage - // * http://www.whatwg.org/specs/web-apps/current-work/multipage/comms.html#crossDocumentMessages - var messagePrefix = "setImmediate$" + Math.random() + "$"; - var onGlobalMessage = function(event) { - if (event.source === global && - typeof event.data === "string" && - event.data.indexOf(messagePrefix) === 0) { - runIfPresent(+event.data.slice(messagePrefix.length)); - } - }; - if (global.addEventListener) { - global.addEventListener("message", onGlobalMessage, false); - } else { - global.attachEvent("onmessage", onGlobalMessage); - } - registerImmediate = function(handle) { - global.postMessage(messagePrefix + handle, "*"); - }; - } - function installMessageChannelImplementation() { - var channel = new MessageChannel(); - channel.port1.onmessage = function(event) { - var handle = event.data; - runIfPresent(handle); - }; +var $ = backbone__WEBPACK_IMPORTED_MODULE_1___default.a.$; +Object(utils_ColorPicker__WEBPACK_IMPORTED_MODULE_3__["default"])($); +/* harmony default export */ __webpack_exports__["default"] = (_Input__WEBPACK_IMPORTED_MODULE_4__["default"].extend({ + template: function template() { + var ppfx = this.ppfx; + return "\n
\n
\n
\n
\n
\n
\n "); + }, + inputClass: function inputClass() { + var ppfx = this.ppfx; + return "".concat(ppfx, "field ").concat(ppfx, "field-color"); + }, + holderClass: function holderClass() { + return "".concat(this.ppfx, "input-holder"); + }, - registerImmediate = function(handle) { - channel.port2.postMessage(handle); - }; - } + /** + * Set value to the model + * @param {string} val + * @param {Object} opts + */ + setValue: function setValue(val) { + var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + var model = this.model; + var def = model.get('defaults'); + var value = !Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isUndefined"])(val) ? val : !Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isUndefined"])(def) ? def : ''; + var inputEl = this.getInputEl(); + var colorEl = this.getColorEl(); + var valueClr = value != 'none' ? value : ''; + inputEl.value = value; + colorEl.get(0).style.backgroundColor = valueClr; // This prevents from adding multiple thumbs in spectrum - function installReadyStateChangeImplementation() { - var html = doc.documentElement; - registerImmediate = function(handle) { - // Create a ") : ''; + return html; + }, - var em = this.target; - var model = this.model; - var coll = this.coll; - var el = this.el; - var sel = em && em.get('selectedComponent'); - sel && sel.get & sel.get('classes').remove(model); - coll && coll.remove(model); - setTimeout(function () { - return _this.remove(); - }, 0); + /** + * Returns CSS built inside canvas + * @param {Object} [opts={}] Options + * @return {string} CSS string + * @private + */ + getCss: function getCss() { + var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var config = this.config; + var wrapperIsBody = config.wrapperIsBody; + var avoidProt = opts.avoidProtected; + var keepUnusedStyles = !Object(underscore__WEBPACK_IMPORTED_MODULE_1__["isUndefined"])(opts.keepUnusedStyles) ? opts.keepUnusedStyles : config.keepUnusedStyles; + var cssc = this.get('CssComposer'); + var wrp = this.get('DomComponents').getComponent(); + var protCss = !avoidProt ? config.protectedCss : ''; + return protCss + this.get('CodeManager').getCode(wrp, 'css', { + cssc: cssc, + wrapperIsBody: wrapperIsBody, + keepUnusedStyles: keepUnusedStyles + }); }, + /** + * Returns JS of all components + * @return {string} JS string + * @private + */ + getJs: function getJs() { + var wrp = this.get('DomComponents').getWrapper(); + return this.get('CodeManager').getCode(wrp, 'js').trim(); + }, /** - * Update status of the checkbox + * Store data to the current storage + * @param {Function} clb Callback function + * @return {Object} Stored data * @private */ - updateStatus: function updateStatus() { - var chkOn = 'fa-check-square-o'; - var chkOff = 'fa-square-o'; + store: function store(clb) { + var _this8 = this; - if (!this.$chk) this.$chk = this.$el.find('#' + this.pfx + 'checkbox'); + var sm = this.get('StorageManager'); + var store = {}; + if (!sm) return; // Fetch what to store - if (this.model.get('active')) { - this.$chk.removeClass(chkOff).addClass(chkOn); - this.$el.removeClass('opac50'); - } else { - this.$chk.removeClass(chkOn).addClass(chkOff); - this.$el.addClass('opac50'); - } - }, - render: function render() { - var pfx = this.pfx; - var ppfx = this.ppfx; - this.$el.html(this.template()); - this.$el.attr('class', pfx + 'tag ' + ppfx + 'three-bg'); - this.updateStatus(); - return this; - } -}); + this.get('storables').forEach(function (m) { + var obj = m.store(1); -/***/ }), -/* 93 */ -/***/ (function(module, exports, __webpack_require__) { + for (var el in obj) { + store[el] = obj[el]; + } + }); + sm.store(store, function (res) { + clb && clb(res); -"use strict"; - - -/** - * * [open](#open) - * * [close](#close) - * * [isOpen](#isopen) - * * [setTitle](#settitle) - * * [getTitle](#gettitle) - * * [setContent](#setcontent) - * * [getContent](#getcontent) - * - * Before using the methods you should get first the module from the editor instance, in this way: - * - * ```js - * var modal = editor.Modal; - * ``` - * @module Modal - */ -module.exports = function () { - var c = {}, - defaults = __webpack_require__(94), - ModalM = __webpack_require__(95), - ModalView = __webpack_require__(96); - var model, modal; - - return { - - /** - * Name of the module - * @type {String} - * @private - */ - name: 'Modal', - - /** - * Initialize module. Automatically called with a new instance of the editor - * @param {Object} config Configurations - * @private - */ - init: function init(config) { - c = config || {}; - for (var name in defaults) { - if (!(name in c)) c[name] = defaults[name]; - } - - var ppfx = c.pStylePrefix; - if (ppfx) c.stylePrefix = ppfx + c.stylePrefix; - - model = new ModalM(c); - modal = new ModalView({ - model: model, - config: c - }); - - return this; - }, - postRender: function postRender(editorView) { - // c.em.config.el || 'body' - this.render().appendTo(editorView.el); - }, - - - /** - * Open the modal window - * @return {this} - */ - open: function open() { - modal.show(); - return this; - }, - - - /** - * Close the modal window - * @return {this} - */ - close: function close() { - modal.hide(); - return this; - }, - - - /** - * Checks if the modal window is open - * @return {Boolean} - */ - isOpen: function isOpen() { - return !!model.get('open'); - }, - - - /** - * Set the title to the modal window - * @param {string} title Title - * @return {this} - * @example - * modal.setTitle('New title'); - */ - setTitle: function setTitle(title) { - model.set('title', title); - return this; - }, - - - /** - * Returns the title of the modal window - * @return {string} - */ - getTitle: function getTitle() { - return model.get('title'); - }, - - - /** - * Set the content of the modal window - * @param {string|HTMLElement} content Content - * @return {this} - * @example - * modal.setContent('
Some HTML content
'); - */ - setContent: function setContent(content) { - model.set('content', ' '); - model.set('content', content); - return this; - }, - - - /** - * Get the content of the modal window - * @return {string} - */ - getContent: function getContent() { - return model.get('content'); - }, - - - /** - * Returns content element - * @return {HTMLElement} - * @private - */ - getContentEl: function getContentEl() { - return modal.getContent().get(0); - }, - - - /** - * Returns modal model - * @return {Model} - * @private - */ - getModel: function getModel() { - return model; - }, - - - /** - * Render the modal window - * @return {HTMLElement} - * @private - */ - render: function render() { - return modal.render().$el; - } - }; -}; - -/***/ }), -/* 94 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -module.exports = { - - stylePrefix: 'mdl-', - - title: '', - - content: '', - - backdrop: true - -};; - -/***/ }), -/* 95 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -var Backbone = __webpack_require__(0); - -module.exports = Backbone.Model.extend({ - defaults: { - title: '', - content: '', - open: false - } -}); - -/***/ }), -/* 96 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -module.exports = __webpack_require__(0).View.extend({ - template: function template(_ref) { - var pfx = _ref.pfx, - ppfx = _ref.ppfx, - content = _ref.content, - title = _ref.title; - - return '
\n
\n
' + title + '
\n
\n
\n
\n
' + content + '
\n
\n
\n
\n
\n '; - }, - - - events: {}, - - initialize: function initialize(o) { - var model = this.model; - var config = o.config || {}; - var pfx = config.stylePrefix || ''; - var bkd = config.backdrop; - this.config = config; - this.pfx = pfx; - this.ppfx = config.pStylePrefix || ''; - this.listenTo(model, 'change:open', this.updateOpen); - this.listenTo(model, 'change:title', this.updateTitle); - this.listenTo(model, 'change:content', this.updateContent); - this.events['click .' + pfx + 'btn-close'] = 'hide'; - bkd && (this.events['click .' + pfx + 'backlayer'] = 'hide'); - this.delegateEvents(); - }, - - - /** - * Returns collector element - * @return {HTMLElement} - * @private - */ - getCollector: function getCollector() { - if (!this.$collector) this.$collector = this.$el.find('.' + this.pfx + 'collector'); - return this.$collector; - }, + _this8.set('changesCount', 0); + _this8.trigger('storage:store', store); + }); + return store; + }, /** - * Returns content element - * @return {HTMLElement} - * @private - */ - getContent: function getContent() { - var pfx = this.pfx; - - if (!this.$content) { - this.$content = this.$el.find('.' + pfx + 'content #' + pfx + 'c'); - } - - return this.$content; - }, - - - /** - * Returns title element - * @return {HTMLElement} + * Load data from the current storage + * @param {Function} clb Callback function * @private */ - getTitle: function getTitle() { - if (!this.$title) this.$title = this.$el.find('.' + this.pfx + 'title'); - return this.$title.get(0); - }, + load: function load() { + var _this9 = this; + var clb = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : null; + this.getCacheLoad(1, function (res) { + _this9.get('storables').forEach(function (module) { + return module.load(res); + }); - /** - * Update content - * @private - * */ - updateContent: function updateContent() { - var content = this.getContent(); - var children = content.children(); - var coll = this.getCollector(); - var body = this.model.get('content'); - children.length && coll.append(children); - content.empty().append(body); + clb && clb(res); + }); }, - /** - * Update title - * @private - * */ - updateTitle: function updateTitle() { - var title = this.getTitle(); - if (title) title.innerHTML = this.model.get('title'); - }, - - - /** - * Update open - * @private - * */ - updateOpen: function updateOpen() { - this.el.style.display = this.model.get('open') ? '' : 'none'; - }, - - - /** - * Hide modal - * @private - * */ - hide: function hide() { - this.model.set('open', 0); - }, - - - /** - * Show modal - * @private - * */ - show: function show() { - this.model.set('open', 1); - }, - render: function render() { - var el = this.$el; - var pfx = this.pfx; - var ppfx = this.ppfx; - var obj = this.model.toJSON(); - obj.pfx = this.pfx; - obj.ppfx = this.ppfx; - el.html(this.template(obj)); - el.attr('class', pfx + 'container'); - this.updateOpen(); - return this; - } -}); - -/***/ }), -/* 97 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -/** - * - [addGenerator](#addgenerator) - * - [getGenerator](#getgenerator) - * - [getGenerators](#getgenerators) - * - [addViewer](#addviewer) - * - [getViewer](#getviewer) - * - [getViewers](#getviewers) - * - [updateViewer](#updateviewer) - * - [getCode](#getcode) - * - * - * Before using methods you should get first the module from the editor instance, in this way: - * - * ```js - * var codeManager = editor.CodeManager; - * ``` - * - * @module CodeManager - */ -module.exports = function () { - - var c = {}, - defaults = __webpack_require__(98), - gHtml = __webpack_require__(99), - gCss = __webpack_require__(100), - gJson = __webpack_require__(101), - gJs = __webpack_require__(102), - eCM = __webpack_require__(103), - editorView = __webpack_require__(108); - - var generators = {}, - defGenerators = {}, - viewers = {}, - defViewers = {}; - - return { - getConfig: function getConfig() { - return c; - }, - - - config: c, - - EditorView: editorView, - - /** - * Name of the module - * @type {String} - * @private - */ - name: 'CodeManager', - - /** - * Initialize module. Automatically called with a new instance of the editor - * @param {Object} config Configurations - */ - init: function init(config) { - c = config || {}; - for (var name in defaults) { - if (!(name in c)) c[name] = defaults[name]; - } - - var ppfx = c.pStylePrefix; - if (ppfx) c.stylePrefix = ppfx + c.stylePrefix; - - defGenerators.html = new gHtml(); - defGenerators.css = new gCss(); - defGenerators.json = new gJson(); - defGenerators.js = new gJs(); - defViewers.CodeMirror = new eCM(); - this.loadDefaultGenerators().loadDefaultViewers(); - - return this; - }, - - - /** - * Add new code generator to the collection - * @param {string} id Code generator ID - * @param {Object} generator Code generator wrapper - * @param {Function} generator.build Function that builds the code - * @return {this} - * @example - * codeManager.addGenerator('html7',{ - * build: function(model){ - * return 'myCode'; - * } - * }); - * */ - addGenerator: function addGenerator(id, generator) { - generators[id] = generator; - return this; - }, - - - /** - * Get code generator by id - * @param {string} id Code generator ID - * @return {Object|null} - * @example - * var generator = codeManager.getGenerator('html7'); - * generator.build = function(model){ - * //extend - * }; - * */ - getGenerator: function getGenerator(id) { - return generators[id] || null; - }, - - - /** - * Returns all code generators - * @return {Array} - * */ - getGenerators: function getGenerators() { - return generators; - }, - - - /** - * Add new code viewer - * @param {string} id Code viewer ID - * @param {Object} viewer Code viewer wrapper - * @param {Function} viewer.init Set element on which viewer will be displayed - * @param {Function} viewer.setContent Set content to the viewer - * @return {this} - * @example - * codeManager.addViewer('ace',{ - * init: function(el){ - * var ace = require('ace-editor'); - * this.editor = ace.edit(el.id); - * }, - * setContent: function(code){ - * this.editor.setValue(code); - * } - * }); - * */ - addViewer: function addViewer(id, viewer) { - viewers[id] = viewer; - return this; - }, - - - /** - * Get code viewer by id - * @param {string} id Code viewer ID - * @return {Object|null} - * @example - * var viewer = codeManager.getViewer('ace'); - * */ - getViewer: function getViewer(id) { - return viewers[id] || null; - }, - - - /** - * Returns all code viewers - * @return {Array} - * */ - getViewers: function getViewers() { - return viewers; - }, - - - /** - * Update code viewer content - * @param {Object} viewer Viewer instance - * @param {string} code Code string - * @example - * var AceViewer = codeManager.getViewer('ace'); - * // ... - * var viewer = AceViewer.init(el); - * // ... - * codeManager.updateViewer(AceViewer, 'code'); - * */ - updateViewer: function updateViewer(viewer, code) { - viewer.setContent(code); - }, - - - /** - * Get code from model - * @param {Object} model Any kind of model that will be passed to the build method of generator - * @param {string} genId Code generator id - * @param {Object} [opt] Options - * @return {string} - * @example - * var codeStr = codeManager.getCode(model, 'html'); - * */ - getCode: function getCode(model, genId) { - var opt = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; - - opt.em = c.em; - var generator = this.getGenerator(genId); - return generator ? generator.build(model, opt) : ''; - }, - - - /** - * Load default code generators - * @return {this} - * @private - * */ - loadDefaultGenerators: function loadDefaultGenerators() { - for (var id in defGenerators) { - this.addGenerator(id, defGenerators[id]); - }return this; - }, - - - /** - * Load default code viewers - * @return {this} - * @private - * */ - loadDefaultViewers: function loadDefaultViewers() { - for (var id in defViewers) { - this.addViewer(id, defViewers[id]); - }return this; - } - }; -}; - -/***/ }), -/* 98 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -module.exports = { - // Style prefix - stylePrefix: 'cm-', - - inlineCss: false -}; - -/***/ }), -/* 99 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -var Backbone = __webpack_require__(0); - -module.exports = Backbone.Model.extend({ - build: function build(model) { - var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; - - var models = model.get('components'); - - if (opts.exportWrapper) { - return opts.wrappesIsBody ? '' + this.buildModels(models) + '' : model.toHTML(); - } - - return this.buildModels(models); - }, - buildModels: function buildModels(models) { - var code = ''; - models.each(function (model) { - code += model.toHTML(); - }); - return code; - } -}); - -/***/ }), -/* 100 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -module.exports = __webpack_require__(0).Model.extend({ - initialize: function initialize() { - this.compCls = []; - this.ids = []; - }, - - - /** - * Get CSS from a component - * @param {Model} model - * @return {String} - */ - buildFromModel: function buildFromModel(model) { - var _this = this; - - var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; - - var code = ''; - var em = this.em; - var avoidInline = em && em.getConfig('avoidInlineStyle'); - var style = model.styleToString(); - var classes = model.get('classes'); - var wrappesIsBody = opts.wrappesIsBody; - var isWrapper = model.get('wrapper'); - this.ids.push('#' + model.getId()); - - // Let's know what classes I've found - classes.each(function (model) { - return _this.compCls.push(model.getFullName()); - }); - - if ((!avoidInline || isWrapper) && style) { - var selector = '#' + model.getId(); - selector = wrappesIsBody && isWrapper ? 'body' : selector; - code = selector + '{' + style + '}'; - } - - var components = model.components(); - components.each(function (model) { - return code += _this.buildFromModel(model, opts); - }); - return code; - }, - build: function build(model) { - var _this2 = this; - - var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; - - var cssc = opts.cssc; - this.em = opts.em || ''; - this.compCls = []; - this.ids = []; - var code = this.buildFromModel(model, opts); - - if (cssc) { - var rules = cssc.getAll(); - var mediaRules = {}; - - rules.each(function (rule) { - var media = rule.get('mediaText'); - - // If media is setted, I'll render it later - if (media) { - var mRules = mediaRules[media]; - if (mRules) { - mRules.push(rule); - } else { - mediaRules[media] = [rule]; - } - return; - } - - code += _this2.buildFromRule(rule); - }); - - // Get media rules - for (var media in mediaRules) { - var rulesStr = ''; - var mRules = mediaRules[media]; - mRules.forEach(function (rule) { - return rulesStr += _this2.buildFromRule(rule); - }); - - if (rulesStr) { - code += '@media ' + media + '{' + rulesStr + '}'; - } - } - } - - return code; - }, - - - /** - * Get CSS from the rule model - * @param {Model} rule - * @return {string} CSS string - */ - buildFromRule: function buildFromRule(rule) { - var _this3 = this; - - var result = ''; - var selectorStr = rule.selectorsToString(); - var selectorStrNoAdd = rule.selectorsToString({ skipAdd: 1 }); - var found = void 0; - - // This will not render a rule if there is no its component - rule.get('selectors').each(function (selector) { - var name = selector.getFullName(); - if (_this3.compCls.indexOf(name) >= 0 || _this3.ids.indexOf(name) >= 0) { - found = 1; - } - }); - - if (selectorStrNoAdd && found || rule.get('selectorsAdd')) { - var style = rule.styleToString(); - - if (style) { - result += selectorStr + '{' + style + '}'; - } - } - - return result; - } -}); - -/***/ }), -/* 101 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; -/* WEBPACK VAR INJECTION */(function(_) { - -var Backbone = __webpack_require__(0); - -module.exports = Backbone.Model.extend({ - - /** @inheritdoc */ - build: function build(model) { - var json = model.toJSON(); - this.beforeEach(json); - - _.each(json, function (v, attr) { - var obj = json[attr]; - if (obj instanceof Backbone.Model) { - json[attr] = this.build(obj); - } else if (obj instanceof Backbone.Collection) { - var coll = obj; - json[attr] = []; - if (coll.length) { - coll.each(function (el, index) { - json[attr][index] = this.build(el); - }, this); - } - } - }, this); - - return json; - }, - - - /** - * Execute on each object - * @param {Object} obj - */ - beforeEach: function beforeEach(obj) { - delete obj.status; - } -}); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(1))) - -/***/ }), -/* 102 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; -/* WEBPACK VAR INJECTION */(function(_) { - -var Backbone = __webpack_require__(0); - -module.exports = Backbone.Model.extend({ - mapModel: function mapModel(model) { - var code = ''; - var script = model.get('script'); - var type = model.get('type'); - var comps = model.get('components'); - var id = model.getId(); - - if (script) { - // If the component has scripts we need to expose his ID - var attr = model.get('attributes'); - attr = _.extend({}, attr, { id: id }); - model.set('attributes', attr); - var scrStr = model.getScriptString(); - - // If the script was updated, I'll put its code in a separate container - if (model.get('scriptUpdated')) { - this.mapJs[type + '-' + id] = { ids: [id], code: scrStr }; - } else { - var mapType = this.mapJs[type]; - - if (mapType) { - mapType.ids.push(id); - } else { - this.mapJs[type] = { ids: [id], code: scrStr }; - } - } - } - - comps.each(function (model) { - code += this.mapModel(model); - }, this); - - return code; - }, - build: function build(model) { - this.mapJs = {}; - this.mapModel(model); - - var code = ''; - - for (var type in this.mapJs) { - var mapType = this.mapJs[type]; - var ids = '#' + mapType.ids.join(', #'); - code += '\n var items = document.querySelectorAll(\'' + ids + '\');\n for (var i = 0, len = items.length; i < len; i++) {\n (function(){' + mapType.code + '}.bind(items[i]))();\n }'; - } - - return code; - } -}); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(1))) - -/***/ }), -/* 103 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; - -var Backbone = __webpack_require__(0); -var CodeMirror = __webpack_require__(6); -var htmlMode = __webpack_require__(104); -var cssMode = __webpack_require__(26); -var formatting = __webpack_require__(107); - -module.exports = Backbone.Model.extend({ - - defaults: { - input: '', - label: '', - codeName: '', - theme: '', - readOnly: true, - lineNumbers: true - }, - - /** @inheritdoc */ - init: function init(el) { - this.editor = CodeMirror.fromTextArea(el, _extends({ - dragDrop: false, - lineWrapping: true, - mode: this.get('codeName') - }, this.attributes)); - - return this; - }, - - - /** @inheritdoc */ - setContent: function setContent(v) { - if (!this.editor) return; - this.editor.setValue(v); - if (this.editor.autoFormatRange) { - CodeMirror.commands.selectAll(this.editor); - this.editor.autoFormatRange(this.editor.getCursor(true), this.editor.getCursor(false)); - CodeMirror.commands.goDocStart(this.editor); - } - } -}); - -/***/ }), -/* 104 */ -/***/ (function(module, exports, __webpack_require__) { - -// CodeMirror, copyright (c) by Marijn Haverbeke and others -// Distributed under an MIT license: http://codemirror.net/LICENSE - -(function(mod) { - if (true) // CommonJS - mod(__webpack_require__(6), __webpack_require__(105), __webpack_require__(106), __webpack_require__(26)); - else if (typeof define == "function" && define.amd) // AMD - define(["../../lib/codemirror", "../xml/xml", "../javascript/javascript", "../css/css"], mod); - else // Plain browser env - mod(CodeMirror); -})(function(CodeMirror) { - "use strict"; - - var defaultTags = { - script: [ - ["lang", /(javascript|babel)/i, "javascript"], - ["type", /^(?:text|application)\/(?:x-)?(?:java|ecma)script$|^module$|^$/i, "javascript"], - ["type", /./, "text/plain"], - [null, null, "javascript"] - ], - style: [ - ["lang", /^css$/i, "css"], - ["type", /^(text\/)?(x-)?(stylesheet|css)$/i, "css"], - ["type", /./, "text/plain"], - [null, null, "css"] - ] - }; - - function maybeBackup(stream, pat, style) { - var cur = stream.current(), close = cur.search(pat); - if (close > -1) { - stream.backUp(cur.length - close); - } else if (cur.match(/<\/?$/)) { - stream.backUp(cur.length); - if (!stream.match(pat, false)) stream.match(cur); - } - return style; - } - - var attrRegexpCache = {}; - function getAttrRegexp(attr) { - var regexp = attrRegexpCache[attr]; - if (regexp) return regexp; - return attrRegexpCache[attr] = new RegExp("\\s+" + attr + "\\s*=\\s*('|\")?([^'\"]+)('|\")?\\s*"); - } - - function getAttrValue(text, attr) { - var match = text.match(getAttrRegexp(attr)) - return match ? /^\s*(.*?)\s*$/.exec(match[2])[1] : "" - } - - function getTagRegexp(tagName, anchored) { - return new RegExp((anchored ? "^" : "") + "<\/\s*" + tagName + "\s*>", "i"); - } - - function addTags(from, to) { - for (var tag in from) { - var dest = to[tag] || (to[tag] = []); - var source = from[tag]; - for (var i = source.length - 1; i >= 0; i--) - dest.unshift(source[i]) - } - } - - function findMatchingMode(tagInfo, tagText) { - for (var i = 0; i < tagInfo.length; i++) { - var spec = tagInfo[i]; - if (!spec[0] || spec[1].test(getAttrValue(tagText, spec[0]))) return spec[2]; - } - } - - CodeMirror.defineMode("htmlmixed", function (config, parserConfig) { - var htmlMode = CodeMirror.getMode(config, { - name: "xml", - htmlMode: true, - multilineTagIndentFactor: parserConfig.multilineTagIndentFactor, - multilineTagIndentPastTag: parserConfig.multilineTagIndentPastTag - }); - - var tags = {}; - var configTags = parserConfig && parserConfig.tags, configScript = parserConfig && parserConfig.scriptTypes; - addTags(defaultTags, tags); - if (configTags) addTags(configTags, tags); - if (configScript) for (var i = configScript.length - 1; i >= 0; i--) - tags.script.unshift(["type", configScript[i].matches, configScript[i].mode]) - - function html(stream, state) { - var style = htmlMode.token(stream, state.htmlState), tag = /\btag\b/.test(style), tagName - if (tag && !/[<>\s\/]/.test(stream.current()) && - (tagName = state.htmlState.tagName && state.htmlState.tagName.toLowerCase()) && - tags.hasOwnProperty(tagName)) { - state.inTag = tagName + " " - } else if (state.inTag && tag && />$/.test(stream.current())) { - var inTag = /^([\S]+) (.*)/.exec(state.inTag) - state.inTag = null - var modeSpec = stream.current() == ">" && findMatchingMode(tags[inTag[1]], inTag[2]) - var mode = CodeMirror.getMode(config, modeSpec) - var endTagA = getTagRegexp(inTag[1], true), endTag = getTagRegexp(inTag[1], false); - state.token = function (stream, state) { - if (stream.match(endTagA, false)) { - state.token = html; - state.localState = state.localMode = null; - return null; - } - return maybeBackup(stream, endTag, state.localMode.token(stream, state.localState)); - }; - state.localMode = mode; - state.localState = CodeMirror.startState(mode, htmlMode.indent(state.htmlState, "")); - } else if (state.inTag) { - state.inTag += stream.current() - if (stream.eol()) state.inTag += " " - } - return style; - }; - - return { - startState: function () { - var state = CodeMirror.startState(htmlMode); - return {token: html, inTag: null, localMode: null, localState: null, htmlState: state}; - }, - - copyState: function (state) { - var local; - if (state.localState) { - local = CodeMirror.copyState(state.localMode, state.localState); - } - return {token: state.token, inTag: state.inTag, - localMode: state.localMode, localState: local, - htmlState: CodeMirror.copyState(htmlMode, state.htmlState)}; - }, - - token: function (stream, state) { - return state.token(stream, state); - }, - - indent: function (state, textAfter, line) { - if (!state.localMode || /^\s*<\//.test(textAfter)) - return htmlMode.indent(state.htmlState, textAfter); - else if (state.localMode.indent) - return state.localMode.indent(state.localState, textAfter, line); - else - return CodeMirror.Pass; - }, - - innerMode: function (state) { - return {state: state.localState || state.htmlState, mode: state.localMode || htmlMode}; - } - }; - }, "xml", "javascript", "css"); - - CodeMirror.defineMIME("text/html", "htmlmixed"); -}); - - -/***/ }), -/* 105 */ -/***/ (function(module, exports, __webpack_require__) { - -// CodeMirror, copyright (c) by Marijn Haverbeke and others -// Distributed under an MIT license: http://codemirror.net/LICENSE - -(function(mod) { - if (true) // CommonJS - mod(__webpack_require__(6)); - else if (typeof define == "function" && define.amd) // AMD - define(["../../lib/codemirror"], mod); - else // Plain browser env - mod(CodeMirror); -})(function(CodeMirror) { -"use strict"; - -var htmlConfig = { - autoSelfClosers: {'area': true, 'base': true, 'br': true, 'col': true, 'command': true, - 'embed': true, 'frame': true, 'hr': true, 'img': true, 'input': true, - 'keygen': true, 'link': true, 'meta': true, 'param': true, 'source': true, - 'track': true, 'wbr': true, 'menuitem': true}, - implicitlyClosed: {'dd': true, 'li': true, 'optgroup': true, 'option': true, 'p': true, - 'rp': true, 'rt': true, 'tbody': true, 'td': true, 'tfoot': true, - 'th': true, 'tr': true}, - contextGrabbers: { - 'dd': {'dd': true, 'dt': true}, - 'dt': {'dd': true, 'dt': true}, - 'li': {'li': true}, - 'option': {'option': true, 'optgroup': true}, - 'optgroup': {'optgroup': true}, - 'p': {'address': true, 'article': true, 'aside': true, 'blockquote': true, 'dir': true, - 'div': true, 'dl': true, 'fieldset': true, 'footer': true, 'form': true, - 'h1': true, 'h2': true, 'h3': true, 'h4': true, 'h5': true, 'h6': true, - 'header': true, 'hgroup': true, 'hr': true, 'menu': true, 'nav': true, 'ol': true, - 'p': true, 'pre': true, 'section': true, 'table': true, 'ul': true}, - 'rp': {'rp': true, 'rt': true}, - 'rt': {'rp': true, 'rt': true}, - 'tbody': {'tbody': true, 'tfoot': true}, - 'td': {'td': true, 'th': true}, - 'tfoot': {'tbody': true}, - 'th': {'td': true, 'th': true}, - 'thead': {'tbody': true, 'tfoot': true}, - 'tr': {'tr': true} - }, - doNotIndent: {"pre": true}, - allowUnquoted: true, - allowMissing: true, - caseFold: true -} - -var xmlConfig = { - autoSelfClosers: {}, - implicitlyClosed: {}, - contextGrabbers: {}, - doNotIndent: {}, - allowUnquoted: false, - allowMissing: false, - caseFold: false -} - -CodeMirror.defineMode("xml", function(editorConf, config_) { - var indentUnit = editorConf.indentUnit - var config = {} - var defaults = config_.htmlMode ? htmlConfig : xmlConfig - for (var prop in defaults) config[prop] = defaults[prop] - for (var prop in config_) config[prop] = config_[prop] - - // Return variables for tokenizers - var type, setStyle; - - function inText(stream, state) { - function chain(parser) { - state.tokenize = parser; - return parser(stream, state); - } - - var ch = stream.next(); - if (ch == "<") { - if (stream.eat("!")) { - if (stream.eat("[")) { - if (stream.match("CDATA[")) return chain(inBlock("atom", "]]>")); - else return null; - } else if (stream.match("--")) { - return chain(inBlock("comment", "-->")); - } else if (stream.match("DOCTYPE", true, true)) { - stream.eatWhile(/[\w\._\-]/); - return chain(doctype(1)); - } else { - return null; - } - } else if (stream.eat("?")) { - stream.eatWhile(/[\w\._\-]/); - state.tokenize = inBlock("meta", "?>"); - return "meta"; - } else { - type = stream.eat("/") ? "closeTag" : "openTag"; - state.tokenize = inTag; - return "tag bracket"; - } - } else if (ch == "&") { - var ok; - if (stream.eat("#")) { - if (stream.eat("x")) { - ok = stream.eatWhile(/[a-fA-F\d]/) && stream.eat(";"); - } else { - ok = stream.eatWhile(/[\d]/) && stream.eat(";"); - } - } else { - ok = stream.eatWhile(/[\w\.\-:]/) && stream.eat(";"); - } - return ok ? "atom" : "error"; - } else { - stream.eatWhile(/[^&<]/); - return null; - } - } - inText.isInText = true; - - function inTag(stream, state) { - var ch = stream.next(); - if (ch == ">" || (ch == "/" && stream.eat(">"))) { - state.tokenize = inText; - type = ch == ">" ? "endTag" : "selfcloseTag"; - return "tag bracket"; - } else if (ch == "=") { - type = "equals"; - return null; - } else if (ch == "<") { - state.tokenize = inText; - state.state = baseState; - state.tagName = state.tagStart = null; - var next = state.tokenize(stream, state); - return next ? next + " tag error" : "tag error"; - } else if (/[\'\"]/.test(ch)) { - state.tokenize = inAttribute(ch); - state.stringStartCol = stream.column(); - return state.tokenize(stream, state); - } else { - stream.match(/^[^\s\u00a0=<>\"\']*[^\s\u00a0=<>\"\'\/]/); - return "word"; - } - } - - function inAttribute(quote) { - var closure = function(stream, state) { - while (!stream.eol()) { - if (stream.next() == quote) { - state.tokenize = inTag; - break; - } - } - return "string"; - }; - closure.isInAttribute = true; - return closure; - } - - function inBlock(style, terminator) { - return function(stream, state) { - while (!stream.eol()) { - if (stream.match(terminator)) { - state.tokenize = inText; - break; - } - stream.next(); - } - return style; - }; - } - function doctype(depth) { - return function(stream, state) { - var ch; - while ((ch = stream.next()) != null) { - if (ch == "<") { - state.tokenize = doctype(depth + 1); - return state.tokenize(stream, state); - } else if (ch == ">") { - if (depth == 1) { - state.tokenize = inText; - break; - } else { - state.tokenize = doctype(depth - 1); - return state.tokenize(stream, state); - } - } - } - return "meta"; - }; - } - - function Context(state, tagName, startOfLine) { - this.prev = state.context; - this.tagName = tagName; - this.indent = state.indented; - this.startOfLine = startOfLine; - if (config.doNotIndent.hasOwnProperty(tagName) || (state.context && state.context.noIndent)) - this.noIndent = true; - } - function popContext(state) { - if (state.context) state.context = state.context.prev; - } - function maybePopContext(state, nextTagName) { - var parentTagName; - while (true) { - if (!state.context) { - return; - } - parentTagName = state.context.tagName; - if (!config.contextGrabbers.hasOwnProperty(parentTagName) || - !config.contextGrabbers[parentTagName].hasOwnProperty(nextTagName)) { - return; - } - popContext(state); - } - } - - function baseState(type, stream, state) { - if (type == "openTag") { - state.tagStart = stream.column(); - return tagNameState; - } else if (type == "closeTag") { - return closeTagNameState; - } else { - return baseState; - } - } - function tagNameState(type, stream, state) { - if (type == "word") { - state.tagName = stream.current(); - setStyle = "tag"; - return attrState; - } else { - setStyle = "error"; - return tagNameState; - } - } - function closeTagNameState(type, stream, state) { - if (type == "word") { - var tagName = stream.current(); - if (state.context && state.context.tagName != tagName && - config.implicitlyClosed.hasOwnProperty(state.context.tagName)) - popContext(state); - if ((state.context && state.context.tagName == tagName) || config.matchClosing === false) { - setStyle = "tag"; - return closeState; - } else { - setStyle = "tag error"; - return closeStateErr; - } - } else { - setStyle = "error"; - return closeStateErr; - } - } - - function closeState(type, _stream, state) { - if (type != "endTag") { - setStyle = "error"; - return closeState; - } - popContext(state); - return baseState; - } - function closeStateErr(type, stream, state) { - setStyle = "error"; - return closeState(type, stream, state); - } - - function attrState(type, _stream, state) { - if (type == "word") { - setStyle = "attribute"; - return attrEqState; - } else if (type == "endTag" || type == "selfcloseTag") { - var tagName = state.tagName, tagStart = state.tagStart; - state.tagName = state.tagStart = null; - if (type == "selfcloseTag" || - config.autoSelfClosers.hasOwnProperty(tagName)) { - maybePopContext(state, tagName); - } else { - maybePopContext(state, tagName); - state.context = new Context(state, tagName, tagStart == state.indented); - } - return baseState; - } - setStyle = "error"; - return attrState; - } - function attrEqState(type, stream, state) { - if (type == "equals") return attrValueState; - if (!config.allowMissing) setStyle = "error"; - return attrState(type, stream, state); - } - function attrValueState(type, stream, state) { - if (type == "string") return attrContinuedState; - if (type == "word" && config.allowUnquoted) {setStyle = "string"; return attrState;} - setStyle = "error"; - return attrState(type, stream, state); - } - function attrContinuedState(type, stream, state) { - if (type == "string") return attrContinuedState; - return attrState(type, stream, state); - } - - return { - startState: function(baseIndent) { - var state = {tokenize: inText, - state: baseState, - indented: baseIndent || 0, - tagName: null, tagStart: null, - context: null} - if (baseIndent != null) state.baseIndent = baseIndent - return state - }, - - token: function(stream, state) { - if (!state.tagName && stream.sol()) - state.indented = stream.indentation(); - - if (stream.eatSpace()) return null; - type = null; - var style = state.tokenize(stream, state); - if ((style || type) && style != "comment") { - setStyle = null; - state.state = state.state(type || style, stream, state); - if (setStyle) - style = setStyle == "error" ? style + " error" : setStyle; - } - return style; - }, - - indent: function(state, textAfter, fullLine) { - var context = state.context; - // Indent multi-line strings (e.g. css). - if (state.tokenize.isInAttribute) { - if (state.tagStart == state.indented) - return state.stringStartCol + 1; - else - return state.indented + indentUnit; - } - if (context && context.noIndent) return CodeMirror.Pass; - if (state.tokenize != inTag && state.tokenize != inText) - return fullLine ? fullLine.match(/^(\s*)/)[0].length : 0; - // Indent the starts of attribute names. - if (state.tagName) { - if (config.multilineTagIndentPastTag !== false) - return state.tagStart + state.tagName.length + 2; - else - return state.tagStart + indentUnit * (config.multilineTagIndentFactor || 1); - } - if (config.alignCDATA && /$/, - blockCommentStart: "", - - configuration: config.htmlMode ? "html" : "xml", - helperType: config.htmlMode ? "html" : "xml", - - skipAttribute: function(state) { - if (state.state == attrValueState) - state.state = attrState - } - }; -}); - -CodeMirror.defineMIME("text/xml", "xml"); -CodeMirror.defineMIME("application/xml", "xml"); -if (!CodeMirror.mimeModes.hasOwnProperty("text/html")) - CodeMirror.defineMIME("text/html", {name: "xml", htmlMode: true}); - -}); - - -/***/ }), -/* 106 */ -/***/ (function(module, exports, __webpack_require__) { - -// CodeMirror, copyright (c) by Marijn Haverbeke and others -// Distributed under an MIT license: http://codemirror.net/LICENSE - -(function(mod) { - if (true) // CommonJS - mod(__webpack_require__(6)); - else if (typeof define == "function" && define.amd) // AMD - define(["../../lib/codemirror"], mod); - else // Plain browser env - mod(CodeMirror); -})(function(CodeMirror) { -"use strict"; - -CodeMirror.defineMode("javascript", function(config, parserConfig) { - var indentUnit = config.indentUnit; - var statementIndent = parserConfig.statementIndent; - var jsonldMode = parserConfig.jsonld; - var jsonMode = parserConfig.json || jsonldMode; - var isTS = parserConfig.typescript; - var wordRE = parserConfig.wordCharacters || /[\w$\xa1-\uffff]/; - - // Tokenizer - - var keywords = function(){ - function kw(type) {return {type: type, style: "keyword"};} - var A = kw("keyword a"), B = kw("keyword b"), C = kw("keyword c"), D = kw("keyword d"); - var operator = kw("operator"), atom = {type: "atom", style: "atom"}; - - var jsKeywords = { - "if": kw("if"), "while": A, "with": A, "else": B, "do": B, "try": B, "finally": B, - "return": D, "break": D, "continue": D, "new": kw("new"), "delete": C, "void": C, "throw": C, - "debugger": kw("debugger"), "var": kw("var"), "const": kw("var"), "let": kw("var"), - "function": kw("function"), "catch": kw("catch"), - "for": kw("for"), "switch": kw("switch"), "case": kw("case"), "default": kw("default"), - "in": operator, "typeof": operator, "instanceof": operator, - "true": atom, "false": atom, "null": atom, "undefined": atom, "NaN": atom, "Infinity": atom, - "this": kw("this"), "class": kw("class"), "super": kw("atom"), - "yield": C, "export": kw("export"), "import": kw("import"), "extends": C, - "await": C - }; - - // Extend the 'normal' keywords with the TypeScript language extensions - if (isTS) { - var type = {type: "variable", style: "type"}; - var tsKeywords = { - // object-like things - "interface": kw("class"), - "implements": C, - "namespace": C, - "module": kw("module"), - "enum": kw("module"), - - // scope modifiers - "public": kw("modifier"), - "private": kw("modifier"), - "protected": kw("modifier"), - "abstract": kw("modifier"), - "readonly": kw("modifier"), - - // types - "string": type, "number": type, "boolean": type, "any": type - }; - - for (var attr in tsKeywords) { - jsKeywords[attr] = tsKeywords[attr]; - } - } - - return jsKeywords; - }(); - - var isOperatorChar = /[+\-*&%=<>!?|~^@]/; - var isJsonldKeyword = /^@(context|id|value|language|type|container|list|set|reverse|index|base|vocab|graph)"/; - - function readRegexp(stream) { - var escaped = false, next, inSet = false; - while ((next = stream.next()) != null) { - if (!escaped) { - if (next == "/" && !inSet) return; - if (next == "[") inSet = true; - else if (inSet && next == "]") inSet = false; - } - escaped = !escaped && next == "\\"; - } - } - - // Used as scratch variables to communicate multiple values without - // consing up tons of objects. - var type, content; - function ret(tp, style, cont) { - type = tp; content = cont; - return style; - } - function tokenBase(stream, state) { - var ch = stream.next(); - if (ch == '"' || ch == "'") { - state.tokenize = tokenString(ch); - return state.tokenize(stream, state); - } else if (ch == "." && stream.match(/^\d+(?:[eE][+\-]?\d+)?/)) { - return ret("number", "number"); - } else if (ch == "." && stream.match("..")) { - return ret("spread", "meta"); - } else if (/[\[\]{}\(\),;\:\.]/.test(ch)) { - return ret(ch); - } else if (ch == "=" && stream.eat(">")) { - return ret("=>", "operator"); - } else if (ch == "0" && stream.eat(/x/i)) { - stream.eatWhile(/[\da-f]/i); - return ret("number", "number"); - } else if (ch == "0" && stream.eat(/o/i)) { - stream.eatWhile(/[0-7]/i); - return ret("number", "number"); - } else if (ch == "0" && stream.eat(/b/i)) { - stream.eatWhile(/[01]/i); - return ret("number", "number"); - } else if (/\d/.test(ch)) { - stream.match(/^\d*(?:\.\d*)?(?:[eE][+\-]?\d+)?/); - return ret("number", "number"); - } else if (ch == "/") { - if (stream.eat("*")) { - state.tokenize = tokenComment; - return tokenComment(stream, state); - } else if (stream.eat("/")) { - stream.skipToEnd(); - return ret("comment", "comment"); - } else if (expressionAllowed(stream, state, 1)) { - readRegexp(stream); - stream.match(/^\b(([gimyu])(?![gimyu]*\2))+\b/); - return ret("regexp", "string-2"); - } else { - stream.eat("="); - return ret("operator", "operator", stream.current()); - } - } else if (ch == "`") { - state.tokenize = tokenQuasi; - return tokenQuasi(stream, state); - } else if (ch == "#") { - stream.skipToEnd(); - return ret("error", "error"); - } else if (isOperatorChar.test(ch)) { - if (ch != ">" || !state.lexical || state.lexical.type != ">") { - if (stream.eat("=")) { - if (ch == "!" || ch == "=") stream.eat("=") - } else if (/[<>*+\-]/.test(ch)) { - stream.eat(ch) - if (ch == ">") stream.eat(ch) - } - } - return ret("operator", "operator", stream.current()); - } else if (wordRE.test(ch)) { - stream.eatWhile(wordRE); - var word = stream.current() - if (state.lastType != ".") { - if (keywords.propertyIsEnumerable(word)) { - var kw = keywords[word] - return ret(kw.type, kw.style, word) - } - if (word == "async" && stream.match(/^\s*[\(\w]/, false)) - return ret("async", "keyword", word) - } - return ret("variable", "variable", word) - } - } - - function tokenString(quote) { - return function(stream, state) { - var escaped = false, next; - if (jsonldMode && stream.peek() == "@" && stream.match(isJsonldKeyword)){ - state.tokenize = tokenBase; - return ret("jsonld-keyword", "meta"); - } - while ((next = stream.next()) != null) { - if (next == quote && !escaped) break; - escaped = !escaped && next == "\\"; - } - if (!escaped) state.tokenize = tokenBase; - return ret("string", "string"); - }; - } - - function tokenComment(stream, state) { - var maybeEnd = false, ch; - while (ch = stream.next()) { - if (ch == "/" && maybeEnd) { - state.tokenize = tokenBase; - break; - } - maybeEnd = (ch == "*"); - } - return ret("comment", "comment"); - } - - function tokenQuasi(stream, state) { - var escaped = false, next; - while ((next = stream.next()) != null) { - if (!escaped && (next == "`" || next == "$" && stream.eat("{"))) { - state.tokenize = tokenBase; - break; - } - escaped = !escaped && next == "\\"; - } - return ret("quasi", "string-2", stream.current()); - } - - var brackets = "([{}])"; - // This is a crude lookahead trick to try and notice that we're - // parsing the argument patterns for a fat-arrow function before we - // actually hit the arrow token. It only works if the arrow is on - // the same line as the arguments and there's no strange noise - // (comments) in between. Fallback is to only notice when we hit the - // arrow, and not declare the arguments as locals for the arrow - // body. - function findFatArrow(stream, state) { - if (state.fatArrowAt) state.fatArrowAt = null; - var arrow = stream.string.indexOf("=>", stream.start); - if (arrow < 0) return; - - if (isTS) { // Try to skip TypeScript return type declarations after the arguments - var m = /:\s*(?:\w+(?:<[^>]*>|\[\])?|\{[^}]*\})\s*$/.exec(stream.string.slice(stream.start, arrow)) - if (m) arrow = m.index - } - - var depth = 0, sawSomething = false; - for (var pos = arrow - 1; pos >= 0; --pos) { - var ch = stream.string.charAt(pos); - var bracket = brackets.indexOf(ch); - if (bracket >= 0 && bracket < 3) { - if (!depth) { ++pos; break; } - if (--depth == 0) { if (ch == "(") sawSomething = true; break; } - } else if (bracket >= 3 && bracket < 6) { - ++depth; - } else if (wordRE.test(ch)) { - sawSomething = true; - } else if (/["'\/]/.test(ch)) { - return; - } else if (sawSomething && !depth) { - ++pos; - break; - } - } - if (sawSomething && !depth) state.fatArrowAt = pos; - } - - // Parser - - var atomicTypes = {"atom": true, "number": true, "variable": true, "string": true, "regexp": true, "this": true, "jsonld-keyword": true}; - - function JSLexical(indented, column, type, align, prev, info) { - this.indented = indented; - this.column = column; - this.type = type; - this.prev = prev; - this.info = info; - if (align != null) this.align = align; - } - - function inScope(state, varname) { - for (var v = state.localVars; v; v = v.next) - if (v.name == varname) return true; - for (var cx = state.context; cx; cx = cx.prev) { - for (var v = cx.vars; v; v = v.next) - if (v.name == varname) return true; - } - } - - function parseJS(state, style, type, content, stream) { - var cc = state.cc; - // Communicate our context to the combinators. - // (Less wasteful than consing up a hundred closures on every call.) - cx.state = state; cx.stream = stream; cx.marked = null, cx.cc = cc; cx.style = style; - - if (!state.lexical.hasOwnProperty("align")) - state.lexical.align = true; - - while(true) { - var combinator = cc.length ? cc.pop() : jsonMode ? expression : statement; - if (combinator(type, content)) { - while(cc.length && cc[cc.length - 1].lex) - cc.pop()(); - if (cx.marked) return cx.marked; - if (type == "variable" && inScope(state, content)) return "variable-2"; - return style; - } - } - } - - // Combinator utils - - var cx = {state: null, column: null, marked: null, cc: null}; - function pass() { - for (var i = arguments.length - 1; i >= 0; i--) cx.cc.push(arguments[i]); - } - function cont() { - pass.apply(null, arguments); - return true; - } - function register(varname) { - function inList(list) { - for (var v = list; v; v = v.next) - if (v.name == varname) return true; - return false; - } - var state = cx.state; - cx.marked = "def"; - if (state.context) { - if (inList(state.localVars)) return; - state.localVars = {name: varname, next: state.localVars}; - } else { - if (inList(state.globalVars)) return; - if (parserConfig.globalVars) - state.globalVars = {name: varname, next: state.globalVars}; - } - } - - // Combinators - - var defaultVars = {name: "this", next: {name: "arguments"}}; - function pushcontext() { - cx.state.context = {prev: cx.state.context, vars: cx.state.localVars}; - cx.state.localVars = defaultVars; - } - function popcontext() { - cx.state.localVars = cx.state.context.vars; - cx.state.context = cx.state.context.prev; - } - function pushlex(type, info) { - var result = function() { - var state = cx.state, indent = state.indented; - if (state.lexical.type == "stat") indent = state.lexical.indented; - else for (var outer = state.lexical; outer && outer.type == ")" && outer.align; outer = outer.prev) - indent = outer.indented; - state.lexical = new JSLexical(indent, cx.stream.column(), type, null, state.lexical, info); - }; - result.lex = true; - return result; - } - function poplex() { - var state = cx.state; - if (state.lexical.prev) { - if (state.lexical.type == ")") - state.indented = state.lexical.indented; - state.lexical = state.lexical.prev; - } - } - poplex.lex = true; - - function expect(wanted) { - function exp(type) { - if (type == wanted) return cont(); - else if (wanted == ";") return pass(); - else return cont(exp); - }; - return exp; - } - - function statement(type, value) { - if (type == "var") return cont(pushlex("vardef", value.length), vardef, expect(";"), poplex); - if (type == "keyword a") return cont(pushlex("form"), parenExpr, statement, poplex); - if (type == "keyword b") return cont(pushlex("form"), statement, poplex); - if (type == "keyword d") return cx.stream.match(/^\s*$/, false) ? cont() : cont(pushlex("stat"), maybeexpression, expect(";"), poplex); - if (type == "debugger") return cont(expect(";")); - if (type == "{") return cont(pushlex("}"), block, poplex); - if (type == ";") return cont(); - if (type == "if") { - if (cx.state.lexical.info == "else" && cx.state.cc[cx.state.cc.length - 1] == poplex) - cx.state.cc.pop()(); - return cont(pushlex("form"), parenExpr, statement, poplex, maybeelse); - } - if (type == "function") return cont(functiondef); - if (type == "for") return cont(pushlex("form"), forspec, statement, poplex); - if (type == "variable") { - if (isTS && value == "type") { - cx.marked = "keyword" - return cont(typeexpr, expect("operator"), typeexpr, expect(";")); - } if (isTS && value == "declare") { - cx.marked = "keyword" - return cont(statement) - } else { - return cont(pushlex("stat"), maybelabel); - } - } - if (type == "switch") return cont(pushlex("form"), parenExpr, expect("{"), pushlex("}", "switch"), - block, poplex, poplex); - if (type == "case") return cont(expression, expect(":")); - if (type == "default") return cont(expect(":")); - if (type == "catch") return cont(pushlex("form"), pushcontext, expect("("), funarg, expect(")"), - statement, poplex, popcontext); - if (type == "class") return cont(pushlex("form"), className, poplex); - if (type == "export") return cont(pushlex("stat"), afterExport, poplex); - if (type == "import") return cont(pushlex("stat"), afterImport, poplex); - if (type == "module") return cont(pushlex("form"), pattern, expect("{"), pushlex("}"), block, poplex, poplex) - if (type == "async") return cont(statement) - if (value == "@") return cont(expression, statement) - return pass(pushlex("stat"), expression, expect(";"), poplex); - } - function expression(type) { - return expressionInner(type, false); - } - function expressionNoComma(type) { - return expressionInner(type, true); - } - function parenExpr(type) { - if (type != "(") return pass() - return cont(pushlex(")"), expression, expect(")"), poplex) - } - function expressionInner(type, noComma) { - if (cx.state.fatArrowAt == cx.stream.start) { - var body = noComma ? arrowBodyNoComma : arrowBody; - if (type == "(") return cont(pushcontext, pushlex(")"), commasep(funarg, ")"), poplex, expect("=>"), body, popcontext); - else if (type == "variable") return pass(pushcontext, pattern, expect("=>"), body, popcontext); - } - - var maybeop = noComma ? maybeoperatorNoComma : maybeoperatorComma; - if (atomicTypes.hasOwnProperty(type)) return cont(maybeop); - if (type == "function") return cont(functiondef, maybeop); - if (type == "class") return cont(pushlex("form"), classExpression, poplex); - if (type == "keyword c" || type == "async") return cont(noComma ? expressionNoComma : expression); - if (type == "(") return cont(pushlex(")"), maybeexpression, expect(")"), poplex, maybeop); - if (type == "operator" || type == "spread") return cont(noComma ? expressionNoComma : expression); - if (type == "[") return cont(pushlex("]"), arrayLiteral, poplex, maybeop); - if (type == "{") return contCommasep(objprop, "}", null, maybeop); - if (type == "quasi") return pass(quasi, maybeop); - if (type == "new") return cont(maybeTarget(noComma)); - return cont(); - } - function maybeexpression(type) { - if (type.match(/[;\}\)\],]/)) return pass(); - return pass(expression); - } - - function maybeoperatorComma(type, value) { - if (type == ",") return cont(expression); - return maybeoperatorNoComma(type, value, false); - } - function maybeoperatorNoComma(type, value, noComma) { - var me = noComma == false ? maybeoperatorComma : maybeoperatorNoComma; - var expr = noComma == false ? expression : expressionNoComma; - if (type == "=>") return cont(pushcontext, noComma ? arrowBodyNoComma : arrowBody, popcontext); - if (type == "operator") { - if (/\+\+|--/.test(value) || isTS && value == "!") return cont(me); - if (value == "?") return cont(expression, expect(":"), expr); - return cont(expr); - } - if (type == "quasi") { return pass(quasi, me); } - if (type == ";") return; - if (type == "(") return contCommasep(expressionNoComma, ")", "call", me); - if (type == ".") return cont(property, me); - if (type == "[") return cont(pushlex("]"), maybeexpression, expect("]"), poplex, me); - if (isTS && value == "as") { cx.marked = "keyword"; return cont(typeexpr, me) } - if (type == "regexp") { - cx.state.lastType = cx.marked = "operator" - cx.stream.backUp(cx.stream.pos - cx.stream.start - 1) - return cont(expr) - } - } - function quasi(type, value) { - if (type != "quasi") return pass(); - if (value.slice(value.length - 2) != "${") return cont(quasi); - return cont(expression, continueQuasi); - } - function continueQuasi(type) { - if (type == "}") { - cx.marked = "string-2"; - cx.state.tokenize = tokenQuasi; - return cont(quasi); - } - } - function arrowBody(type) { - findFatArrow(cx.stream, cx.state); - return pass(type == "{" ? statement : expression); - } - function arrowBodyNoComma(type) { - findFatArrow(cx.stream, cx.state); - return pass(type == "{" ? statement : expressionNoComma); - } - function maybeTarget(noComma) { - return function(type) { - if (type == ".") return cont(noComma ? targetNoComma : target); - else if (type == "variable" && isTS) return cont(maybeTypeArgs, noComma ? maybeoperatorNoComma : maybeoperatorComma) - else return pass(noComma ? expressionNoComma : expression); - }; - } - function target(_, value) { - if (value == "target") { cx.marked = "keyword"; return cont(maybeoperatorComma); } - } - function targetNoComma(_, value) { - if (value == "target") { cx.marked = "keyword"; return cont(maybeoperatorNoComma); } - } - function maybelabel(type) { - if (type == ":") return cont(poplex, statement); - return pass(maybeoperatorComma, expect(";"), poplex); - } - function property(type) { - if (type == "variable") {cx.marked = "property"; return cont();} - } - function objprop(type, value) { - if (type == "async") { - cx.marked = "property"; - return cont(objprop); - } else if (type == "variable" || cx.style == "keyword") { - cx.marked = "property"; - if (value == "get" || value == "set") return cont(getterSetter); - var m // Work around fat-arrow-detection complication for detecting typescript typed arrow params - if (isTS && cx.state.fatArrowAt == cx.stream.start && (m = cx.stream.match(/^\s*:\s*/, false))) - cx.state.fatArrowAt = cx.stream.pos + m[0].length - return cont(afterprop); - } else if (type == "number" || type == "string") { - cx.marked = jsonldMode ? "property" : (cx.style + " property"); - return cont(afterprop); - } else if (type == "jsonld-keyword") { - return cont(afterprop); - } else if (type == "modifier") { - return cont(objprop) - } else if (type == "[") { - return cont(expression, expect("]"), afterprop); - } else if (type == "spread") { - return cont(expressionNoComma, afterprop); - } else if (value == "*") { - cx.marked = "keyword"; - return cont(objprop); - } else if (type == ":") { - return pass(afterprop) - } - } - function getterSetter(type) { - if (type != "variable") return pass(afterprop); - cx.marked = "property"; - return cont(functiondef); - } - function afterprop(type) { - if (type == ":") return cont(expressionNoComma); - if (type == "(") return pass(functiondef); - } - function commasep(what, end, sep) { - function proceed(type, value) { - if (sep ? sep.indexOf(type) > -1 : type == ",") { - var lex = cx.state.lexical; - if (lex.info == "call") lex.pos = (lex.pos || 0) + 1; - return cont(function(type, value) { - if (type == end || value == end) return pass() - return pass(what) - }, proceed); - } - if (type == end || value == end) return cont(); - return cont(expect(end)); - } - return function(type, value) { - if (type == end || value == end) return cont(); - return pass(what, proceed); - }; - } - function contCommasep(what, end, info) { - for (var i = 3; i < arguments.length; i++) - cx.cc.push(arguments[i]); - return cont(pushlex(end, info), commasep(what, end), poplex); - } - function block(type) { - if (type == "}") return cont(); - return pass(statement, block); - } - function maybetype(type, value) { - if (isTS) { - if (type == ":") return cont(typeexpr); - if (value == "?") return cont(maybetype); - } - } - function typeexpr(type, value) { - if (type == "variable" || value == "void") { - if (value == "keyof") { - cx.marked = "keyword" - return cont(typeexpr) - } else { - cx.marked = "type" - return cont(afterType) - } - } - if (type == "string" || type == "number" || type == "atom") return cont(afterType); - if (type == "[") return cont(pushlex("]"), commasep(typeexpr, "]", ","), poplex, afterType) - if (type == "{") return cont(pushlex("}"), commasep(typeprop, "}", ",;"), poplex, afterType) - if (type == "(") return cont(commasep(typearg, ")"), maybeReturnType) - } - function maybeReturnType(type) { - if (type == "=>") return cont(typeexpr) - } - function typeprop(type, value) { - if (type == "variable" || cx.style == "keyword") { - cx.marked = "property" - return cont(typeprop) - } else if (value == "?") { - return cont(typeprop) - } else if (type == ":") { - return cont(typeexpr) - } else if (type == "[") { - return cont(expression, maybetype, expect("]"), typeprop) - } - } - function typearg(type) { - if (type == "variable") return cont(typearg) - else if (type == ":") return cont(typeexpr) - } - function afterType(type, value) { - if (value == "<") return cont(pushlex(">"), commasep(typeexpr, ">"), poplex, afterType) - if (value == "|" || type == ".") return cont(typeexpr) - if (type == "[") return cont(expect("]"), afterType) - if (value == "extends") return cont(typeexpr) - } - function maybeTypeArgs(_, value) { - if (value == "<") return cont(pushlex(">"), commasep(typeexpr, ">"), poplex, afterType) - } - function vardef() { - return pass(pattern, maybetype, maybeAssign, vardefCont); - } - function pattern(type, value) { - if (type == "modifier") return cont(pattern) - if (type == "variable") { register(value); return cont(); } - if (type == "spread") return cont(pattern); - if (type == "[") return contCommasep(pattern, "]"); - if (type == "{") return contCommasep(proppattern, "}"); - } - function proppattern(type, value) { - if (type == "variable" && !cx.stream.match(/^\s*:/, false)) { - register(value); - return cont(maybeAssign); - } - if (type == "variable") cx.marked = "property"; - if (type == "spread") return cont(pattern); - if (type == "}") return pass(); - return cont(expect(":"), pattern, maybeAssign); - } - function maybeAssign(_type, value) { - if (value == "=") return cont(expressionNoComma); - } - function vardefCont(type) { - if (type == ",") return cont(vardef); - } - function maybeelse(type, value) { - if (type == "keyword b" && value == "else") return cont(pushlex("form", "else"), statement, poplex); - } - function forspec(type) { - if (type == "(") return cont(pushlex(")"), forspec1, expect(")"), poplex); - } - function forspec1(type) { - if (type == "var") return cont(vardef, expect(";"), forspec2); - if (type == ";") return cont(forspec2); - if (type == "variable") return cont(formaybeinof); - return pass(expression, expect(";"), forspec2); - } - function formaybeinof(_type, value) { - if (value == "in" || value == "of") { cx.marked = "keyword"; return cont(expression); } - return cont(maybeoperatorComma, forspec2); - } - function forspec2(type, value) { - if (type == ";") return cont(forspec3); - if (value == "in" || value == "of") { cx.marked = "keyword"; return cont(expression); } - return pass(expression, expect(";"), forspec3); - } - function forspec3(type) { - if (type != ")") cont(expression); - } - function functiondef(type, value) { - if (value == "*") {cx.marked = "keyword"; return cont(functiondef);} - if (type == "variable") {register(value); return cont(functiondef);} - if (type == "(") return cont(pushcontext, pushlex(")"), commasep(funarg, ")"), poplex, maybetype, statement, popcontext); - if (isTS && value == "<") return cont(pushlex(">"), commasep(typeexpr, ">"), poplex, functiondef) - } - function funarg(type, value) { - if (value == "@") cont(expression, funarg) - if (type == "spread" || type == "modifier") return cont(funarg); - return pass(pattern, maybetype, maybeAssign); - } - function classExpression(type, value) { - // Class expressions may have an optional name. - if (type == "variable") return className(type, value); - return classNameAfter(type, value); - } - function className(type, value) { - if (type == "variable") {register(value); return cont(classNameAfter);} - } - function classNameAfter(type, value) { - if (value == "<") return cont(pushlex(">"), commasep(typeexpr, ">"), poplex, classNameAfter) - if (value == "extends" || value == "implements" || (isTS && type == ",")) - return cont(isTS ? typeexpr : expression, classNameAfter); - if (type == "{") return cont(pushlex("}"), classBody, poplex); - } - function classBody(type, value) { - if (type == "modifier" || type == "async" || - (type == "variable" && - (value == "static" || value == "get" || value == "set") && - cx.stream.match(/^\s+[\w$\xa1-\uffff]/, false))) { - cx.marked = "keyword"; - return cont(classBody); - } - if (type == "variable" || cx.style == "keyword") { - cx.marked = "property"; - return cont(isTS ? classfield : functiondef, classBody); + * Returns cached load + * @param {Boolean} force Force to reload + * @param {Function} clb Callback function + * @return {Object} + * @private + */ + getCacheLoad: function getCacheLoad(force, clb) { + var _this10 = this; + + var f = force ? 1 : 0; + if (this.cacheLoad && !f) return this.cacheLoad; + var sm = this.get('StorageManager'); + var load = []; + if (!sm) return {}; + this.get('storables').forEach(function (m) { + var key = m.storageKey; + key = typeof key === 'function' ? key() : key; + var keys = key instanceof Array ? key : [key]; + keys.forEach(function (k) { + load.push(k); + }); + }); + sm.load(load, function (res) { + _this10.cacheLoad = res; + clb && clb(res); + setTimeout(function () { + return _this10.trigger('storage:load', res); + }, 0); + }); + }, + + /** + * Returns device model by name + * @return {Device|null} + * @private + */ + getDeviceModel: function getDeviceModel() { + var name = this.get('device'); + return this.get('DeviceManager').get(name); + }, + + /** + * Run default command if setted + * @param {Object} [opts={}] Options + * @private + */ + runDefault: function runDefault() { + var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var command = this.get('Commands').get(this.config.defaultCommand); + if (!command || this.defaultRunning) return; + command.stop(this, this, opts); + command.run(this, this, opts); + this.defaultRunning = 1; + }, + + /** + * Stop default command + * @param {Object} [opts={}] Options + * @private + */ + stopDefault: function stopDefault() { + var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var command = this.get('Commands').get(this.config.defaultCommand); + if (!command) return; + command.stop(this, this, opts); + this.defaultRunning = 0; + }, + + /** + * Update canvas dimensions and refresh data useful for tools positioning + * @private + */ + refreshCanvas: function refreshCanvas() { + this.set('canvasOffset', null); + this.set('canvasOffset', this.get('Canvas').getOffset()); + }, + + /** + * Clear all selected stuf inside the window, sometimes is useful to call before + * doing some dragging opearation + * @param {Window} win If not passed the current one will be used + * @private + */ + clearSelection: function clearSelection(win) { + var w = win || window; + w.getSelection().removeAllRanges(); + }, + + /** + * Get the current media text + * @return {string} + */ + getCurrentMedia: function getCurrentMedia() { + var config = this.config; + var device = this.getDeviceModel(); + var condition = config.mediaCondition; + var preview = config.devicePreviewMode; + var width = device && device.get('widthMedia'); + return device && width && !preview ? "(".concat(condition, ": ").concat(width, ")") : ''; + }, + + /** + * Return the component wrapper + * @return {Component} + */ + getWrapper: function getWrapper() { + return this.get('DomComponents').getWrapper(); + }, + + /** + * Return the count of changes made to the content and not yet stored. + * This count resets at any `store()` + * @return {number} + */ + getDirtyCount: function getDirtyCount() { + return this.get('changesCount'); + }, + getZoomDecimal: function getZoomDecimal() { + return this.get('Canvas').getZoomDecimal(); + }, + setDragMode: function setDragMode(value) { + return this.set('dmode', value); + }, + + /** + * Returns true if the editor is in absolute mode + * @returns {Boolean} + */ + inAbsoluteMode: function inAbsoluteMode() { + return this.get('dmode') === 'absolute'; + }, + + /** + * Destroy editor + */ + destroyAll: function destroyAll() { + var _this$attributes = this.attributes, + DomComponents = _this$attributes.DomComponents, + CssComposer = _this$attributes.CssComposer, + UndoManager = _this$attributes.UndoManager, + Panels = _this$attributes.Panels, + Canvas = _this$attributes.Canvas, + Keymaps = _this$attributes.Keymaps; + DomComponents.clear(); + CssComposer.clear(); + UndoManager.clear().removeAll(); + Panels.getPanels().reset(); + Canvas.getCanvasView().remove(); + Keymaps.removeAll(); + this.view.remove(); + this.stopListening(); + $(this.config.el).empty().attr(this.attrsOrig); + }, + setEditing: function setEditing(value) { + this.set('editing', value); + return this; + }, + isEditing: function isEditing() { + return !!this.get('editing'); + }, + log: function log(msg) { + var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + var ns = opts.ns, + _opts$level = opts.level, + level = _opts$level === void 0 ? 'debug' : _opts$level; + this.trigger('log', msg, opts); + level && this.trigger("log:".concat(level), msg, opts); + + if (ns) { + var logNs = "log-".concat(ns); + this.trigger(logNs, msg, opts); + level && this.trigger("".concat(logNs, ":").concat(level), msg, opts); } - if (type == "[") - return cont(expression, expect("]"), isTS ? classfield : functiondef, classBody) - if (value == "*") { - cx.marked = "keyword"; - return cont(classBody); + }, + logInfo: function logInfo(msg, opts) { + this.log(msg, _objectSpread({}, opts, { + level: 'info' + })); + }, + logWarning: function logWarning(msg, opts) { + this.log(msg, _objectSpread({}, opts, { + level: 'warning' + })); + }, + logError: function logError(msg, opts) { + this.log(msg, _objectSpread({}, opts, { + level: 'error' + })); + }, + + /** + * Set/get data from the HTMLElement + * @param {HTMLElement} el + * @param {string} name Data name + * @param {any} value Date value + * @return {any} + * @private + */ + data: function data(el, name, value) { + var varName = '_gjs-data'; + + if (!el[varName]) { + el[varName] = {}; } - if (type == ";") return cont(classBody); - if (type == "}") return cont(); - if (value == "@") return cont(expression, classBody) - } - function classfield(type, value) { - if (value == "?") return cont(classfield) - if (type == ":") return cont(typeexpr, maybeAssign) - if (value == "=") return cont(expressionNoComma) - return pass(functiondef) - } - function afterExport(type, value) { - if (value == "*") { cx.marked = "keyword"; return cont(maybeFrom, expect(";")); } - if (value == "default") { cx.marked = "keyword"; return cont(expression, expect(";")); } - if (type == "{") return cont(commasep(exportField, "}"), maybeFrom, expect(";")); - return pass(statement); - } - function exportField(type, value) { - if (value == "as") { cx.marked = "keyword"; return cont(expect("variable")); } - if (type == "variable") return pass(expressionNoComma, exportField); - } - function afterImport(type) { - if (type == "string") return cont(); - return pass(importSpec, maybeMoreImports, maybeFrom); - } - function importSpec(type, value) { - if (type == "{") return contCommasep(importSpec, "}"); - if (type == "variable") register(value); - if (value == "*") cx.marked = "keyword"; - return cont(maybeAs); - } - function maybeMoreImports(type) { - if (type == ",") return cont(importSpec, maybeMoreImports) - } - function maybeAs(_type, value) { - if (value == "as") { cx.marked = "keyword"; return cont(importSpec); } - } - function maybeFrom(_type, value) { - if (value == "from") { cx.marked = "keyword"; return cont(expression); } - } - function arrayLiteral(type) { - if (type == "]") return cont(); - return pass(commasep(expressionNoComma, "]")); - } - function isContinuedStatement(state, textAfter) { - return state.lastType == "operator" || state.lastType == "," || - isOperatorChar.test(textAfter.charAt(0)) || - /[,.]/.test(textAfter.charAt(0)); + if (Object(underscore__WEBPACK_IMPORTED_MODULE_1__["isUndefined"])(value)) { + return el[varName][name]; + } else { + el[varName][name] = value; + } } +})); - function expressionAllowed(stream, state, backUp) { - return state.tokenize == tokenBase && - /^(?:operator|sof|keyword [bcd]|case|new|export|default|spread|[\[{}\(,;:]|=>)$/.test(state.lastType) || - (state.lastType == "quasi" && /\{\s*$/.test(stream.string.slice(0, stream.pos - (backUp || 0)))) - } +/***/ }), - // Interface +/***/ "./src/editor/view/EditorView.js": +/*!***************************************!*\ + !*** ./src/editor/view/EditorView.js ***! + \***************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - return { - startState: function(basecolumn) { - var state = { - tokenize: tokenBase, - lastType: "sof", - cc: [], - lexical: new JSLexical((basecolumn || 0) - indentUnit, 0, "block", false), - localVars: parserConfig.localVars, - context: parserConfig.localVars && {vars: parserConfig.localVars}, - indented: basecolumn || 0 - }; - if (parserConfig.globalVars && typeof parserConfig.globalVars == "object") - state.globalVars = parserConfig.globalVars; - return state; - }, +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); - token: function(stream, state) { - if (stream.sol()) { - if (!state.lexical.hasOwnProperty("align")) - state.lexical.align = false; - state.indented = stream.indentation(); - findFatArrow(stream, state); - } - if (state.tokenize != tokenComment && stream.eatSpace()) return null; - var style = state.tokenize(stream, state); - if (type == "comment") return style; - state.lastType = type == "operator" && (content == "++" || content == "--") ? "incdec" : type; - return parseJS(state, style, type, content, stream); - }, +var $ = backbone__WEBPACK_IMPORTED_MODULE_0___default.a.$; +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_0___default.a.View.extend({ + initialize: function initialize() { + var _this = this; - indent: function(state, textAfter) { - if (state.tokenize == tokenComment) return CodeMirror.Pass; - if (state.tokenize != tokenBase) return 0; - var firstChar = textAfter && textAfter.charAt(0), lexical = state.lexical, top - // Kludge to prevent 'maybelse' from blocking lexical scope pops - if (!/^\s*else\b/.test(textAfter)) for (var i = state.cc.length - 1; i >= 0; --i) { - var c = state.cc[i]; - if (c == poplex) lexical = lexical.prev; - else if (c != maybeelse) break; - } - while ((lexical.type == "stat" || lexical.type == "form") && - (firstChar == "}" || ((top = state.cc[state.cc.length - 1]) && - (top == maybeoperatorComma || top == maybeoperatorNoComma) && - !/^[,\.=+\-*:?[\(]/.test(textAfter)))) - lexical = lexical.prev; - if (statementIndent && lexical.type == ")" && lexical.prev.type == "stat") - lexical = lexical.prev; - var type = lexical.type, closing = firstChar == type; + var model = this.model; + model.view = this; + this.conf = model.config; + this.pn = model.get('Panels'); + model.on('loaded', function () { + _this.pn.active(); - if (type == "vardef") return lexical.indented + (state.lastType == "operator" || state.lastType == "," ? lexical.info + 1 : 0); - else if (type == "form" && firstChar == "{") return lexical.indented; - else if (type == "form") return lexical.indented + indentUnit; - else if (type == "stat") - return lexical.indented + (isContinuedStatement(state, textAfter) ? statementIndent || indentUnit : 0); - else if (lexical.info == "switch" && !closing && parserConfig.doubleIndentSwitch != false) - return lexical.indented + (/^(?:case|default)\b/.test(textAfter) ? indentUnit : 2 * indentUnit); - else if (lexical.align) return lexical.column + (closing ? 0 : 1); - else return lexical.indented + (closing ? 0 : indentUnit); - }, + _this.pn.disableButtons(); - electricInput: /^\s*(?:case .*?:|default:|\{|\})$/, - blockCommentStart: jsonMode ? null : "/*", - blockCommentEnd: jsonMode ? null : "*/", - blockCommentContinue: jsonMode ? null : " * ", - lineComment: jsonMode ? null : "//", - fold: "brace", - closeBrackets: "()[]{}''\"\"``", + model.runDefault(); + setTimeout(function () { + return model.trigger('load', model.get('Editor')); + }); + }); + }, + render: function render() { + var model = this.model; + var el = this.$el; + var conf = this.conf; + var contEl = $(conf.el || "body ".concat(conf.container)); + var pfx = conf.stylePrefix; + el.empty(); + if (conf.width) contEl.css('width', conf.width); + if (conf.height) contEl.css('height', conf.height); + el.append(model.get('Canvas').render()); + el.append(this.pn.render()); + el.attr('class', "".concat(pfx, "editor ").concat(pfx, "one-bg ").concat(pfx, "two-color")); + contEl.addClass("".concat(pfx, "editor-cont")).empty().append(el); + return this; + } +})); - helperType: jsonMode ? "json" : "javascript", - jsonldMode: jsonldMode, - jsonMode: jsonMode, +/***/ }), - expressionAllowed: expressionAllowed, +/***/ "./src/index.js": +/*!**********************!*\ + !*** ./src/index.js ***! + \**********************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - skipExpression: function(state) { - var top = state.cc[state.cc.length - 1] - if (top == expression || top == expressionNoComma) state.cc.pop() - } - }; -}); +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var cash_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! cash-dom */ "./node_modules/cash-dom/dist/cash.js"); +/* harmony import */ var cash_dom__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(cash_dom__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var _editor__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./editor */ "./src/editor/index.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_3__); +/* harmony import */ var utils_polyfills__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! utils/polyfills */ "./src/utils/polyfills.js"); +/* harmony import */ var _plugin_manager__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./plugin_manager */ "./src/plugin_manager/index.js"); -CodeMirror.registerHelper("wordChars", "javascript", /[\w$]/); -CodeMirror.defineMIME("text/javascript", "javascript"); -CodeMirror.defineMIME("text/ecmascript", "javascript"); -CodeMirror.defineMIME("application/javascript", "javascript"); -CodeMirror.defineMIME("application/x-javascript", "javascript"); -CodeMirror.defineMIME("application/ecmascript", "javascript"); -CodeMirror.defineMIME("application/json", {name: "javascript", json: true}); -CodeMirror.defineMIME("application/x-json", {name: "javascript", json: true}); -CodeMirror.defineMIME("application/ld+json", {name: "javascript", jsonld: true}); -CodeMirror.defineMIME("text/typescript", { name: "javascript", typescript: true }); -CodeMirror.defineMIME("application/typescript", { name: "javascript", typescript: true }); +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } -}); +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } -/***/ }), -/* 107 */ -/***/ (function(module, exports, __webpack_require__) { -(function(mod) { - if (true) // CommonJS - mod(__webpack_require__(6)); - else if (typeof define == "function" && define.amd) // AMD - define(["codemirror/lib/codemirror"], mod); - else // Plain browser env - mod(CodeMirror); -})(function(CodeMirror) { - CodeMirror.extendMode("css", { - commentStart: "/*", - commentEnd: "*/", - newlineAfterToken: function(_type, content) { - return /^[;{}]$/.test(content); - } - }); - CodeMirror.extendMode("javascript", { - commentStart: "/*", - commentEnd: "*/", - // FIXME semicolons inside of for - newlineAfterToken: function(_type, content, textAfter, state) { - if (this.jsonMode) { - return /^[\[,{]$/.test(content) || /^}/.test(textAfter); + +Object(utils_polyfills__WEBPACK_IMPORTED_MODULE_4__["default"])(); +var plugins = new _plugin_manager__WEBPACK_IMPORTED_MODULE_5__["default"](); +var editors = []; +var defaultConfig = { + // If true renders editor on init + autorender: 1, + // Array of plugins to init + plugins: [], + // Custom options for plugins + pluginsOpts: {} +}; +/* harmony default export */ __webpack_exports__["default"] = ({ + $: cash_dom__WEBPACK_IMPORTED_MODULE_1___default.a, + editors: editors, + plugins: plugins, + // Will be replaced on build + version: '0.15.8', + + /** + * Initialize the editor with passed options + * @param {Object} config Configuration object + * @param {string|HTMLElement} config.container Selector which indicates where render the editor + * @param {Boolean} [config.autorender=true] If true, auto-render the content + * @param {Array} [config.plugins=[]] Array of plugins to execute on start + * @param {Object} [config.pluginsOpts={}] Custom options for plugins + * @return {Editor} Editor instance + * @example + * var editor = grapesjs.init({ + * container: '#myeditor', + * components: '
Hello world
', + * style: '.hello{color: red}', + * }) + */ + init: function init() { + var config = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var els = config.container; + if (!els) throw new Error("'container' is required"); + config = _objectSpread({}, defaultConfig, {}, config); + config.el = Object(underscore__WEBPACK_IMPORTED_MODULE_3__["isElement"])(els) ? els : document.querySelector(els); + var editor = new _editor__WEBPACK_IMPORTED_MODULE_2__["default"](config).init(); // Load plugins + + config.plugins.forEach(function (pluginId) { + var plugin = plugins.get(pluginId); + var plgOptions = config.pluginsOpts[pluginId] || {}; // Try to search in global context + + if (!plugin) { + var wplg = window[pluginId]; + plugin = wplg && wplg.default ? wplg.default : wplg; + } + + if (plugin) { + plugin(editor, plgOptions); + } else if (Object(underscore__WEBPACK_IMPORTED_MODULE_3__["isFunction"])(pluginId)) { + pluginId(editor, plgOptions); } else { - if (content == ";" && state.lexical && state.lexical.type == ")") return false; - return /^[;{}]$/.test(content) && !/^;/.test(textAfter); + console.warn("Plugin ".concat(pluginId, " not found")); } - } - }); + }); // Execute `onLoad` on modules once all plugins are initialized. + // A plugin might have extended/added some custom type so this + // is a good point to load stuff like components, css rules, etc. - var inlineElements = /^(a|abbr|acronym|area|base|bdo|big|br|button|caption|cite|code|col|colgroup|dd|del|dfn|em|frame|hr|iframe|img|input|ins|kbd|label|legend|link|map|object|optgroup|option|param|q|samp|script|select|small|span|strong|sub|sup|textarea|tt|var)$/; + editor.getModel().loadOnStart(); + config.autorender && editor.render(); + editors.push(editor); + return editor; + } +}); - CodeMirror.extendMode("xml", { - commentStart: "", - newlineAfterToken: function(type, content, textAfter, state) { - var inline = false; - if (this.configuration == "html") - inline = state.context ? inlineElements.test(state.context.tagName) : false; - return !inline && ((type == "tag" && />$/.test(content) && state.context) || - /^ -1 && endIndex > -1 && endIndex > startIndex) { - // Take string till comment start - selText = selText.substr(0, startIndex) + - // From comment start till comment end - selText.substring(startIndex + curMode.commentStart.length, endIndex) + - // From comment end till string end - selText.substr(endIndex + curMode.commentEnd.length); - } - cm.replaceRange(selText, from, to); - } - }); - }); +/***/ "./src/keymaps/index.js": +/*!******************************!*\ + !*** ./src/keymaps/index.js ***! + \******************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // Applies automatic mode-aware indentation to the specified range - CodeMirror.defineExtension("autoIndentRange", function (from, to) { - var cmInstance = this; - this.operation(function () { - for (var i = from.line; i <= to.line; i++) { - cmInstance.indentLine(i, "smart"); - } - }); - }); +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/typeof */ "./node_modules/@babel/runtime/helpers/typeof.js"); +/* harmony import */ var _babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_2__); +/* harmony import */ var keymaster__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! keymaster */ "./node_modules/keymaster/keymaster.js"); +/* harmony import */ var keymaster__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(keymaster__WEBPACK_IMPORTED_MODULE_3__); - // Applies automatic formatting to the specified range - CodeMirror.defineExtension("autoFormatRange", function (from, to) { - var cm = this; - var outer = cm.getMode(), text = cm.getRange(from, to).split("\n"); - var state = CodeMirror.copyState(outer, cm.getTokenAt(from).state); - var tabSize = cm.getOption("tabSize"); - var out = "", lines = 0, atSol = from.ch === 0; - function newline() { - out += "\n"; - atSol = true; - ++lines; + +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } + +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } + +/** + * You can customize the initial state of the module from the editor initialization + * ```js + * const editor = grapesjs.init({ + * keymaps: { + * // Object of keymaps + * defaults: { + * 'your-namespace:keymap-name' { + * keys: '⌘+z, ctrl+z', + * handler: 'some-command-id' + * }, + * ... + * } + * } + * }) + * ``` + * + * Once the editor is instantiated you can use its API. Before using these methods you should get the module from the instance + * + * ```js + * const keymaps = editor.Keymaps; + * ``` + * + * * [getConfig](#getconfig) + * * [add](#add) + * * [get](#get) + * * [getAll](#getAll) + * * [remove](#remove) + * * [removeAll](#removeall) + * + * @module Keymaps + */ + + +/* harmony default export */ __webpack_exports__["default"] = (function () { + var em; + var config; + var keymaps = {}; + var configDef = { + defaults: { + 'core:undo': { + keys: '⌘+z, ctrl+z', + handler: 'core:undo' + }, + 'core:redo': { + keys: '⌘+shift+z, ctrl+shift+z', + handler: 'core:redo' + }, + 'core:copy': { + keys: '⌘+c, ctrl+c', + handler: 'core:copy' + }, + 'core:paste': { + keys: '⌘+v, ctrl+v', + handler: 'core:paste' + }, + 'core:component-next': { + keys: 's', + handler: 'core:component-next' + }, + 'core:component-prev': { + keys: 'w', + handler: 'core:component-prev' + }, + 'core:component-enter': { + keys: 'd', + handler: 'core:component-enter' + }, + 'core:component-exit': { + keys: 'a', + handler: 'core:component-exit' + }, + 'core:component-delete': { + keys: 'backspace, delete', + handler: 'core:component-delete' + } } + }; + return { + keymaster: keymaster__WEBPACK_IMPORTED_MODULE_3___default.a, + name: 'Keymaps', + + /** + * Get module configurations + * @return {Object} Configuration object + */ + getConfig: function getConfig() { + return config; + }, + + /** + * Initialize module + * @param {Object} config Configurations + * @private + */ + init: function init() { + var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + config = _objectSpread({}, configDef, {}, opts); + em = config.em; + this.em = em; + return this; + }, + onLoad: function onLoad() { + var defKeys = config.defaults; + + for (var id in defKeys) { + var value = defKeys[id]; + this.add(id, value.keys, value.handler); + } + }, + + /** + * Add new keymap + * @param {string} id Keymap id + * @param {string} keys Keymap keys, eg. `ctrl+a`, `⌘+z, ctrl+z` + * @param {Function|string} handler Keymap handler, might be a function + * @param {Object} [opts={}] Options + * @return {Object} Added keymap + * or just a command id as a string + * @example + * // 'ns' is just a custom namespace + * keymaps.add('ns:my-keymap', '⌘+j, ⌘+u, ctrl+j, alt+u', editor => { + * console.log('do stuff'); + * }); + * // or + * keymaps.add('ns:my-keymap', '⌘+s, ctrl+s', 'some-gjs-command'); + * + * // listen to events + * editor.on('keymap:emit', (id, shortcut, e) => { + * // ... + * }) + */ + add: function add(id, keys, handler) { + var opts = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {}; + var em = this.em; + var cmd = em.get('Commands'); + var editor = em.getEditor(); + var canvas = em.get('Canvas'); + var keymap = { + id: id, + keys: keys, + handler: handler + }; + var pk = keymaps[id]; + pk && this.remove(id); + keymaps[id] = keymap; + keymaster__WEBPACK_IMPORTED_MODULE_3___default()(keys, function (e, h) { + // It's safer putting handlers resolution inside the callback + var opt = { + event: e, + h: h + }; + handler = Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isString"])(handler) ? cmd.get(handler) : handler; + opts.prevent && canvas.getCanvasView().preventDefault(e); + var ableTorun = !em.isEditing() && !editor.Canvas.isInputFocused(); - for (var i = 0; i < text.length; ++i) { - var stream = new CodeMirror.StringStream(text[i], tabSize); - while (!stream.eol()) { - var inner = CodeMirror.innerMode(outer, state); - var style = outer.token(stream, state), cur = stream.current(); - stream.start = stream.pos; - if (!atSol || /\S/.test(cur)) { - out += cur; - atSol = false; + if (ableTorun || opts.force) { + _babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0___default()(handler) == 'object' ? handler.run(editor, 0, opt) : handler(editor, 0, opt); + var args = [id, h.shortcut, e]; + em.trigger.apply(em, ['keymap:emit'].concat(args)); + em.trigger.apply(em, ["keymap:emit:".concat(id)].concat(args)); } - if (!atSol && inner.mode.newlineAfterToken && - inner.mode.newlineAfterToken(style, cur, stream.string.slice(stream.pos) || text[i+1] || "", inner.state)) - newline(); - } - if (!stream.pos && outer.blankLine) outer.blankLine(state); - if (!atSol && i < text.length - 1) newline(); - } + }); + em.trigger('keymap:add', keymap); + return keymap; + }, - cm.operation(function () { - cm.replaceRange(out, from, to); - for (var cur = from.line + 1, end = from.line + lines; cur <= end; ++cur) - cm.indentLine(cur, "smart"); - cm.setSelection(from, cm.getCursor(false)); - }); - }); -}); + /** + * Get the keymap by id + * @param {string} id Keymap id + * @return {Object} Keymap object + * @example + * keymaps.get('ns:my-keymap'); + * // -> {keys, handler}; + */ + get: function get(id) { + return keymaps[id]; + }, + /** + * Get all keymaps + * @return {Object} + * @example + * keymaps.getAll(); + * // -> {id1: {}, id2: {}}; + */ + getAll: function getAll() { + return keymaps; + }, -/***/ }), -/* 108 */ -/***/ (function(module, exports, __webpack_require__) { + /** + * Remove the keymap by id + * @param {string} id Keymap id + * @return {Object} Removed keymap + * @example + * keymaps.remove('ns:my-keymap'); + * // -> {keys, handler}; + */ + remove: function remove(id) { + var em = this.em; + var keymap = this.get(id); -"use strict"; -/* WEBPACK VAR INJECTION */(function(_) { + if (keymap) { + delete keymaps[id]; + keymaster__WEBPACK_IMPORTED_MODULE_3___default.a.unbind(keymap.keys); + em && em.trigger('keymap:remove', keymap); + return keymap; + } + }, -var Backbone = __webpack_require__(0); + /** + * Remove all binded keymaps + * @return {this} + */ + removeAll: function removeAll() { + var _this = this; -module.exports = Backbone.View.extend({ + Object.keys(keymaps).forEach(function (keymap) { + return _this.remove(keymap); + }); + return this; + } + }; +}); - template: _.template('\n
\n \t
<%= label %>
\n \t
\n
'), +/***/ }), - initialize: function initialize(o) { - this.config = o.config || {}; - this.pfx = this.config.stylePrefix; - }, - render: function render() { - var obj = this.model.toJSON(); - obj.pfx = this.pfx; - this.$el.html(this.template(obj)); - this.$el.attr('class', this.pfx + 'editor-c'); - this.$el.find('#' + this.pfx + 'code').append(this.model.get('input')); - return this; - } +/***/ "./src/modal_dialog/config/config.js": +/*!*******************************************!*\ + !*** ./src/modal_dialog/config/config.js ***! + \*******************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony default export */ __webpack_exports__["default"] = ({ + stylePrefix: 'mdl-', + title: '', + content: '', + backdrop: true }); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(1))) /***/ }), -/* 109 */ -/***/ (function(module, exports, __webpack_require__) { + +/***/ "./src/modal_dialog/index.js": +/*!***********************************!*\ + !*** ./src/modal_dialog/index.js ***! + \***********************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _config_config__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./config/config */ "./src/modal_dialog/config/config.js"); +/* harmony import */ var _model_Modal__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./model/Modal */ "./src/modal_dialog/model/Modal.js"); +/* harmony import */ var _view_ModalView__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./view/ModalView */ "./src/modal_dialog/view/ModalView.js"); + + +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } /** - * - * * [addPanel](#addpanel) - * * [addButton](#addbutton) - * * [removeButton](#removebutton) - * * [getButton](#getbutton) - * * [getPanel](#getpanel) - * * [getPanels](#getpanels) - * * [render](#render) - * - * This module manages panels and buttons inside the editor. - * You can init the editor with all panels and buttons necessary via configuration - * + * You can customize the initial state of the module from the editor initialization, by passing the following [Configuration Object](https://github.com/artf/grapesjs/blob/master/src/modal_dialog/config/config.js) * ```js - * var editor = grapesjs.init({ - * ... - * panels: {...} // Check below for the possible properties - * ... - * }); + * const editor = grapesjs.init({ + * modal: { + * // options + * } + * }) * ``` * - * - * Before using methods you should get first the module from the editor instance, in this way: + * Once the editor is instantiated you can use its API. Before using these methods you should get the module from the instance * * ```js - * var panelManager = editor.Panels; + * const modal = editor.Modal; * ``` * - * @module Panels - * @param {Object} config Configurations - * @param {Array} [config.defaults=[]] Array of possible panels - * @example - * ... - * panels: { - * defaults: [{ - * id: 'main-toolbar', - * buttons: [{ - * id: 'btn-id', - * className: 'some', - * attributes: { - * title: 'MyTitle' - * } - * }], - * }], - * } - * ... + * * [open](#open) + * * [close](#close) + * * [isOpen](#isopen) + * * [setTitle](#settitle) + * * [getTitle](#gettitle) + * * [setContent](#setcontent) + * * [getContent](#getcontent) + * * [onceClose](#onceclose) + * * [onceOpen](#onceopen) + * + * @module Modal */ -module.exports = function () { - var c = {}, - defaults = __webpack_require__(110), - Panel = __webpack_require__(27), - Panels = __webpack_require__(112), - PanelView = __webpack_require__(29), - PanelsView = __webpack_require__(114); - var panels, PanelsViewObj; - return { + +/* harmony default export */ __webpack_exports__["default"] = (function () { + var c = {}; + var model, modal; + + var triggerEvent = function triggerEvent(enable, em) { + em && em.trigger("modal:".concat(enable ? 'open' : 'close')); + }; + + return { /** * Name of the module * @type {String} * @private */ - name: 'Panels', + name: 'Modal', + getConfig: function getConfig() { + return c; + }, /** * Initialize module. Automatically called with a new instance of the editor * @param {Object} config Configurations + * @private */ - init: function init(config) { - c = config || {}; - for (var name in defaults) { - if (!(name in c)) c[name] = defaults[name]; - } - + init: function init() { + var config = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + c = _objectSpread({}, _config_config__WEBPACK_IMPORTED_MODULE_1__["default"], {}, config); + var em = c.em; + this.em = em; var ppfx = c.pStylePrefix; if (ppfx) c.stylePrefix = ppfx + c.stylePrefix; - - panels = new Panels(c.defaults); - PanelsViewObj = new PanelsView({ - collection: panels, + model = new _model_Modal__WEBPACK_IMPORTED_MODULE_2__["default"](c); + model.on('change:open', function (m, enb) { + return triggerEvent(enb, em); + }); + modal = new _view_ModalView__WEBPACK_IMPORTED_MODULE_3__["default"]({ + model: model, config: c }); return this; }, - - - /** - * Returns the collection of panels - * @return {Collection} Collection of panel - */ - getPanels: function getPanels() { - return panels; + postRender: function postRender(view) { + var el = view.model.getConfig().el || view.el; + this.render().appendTo(el); }, - /** - * Returns panels element - * @return {HTMLElement} + * Open the modal window + * @param {Object} [opts={}] Options + * @param {String|HTMLElement} [opts.title] Title to set for the modal + * @param {String|HTMLElement} [opts.content] Content to set for the modal + * @return {this} */ - getPanelsEl: function getPanelsEl() { - return PanelsViewObj.el; + open: function open() { + var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + opts.title && this.setTitle(opts.title); + opts.content && this.setContent(opts.content); + modal.show(); + return this; }, - /** - * Add new panel to the collection - * @param {Object|Panel} panel Object with right properties or an instance of Panel - * @return {Panel} Added panel. Useful in case passed argument was an Object - * @example - * var newPanel = panelManager.addPanel({ - * id: 'myNewPanel', - * visible : true, - * buttons : [...], - * }); + * Close the modal window + * @return {this} */ - addPanel: function addPanel(panel) { - return panels.add(panel); + close: function close() { + modal.hide(); + return this; }, - /** - * Remove a panel from the collection - * @param {Object|Panel|String} panel Object with right properties or an instance of Panel or Painel id - * @return {Panel} Removed panel. Useful in case passed argument was an Object - * @example - * const newPanel = panelManager.removePanel({ - * id: 'myNewPanel', - * visible : true, - * buttons : [...], - * }); - * - * const newPanel = panelManager.removePanel('myNewPanel'); - * + * Execute callback when the modal will be closed. + * The callback will be called one only time + * @param {Function} clb + * @returns {this} */ - removePanel: function removePanel(panel) { - return panels.remove(panel); + onceClose: function onceClose(clb) { + this.em.once('modal:close', clb); + return this; }, - /** - * Get panel by ID - * @param {string} id Id string - * @return {Panel|null} - * @example - * var myPanel = panelManager.getPanel('myNewPanel'); + * Execute callback when the modal will be opened. + * The callback will be called one only time + * @param {Function} clb + * @returns {this} */ - getPanel: function getPanel(id) { - var res = panels.where({ id: id }); - return res.length ? res[0] : null; + onceOpen: function onceOpen(clb) { + this.em.once('modal:open', clb); + return this; }, - /** - * Add button to the panel - * @param {string} panelId Panel's ID - * @param {Object|Button} button Button object or instance of Button - * @return {Button|null} Added button. Useful in case passed button was an Object - * @example - * var newButton = panelManager.addButton('myNewPanel',{ - * id: 'myNewButton', - * className: 'someClass', - * command: 'someCommand', - * attributes: { title: 'Some title'}, - * active: false, - * }); - * // It's also possible to pass the command as an object - * // with .run and .stop methods - * ... - * command: { - * run: function(editor) { - * ... - * }, - * stop: function(editor) { - * ... - * } - * }, - * // Or simply like a function which will be evaluated as a single .run command - * ... - * command: function(editor) { - * ... - * } + * Checks if the modal window is open + * @return {Boolean} */ - addButton: function addButton(panelId, button) { - var pn = this.getPanel(panelId); - return pn ? pn.get('buttons').add(button) : null; + isOpen: function isOpen() { + return !!model.get('open'); }, - /** - * Remove button from the panel - * @param {string} panelId Panel's ID - * @param {Object|Button|String} button Button object or instance of Button or button id - * @return {Button|null} Removed button. + * Set the title to the modal window + * @param {string} title Title + * @return {this} * @example - * const removedButton = panelManager.removeButton('myNewPanel',{ - * id: 'myNewButton', - * className: 'someClass', - * command: 'someCommand', - * attributes: { title: 'Some title'}, - * active: false, - * }); - * - * // It's also possible to use the button id - * const removedButton = panelManager.removeButton('myNewPanel','myNewButton'); - * + * modal.setTitle('New title'); */ - removeButton: function removeButton(panelId, button) { - var pn = this.getPanel(panelId); - return pn && pn.get('buttons').remove(button); + setTitle: function setTitle(title) { + model.set('title', title); + return this; }, + /** + * Returns the title of the modal window + * @return {string} + */ + getTitle: function getTitle() { + return model.get('title'); + }, /** - * Get button from the panel - * @param {string} panelId Panel's ID - * @param {string} id Button's ID - * @return {Button|null} + * Set the content of the modal window + * @param {string|HTMLElement} content Content + * @return {this} * @example - * var button = panelManager.getButton('myPanel','myButton'); + * modal.setContent('
Some HTML content
'); */ - getButton: function getButton(panelId, id) { - var pn = this.getPanel(panelId); - if (pn) { - var res = pn.get('buttons').where({ id: id }); - return res.length ? res[0] : null; - } - return null; + setContent: function setContent(content) { + model.set('content', ' '); + model.set('content', content); + return this; }, + /** + * Get the content of the modal window + * @return {string} + */ + getContent: function getContent() { + return model.get('content'); + }, /** - * Render panels and buttons + * Returns content element * @return {HTMLElement} + * @private */ - render: function render() { - return PanelsViewObj.render().el; + getContentEl: function getContentEl() { + return modal.getContent().get(0); }, - /** - * Active activable buttons + * Returns modal model + * @return {Model} * @private */ - active: function active() { - this.getPanels().each(function (p) { - p.get('buttons').each(function (btn) { - if (btn.get('active')) btn.trigger('updateActive'); - }); - }); + getModel: function getModel() { + return model; }, - /** - * Disable buttons flagged as disabled + * Render the modal window + * @return {HTMLElement} * @private */ - disableButtons: function disableButtons() { - this.getPanels().each(function (p) { - p.get('buttons').each(function (btn) { - if (btn.get('disable')) btn.trigger('change:disable'); - }); - }); - }, + render: function render() { + return modal.render().$el; + } + }; +}); +/***/ }), - Panel: Panel +/***/ "./src/modal_dialog/model/Modal.js": +/*!*****************************************!*\ + !*** ./src/modal_dialog/model/Modal.js ***! + \*****************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - }; -}; +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); + +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_0___default.a.Model.extend({ + defaults: { + title: '', + content: '', + open: false + } +})); /***/ }), -/* 110 */ -/***/ (function(module, exports, __webpack_require__) { + +/***/ "./src/modal_dialog/view/ModalView.js": +/*!********************************************!*\ + !*** ./src/modal_dialog/view/ModalView.js ***! + \********************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_0___default.a.View.extend({ + template: function template(_ref) { + var pfx = _ref.pfx, + ppfx = _ref.ppfx, + content = _ref.content, + title = _ref.title; + return "
\n
\n
").concat(title, "
\n
\n
\n
\n
").concat(content, "
\n
\n
\n
\n
"); + }, + events: { + click: 'onClick', + 'click [data-close-modal]': 'hide' + }, + initialize: function initialize(o) { + var model = this.model; + var config = o.config || {}; + var pfx = config.stylePrefix || ''; + this.config = config; + this.pfx = pfx; + this.ppfx = config.pStylePrefix || ''; + this.listenTo(model, 'change:open', this.updateOpen); + this.listenTo(model, 'change:title', this.updateTitle); + this.listenTo(model, 'change:content', this.updateContent); + }, + onClick: function onClick(e) { + var bkd = this.config.backdrop; + bkd && e.target === this.el && this.hide(); + }, -var crc = 'create-comp'; -var mvc = 'move-comp'; -var swv = 'sw-visibility'; -var expt = 'export-template'; -var osm = 'open-sm'; -var otm = 'open-tm'; -var ola = 'open-layers'; -var obl = 'open-blocks'; -var ful = 'fullscreen'; -var prv = 'preview'; + /** + * Returns collector element + * @return {HTMLElement} + * @private + */ + getCollector: function getCollector() { + if (!this.$collector) this.$collector = this.$el.find('.' + this.pfx + 'collector'); + return this.$collector; + }, -module.exports = { - stylePrefix: 'pn-', + /** + * Returns content element + * @return {HTMLElement} + * @private + */ + getContent: function getContent() { + var pfx = this.pfx; - // Default panels fa-sliders for features - defaults: [{ - id: 'commands', - buttons: [{}] - }, { - id: 'options', - buttons: [{ - active: true, - id: swv, - className: 'fa fa-square-o', - command: swv, - context: swv, - attributes: { title: 'View components' } - }, { - id: prv, - className: 'fa fa-eye', - command: prv, - context: prv, - attributes: { title: 'Preview' } - }, { - id: ful, - className: 'fa fa-arrows-alt', - command: ful, - context: ful, - attributes: { title: 'Fullscreen' } - }, { - id: expt, - className: 'fa fa-code', - command: expt, - attributes: { title: 'View code' } - }] - }, { - id: 'views', - buttons: [{ - id: osm, - className: 'fa fa-paint-brush', - command: osm, - active: true, - attributes: { title: 'Open Style Manager' } - }, { - id: otm, - className: 'fa fa-cog', - command: otm, - attributes: { title: 'Settings' } - }, { - id: ola, - className: 'fa fa-bars', - command: ola, - attributes: { title: 'Open Layer Manager' } - }, { - id: obl, - className: 'fa fa-th-large', - command: obl, - attributes: { title: 'Open Blocks' } - }] - }], + if (!this.$content) { + this.$content = this.$el.find(".".concat(pfx, "content #").concat(pfx, "c")); + } + + return this.$content; + }, + + /** + * Returns title element + * @return {HTMLElement} + * @private + */ + getTitle: function getTitle() { + if (!this.$title) this.$title = this.$el.find('.' + this.pfx + 'title'); + return this.$title.get(0); + }, + + /** + * Update content + * @private + * */ + updateContent: function updateContent() { + var content = this.getContent(); + var children = content.children(); + var coll = this.getCollector(); + var body = this.model.get('content'); + children.length && coll.append(children); + content.empty().append(body); + }, + + /** + * Update title + * @private + * */ + updateTitle: function updateTitle() { + var title = this.getTitle(); + if (title) title.innerHTML = this.model.get('title'); + }, + + /** + * Update open + * @private + * */ + updateOpen: function updateOpen() { + this.el.style.display = this.model.get('open') ? '' : 'none'; + }, + + /** + * Hide modal + * @private + * */ + hide: function hide() { + this.model.set('open', 0); + }, + + /** + * Show modal + * @private + * */ + show: function show() { + this.model.set('open', 1); + }, + render: function render() { + var el = this.$el; + var pfx = this.pfx; + var ppfx = this.ppfx; + var obj = this.model.toJSON(); + obj.pfx = this.pfx; + obj.ppfx = this.ppfx; + el.html(this.template(obj)); + el.attr('class', "".concat(pfx, "container")); + this.updateOpen(); + return this; + } +})); - // Editor model - em: null, +/***/ }), - // Delay before show children buttons (in milliseconds) - delayBtnsShow: 300 -}; +/***/ "./src/navigator/config/config.js": +/*!****************************************!*\ + !*** ./src/navigator/config/config.js ***! + \****************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony default export */ __webpack_exports__["default"] = ({ + stylePrefix: '', + // Specify the element to use as a container, string (query) or HTMLElement + // With the empty value, nothing will be rendered + appendTo: '', + // Enable/Disable globally the possibility to sort layers + sortable: 1, + // Enable/Disable globally the possibility to hide layers + hidable: 1, + // Hide textnodes + hideTextnode: 1, + // Indicate a query string of the element to be selected as the root of layers. + // By default the root is the wrapper + root: '', + // Indicates if the wrapper is visible in layers + showWrapper: 1, + // Show hovered components in canvas + showHover: 1, + // Scroll to selected component in Canvas when it's selected in Layers + // true, false or `scrollIntoView`-like options, + // `block: 'nearest'` avoids the issue of window scolling + scrollCanvas: { + behavior: 'smooth', + block: 'nearest' + }, + // Scroll to selected component in Layers when it's selected in Canvas + // true, false or `scrollIntoView`-like options + scrollLayers: { + behavior: 'auto', + block: 'nearest' + }, + // Highlight when a layer component is hovered + highlightHover: 1 +}); /***/ }), -/* 111 */ -/***/ (function(module, exports, __webpack_require__) { + +/***/ "./src/navigator/index.js": +/*!********************************!*\ + !*** ./src/navigator/index.js ***! + \********************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _config_config__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./config/config */ "./src/navigator/config/config.js"); +/* harmony import */ var _view_ItemView__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./view/ItemView */ "./src/navigator/view/ItemView.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_3__); -var Backbone = __webpack_require__(0); +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } -module.exports = Backbone.Model.extend({ +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - defaults: { - id: '', - className: '', - command: '', - context: '', - buttons: [], - attributes: {}, - options: {}, - active: false, - dragDrop: false, - runDefaultCommand: true, - stopDefaultCommand: false, - disable: false - }, - initialize: function initialize(options) { - if (this.get('buttons').length) { - var Buttons = __webpack_require__(28); - this.set('buttons', new Buttons(this.get('buttons'))); - } - } -}); -/***/ }), -/* 112 */ -/***/ (function(module, exports, __webpack_require__) { -"use strict"; +/* harmony default export */ __webpack_exports__["default"] = (function () { + var em; + var layers; + var config = {}; + return { + name: 'LayerManager', + init: function init() { + var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + config = _objectSpread({}, _config_config__WEBPACK_IMPORTED_MODULE_1__["default"], {}, opts); + config.stylePrefix = opts.pStylePrefix; + em = config.em; + return this; + }, + getConfig: function getConfig() { + return config; + }, + onLoad: function onLoad() { + layers = new _view_ItemView__WEBPACK_IMPORTED_MODULE_2__["default"]({ + level: 0, + config: config, + opened: config.opened || {}, + model: em.get('DomComponents').getWrapper() + }); + em && em.on('component:selected', this.componentChanged); + this.componentChanged(); + }, + postRender: function postRender() { + var elTo = config.appendTo; + var root = config.root; + root && this.setRoot(root); + if (elTo) { + var el = Object(underscore__WEBPACK_IMPORTED_MODULE_3__["isElement"])(elTo) ? elTo : document.querySelector(elTo); + el.appendChild(this.render()); + } + }, -var Backbone = __webpack_require__(0); -var Panel = __webpack_require__(27); + /** + * Set new root for layers + * @param {HTMLElement|Component|String} el Component to be set as the root + * @return {self} + */ + setRoot: function setRoot(el) { + layers.setRoot(el); + return this; + }, -module.exports = Backbone.Collection.extend({ - model: Panel -}); + /** + * Get the root of layers + * @return {Component} + */ + getRoot: function getRoot() { + return layers.model; + }, -/***/ }), -/* 113 */ -/***/ (function(module, exports, __webpack_require__) { + /** + * Return the view of layers + * @return {View} + */ + getAll: function getAll() { + return layers; + }, -"use strict"; -/* WEBPACK VAR INJECTION */(function(Backbone, _) { + /** + * Triggered when the selected component is changed + * @private + */ + componentChanged: function componentChanged(selected) { + var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + if (opts.fromLayers) return; + var opened = em.get('opened'); + var model = em.getSelected(); + var scroll = config.scrollLayers; + var parent = model && model.collection ? model.collection.parent : null; + + for (var cid in opened) { + opened[cid].set('open', 0); + } -var _underscore = __webpack_require__(1); + while (parent) { + parent.set('open', 1); + opened[parent.cid] = parent; + parent = parent.collection ? parent.collection.parent : null; + } -var $ = Backbone.$; + if (model && scroll) { + var el = model.viewLayer && model.viewLayer.el; + el && el.scrollIntoView(scroll); + } + }, + render: function render() { + return layers.render().el; + } + }; +}); -module.exports = Backbone.View.extend({ +/***/ }), - tagName: 'span', +/***/ "./src/navigator/view/ItemView.js": +/*!****************************************!*\ + !*** ./src/navigator/view/ItemView.js ***! + \****************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - initialize: function initialize(o) { - _.bindAll(this, 'startTimer', 'stopTimer', 'showButtons', 'hideButtons', 'closeOnKeyPress', 'onDrop', 'initSorter', 'stopDrag'); - var cls = this.model.get('className'); - this.config = o.config || {}; - this.em = this.config.em || {}; - var pfx = this.config.stylePrefix || ''; - var ppfx = this.config.pStylePrefix || ''; - this.pfx = pfx; - this.ppfx = this.config.pStylePrefix || ''; - this.id = pfx + this.model.get('id'); - this.activeCls = pfx + 'active ' + ppfx + 'four-color'; - this.disableCls = pfx + 'active'; - this.btnsVisCls = pfx + 'visible'; - this.parentM = o.parentM || null; - this.className = pfx + 'btn' + (cls ? ' ' + cls : ''); - this.listenTo(this.model, 'change:active updateActive', this.updateActive); - this.listenTo(this.model, 'checkActive', this.checkActive); - this.listenTo(this.model, 'change:bntsVis', this.updateBtnsVis); - this.listenTo(this.model, 'change:attributes', this.updateAttributes); - this.listenTo(this.model, 'change:className', this.updateClassName); - this.listenTo(this.model, 'change:disable', this.updateDisable); +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var utils_mixins__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! utils/mixins */ "./src/utils/mixins.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_2__); +/* harmony import */ var dom_components_view_ComponentView__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! dom_components/view/ComponentView */ "./src/dom_components/view/ComponentView.js"); - if (this.model.get('buttons').length) { - this.$el.on('mousedown', this.startTimer); - this.$el.append($('
', { class: pfx + 'arrow-rd' })); - } - if (this.em && this.em.get) this.commands = this.em.get('Commands'); - this.events = {}; - if (this.model.get('dragDrop')) { - this.events.mousedown = 'initDrag'; - this.em.on('loaded', this.initSorter); - } else this.events.click = 'clicked'; - this.delegateEvents(); +var inputProp = 'contentEditable'; +var $ = backbone__WEBPACK_IMPORTED_MODULE_2___default.a.$; +var ItemsView; +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_2___default.a.View.extend({ + events: { + 'mousedown [data-toggle-move]': 'startSort', + 'touchstart [data-toggle-move]': 'startSort', + 'click [data-toggle-visible]': 'toggleVisibility', + 'click [data-toggle-select]': 'handleSelect', + 'mouseover [data-toggle-select]': 'handleHover', + 'click [data-toggle-open]': 'toggleOpening', + 'dblclick [data-name]': 'handleEdit', + 'focusout [data-name]': 'handleEditEnd' }, - initSorter: function initSorter() { - if (this.em.Canvas) { - var canvas = this.em.Canvas; - this.canvasEl = canvas.getBody(); - this.sorter = new this.em.Utils.Sorter({ - container: this.canvasEl, - placer: canvas.getPlacerEl(), - containerSel: '*', - itemSel: '*', - pfx: this.ppfx, - onMove: this.onDrag, - onEndMove: this.onDrop, - document: canvas.getFrameEl().contentDocument, - direction: 'a', - wmargin: 1, - nested: 1 - }); - var offDim = canvas.getOffset(); - this.sorter.offTop = offDim.top; - this.sorter.offLeft = offDim.left; - } + template: function template(model) { + var pfx = this.pfx, + ppfx = this.ppfx, + config = this.config, + clsNoEdit = this.clsNoEdit; + var hidable = config.hidable; + var count = this.countChildren(model); + var addClass = !count ? this.clsNoChild : ''; + var clsTitle = "".concat(this.clsTitle, " ").concat(addClass); + var clsTitleC = "".concat(this.clsTitleC, " ").concat(ppfx, "one-bg"); + var clsCaret = "".concat(this.clsCaret, " fa fa-chevron-right"); + var clsInput = "".concat(this.inputNameCls, " ").concat(clsNoEdit, " ").concat(ppfx, "no-app"); + var level = this.level + 1; + var gut = "".concat(30 + level * 10, "px"); + var name = model.getName(); + var icon = model.getIcon(); + var clsBase = "".concat(pfx, "layer"); + return "\n ".concat(hidable ? "") : '', "\n
\n
\n
\n \n ").concat(icon ? "").concat(icon, "") : '', "\n ").concat(name, "\n
\n
\n
\n
").concat(count || '', "
\n
\n \n
\n
"); + }, + initialize: function initialize() { + var o = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + this.opt = o; + this.level = o.level; + this.config = o.config; + this.em = o.config.em; + this.ppfx = this.em.get('Config').stylePrefix; + this.sorter = o.sorter || ''; + this.pfx = this.config.stylePrefix; + var pfx = this.pfx; + var ppfx = this.ppfx; + var model = this.model; + var components = model.get('components'); + var type = model.get('type') || 'default'; + model.set('open', false); + this.listenTo(components, 'remove add reset', this.checkChildren); + this.listenTo(model, 'change:status', this.updateStatus); + this.listenTo(model, 'change:open', this.updateOpening); + this.listenTo(model, 'change:style:display', this.updateVisibility); + this.className = "".concat(pfx, "layer ").concat(pfx, "layer__t-").concat(type, " no-select ").concat(ppfx, "two-color"); + this.inputNameCls = "".concat(ppfx, "layer-name"); + this.clsTitleC = "".concat(pfx, "layer-title-c"); + this.clsTitle = "".concat(pfx, "layer-title"); + this.clsCaret = "".concat(pfx, "layer-caret"); + this.clsCount = "".concat(pfx, "layer-count"); + this.clsMove = "".concat(pfx, "layer-move"); + this.clsChildren = "".concat(pfx, "layer-children"); + this.clsNoChild = "".concat(pfx, "layer-no-chld"); + this.clsEdit = "".concat(this.inputNameCls, "--edit"); + this.clsNoEdit = "".concat(this.inputNameCls, "--no-edit"); + this.$el.data('model', model); + this.$el.data('collection', components); + model.viewLayer = this; }, + getVisibilityEl: function getVisibilityEl() { + if (!this.eyeEl) { + this.eyeEl = this.$el.children(".".concat(this.pfx, "layer-vis")); + } + return this.eyeEl; + }, + updateVisibility: function updateVisibility() { + var pfx = this.pfx; + var model = this.model; + var hClass = "".concat(pfx, "layer-hidden"); + var hideIcon = 'fa-eye-slash'; + var hidden = model.getStyle().display == 'none'; + var method = hidden ? 'addClass' : 'removeClass'; + this.$el[method](hClass); + this.getVisibilityEl()[method](hideIcon); + }, /** - * Init dragging element - * @private - */ - initDrag: function initDrag() { - this.model.collection.deactivateAll(this.model.get('context')); - this.sorter.startSort(this.el); - this.sorter.setDropContent(this.model.get('options').content); - this.canvasEl.style.cursor = 'grabbing'; - $(document).on('mouseup', this.stopDrag); - }, + * Toggle visibility + * @param Event + * + * @return void + * */ + toggleVisibility: function toggleVisibility(e) { + e && e.stopPropagation(); + var model = this.model; + var style = model.getStyle(); + var hidden = style.display == 'none'; + + if (hidden) { + delete style.display; + } else { + style.display = 'none'; + } + model.setStyle(style); + }, /** - * Stop dragging - * @private + * Handle the edit of the component name */ - stopDrag: function stopDrag() { - $(document).off('mouseup', this.stopDrag); - this.sorter.endMove(); + handleEdit: function handleEdit(e) { + e && e.stopPropagation(); + var em = this.em, + $el = this.$el, + clsNoEdit = this.clsNoEdit, + clsEdit = this.clsEdit; + var inputEl = this.getInputName(); + inputEl[inputProp] = true; + inputEl.focus(); + em && em.setEditing(1); + $el.find(".".concat(this.inputNameCls)).removeClass(clsNoEdit).addClass(clsEdit); }, - /** - * During drag method - * @private + * Handle with the end of editing of the component name */ - onDrag: function onDrag(e) {}, - + handleEditEnd: function handleEditEnd(e) { + e && e.stopPropagation(); + var em = this.em, + $el = this.$el, + clsNoEdit = this.clsNoEdit, + clsEdit = this.clsEdit; + var inputEl = this.getInputName(); + var name = inputEl.textContent; + inputEl.scrollLeft = 0; + inputEl[inputProp] = false; + this.model.set({ + name: name + }); + em && em.setEditing(0); + $el.find(".".concat(this.inputNameCls)).addClass(clsNoEdit).removeClass(clsEdit); + }, /** - * During drag method - * @private + * Get the input containing the name of the component + * @return {HTMLElement} */ - onDrop: function onDrop(e) { - this.canvasEl.style.cursor = 'default'; - }, + getInputName: function getInputName() { + if (!this.inputName) { + this.inputName = this.el.querySelector(".".concat(this.inputNameCls)); + } + return this.inputName; + }, /** - * Updates class name of the button + * Update item opening * - * @return void + * @return void * */ - updateClassName: function updateClassName() { - var cls = this.model.get('className'); - this.$el.attr('class', this.pfx + 'btn' + (cls ? ' ' + cls : '')); - }, + updateOpening: function updateOpening() { + var opened = this.opt.opened || {}; + var model = this.model; + var chvDown = 'fa-chevron-down'; + if (model.get('open')) { + this.$el.addClass('open'); + this.getCaret().addClass(chvDown); + opened[model.cid] = model; + } else { + this.$el.removeClass('open'); + this.getCaret().removeClass(chvDown); + delete opened[model.cid]; + } + }, /** - * Updates attributes of the button + * Toggle item opening + * @param {Object} e * - * @return void + * @return void * */ - updateAttributes: function updateAttributes() { - this.$el.attr(this.model.get("attributes")); + toggleOpening: function toggleOpening(e) { + e.stopPropagation(); + if (!this.model.get('components').length) return; + this.model.set('open', !this.model.get('open')); }, - /** - * Updates visibility of children buttons - * - * @return void - * */ - updateBtnsVis: function updateBtnsVis() { - if (!this.$buttons) return; + * Handle component selection + */ + handleSelect: function handleSelect(e) { + e.stopPropagation(); + var em = this.em, + config = this.config; - if (this.model.get('bntsVis')) this.$buttons.addClass(this.btnsVisCls);else this.$buttons.removeClass(this.btnsVisCls); + if (em) { + var model = this.model; + em.setSelected(model, { + fromLayers: 1 + }); + var scroll = config.scrollCanvas; + scroll && em.get('Canvas').scrollTo(model, scroll); + } }, + /** + * Handle component selection + */ + handleHover: function handleHover(e) { + e.stopPropagation(); + var em = this.em, + config = this.config, + model = this.model; + em && config.showHover && em.setHovered(model, { + fromLayers: 1 + }); + }, /** - * Start timer for showing children buttons - * - * @return void + * Delegate to sorter + * @param Event * */ - startTimer: function startTimer() { - this.timeout = setTimeout(this.showButtons, this.config.delayBtnsShow); - $(document).on('mouseup', this.stopTimer); - }, + startSort: function startSort(e) { + e.stopPropagation(); + var sorter = this.sorter; // Right or middel click + if (e.button && e.button !== 0) return; + sorter && sorter.startSort(e.target); + }, /** - * Stop timer for showing children buttons - * - * @return void + * Freeze item + * @return void * */ - stopTimer: function stopTimer() { - $(document).off('mouseup', this.stopTimer); - if (this.timeout) clearTimeout(this.timeout); + freeze: function freeze() { + this.$el.addClass(this.pfx + 'opac50'); + this.model.set('open', 0); }, - /** - * Show children buttons - * - * @return void + * Unfreeze item + * @return void * */ - showButtons: function showButtons() { - clearTimeout(this.timeout); - this.model.set('bntsVis', true); - $(document).on('mousedown', this.hideButtons); - $(document).on('keypress', this.closeOnKeyPress); + unfreeze: function unfreeze() { + this.$el.removeClass(this.pfx + 'opac50'); }, - /** - * Hide children buttons - * - * @return void + * Update item on status change + * @param Event * */ - hideButtons: function hideButtons(e) { - if (e) { - $(e.target).trigger('click'); - } - this.model.set('bntsVis', false); - $(document).off('mousedown', this.hideButtons); - $(document).off('keypress', this.closeOnKeyPress); + updateStatus: function updateStatus(e) { + dom_components_view_ComponentView__WEBPACK_IMPORTED_MODULE_3__["default"].prototype.updateStatus.apply(this, [{ + avoidHover: !this.config.highlightHover + }]); }, - /** - * Close buttons on ESC key press - * @param {Object} e Event + * Check if component is visible * - * @return void + * @return bool * */ - closeOnKeyPress: function closeOnKeyPress(e) { - var key = e.which || e.keyCode; - if (key == 27) this.hideButtons(); + isVisible: function isVisible() { + var css = this.model.get('style'), + pr = css.display; + if (pr && pr == 'none') return; + return 1; }, - /** - * Update active status of the button + * Update item aspect after children changes * - * @return void + * @return void * */ - updateActive: function updateActive() { + checkChildren: function checkChildren() { var model = this.model; - var context = model.get('context'); - var parent = this.parentM; - var command = {}; - var editor = this.em && this.em.get ? this.em.get('Editor') : null; - var commandName = model.get('command'); + var count = this.countChildren(model); + var pfx = this.pfx; + var noChildCls = this.clsNoChild; + var title = this.$el.children(".".concat(this.clsTitleC)).children(".".concat(this.clsTitle)); - if (this.commands && (0, _underscore.isString)(commandName)) { - command = this.commands.get(commandName) || {}; - } else if ((0, _underscore.isFunction)(commandName)) { - command = { run: commandName }; - } else if (commandName !== null && (0, _underscore.isObject)(commandName)) { - command = commandName; + if (!this.cnt) { + this.cnt = this.$el.children(".".concat(this.clsCount)); } - if (model.get('active')) { - model.collection.deactivateAll(context); - model.set('active', true, { silent: true }).trigger('checkActive'); - parent && parent.set('active', true, { silent: true }).trigger('checkActive'); - - if (command.run) { - command.run(editor, model, model.get('options')); - editor.trigger('run:' + commandName); - } - - // Disable button if there is no stop method - !command.stop && model.set('active', false); - } else { - this.$el.removeClass(this.activeCls); - model.collection.deactivateAll(context); - parent && parent.set('active', false, { silent: true }).trigger('checkActive'); - - if (command.stop) { - command.stop(editor, model, model.get('options')); - editor.trigger('stop:' + commandName); - } - } - }, - updateDisable: function updateDisable() { - if (this.model.get('disable')) { - this.$el.addClass(this.disableCls); + if (count) { + title.removeClass(noChildCls); + this.cnt.html(count); } else { - this.$el.removeClass(this.disableCls); + title.addClass(noChildCls); + this.cnt.empty(); + model.set('open', 0); } }, - /** - * Update active style status - * - * @return void - * */ - checkActive: function checkActive() { - if (this.model.get('active')) this.$el.addClass(this.activeCls);else this.$el.removeClass(this.activeCls); + * Count children inside model + * @param {Object} model + * @return {number} + * @private + */ + countChildren: function countChildren(model) { + var count = 0; + model.get('components').each(function (m) { + var isCountable = this.opt.isCountable; + var hide = this.config.hideTextnode; + if (isCountable && !isCountable(m, hide)) return; + count++; + }, this); + return count; }, + getCaret: function getCaret() { + if (!this.caret || !this.caret.length) { + var pfx = this.pfx; + this.caret = this.$el.children(".".concat(this.clsTitleC)).find(".".concat(this.clsCaret)); + } - - /** - * Triggered when button is clicked - * @param {Object} e Event - * - * @return void - * */ - clicked: function clicked(e) { - if (this.model.get('bntsVis')) return; - - if (this.model.get('disable')) return; - - this.toogleActive(); + return this.caret; }, - toogleActive: function toogleActive() { - - if (this.parentM) this.swapParent(); + setRoot: function setRoot(el) { + el = Object(underscore__WEBPACK_IMPORTED_MODULE_0__["isString"])(el) ? this.em.getWrapper().find(el)[0] : el; + var model = Object(utils_mixins__WEBPACK_IMPORTED_MODULE_1__["getModel"])(el, $); + if (!model) return; + this.stopListening(); + this.model = model; + this.initialize(this.opt); + this.render(); + }, + render: function render() { + var model = this.model, + config = this.config, + pfx = this.pfx, + ppfx = this.ppfx, + opt = this.opt; + var isCountable = opt.isCountable; + var hidden = isCountable && !isCountable(model, config.hideTextnode); + var vis = this.isVisible(); + var el = this.$el.empty(); + var level = this.level + 1; - var active = this.model.get('active'); - this.model.set('active', !active); + if (Object(underscore__WEBPACK_IMPORTED_MODULE_0__["isUndefined"])(ItemsView)) { + ItemsView = __webpack_require__(/*! ./ItemsView */ "./src/navigator/view/ItemsView.js").default; + } - // If the stop is requested - var command = this.em.get('Commands').get('select-comp'); + var children = new ItemsView({ + collection: model.get('components'), + config: this.config, + sorter: this.sorter, + opened: this.opt.opened, + parent: model, + level: level + }).render().$el; - if (active) { - if (this.model.get('runDefaultCommand')) this.em.runDefault(); + if (!this.config.showWrapper && level === 1) { + el.append(children); } else { - if (this.model.get('stopDefaultCommand')) this.em.stopDefault(); + el.html(this.template(model)); + el.find(".".concat(this.clsChildren)).append(children); } - }, - - - /** - * Updates parent model swapping properties - * - * @return void - * */ - swapParent: function swapParent() { - this.parentM.collection.deactivateAll(this.model.get('context')); - this.parentM.set('attributes', this.model.get('attributes')); - this.parentM.set('options', this.model.get('options')); - this.parentM.set('command', this.model.get('command')); - this.parentM.set('className', this.model.get('className')); - this.parentM.set('active', true, { silent: true }).trigger('checkActive'); - }, - render: function render() { - this.updateAttributes(); - this.$el.attr('class', this.className); - if (this.model.get('buttons').length) { - var btnsView = __webpack_require__(30); //Avoid Circular Dependencies - var view = new btnsView({ - collection: this.model.get('buttons'), - config: this.config, - parentM: this.model - }); - this.$buttons = view.render().$el; - this.$buttons.append($('
', { class: this.pfx + 'arrow-l' })); - this.$el.append(this.$buttons); //childNodes avoids wrapping 'div' + if (!model.get('draggable') || !this.config.sortable) { + el.children(".".concat(this.clsMove)).remove(); } + !vis && (this.className += " ".concat(pfx, "hide")); + hidden && (this.className += " ".concat(ppfx, "hidden")); + el.attr('class', this.className); + this.updateOpening(); + this.updateStatus(); + this.updateVisibility(); return this; } -}); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(0), __webpack_require__(1))) +})); /***/ }), -/* 114 */ -/***/ (function(module, exports, __webpack_require__) { + +/***/ "./src/navigator/view/ItemsView.js": +/*!*****************************************!*\ + !*** ./src/navigator/view/ItemsView.js ***! + \*****************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _ItemView__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./ItemView */ "./src/navigator/view/ItemView.js"); -var Backbone = __webpack_require__(0); -var PanelView = __webpack_require__(29); +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_0___default.a.View.extend({ + initialize: function initialize() { + var o = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + this.opt = o; + var config = o.config || {}; + this.level = o.level; + this.config = config; + this.preview = o.preview; + this.ppfx = config.pStylePrefix || ''; + this.pfx = config.stylePrefix || ''; + this.parent = o.parent; + var pfx = this.pfx; + var ppfx = this.ppfx; + var parent = this.parent; + var coll = this.collection; + this.listenTo(coll, 'add', this.addTo); + this.listenTo(coll, 'reset resetNavigator', this.render); + this.listenTo(coll, 'remove', this.removeChildren); + this.className = "".concat(pfx, "layers"); + var em = config.em; -module.exports = Backbone.View.extend({ - initialize: function initialize(o) { - this.opt = o || {}; - this.config = this.opt.config || {}; - this.pfx = this.config.stylePrefix || ''; - this.listenTo(this.collection, 'add', this.addTo); - this.listenTo(this.collection, 'reset', this.render); - this.className = this.pfx + 'panels'; - }, + if (config.sortable && !this.opt.sorter) { + var utils = em.get('Utils'); + this.opt.sorter = new utils.Sorter({ + container: config.sortContainer || this.el, + containerSel: ".".concat(this.className), + itemSel: ".".concat(pfx, "layer"), + ignoreViewChildren: 1, + onEndMove: function onEndMove(created, sorter) { + var srcModel = sorter.getSourceModel(); + em.setSelected(srcModel, { + forceChange: 1 + }); + }, + avoidSelectOnEnd: 1, + nested: 1, + ppfx: ppfx, + pfx: pfx + }); + } + + this.sorter = this.opt.sorter || ''; // For the sorter + this.$el.data('collection', coll); + parent && this.$el.data('model', parent); + }, + removeChildren: function removeChildren(removed) { + var view = removed.viewLayer; + if (!view) return; + view.remove.apply(view); + }, /** * Add to collection * @param Object Model * * @return Object - * @private * */ addTo: function addTo(model) { - this.addToCollection(model); + var i = this.collection.indexOf(model); + this.addToCollection(model, null, i); }, - /** * Add new object to collection * @param Object Model @@ -35575,11201 +37579,14984 @@ module.exports = Backbone.View.extend({ * @param integer Index of append * * @return Object Object created - * @private * */ - addToCollection: function addToCollection(model, fragmentEl) { + addToCollection: function addToCollection(model, fragmentEl, index) { + var level = this.level; var fragment = fragmentEl || null; - var view = new PanelView({ + var viewObject = _ItemView__WEBPACK_IMPORTED_MODULE_1__["default"]; + var view = new viewObject({ + level: level, model: model, - config: this.config + config: this.config, + sorter: this.sorter, + isCountable: this.isCountable, + opened: this.opt.opened }); var rendered = view.render().el; - var appendTo = model.get('appendTo'); - if (appendTo) { - var appendEl = document.querySelector(appendTo); - appendEl.appendChild(rendered); + if (fragment) { + fragment.appendChild(rendered); } else { - if (fragment) { - fragment.appendChild(rendered); - } else { - this.$el.append(rendered); - } + if (typeof index != 'undefined') { + var method = 'before'; // If the added model is the last of collection + // need to change the logic of append + + if (this.$el.children().length == index) { + index--; + method = 'after'; + } // In case the added is new in the collection index will be -1 + + + if (index < 0) { + this.$el.append(rendered); + } else this.$el.children().eq(index)[method](rendered); + } else this.$el.append(rendered); } - view.initResize(); return rendered; }, + + /** + * Check if the model could be count by the navigator + * @param {Object} model + * @return {Boolean} + * @private + */ + isCountable: function isCountable(model, hide) { + var type = model.get('type'); + var tag = model.get('tagName'); + + if ((type == 'textnode' || tag == 'br') && hide || !model.get('layerable')) { + return false; + } + + return true; + }, render: function render() { - var fragment = document.createDocumentFragment(); - this.$el.empty(); + var _this = this; + var frag = document.createDocumentFragment(); + var el = this.el; + el.innerHTML = ''; this.collection.each(function (model) { - this.addToCollection(model, fragment); - }, this); - - this.$el.append(fragment); - this.$el.attr('class', this.className); + return _this.addToCollection(model, frag); + }); + el.appendChild(frag); + el.className = this.className; return this; } -}); +})); /***/ }), -/* 115 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - -var _RichTextEditor = __webpack_require__(116); +/***/ "./src/panels/config/config.js": +/*!*************************************!*\ + !*** ./src/panels/config/config.js ***! + \*************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { -var _RichTextEditor2 = _interopRequireDefault(_RichTextEditor); +"use strict"; +__webpack_require__.r(__webpack_exports__); +var swv = 'sw-visibility'; +var expt = 'export-template'; +var osm = 'open-sm'; +var otm = 'open-tm'; +var ola = 'open-layers'; +var obl = 'open-blocks'; +var ful = 'fullscreen'; +var prv = 'preview'; +/* harmony default export */ __webpack_exports__["default"] = ({ + stylePrefix: 'pn-', + // Default panels fa-sliders for features + defaults: [{ + id: 'commands', + buttons: [{}] + }, { + id: 'options', + buttons: [{ + active: true, + id: swv, + className: 'fa fa-square-o', + command: swv, + context: swv, + attributes: { + title: 'View components' + } + }, { + id: prv, + className: 'fa fa-eye', + command: prv, + context: prv, + attributes: { + title: 'Preview' + } + }, { + id: ful, + className: 'fa fa-arrows-alt', + command: ful, + context: ful, + attributes: { + title: 'Fullscreen' + } + }, { + id: expt, + className: 'fa fa-code', + command: expt, + attributes: { + title: 'View code' + } + }] + }, { + id: 'views', + buttons: [{ + id: osm, + className: 'fa fa-paint-brush', + command: osm, + active: true, + togglable: 0, + attributes: { + title: 'Open Style Manager' + } + }, { + id: otm, + className: 'fa fa-cog', + command: otm, + togglable: 0, + attributes: { + title: 'Settings' + } + }, { + id: ola, + className: 'fa fa-bars', + command: ola, + togglable: 0, + attributes: { + title: 'Open Layer Manager' + } + }, { + id: obl, + className: 'fa fa-th-large', + command: obl, + togglable: 0, + attributes: { + title: 'Open Blocks' + } + }] + }], + // Editor model + em: null, + // Delay before show children buttons (in milliseconds) + delayBtnsShow: 300 +}); -var _mixins = __webpack_require__(2); +/***/ }), -function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } +/***/ "./src/panels/index.js": +/*!*****************************!*\ + !*** ./src/panels/index.js ***! + \*****************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _config_config__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./config/config */ "./src/panels/config/config.js"); +/* harmony import */ var _model_Panel__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./model/Panel */ "./src/panels/model/Panel.js"); +/* harmony import */ var _model_Panels__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./model/Panels */ "./src/panels/model/Panels.js"); +/* harmony import */ var _view_PanelView__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./view/PanelView */ "./src/panels/view/PanelView.js"); +/* harmony import */ var _view_PanelsView__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./view/PanelsView */ "./src/panels/view/PanelsView.js"); /** - * This module allows to customize the toolbar of the Rich Text Editor and use commands from the HTML Editing APIs. - * For more info about HTML Editing APIs check here: - * https://developer.mozilla.org/en-US/docs/Web/API/Document/execCommand - * - * It's highly recommended to keep this toolbar as small as possible, especially from styling commands (eg. 'fontSize') - * and leave this task to the Style Manager. + * You can customize the initial state of the module from the editor initialization, by passing the following [Configuration Object](https://github.com/artf/grapesjs/blob/master/src/panels/config/config.js) + * ```js + * const editor = grapesjs.init({ + * panels: { + * // options + * } + * }) + * ``` * - * Before using methods you should get first the module from the editor instance, in this way: + * Once the editor is instantiated you can use its API. Before using these methods you should get the module from the instance * * ```js - * var rte = editor.RichTextEditor; + * const panelManager = editor.Panels; * ``` - * @module RichTextEditor + * + * * [addPanel](#addpanel) + * * [addButton](#addbutton) + * * [getButton](#getbutton) + * * [getPanel](#getpanel) + * * [getPanels](#getpanels) + * * [getPanelsEl](#getpanelsel) + * * [removePanel](#removepanel) + * * [removeButton](#removebutton) + * + * @module Panels */ -module.exports = function () { - var config = {}; - var defaults = __webpack_require__(117); - var toolbar = void 0, - actions = void 0, - lastEl = void 0, - globalRte = void 0; - var hideToolbar = function hideToolbar() { - var style = toolbar.style; - var size = '-100px'; - style.top = size; - style.left = size; - style.display = 'none'; - }; - return { - customRte: null, + +/* harmony default export */ __webpack_exports__["default"] = (function () { + var c = {}; + var panels, PanelsViewObj; + return { /** * Name of the module * @type {String} * @private */ - name: 'RichTextEditor', + name: 'Panels', /** * Initialize module. Automatically called with a new instance of the editor - * @param {Object} opts Options + * @param {Object} config Configurations * @private */ - init: function init() { - var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; - - config = opts; - - for (var name in defaults) { - if (!(name in config)) { - config[name] = defaults[name]; - } - } - - var ppfx = config.pStylePrefix; + init: function init(config) { + c = config || {}; - if (ppfx) { - config.stylePrefix = ppfx + config.stylePrefix; + for (var name in _config_config__WEBPACK_IMPORTED_MODULE_0__["default"]) { + if (!(name in c)) c[name] = _config_config__WEBPACK_IMPORTED_MODULE_0__["default"][name]; } - this.pfx = config.stylePrefix; - actions = config.actions || []; - toolbar = document.createElement('div'); - toolbar.className = ppfx + 'rte-toolbar ' + ppfx + 'one-bg'; - globalRte = this.initRte(document.createElement('div')); - - //Avoid closing on toolbar clicking - (0, _mixins.on)(toolbar, 'mousedown', function (e) { - return e.stopPropagation(); + var ppfx = c.pStylePrefix; + if (ppfx) c.stylePrefix = ppfx + c.stylePrefix; + panels = new _model_Panels__WEBPACK_IMPORTED_MODULE_2__["default"](c.defaults); + PanelsViewObj = new _view_PanelsView__WEBPACK_IMPORTED_MODULE_4__["default"]({ + collection: panels, + config: c }); return this; }, - /** - * Post render callback - * @param {View} ev - * @private + * Returns the collection of panels + * @return {Collection} Collection of panel */ - postRender: function postRender(ev) { - var canvas = ev.model.get('Canvas'); - toolbar.style.pointerEvents = 'all'; - hideToolbar(); - canvas.getToolsEl().appendChild(toolbar); + getPanels: function getPanels() { + return panels; }, - /** - * Init the built-in RTE - * @param {HTMLElement} el - * @return {RichTextEditor} - * @private + * Returns panels element + * @return {HTMLElement} */ - initRte: function initRte(el) { - var pfx = this.pfx; - var actionbarContainer = toolbar; - var actionbar = this.actionbar; - var actions = this.actions || config.actions; - var classes = { - actionbar: pfx + 'actionbar', - button: pfx + 'action', - active: pfx + 'active' - }; - var rte = new _RichTextEditor2.default({ - el: el, - classes: classes, - actions: actions, - actionbar: actionbar, - actionbarContainer: actionbarContainer - }); - globalRte && globalRte.setEl(el); - - if (rte.actionbar) { - this.actionbar = rte.actionbar; - } - - if (rte.actions) { - this.actions = rte.actions; - } - - return rte; + getPanelsEl: function getPanelsEl() { + return PanelsViewObj.el; }, - /** - * Add a new action to the built-in RTE toolbar - * @param {string} name Action name - * @param {Object} action Action options + * Add new panel to the collection + * @param {Object|Panel} panel Object with right properties or an instance of Panel + * @return {Panel} Added panel. Useful in case passed argument was an Object * @example - * rte.add('bold', { - * icon: 'B', - * attributes: {title: 'Bold',} - * result: rte => rte.exec('bold') + * var newPanel = panelManager.addPanel({ + * id: 'myNewPanel', + * visible : true, + * buttons : [...], * }); - * rte.add('link', { - * icon: document.getElementById('t'), - * attributes: {title: 'Link',} - * // Example on it's easy to wrap a selected content - * result: rte => rte.insertHTML(`${rte.selection()}`) + */ + addPanel: function addPanel(panel) { + return panels.add(panel); + }, + + /** + * Remove a panel from the collection + * @param {Object|Panel|String} panel Object with right properties or an instance of Panel or Painel id + * @return {Panel} Removed panel. Useful in case passed argument was an Object + * @example + * const newPanel = panelManager.removePanel({ + * id: 'myNewPanel', + * visible : true, + * buttons : [...], * }); - * // An example with fontSize - * rte.add('fontSize', { - * icon: ``, - * // Bind the 'result' on 'change' listener - * event: 'change', - * result: (rte, action) => rte.exec('fontSize', action.btn.firstChild.value), - * // Callback on any input change (mousedown, keydown, etc..) - * update: (rte, action) => { - * const value = rte.doc.queryCommandValue(action.name); - * if (value != 'false') { // value is a string - * action.btn.firstChild.value = value; - * } - * } - * }) + * + * const newPanel = panelManager.removePanel('myNewPanel'); + * */ - add: function add(name) { - var action = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + removePanel: function removePanel(panel) { + return panels.remove(panel); + }, - action.name = name; - globalRte.addAction(action, { sync: 1 }); + /** + * Get panel by ID + * @param {string} id Id string + * @return {Panel|null} + * @example + * var myPanel = panelManager.getPanel('myNewPanel'); + */ + getPanel: function getPanel(id) { + var res = panels.where({ + id: id + }); + return res.length ? res[0] : null; }, - /** - * Get the action by its name - * @param {string} name Action name - * @return {Object} + * Add button to the panel + * @param {string} panelId Panel's ID + * @param {Object|Button} button Button object or instance of Button + * @return {Button|null} Added button. Useful in case passed button was an Object * @example - * const action = rte.get('bold'); - * // {name: 'bold', ...} + * var newButton = panelManager.addButton('myNewPanel',{ + * id: 'myNewButton', + * className: 'someClass', + * command: 'someCommand', + * attributes: { title: 'Some title'}, + * active: false, + * }); + * // It's also possible to pass the command as an object + * // with .run and .stop methods + * ... + * command: { + * run: function(editor) { + * ... + * }, + * stop: function(editor) { + * ... + * } + * }, + * // Or simply like a function which will be evaluated as a single .run command + * ... + * command: function(editor) { + * ... + * } */ - get: function get(name) { - var result = void 0; - globalRte.getActions().forEach(function (action) { - if (action.name == name) { - result = action; - } - }); - return result; + addButton: function addButton(panelId, button) { + var pn = this.getPanel(panelId); + return pn ? pn.get('buttons').add(button) : null; }, - /** - * Get all actions - * @return {Array} + * Remove button from the panel + * @param {String} panelId Panel's ID + * @param {String} buttonId Button's ID + * @return {Button|null} Removed button. + * @example + * const removedButton = panelManager.addButton('myNewPanel',{ + * id: 'myNewButton', + * className: 'someClass', + * command: 'someCommand', + * attributes: { title: 'Some title'}, + * active: false, + * }); + * + * const removedButton = panelManager.removeButton('myNewPanel', 'myNewButton'); + * */ - getAll: function getAll() { - return globalRte.getActions(); + removeButton: function removeButton(panelId, button) { + var pn = this.getPanel(panelId); + return pn && pn.get('buttons').remove(button); }, - /** - * Remove the action from the toolbar - * @param {string} name - * @return {Object} Removed action + * Get button from the panel + * @param {string} panelId Panel's ID + * @param {string} id Button's ID + * @return {Button|null} * @example - * const action = rte.remove('bold'); - * // {name: 'bold', ...} + * var button = panelManager.getButton('myPanel','myButton'); */ - remove: function remove(name) { - var actions = this.getAll(); - var action = this.get(name); + getButton: function getButton(panelId, id) { + var pn = this.getPanel(panelId); - if (action) { - var btn = action.btn; - var index = actions.indexOf(action); - btn.parentNode.removeChild(btn); - actions.splice(index, 1); + if (pn) { + var res = pn.get('buttons').where({ + id: id + }); + return res.length ? res[0] : null; } - return action; + return null; }, - /** - * Get the toolbar element + * Render panels and buttons * @return {HTMLElement} + * @private */ - getToolbarEl: function getToolbarEl() { - return toolbar; + render: function render() { + return PanelsViewObj.render().el; }, + /** + * Active activable buttons + * @private + */ + active: function active() { + this.getPanels().each(function (p) { + p.get('buttons').each(function (btn) { + btn.get('active') && btn.trigger('updateActive'); + }); + }); + }, /** - * Triggered when the offset of the editor is changed + * Disable buttons flagged as disabled * @private */ - udpatePosition: function udpatePosition() { - var un = 'px'; - var canvas = config.em.get('Canvas'); - var pos = canvas.getTargetToElementDim(toolbar, lastEl, { - event: 'rteToolbarPosUpdate' + disableButtons: function disableButtons() { + this.getPanels().each(function (p) { + p.get('buttons').each(function (btn) { + if (btn.get('disable')) btn.trigger('change:disable'); + }); }); + }, + Panel: _model_Panel__WEBPACK_IMPORTED_MODULE_1__["default"] + }; +}); - if (config.adjustToolbar) { - // Move the toolbar down when the top canvas edge is reached - if (pos.top <= pos.canvasTop) { - pos.top = pos.elementTop + pos.elementHeight; - } - } +/***/ }), - var toolbarStyle = toolbar.style; - toolbarStyle.top = pos.top + un; - toolbarStyle.left = pos.left + un; - }, +/***/ "./src/panels/model/Button.js": +/*!************************************!*\ + !*** ./src/panels/model/Button.js ***! + \************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); - /** - * Enable rich text editor on the element - * @param {View} view Component view - * @param {Object} rte The instance of already defined RTE - * @private - * */ - enable: function enable(view, rte) { - lastEl = view.el; - var em = config.em; - var el = view.getChildrenContainer(); - var customRte = this.customRte; +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_0___default.a.Model.extend({ + defaults: { + id: '', + label: '', + tagName: 'span', + className: '', + command: '', + context: '', + buttons: [], + attributes: {}, + options: {}, + active: false, + dragDrop: false, + togglable: true, + runDefaultCommand: true, + stopDefaultCommand: false, + disable: false + }, + initialize: function initialize(options) { + if (this.get('buttons').length) { + var Buttons = __webpack_require__(/*! ./Buttons */ "./src/panels/model/Buttons.js").default; - toolbar.style.display = ''; - rte = customRte ? customRte.enable(el, rte) : this.initRte(el).enable(); + this.set('buttons', new Buttons(this.get('buttons'))); + } + } +})); - if (em) { - setTimeout(this.udpatePosition.bind(this), 0); - var event = 'change:canvasOffset canvasScroll'; - em.off(event, this.udpatePosition, this); - em.on(event, this.udpatePosition, this); - em.trigger('rte:enable', view, rte); - } +/***/ }), - return rte; - }, +/***/ "./src/panels/model/Buttons.js": +/*!*************************************!*\ + !*** ./src/panels/model/Buttons.js ***! + \*************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _Button__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Button */ "./src/panels/model/Button.js"); - /** - * Unbind rich text editor from the element - * @param {View} view - * @param {Object} rte The instance of already defined RTE - * @private - * */ - disable: function disable(view, rte) { - var em = config.em; - var customRte = this.customRte; - var el = view.getChildrenContainer(); - if (customRte) { - customRte.disable(el, rte); - } else { - rte && rte.disable(); +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_0___default.a.Collection.extend({ + model: _Button__WEBPACK_IMPORTED_MODULE_1__["default"], + + /** + * Deactivate all buttons, except one passed + * @param {Object} except Model to ignore + * @param {Boolean} r Recursive flag + * + * @return void + * */ + deactivateAllExceptOne: function deactivateAllExceptOne(except, r) { + this.forEach(function (model, index) { + if (model !== except) { + model.set('active', false); + if (r && model.get('buttons').length) model.get('buttons').deactivateAllExceptOne(except, r); } + }); + }, - hideToolbar(); - em && em.trigger('rte:disable', view, rte); - } - }; -}; + /** + * Deactivate all buttons + * @param {String} ctx Context string + * + * @return void + * */ + deactivateAll: function deactivateAll(ctx, sender) { + var context = ctx || ''; + this.forEach(function (model) { + if (model.get('context') == context && model !== sender) { + model.set('active', false, { + silent: 1 + }); + model.trigger('updateActive', { + fromCollection: 1 + }); + } + }); + }, + + /** + * Disables all buttons + * @param {String} ctx Context string + * + * @return void + * */ + disableAllButtons: function disableAllButtons(ctx) { + var context = ctx || ''; + this.forEach(function (model, index) { + if (model.get('context') == context) { + model.set('disable', true); + } + }); + }, + + /** + * Disables all buttons, except one passed + * @param {Object} except Model to ignore + * @param {Boolean} r Recursive flag + * + * @return void + * */ + disableAllButtonsExceptOne: function disableAllButtonsExceptOne(except, r) { + this.forEach(function (model, index) { + if (model !== except) { + model.set('disable', true); + if (r && model.get('buttons').length) model.get('buttons').disableAllButtonsExceptOne(except, r); + } + }); + } +})); + +/***/ }), + +/***/ "./src/panels/model/Panel.js": +/*!***********************************!*\ + !*** ./src/panels/model/Panel.js ***! + \***********************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _Buttons__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Buttons */ "./src/panels/model/Buttons.js"); + + +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_0___default.a.Model.extend({ + defaults: { + id: '', + content: '', + visible: true, + buttons: [], + attributes: {} + }, + initialize: function initialize(options) { + this.btn = this.get('buttons') || []; + this.buttons = new _Buttons__WEBPACK_IMPORTED_MODULE_1__["default"](this.btn); + this.set('buttons', this.buttons); + } +})); /***/ }), -/* 116 */ -/***/ (function(module, exports, __webpack_require__) { + +/***/ "./src/panels/model/Panels.js": +/*!************************************!*\ + !*** ./src/panels/model/Panels.js ***! + \************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _Panel__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Panel */ "./src/panels/model/Panel.js"); -Object.defineProperty(exports, "__esModule", { - value: true -}); +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_0___default.a.Collection.extend({ + model: _Panel__WEBPACK_IMPORTED_MODULE_1__["default"] +})); -var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; +/***/ }), -var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); // The initial version of this RTE was borrowed from https://github.com/jaredreich/pell -// and adapted to the GrapesJS's need +/***/ "./src/panels/view/ButtonView.js": +/*!***************************************!*\ + !*** ./src/panels/view/ButtonView.js ***! + \***************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { -var _mixins = __webpack_require__(2); +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_2__); -function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } -var RTE_KEY = '_rte'; +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } -var defActions = { - bold: { - name: 'bold', - icon: 'B', - attributes: { title: 'Bold' }, - result: function result(rte) { - return rte.exec('bold'); - } - }, - italic: { - name: 'italic', - icon: 'I', - attributes: { title: 'Italic' }, - result: function result(rte) { - return rte.exec('italic'); - } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } + + + +var $ = backbone__WEBPACK_IMPORTED_MODULE_1___default.a.$; +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_1___default.a.View.extend({ + tagName: function tagName() { + return this.model.get('tagName'); }, - underline: { - name: 'underline', - icon: 'U', - attributes: { title: 'Underline' }, - result: function result(rte) { - return rte.exec('underline'); - } + events: { + click: 'clicked' }, - strikethrough: { - name: 'strikethrough', - icon: 'S', - attributes: { title: 'Strike-through' }, - result: function result(rte) { - return rte.exec('strikeThrough'); - } + initialize: function initialize(o) { + var cls = this.model.get('className'); + this.config = o.config || {}; + this.em = this.config.em || {}; + var pfx = this.config.stylePrefix || ''; + var ppfx = this.config.pStylePrefix || ''; + this.pfx = pfx; + this.ppfx = this.config.pStylePrefix || ''; + this.id = pfx + this.model.get('id'); + this.activeCls = "".concat(pfx, "active ").concat(ppfx, "four-color"); + this.disableCls = "".concat(ppfx, "disabled"); + this.btnsVisCls = "".concat(pfx, "visible"); + this.className = pfx + 'btn' + (cls ? ' ' + cls : ''); + this.listenTo(this.model, 'change', this.render); + this.listenTo(this.model, 'change:active updateActive', this.updateActive); + this.listenTo(this.model, 'checkActive', this.checkActive); + this.listenTo(this.model, 'change:bntsVis', this.updateBtnsVis); + this.listenTo(this.model, 'change:attributes', this.updateAttributes); + this.listenTo(this.model, 'change:className', this.updateClassName); + this.listenTo(this.model, 'change:disable', this.updateDisable); + if (this.em && this.em.get) this.commands = this.em.get('Commands'); }, - link: { - icon: '', - name: 'link', - attributes: { - style: 'font-size:1.4rem;padding:0 4px 2px;', - title: 'Link' - }, - result: function result(rte) { - return rte.insertHTML('' + rte.selection() + ''); - } - } -}; -var RichTextEditor = function () { - function RichTextEditor() { - var _this = this; + /** + * Updates class name of the button + * + * @return void + * */ + updateClassName: function updateClassName() { + var model = this.model, + pfx = this.pfx; + var cls = model.get('className'); + var attrCls = model.get('attributes').class; + var classStr = "".concat(attrCls ? attrCls : '', " ").concat(pfx, "btn ").concat(cls ? cls : ''); + this.$el.attr('class', classStr.trim()); + }, - var settings = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + /** + * Updates attributes of the button + * + * @return void + * */ + updateAttributes: function updateAttributes() { + this.$el.attr(this.model.get('attributes')); + this.updateClassName(); + }, - _classCallCheck(this, RichTextEditor); + /** + * Updates visibility of children buttons + * + * @return void + * */ + updateBtnsVis: function updateBtnsVis() { + if (!this.$buttons) return; + if (this.model.get('bntsVis')) this.$buttons.addClass(this.btnsVisCls);else this.$buttons.removeClass(this.btnsVisCls); + }, - var el = settings.el; + /** + * Update active status of the button + * + * @return void + * */ + updateActive: function updateActive() { + var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var model = this.model, + commands = this.commands, + $el = this.$el, + activeCls = this.activeCls; + var fromCollection = opts.fromCollection; + var context = model.get('context'); + var options = model.get('options'); + var commandName = model.get('command'); + var command = {}; - if (el[RTE_KEY]) { - return el[RTE_KEY]; + if (commands && Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isString"])(commandName)) { + command = commands.get(commandName) || {}; + } else if (Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isFunction"])(commandName)) { + command = commands.create({ + run: commandName + }); + } else if (commandName !== null && Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isObject"])(commandName)) { + command = commands.create(commandName); } - el[RTE_KEY] = this; - this.setEl(el); - this.updateActiveActions = this.updateActiveActions.bind(this); + if (model.get('active')) { + !fromCollection && model.collection.deactivateAll(context, model); + model.set('active', true, { + silent: true + }).trigger('checkActive'); + commands.runCommand(command, _objectSpread({}, options, { + sender: model + })); // Disable button if the command has no stop method + + command.noStop && model.set('active', false); + } else { + $el.removeClass(activeCls); + commands.stopCommand(command, _objectSpread({}, options, { + sender: model, + force: 1 + })); + } + }, + updateDisable: function updateDisable() { + var disableCls = this.disableCls, + model = this.model; + var disable = model.get('disable'); + this.$el[disable ? 'addClass' : 'removeClass'](disableCls); + }, - var settAct = settings.actions || []; - settAct.forEach(function (action, i) { - if (typeof action === 'string') { - action = defActions[action]; - } else if (defActions[action.name]) { - action = _extends({}, defActions[action.name], action); - } - settAct[i] = action; - }); - var actions = settAct.length ? settAct : Object.keys(defActions).map(function (action) { - return defActions[action]; - }); + /** + * Update active style status + * + * @return void + * */ + checkActive: function checkActive() { + var model = this.model, + $el = this.$el, + activeCls = this.activeCls; + model.get('active') ? $el.addClass(activeCls) : $el.removeClass(activeCls); + }, - settings.classes = _extends({ - actionbar: 'actionbar', - button: 'action', - active: 'active' - }, settings.classes); + /** + * Triggered when button is clicked + * @param {Object} e Event + * + * @return void + * */ + clicked: function clicked(e) { + if (this.model.get('bntsVis')) return; + if (this.model.get('disable')) return; + this.toogleActive(); + }, + toogleActive: function toogleActive() { + var model = this.model; + var _model$attributes = model.attributes, + active = _model$attributes.active, + togglable = _model$attributes.togglable; + if (active && !togglable) return; + model.set('active', !active); // If the stop is requested - var classes = settings.classes; - var actionbar = settings.actionbar; - this.actionbar = actionbar; - this.settings = settings; - this.classes = classes; - this.actions = actions; + var command = this.em.get('Commands').get('select-comp'); - if (!actionbar) { - var actionbarCont = settings.actionbarContainer; - actionbar = document.createElement('div'); - actionbar.className = classes.actionbar; - actionbarCont.appendChild(actionbar); - this.actionbar = actionbar; - actions.forEach(function (action) { - return _this.addAction(action); - }); + if (active) { + if (model.get('runDefaultCommand')) this.em.runDefault(); + } else { + if (model.get('stopDefaultCommand')) this.em.stopDefault(); } - - settings.styleWithCSS && this.exec('styleWithCSS'); - this.syncActions(); - + }, + render: function render() { + var label = this.model.get('label'); + var $el = this.$el; + $el.empty(); + this.updateAttributes(); + label && $el.append(label); + this.checkActive(); + this.updateDisable(); return this; } +})); - _createClass(RichTextEditor, [{ - key: 'setEl', - value: function setEl(el) { - this.el = el; - this.doc = el.ownerDocument; - } - }, { - key: 'updateActiveActions', - value: function updateActiveActions() { - var _this2 = this; - - this.getActions().forEach(function (action) { - var btn = action.btn; - var update = action.update; - var active = _this2.classes.active; - var name = action.name; - var doc = _this2.doc; - btn.className = btn.className.replace(active, '').trim(); +/***/ }), - // doc.queryCommandValue(name) != 'false' - if (doc.queryCommandState(name)) { - btn.className += ' ' + active; - } +/***/ "./src/panels/view/ButtonsView.js": +/*!****************************************!*\ + !*** ./src/panels/view/ButtonsView.js ***! + \****************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - update && update(_this2, action); - }); - } - }, { - key: 'enable', - value: function enable() { - if (this.enabled) { - return this; - } +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _ButtonView__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./ButtonView */ "./src/panels/view/ButtonView.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_2__); - this.actionbarEl().style.display = ''; - this.el.contentEditable = true; - (0, _mixins.on)(this.el, 'mouseup keyup', this.updateActiveActions); - this.syncActions(); - this.updateActiveActions(); - this.el.focus(); - this.enabled = 1; - return this; - } - }, { - key: 'disable', - value: function disable() { - this.actionbarEl().style.display = 'none'; - this.el.contentEditable = false; - (0, _mixins.off)(this.el, 'mouseup keyup', this.updateActiveActions); - this.enabled = 0; - return this; - } - /** - * Sync actions with the current RTE - */ - }, { - key: 'syncActions', - value: function syncActions() { - var _this3 = this; +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_0___default.a.View.extend({ + initialize: function initialize(o) { + this.opt = o || {}; + this.config = this.opt.config || {}; + this.pfx = this.config.stylePrefix || ''; + this.parentM = this.opt.parentM || null; + this.listenTo(this.collection, 'add', this.addTo); + this.listenTo(this.collection, 'reset remove', this.render); + this.className = this.pfx + 'buttons'; + }, - this.getActions().forEach(function (action) { - var event = action.event || 'click'; - action.btn['on' + event] = function (e) { - action.result(_this3, action); - _this3.updateActiveActions(); - }; - }); - } + /** + * Add to collection + * @param Object Model + * + * @return Object + * */ + addTo: function addTo(model) { + this.addToCollection(model); + }, - /** - * Add new action to the actionbar - * @param {Object} action - * @param {Object} [opts={}] - */ + /** + * Add new object to collection + * @param Object Model + * @param Object Fragment collection + * + * @return Object Object created + * */ + addToCollection: function addToCollection(model, fragmentEl) { + var fragment = fragmentEl || null; + var viewObject = _ButtonView__WEBPACK_IMPORTED_MODULE_1__["default"]; + var view = new viewObject({ + model: model, + config: this.config, + parentM: this.parentM + }); + var rendered = view.render().el; - }, { - key: 'addAction', - value: function addAction(action) { - var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + if (fragment) { + fragment.appendChild(rendered); + } else { + this.$el.append(rendered); + } - var sync = opts.sync; - var btn = document.createElement('span'); - var icon = action.icon; - var attr = action.attributes || {}; - btn.className = this.classes.button; - action.btn = btn; + return rendered; + }, + render: function render() { + var fragment = document.createDocumentFragment(); + this.$el.empty(); + this.collection.each(function (model) { + this.addToCollection(model, fragment); + }, this); + this.$el.append(fragment); + this.$el.attr('class', Object(underscore__WEBPACK_IMPORTED_MODULE_2__["result"])(this, 'className')); + return this; + } +})); - for (var key in attr) { - btn.setAttribute(key, attr[key]); - } +/***/ }), - if (typeof icon == 'string') { - btn.innerHTML = icon; - } else { - btn.appendChild(icon); - } +/***/ "./src/panels/view/PanelView.js": +/*!**************************************!*\ + !*** ./src/panels/view/PanelView.js ***! + \**************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - this.actionbarEl().appendChild(btn); +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var _ButtonsView__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./ButtonsView */ "./src/panels/view/ButtonsView.js"); - if (sync) { - this.actions.push(action); - this.syncActions(); - } - } - /** - * Get the array of current actions - * @return {Array} - */ +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - }, { - key: 'getActions', - value: function getActions() { - return this.actions; - } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - /** - * Returns the Selection instance - * @return {Selection} - */ - }, { - key: 'selection', - value: function selection() { - return this.doc.getSelection(); - } - /** - * Execute the command - * @param {string} command Command name - * @param {any} [value=null Command's arguments - */ +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_1___default.a.View.extend({ + initialize: function initialize(o) { + var config = o.config || {}; + var model = this.model; + this.config = config; + this.pfx = config.stylePrefix || ''; + this.ppfx = config.pStylePrefix || ''; + this.buttons = model.get('buttons'); + this.className = this.pfx + 'panel'; + this.id = this.pfx + model.get('id'); + this.listenTo(model, 'change:appendContent', this.appendContent); + this.listenTo(model, 'change:content', this.updateContent); + this.listenTo(model, 'change:visible', this.toggleVisible); + model.view = this; + }, - }, { - key: 'exec', - value: function exec(command) { - var value = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null; + /** + * Append content of the panel + * */ + appendContent: function appendContent() { + this.$el.append(this.model.get('appendContent')); + }, - this.doc.execCommand(command, false, value); + /** + * Update content + * */ + updateContent: function updateContent() { + this.$el.html(this.model.get('content')); + }, + toggleVisible: function toggleVisible() { + if (!this.model.get('visible')) { + this.$el.addClass("".concat(this.ppfx, "hidden")); + return; } - /** - * Get the actionbar element - * @return {HTMLElement} - */ + this.$el.removeClass("".concat(this.ppfx, "hidden")); + }, + attributes: function attributes() { + return this.model.get('attributes'); + }, + initResize: function initResize() { + var em = this.config.em; + var editor = em ? em.get('Editor') : ''; + var resizable = this.model.get('resizable'); - }, { - key: 'actionbarEl', - value: function actionbarEl() { - return this.actionbar; - } + if (editor && resizable) { + var resz = resizable === true ? [1, 1, 1, 1] : resizable; + var resLen = resz.length; + var tc, + cr, + bc, + cl = 0; // Choose which sides of the panel are resizable - /** - * Set custom HTML to the selection, useful as the default 'insertHTML' command - * doesn't work in the same way on all browsers - * @param {string} value HTML string - */ + if (resLen == 2) { + tc = resz[0]; + bc = resz[0]; + cr = resz[1]; + cl = resz[1]; + } else if (resLen == 4) { + tc = resz[0]; + cr = resz[1]; + bc = resz[2]; + cl = resz[3]; + } - }, { - key: 'insertHTML', - value: function insertHTML(value) { - var lastNode = void 0; - var doc = this.doc; - var sel = doc.getSelection(); + var resizer = editor.Utils.Resizer.init(_objectSpread({ + tc: tc, + cr: cr, + bc: bc, + cl: cl, + tl: 0, + tr: 0, + bl: 0, + br: 0, + appendTo: this.el, + silentFrames: 1, + avoidContainerUpdate: 1, + prefix: editor.getConfig().stylePrefix, + onEnd: function onEnd() { + em && em.trigger('change:canvasOffset'); + }, + posFetcher: function posFetcher(el, _ref) { + var target = _ref.target; + var style = el.style; + var config = resizer.getConfig(); + var keyWidth = config.keyWidth; + var keyHeight = config.keyHeight; + var rect = el.getBoundingClientRect(); + var forContainer = target == 'container'; + var styleWidth = style[keyWidth]; + var styleHeight = style[keyHeight]; + var width = styleWidth && !forContainer ? parseFloat(styleWidth) : rect.width; + var height = styleHeight && !forContainer ? parseFloat(styleHeight) : rect.height; + return { + left: 0, + top: 0, + width: width, + height: height + }; + } + }, resizable)); - if (sel && sel.rangeCount) { - var node = doc.createElement('div'); - var range = sel.getRangeAt(0); - range.deleteContents(); - node.innerHTML = value; - Array.prototype.slice.call(node.childNodes).forEach(function (nd) { - range.insertNode(nd); - lastNode = nd; - }); + resizer.blur = function () {}; - sel.removeAllRanges(); - sel.addRange(range); - this.el.focus(); - } + resizer.focus(this.el); } - }]); + }, + render: function render() { + var $el = this.$el; + var ppfx = this.ppfx; + var cls = "".concat(this.className, " ").concat(this.id, " ").concat(ppfx, "one-bg ").concat(ppfx, "two-color"); + $el.addClass(cls); - return RichTextEditor; -}(); + if (this.buttons.length) { + var buttons = new _ButtonsView__WEBPACK_IMPORTED_MODULE_2__["default"]({ + collection: this.buttons, + config: this.config + }); + $el.append(buttons.render().el); + } -exports.default = RichTextEditor; + $el.append(this.model.get('content')); + return this; + } +})); /***/ }), -/* 117 */ -/***/ (function(module, exports, __webpack_require__) { + +/***/ "./src/panels/view/PanelsView.js": +/*!***************************************!*\ + !*** ./src/panels/view/PanelsView.js ***! + \***************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _PanelView__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./PanelView */ "./src/panels/view/PanelView.js"); -module.exports = { +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_0___default.a.View.extend({ + initialize: function initialize(o) { + this.opt = o || {}; + this.config = this.opt.config || {}; + this.pfx = this.config.stylePrefix || ''; + var items = this.collection; + this.listenTo(items, 'add', this.addTo); + this.listenTo(items, 'reset', this.render); + this.listenTo(items, 'remove', this.onRemove); + this.className = this.pfx + 'panels'; + }, + onRemove: function onRemove(model) { + var view = model.view; + view && view.remove(); + }, - stylePrefix: 'rte-', + /** + * Add to collection + * @param Object Model + * + * @return Object + * @private + * */ + addTo: function addTo(model) { + this.addToCollection(model); + }, - // If true, moves the toolbar below the element when the top canvas - // edge is reached - adjustToolbar: 1, + /** + * Add new object to collection + * @param Object Model + * @param Object Fragment collection + * @param integer Index of append + * + * @return Object Object created + * @private + * */ + addToCollection: function addToCollection(model, fragmentEl) { + var fragment = fragmentEl || null; + var config = this.config; + var el = model.get('el'); + var view = new _PanelView__WEBPACK_IMPORTED_MODULE_1__["default"]({ + el: el, + model: model, + config: config + }); + var rendered = view.render().el; + var appendTo = model.get('appendTo'); // Do nothing if the panel was requested to be another element + + if (el) {} else if (appendTo) { + var appendEl = document.querySelector(appendTo); + appendEl.appendChild(rendered); + } else { + if (fragment) { + fragment.appendChild(rendered); + } else { + this.$el.append(rendered); + } + } + + view.initResize(); + return rendered; + }, + render: function render() { + var _this = this; - // Default RTE actions - actions: ['bold', 'italic', 'underline', 'strikethrough', 'link'] -}; + var $el = this.$el; + var frag = document.createDocumentFragment(); + $el.empty(); + this.collection.each(function (model) { + return _this.addToCollection(model, frag); + }); + $el.append(frag); + $el.attr('class', this.className); + return this; + } +})); /***/ }), -/* 118 */ -/***/ (function(module, exports, __webpack_require__) { + +/***/ "./src/parser/config/config.js": +/*!*************************************!*\ + !*** ./src/parser/config/config.js ***! + \*************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony default export */ __webpack_exports__["default"] = ({ + textTags: ['br', 'b', 'i', 'u', 'a', 'ul', 'ol'], + // Custom CSS parser + parserCss: null, + // Custom HTML parser + parserHtml: null +}); +/***/ }), -module.exports = { - stylePrefix: 'sm-', +/***/ "./src/parser/index.js": +/*!*****************************!*\ + !*** ./src/parser/index.js ***! + \*****************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - sectors: [], +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _config_config__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./config/config */ "./src/parser/config/config.js"); +/* harmony import */ var _model_ParserCss__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./model/ParserCss */ "./src/parser/model/ParserCss.js"); +/* harmony import */ var _model_ParserHtml__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./model/ParserHtml */ "./src/parser/model/ParserHtml.js"); - // Text to show in case no element selected - textNoElement: 'Select an element before using Style Manager', - // Hide the property in case it's not stylable for the - // selected component (each component has 'stylable' property) - hideNotStylable: true, +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - // Highlight changed properties of the selected component - highlightChanged: true, +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - // Highlight computed properties of the selected component - highlightComputed: true, - // Show computed properties of the selected component, if this value - // is set to false, highlightComputed will not take effect - showComputed: true, - // Adds the possibility to clear property value from the target style - clearProperties: 0, - // Properties not to take in account for computed styles - avoidComputed: ['width', 'height'] -}; +/* harmony default export */ __webpack_exports__["default"] = (function () { + var conf = {}; + var pHtml, pCss; + return { + compTypes: '', + parserCss: null, + parserHtml: null, -/***/ }), -/* 119 */ -/***/ (function(module, exports, __webpack_require__) { + /** + * Name of the module + * @type {String} + * @private + */ + name: 'Parser', -"use strict"; + /** + * Get config object + * @return {Object} + */ + getConfig: function getConfig() { + return conf; + }, + /** + * Initialize module. Automatically called with a new instance of the editor + * @param {Object} config Configurations + * @param {Array} [config.blocks=[]] Default blocks + * @return {this} + * @example + * ... + * { + * blocks: [ + * {id:'h1-block' label: 'Heading', content:'

...

'}, + * ... + * ], + * } + * ... + */ + init: function init() { + var config = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + conf = _objectSpread({}, _config_config__WEBPACK_IMPORTED_MODULE_1__["default"], {}, config); + conf.Parser = this; + pHtml = new _model_ParserHtml__WEBPACK_IMPORTED_MODULE_3__["default"](conf); + pCss = new _model_ParserCss__WEBPACK_IMPORTED_MODULE_2__["default"](conf); + this.em = conf.em; + this.parserCss = pCss; + this.parserHtml = pHtml; + return this; + }, -var Sector = __webpack_require__(120); + /** + * Parse HTML string and return valid model + * @param {string} str HTML string + * @return {Object} + */ + parseHtml: function parseHtml(str) { + var em = this.em, + compTypes = this.compTypes; + pHtml.compTypes = em ? em.get('DomComponents').getTypes() : compTypes; + return pHtml.parse(str, pCss); + }, -module.exports = __webpack_require__(0).Collection.extend({ - model: Sector + /** + * Parse CSS string and return valid model + * @param {string} str CSS string + * @return {Array} + */ + parseCss: function parseCss(str) { + return pCss.parse(str); + } + }; }); /***/ }), -/* 120 */ -/***/ (function(module, exports, __webpack_require__) { + +/***/ "./src/parser/model/BrowserParserCss.js": +/*!**********************************************!*\ + !*** ./src/parser/model/BrowserParserCss.js ***! + \**********************************************/ +/*! exports provided: parseSelector, parseStyle, parseCondition, createNode, parseNode, default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "parseSelector", function() { return parseSelector; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "parseStyle", function() { return parseStyle; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "parseCondition", function() { return parseCondition; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "createNode", function() { return createNode; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "parseNode", function() { return parseNode; }); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_0__); + // At-rules +// https://developer.mozilla.org/it/docs/Web/API/CSSRule#Type_constants + +var atRules = { + 4: 'media', + 5: 'font-face', + 6: 'page', + 7: 'keyframes', + 11: 'counter-style', + 12: 'supports', + 13: 'document', + 14: 'font-feature-values', + 15: 'viewport' +}; +var atRuleKeys = Object(underscore__WEBPACK_IMPORTED_MODULE_0__["keys"])(atRules); +var singleAtRules = ['5', '6', '11', '15']; +var singleAtRulesNames = ['font-face', 'page', 'counter-style', 'viewport']; +/** + * Parse selector string to array. + * Only classe based are valid as CSS rules inside editor, not valid + * selectors will be dropped as additional + * It's ok with the last part of the string as state (:hover, :active) + * @param {string} str Selectors string + * @return {Object} + * @example + * var res = parseSelector('.test1, .test1.test2, .test2 .test3'); + * console.log(res); + * // { + * //result: [['test1'], ['test1', 'test2']], + * //add: ['.test2 .test3'] + * //} + */ +var parseSelector = function parseSelector() { + var str = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ''; + var add = []; + var result = []; + var sels = str.split(','); + + for (var i = 0, len = sels.length; i < len; i++) { + var sel = sels[i].trim(); // Will accept only concatenated classes and last + // class might be with state (eg. :hover), nothing else. + // Can also accept SINGLE ID selectors, eg. `#myid`, `#myid:hover` + // Composed are not valid: `#myid.some-class`, `#myid.some-class:hover` + + if (/^(\.{1}[\w\-]+)+(:{1,2}[\w\-()]+)?$/gi.test(sel) || /^(#{1}[\w\-]+){1}(:{1,2}[\w\-()]+)?$/gi.test(sel)) { + var cls = sel.split('.').filter(Boolean); + result.push(cls); + } else { + add.push(sel); + } + } -var _underscore = __webpack_require__(1); + return { + result: result, + add: add + }; +}; +/** + * Parse style declarations of the node + * @param {CSSRule} node + * @return {Object} + */ -var Backbone = __webpack_require__(0); -var Properties = __webpack_require__(11); -var PropertyFactory = __webpack_require__(129); +var parseStyle = function parseStyle(node) { + var stl = node.style; + var style = {}; -module.exports = Backbone.Model.extend({ + for (var i = 0, len = stl.length; i < len; i++) { + var propName = stl[i]; + var propValue = stl.getPropertyValue(propName); + var important = stl.getPropertyPriority(propName); + style[propName] = "".concat(propValue).concat(important ? " !".concat(important) : ''); + } - defaults: { - id: '', - name: '', - open: true, - buildProps: '', - extendBuilded: 1, - properties: [] - }, + return style; +}; +/** + * Get the condition when possible + * @param {CSSRule} node + * @return {string} + */ - initialize: function initialize(opts) { - var o = opts || {}; - var props = []; - var builded = this.buildProperties(o.buildProps); - !this.get('id') && this.set('id', this.get('name')); +var parseCondition = function parseCondition(node) { + var condition = node.conditionText || node.media && node.media.mediaText || node.name || node.selectorText || ''; + return condition.trim(); +}; +/** + * Create node for the editor + * @param {Array} selectors Array containing strings of classes + * @param {Object} style Key-value object of style declarations + * @return {Object} + */ - if (!builded) props = this.get('properties');else props = this.extendProperties(builded); +var createNode = function createNode(selectors) { + var style = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + var node = {}; + var selLen = selectors.length; + var lastClass = selectors[selLen - 1]; + var stateArr = lastClass ? lastClass.split(/:(.+)/) : []; + var state = stateArr[1]; + var atRule = opts.atRule, + selectorsAdd = opts.selectorsAdd, + mediaText = opts.mediaText; + var singleAtRule = singleAtRulesNames.indexOf(atRule) >= 0; + singleAtRule && (node.singleAtRule = 1); + atRule && (node.atRuleType = atRule); + selectorsAdd && (node.selectorsAdd = selectorsAdd); + mediaText && (node.mediaText = mediaText); // Isolate the state from selectors + + if (state) { + selectors[selLen - 1] = stateArr[0]; + node.state = state; + stateArr.splice(stateArr.length - 1, 1); + } + + node.selectors = selectors; + node.style = style; + return node; +}; +/** + * Fetch data from node + * @param {StyleSheet|CSSRule} el + * @return {Array} + */ - var propsModel = new Properties(props); - propsModel.sector = this; - this.set('properties', propsModel); - }, +var parseNode = function parseNode(el) { + var result = []; + var nodes = el.cssRules || []; + for (var i = 0, len = nodes.length; i < len; i++) { + var node = nodes[i]; + var type = node.type.toString(); + var singleAtRule = 0; + var atRuleType = ''; + var condition = ''; // keyText is for CSSKeyframeRule - /** - * Extend properties - * @param {Array} props Start properties - * @param {Array} moProps Model props - * @param {Boolean} ex Returns the same amount of passed model props - * @return {Array} Final props - * @private - */ - extendProperties: function extendProperties(props, moProps, ex) { - var pLen = props.length; - var mProps = moProps || this.get('properties'); - var ext = this.get('extendBuilded'); - var isolated = []; + var sels = node.selectorText || node.keyText; + var isSingleAtRule = singleAtRules.indexOf(type) >= 0; // Check if the node is an at-rule - for (var i = 0, len = mProps.length; i < len; i++) { - var mProp = mProps[i]; - var found = 0; + if (isSingleAtRule) { + singleAtRule = 1; + atRuleType = atRules[type]; + condition = parseCondition(node); + } else if (atRuleKeys.indexOf(type) >= 0) { + var subRules = parseNode(node); + condition = parseCondition(node); - for (var j = 0; j < pLen; j++) { - var prop = props[j]; - if (mProp.property == prop.property || mProp.id == prop.property) { - // Check for nested properties - var mPProps = mProp.properties; - if (mPProps && mPProps.length) { - mProp.properties = this.extendProperties(prop.properties, mPProps, 1); - } - props[j] = ext ? (0, _underscore.extend)(prop, mProp) : mProp; - isolated[j] = props[j]; - found = 1; - continue; - } + for (var s = 0, lens = subRules.length; s < lens; s++) { + var subRule = subRules[s]; + condition && (subRule.mediaText = condition); + subRule.atRuleType = atRules[type]; } - if (!found) { - props.push(mProp); - isolated.push(mProp); - } + result = result.concat(subRules); } - return ex ? isolated : props; - }, - + if (!sels && !isSingleAtRule) continue; + var style = parseStyle(node); + var selsParsed = parseSelector(sels); + var selsAdd = selsParsed.add; + sels = selsParsed.result; + var lastRule = void 0; // For each group of selectors - /** - * Build properties - * @param {Array} propr Array of props as sting - * @return {Array} - * @private - */ - buildProperties: function buildProperties(props) { - var r; - var buildP = props || []; + for (var k = 0, len3 = sels.length; k < len3; k++) { + var model = createNode(sels[k], style, { + atRule: atRules[type] + }); + result.push(model); + lastRule = model; + } // Need to push somewhere not class-based selectors, if some rule was + // created will push them there, otherwise will create a new rule - if (!buildP.length) return; - if (!this.propFactory) this.propFactory = new PropertyFactory(); + if (selsAdd.length) { + var selsAddStr = selsAdd.join(', '); - r = this.propFactory.build(buildP); + if (lastRule) { + lastRule.selectorsAdd = selsAddStr; + } else { + var _model = { + selectors: [], + selectorsAdd: selsAddStr, + style: style + }; + singleAtRule && (_model.singleAtRule = singleAtRule); + atRuleType && (_model.atRuleType = atRuleType); + condition && (_model.mediaText = condition); + result.push(_model); + } + } // console.log('LAST PUSH', result[result.length - 1]); - return r; } + + return result; +}; +/** + * Parse CSS string and return the array of objects + * @param {String} str CSS string + * @return {Array} Array of objects for the definition of CSSRules + */ + +/* harmony default export */ __webpack_exports__["default"] = (function (str) { + var el = document.createElement('style'); + el.innerHTML = str; // There is no .sheet before adding it to the + + document.head.appendChild(el); + var sheet = el.sheet; + document.head.removeChild(el); + return parseNode(sheet); }); /***/ }), -/* 121 */ -/***/ (function(module, exports, __webpack_require__) { + +/***/ "./src/parser/model/ParserCss.js": +/*!***************************************!*\ + !*** ./src/parser/model/ParserCss.js ***! + \***************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _BrowserParserCss__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./BrowserParserCss */ "./src/parser/model/BrowserParserCss.js"); + +/* harmony default export */ __webpack_exports__["default"] = (function () { + var config = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + return { + /** + * Parse CSS string to a desired model object + * @param {String} str CSS string + * @return {Array} + */ + parse: function parse(str) { + var _this = this; -var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; + var result = []; + var parserCss = config.parserCss, + _config$em = config.em, + em = _config$em === void 0 ? {} : _config$em; + var editor = em && em.get && em.get('Editor'); + var nodes = parserCss ? parserCss(str, editor) : Object(_BrowserParserCss__WEBPACK_IMPORTED_MODULE_1__["default"])(str); + nodes.forEach(function (node) { + return result = result.concat(_this.checkNode(node)); + }); + return result; + }, -var Property = __webpack_require__(33); -var Layers = __webpack_require__(122); + /** + * Check the returned node from a custom parser and transforms it to + * a valid object for the CSS composer + * @return {[type]} + */ + checkNode: function checkNode(node) { + var _node = node, + selectors = _node.selectors, + style = _node.style; -module.exports = Property.extend({ + if (Object(underscore__WEBPACK_IMPORTED_MODULE_0__["isString"])(selectors)) { + var nodes = []; + var selsParsed = Object(_BrowserParserCss__WEBPACK_IMPORTED_MODULE_1__["parseSelector"])(selectors); + var classSets = selsParsed.result; + var selectorsAdd = selsParsed.add.join(', '); + var opts = { + atRule: node.atRule, + mediaText: node.params + }; - defaults: _extends({}, Property.prototype.defaults, { - // Array of layers (which contain properties) - layers: [], + if (classSets.length) { + classSets.forEach(function (classSet) { + nodes.push(Object(_BrowserParserCss__WEBPACK_IMPORTED_MODULE_1__["createNode"])(classSet, style, opts)); + }); + } else { + nodes.push(Object(_BrowserParserCss__WEBPACK_IMPORTED_MODULE_1__["createNode"])([], style, opts)); + } - // Layer preview - preview: 0 - }), + if (selectorsAdd) { + var lastNode = nodes[nodes.length - 1]; + lastNode.selectorsAdd = selectorsAdd; + } - init: function init() { - Property.prototype.init.apply(this, arguments); - var layers = this.get('layers'); - var layersColl = new Layers(layers); - layersColl.properties = this.get('properties'); - this.set('layers', layersColl); - }, - getFullValue: function getFullValue() { - return this.get('detached') ? '' : this.get('layers').getFullValue(); - } + node = nodes; + } + + return node; + } + }; }); /***/ }), -/* 122 */ -/***/ (function(module, exports, __webpack_require__) { -"use strict"; -/* WEBPACK VAR INJECTION */(function(Backbone) { +/***/ "./src/parser/model/ParserHtml.js": +/*!****************************************!*\ + !*** ./src/parser/model/ParserHtml.js ***! + \****************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/typeof */ "./node_modules/@babel/runtime/helpers/typeof.js"); +/* harmony import */ var _babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_1__); + + +/* harmony default export */ __webpack_exports__["default"] = (function (config) { + var TEXT_NODE = 'span'; + var c = config; + var modelAttrStart = 'data-gjs-'; + return { + compTypes: '', + modelAttrStart: modelAttrStart, + + /** + * Extract component props from an attribute object + * @param {Object} attr + * @returns {Object} An object containing props and attributes without them + */ + splitPropsFromAttr: function splitPropsFromAttr() { + var _this = this; + + var attr = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var props = {}; + var attrs = {}; + Object(underscore__WEBPACK_IMPORTED_MODULE_1__["each"])(attr, function (value, key) { + if (key.indexOf(_this.modelAttrStart) === 0) { + var modelAttr = key.replace(modelAttrStart, ''); + var valueLen = value.length; + var valStr = value && Object(underscore__WEBPACK_IMPORTED_MODULE_1__["isString"])(value); + var firstChar = valStr && value.substr(0, 1); + var lastChar = valStr && value.substr(valueLen - 1); + value = value === 'true' ? true : value; + value = value === 'false' ? false : value; // Try to parse JSON where it's possible + // I can get false positive here (eg. a selector '[data-attr]') + // so put it under try/catch and let fail silently + + try { + value = firstChar == '{' && lastChar == '}' || firstChar == '[' && lastChar == ']' ? JSON.parse(value) : value; + } catch (e) {} + + props[modelAttr] = value; + } else { + attrs[key] = value; + } + }); + return { + props: props, + attrs: attrs + }; + }, + + /** + * Parse style string to object + * @param {string} str + * @return {Object} + * @example + * var stl = ParserHtml.parseStyle('color:black; width:100px; test:value;'); + * console.log(stl); + * // {color: 'black', width: '100px', test: 'value'} + */ + parseStyle: function parseStyle(str) { + var result = {}; + var decls = str.split(';'); + + for (var i = 0, len = decls.length; i < len; i++) { + var decl = decls[i].trim(); + if (!decl) continue; + var prop = decl.split(':'); + result[prop[0].trim()] = prop.slice(1).join(':').trim(); + } -var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; + return result; + }, -var Layer = __webpack_require__(123); + /** + * Parse class string to array + * @param {string} str + * @return {Array} + * @example + * var res = ParserHtml.parseClass('test1 test2 test3'); + * console.log(res); + * // ['test1', 'test2', 'test3'] + */ + parseClass: function parseClass(str) { + var result = []; + var cls = str.split(' '); -module.exports = Backbone.Collection.extend({ + for (var i = 0, len = cls.length; i < len; i++) { + var cl = cls[i].trim(); + if (!cl) continue; + result.push(cl); + } - model: Layer, + return result; + }, - initialize: function initialize() { - this.idx = 1; - this.on('add', this.onAdd); - this.on('reset', this.onReset); - }, - onAdd: function onAdd(model, c, opts) { - if (!opts.noIncrement) model.set('index', this.idx++); - }, - onReset: function onReset() { - this.idx = 1; - }, + /** + * Get data from the node element + * @param {HTMLElement} el DOM element to traverse + * @return {Array} + */ + parseNode: function parseNode(el) { + var result = []; + var nodes = el.childNodes; + for (var i = 0, len = nodes.length; i < len; i++) { + var node = nodes[i]; + var attrs = node.attributes || []; + var attrsLen = attrs.length; + var nodePrev = result[result.length - 1]; + var nodeChild = node.childNodes.length; + var ct = this.compTypes; + var model = {}; // Start with understanding what kind of component it is - /** - * Get layers from a value string (for not detached properties), - * example of input: - * `layer1Value, layer2Value, layer3Value, ...` - * @param {string} value - * @return {Array} - * @private - */ - getLayersFromValue: function getLayersFromValue(value) { - var _this = this; + if (ct) { + var obj = ''; + var type = node.getAttribute && node.getAttribute("".concat(modelAttrStart, "type")); // If the type is already defined, use it - var layers = []; - // Remove spaces inside functions, eg: - // From: 1px 1px rgba(2px, 2px, 2px), 2px 2px rgba(3px, 3px, 3px) - // To: 1px 1px rgba(2px,2px,2px), 2px 2px rgba(3px,3px,3px) - value.replace(/\(([\w\s,.]*)\)/g, function (match) { - var cleaned = match.replace(/,\s*/g, ','); - value = value.replace(match, cleaned); - }); - var layerValues = value ? value.split(', ') : []; - layerValues.forEach(function (layerValue) { - layers.push({ properties: _this.properties.parseValue(layerValue) }); - }); - return layers; - }, + if (type) { + model = { + type: type + }; + } else { + // Iterate over all available Component Types and + // the first with a valid result will be that component + for (var it = 0; it < ct.length; it++) { + var compType = ct[it]; + obj = compType.model.isComponent(node); + + if (obj) { + if (_babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0___default()(obj) !== 'object') { + obj = { + type: compType.id + }; + } + break; + } + } - /** - * Get layers from a style object (for detached properties), - * example of input: - * { - * subPropname1: sub-propvalue11, sub-propvalue12, sub-propvalue13, ... - * subPropname2: sub-propvalue21, sub-propvalue22, sub-propvalue23, ... - * subPropname3: sub-propvalue31, sub-propvalue32, sub-propvalue33, ... - * } - * @param {Object} styleObj - * @return {Array} - * @private - */ - getLayersFromStyle: function getLayersFromStyle(styleObj) { - var layers = []; - var properties = this.properties; - var propNames = properties.pluck('property'); + model = obj; + } + } // Set tag name if not yet done - properties.each(function (propModel) { - var style = styleObj[propModel.get('property')]; - var values = style ? style.split(', ') : []; - values.forEach(function (value, i) { - value = propModel.parseValue(value.trim()).value; - var layer = layers[i]; - var propertyObj = _extends({}, propModel.attributes, { value: value }); - if (layer) { - layer.properties.push(propertyObj); - } else { - layers[i] = { - properties: [propertyObj] - }; + if (!model.tagName) { + model.tagName = node.tagName ? node.tagName.toLowerCase() : ''; } - }); - }); - // Now whit all layers in, will check missing properties - layers.forEach(function (layer) { - var layerProprs = layer.properties.map(function (prop) { - return prop.property; - }); - properties.each(function (propModel) { - var propertyName = propModel.get('property'); + if (attrsLen) { + model.attributes = {}; + } // Parse attributes - if (layerProprs.indexOf(propertyName) < 0) { - layer.properties.push(_extends({}, propModel.attributes)); - } - }); - }); - return layers; - }, - active: function active(index) { - this.each(function (layer) { - return layer.set('active', 0); - }); - var layer = this.at(index); - layer && layer.set('active', 1); - }, - getFullValue: function getFullValue() { - var result = []; - this.each(function (layer) { - return result.push(layer.getFullValue()); - }); - return result.join(', '); - }, - getPropertyValues: function getPropertyValues(property) { - var result = []; - this.each(function (layer) { - var value = layer.getPropertyValue(property); - value && result.push(value); - }); - return result.join(', '); - } -}); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(0))) + for (var j = 0; j < attrsLen; j++) { + var nodeName = attrs[j].nodeName; + var nodeValue = attrs[j].nodeValue; // Isolate attributes -/***/ }), -/* 123 */ -/***/ (function(module, exports, __webpack_require__) { + if (nodeName == 'style') { + model.style = this.parseStyle(nodeValue); + } else if (nodeName == 'class') { + model.classes = this.parseClass(nodeValue); + } else if (nodeName == 'contenteditable') { + continue; + } else if (nodeName.indexOf(modelAttrStart) === 0) { + var modelAttr = nodeName.replace(modelAttrStart, ''); + var valueLen = nodeValue.length; + var firstChar = nodeValue && nodeValue.substr(0, 1); + var lastChar = nodeValue && nodeValue.substr(valueLen - 1); + nodeValue = nodeValue === 'true' ? true : nodeValue; + nodeValue = nodeValue === 'false' ? false : nodeValue; // Try to parse JSON where it's possible + // I can get false positive here (eg. a selector '[data-attr]') + // so put it under try/catch and let fail silently -"use strict"; -/* WEBPACK VAR INJECTION */(function(Backbone) { + try { + nodeValue = firstChar == '{' && lastChar == '}' || firstChar == '[' && lastChar == ']' ? JSON.parse(nodeValue) : nodeValue; + } catch (e) {} -module.exports = Backbone.Model.extend({ + model[modelAttr] = nodeValue; + } else { + model.attributes[nodeName] = nodeValue; + } + } // Check for nested elements but avoid it if already provided - defaults: { - index: '', - value: '', - values: {}, - active: false, - preview: false, - properties: [] - }, - initialize: function initialize() { - var Properties = __webpack_require__(11); - var properties = this.get('properties'); - var value = this.get('value'); - this.set('properties', properties instanceof Properties ? properties : new Properties(properties)); + if (nodeChild && !model.components) { + // Avoid infinite nested text nodes + var firstChild = node.childNodes[0]; // If there is only one child and it's a TEXTNODE + // just make it content of the current node - // If there is no value I'll try to get it from values - // I need value setted to make preview working - if (!value) { - var val = ''; - var values = this.get('values'); + if (nodeChild === 1 && firstChild.nodeType === 3) { + !model.type && (model.type = 'text'); + model.content = firstChild.nodeValue; + } else { + model.components = this.parseNode(node); + } + } // Check if it's a text node and if could be moved to the prevous model - for (var prop in values) { - val += ' ' + values[prop]; - } - this.set('value', val.trim()); - } - }, - getPropertyValue: function getPropertyValue(property) { - var result = ''; - this.get('properties').each(function (prop) { - if (prop.get('property') == property) { - result = prop.getFullValue(); - } - }); - return result; - }, - getFullValue: function getFullValue() { - var result = []; - this.get('properties').each(function (prop) { - return result.push(prop.getFullValue()); - }); - return result.join(' '); - } -}); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(0))) + if (model.type == 'textnode') { + if (nodePrev && nodePrev.type == 'textnode') { + nodePrev.content += model.content; + continue; + } // Throw away empty nodes (keep spaces) -/***/ }), -/* 124 */ -/***/ (function(module, exports, __webpack_require__) { -"use strict"; -/* WEBPACK VAR INJECTION */(function(Backbone) { + if (!config.keepEmptyTextNodes) { + var content = node.nodeValue; -var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; + if (content != ' ' && !content.trim()) { + continue; + } + } + } // If all children are texts and there is some textnode the parent should + // be text too otherwise I'm unable to edit texnodes -// Without jquery I have to update few stuff -// -// Spectrum Colorpicker v1.8.0 -// https://github.com/bgrins/spectrum -// Author: Brian Grinstead -// License: MIT -(function (factory) { - factory(Backbone.$); -})(function ($, undefined) { - "use strict"; + var comps = model.components; - var defaultOpts = { - - // Callbacks - beforeShow: noop, - move: noop, - change: noop, - show: noop, - hide: noop, - - // Options - color: false, - flat: false, - showInput: false, - allowEmpty: false, - showButtons: true, - clickoutFiresChange: true, - showInitial: false, - showPalette: false, - showPaletteOnly: false, - hideAfterPaletteSelect: false, - togglePaletteOnly: false, - showSelectionPalette: true, - localStorageKey: false, - appendTo: "body", - maxSelectionSize: 7, - cancelText: "cancel", - chooseText: "choose", - togglePaletteMoreText: "more", - togglePaletteLessText: "less", - clearText: "Clear Color Selection", - noColorSelectedText: "No Color Selected", - preferredFormat: false, - className: "", // Deprecated - use containerClassName and replacerClassName instead. - containerClassName: "", - replacerClassName: "", - showAlpha: false, - theme: "sp-light", - palette: [["#ffffff", "#000000", "#ff0000", "#ff8000", "#ffff00", "#008000", "#0000ff", "#4b0082", "#9400d3"]], - selectionPalette: [], - disabled: false, - offset: null - }, - spectrums = [], - IE = !!/msie/i.exec(window.navigator.userAgent), - rgbaSupport = function () { - function contains(str, substr) { - return !!~('' + str).indexOf(substr); - } - - var elem = document.createElement('div'); - var style = elem.style; - style.cssText = 'background-color:rgba(0,0,0,.5)'; - return contains(style.backgroundColor, 'rgba') || contains(style.backgroundColor, 'hsla'); - }(), - replaceInput = ["
", "
", "
", "
"].join(''), - markup = function () { - - // IE does not support gradients with multiple stops, so we need to simulate - // that for the rainbow slider with 8 divs that each have a single gradient - var gradientFix = ""; - if (IE) { - for (var i = 1; i <= 6; i++) { - gradientFix += "
"; - } - } + if (!model.type && comps) { + var allTxt = 1; + var foundTextNode = 0; - return ["
", "
", "
", "
", "", "
", "
", "
", "
", "
", "
", "
", "
", "
", "
", "
", "
", "
", "
", "
", "
", "
", gradientFix, "
", "
", "
", "
", "
", "", "
", "
", "
", "", "", "
", "
", "
"].join(""); - }(); - - function paletteTemplate(p, color, className, opts) { - var html = []; - for (var i = 0; i < p.length; i++) { - var current = p[i]; - if (current) { - var tiny = tinycolor(current); - var c = tiny.toHsl().l < 0.5 ? "sp-thumb-el sp-thumb-dark" : "sp-thumb-el sp-thumb-light"; - c += tinycolor.equals(color, current) ? " sp-thumb-active" : ""; - var formattedString = tiny.toString(opts.preferredFormat || "rgb"); - var swatchStyle = rgbaSupport ? "background-color:" + tiny.toRgbString() : "filter:" + tiny.toFilter(); - html.push(''); - } else { - var cls = 'sp-clear-display'; - html.push($('
').append($('').attr('title', opts.noColorSelectedText)).html()); - } - } - return "
" + html.join('') + "
"; - } + for (var ci = 0; ci < comps.length; ci++) { + var comp = comps[ci]; + var cType = comp.type; - function hideAll() { - for (var i = 0; i < spectrums.length; i++) { - if (spectrums[i]) { - spectrums[i].hide(); + if (['text', 'textnode'].indexOf(cType) < 0 && c.textTags.indexOf(comp.tagName) < 0) { + allTxt = 0; + break; } - } - } - function instanceOptions(o, callbackContext) { - var opts = $.extend({}, defaultOpts, o); - opts.callbacks = { - 'move': bind(opts.move, callbackContext), - 'change': bind(opts.change, callbackContext), - 'show': bind(opts.show, callbackContext), - 'hide': bind(opts.hide, callbackContext), - 'beforeShow': bind(opts.beforeShow, callbackContext) - }; - return opts; - } - - function spectrum(element, o) { - - var opts = instanceOptions(o, element), - flat = opts.flat, - showSelectionPalette = opts.showSelectionPalette, - localStorageKey = opts.localStorageKey, - theme = opts.theme, - callbacks = opts.callbacks, - resize = throttle(reflow, 10), - visible = false, - isDragging = false, - dragWidth = 0, - dragHeight = 0, - dragHelperHeight = 0, - slideHeight = 0, - slideWidth = 0, - alphaWidth = 0, - alphaSlideHelperWidth = 0, - slideHelperHeight = 0, - currentHue = 0, - currentSaturation = 0, - currentValue = 0, - currentAlpha = 1, - palette = [], - paletteArray = [], - paletteLookup = {}, - selectionPalette = opts.selectionPalette.slice(0), - maxSelectionSize = opts.maxSelectionSize, - draggingClass = "sp-dragging", - shiftMovementDirection = null; - - var doc = element.ownerDocument, - body = doc.body, - boundElement = $(element), - disabled = false, - container = $(markup, doc).addClass(theme), - pickerContainer = container.find(".sp-picker-container"), - dragger = container.find(".sp-color"), - dragHelper = container.find(".sp-dragger"), - slider = container.find(".sp-hue"), - slideHelper = container.find(".sp-slider"), - alphaSliderInner = container.find(".sp-alpha-inner"), - alphaSlider = container.find(".sp-alpha"), - alphaSlideHelper = container.find(".sp-alpha-handle"), - textInput = container.find(".sp-input"), - paletteContainer = container.find(".sp-palette"), - initialColorContainer = container.find(".sp-initial"), - cancelButton = container.find(".sp-cancel"), - clearButton = container.find(".sp-clear"), - chooseButton = container.find(".sp-choose"), - toggleButton = container.find(".sp-palette-toggle"), - isInput = boundElement.is("input"), - isInputTypeColor = isInput && boundElement.attr("type") === "color" && inputTypeColorSupport(), - shouldReplace = isInput && !flat, - replacer = shouldReplace ? $(replaceInput).addClass(theme).addClass(opts.className).addClass(opts.replacerClassName) : $([]), - offsetElement = shouldReplace ? replacer : boundElement, - previewElement = replacer.find(".sp-preview-inner"), - initialColor = opts.color || isInput && boundElement.val(), - colorOnShow = false, - currentPreferredFormat = opts.preferredFormat, - clickoutFiresChange = !opts.showButtons || opts.clickoutFiresChange, - isEmpty = !initialColor, - allowEmpty = opts.allowEmpty && !isInputTypeColor; - - function applyOptions() { - - if (opts.showPaletteOnly) { - opts.showPalette = true; + if (cType == 'textnode') { + foundTextNode = 1; } + } - toggleButton.text(opts.showPaletteOnly ? opts.togglePaletteMoreText : opts.togglePaletteLessText); - - if (opts.palette) { - palette = opts.palette.slice(0); - paletteArray = $.isArray(palette[0]) ? palette : [palette]; - paletteLookup = {}; - for (var i = 0; i < paletteArray.length; i++) { - for (var j = 0; j < paletteArray[i].length; j++) { - var rgb = tinycolor(paletteArray[i][j]).toRgbString(); - paletteLookup[rgb] = true; - } - } - } + if (allTxt && foundTextNode) { + model.type = 'text'; + } + } // If tagName is still empty and is not a textnode, do not push it - container.toggleClass("sp-flat", flat); - container.toggleClass("sp-input-disabled", !opts.showInput); - container.toggleClass("sp-alpha-enabled", opts.showAlpha); - container.toggleClass("sp-clear-enabled", allowEmpty); - container.toggleClass("sp-buttons-disabled", !opts.showButtons); - container.toggleClass("sp-palette-buttons-disabled", !opts.togglePaletteOnly); - container.toggleClass("sp-palette-disabled", !opts.showPalette); - container.toggleClass("sp-palette-only", opts.showPaletteOnly); - container.toggleClass("sp-initial-disabled", !opts.showInitial); - container.addClass(opts.className).addClass(opts.containerClassName); - reflow(); + if (!model.tagName && model.type != 'textnode') { + continue; } - function initialize() { - - if (IE) { - container.find("*:not(input)").attr("unselectable", "on"); - } - - applyOptions(); - - if (shouldReplace) { - boundElement.after(replacer).hide(); - } + result.push(model); + } - if (!allowEmpty) { - clearButton.hide(); - } + return result; + }, - if (flat) { - boundElement.after(container).hide(); - } else { + /** + * Parse HTML string to a desired model object + * @param {string} str HTML string + * @param {ParserCss} parserCss In case there is style tags inside HTML + * @return {Object} + */ + parse: function parse(str, parserCss) { + var config = c.em && c.em.get('Config') || {}; + var res = { + html: '', + css: '' + }; + var el = document.createElement('div'); + el.innerHTML = str; + var scripts = el.querySelectorAll('script'); + var i = scripts.length; // Remove all scripts - var appendTo = opts.appendTo === "parent" ? boundElement.parent() : $(opts.appendTo); - if (appendTo.length !== 1) { - appendTo = $("body"); - } + if (!config.allowScripts) { + while (i--) { + scripts[i].parentNode.removeChild(scripts[i]); + } + } // Detach style tags and parse them - appendTo.append(container); - } - updateSelectionPaletteFromStorage(); + if (parserCss) { + var styleStr = ''; + var styles = el.querySelectorAll('style'); + var j = styles.length; - offsetElement.bind("click.spectrum touchstart.spectrum", function (e) { + while (j--) { + styleStr = styles[j].innerHTML + styleStr; + styles[j].parentNode.removeChild(styles[j]); + } - if (!disabled) { - toggle(); - } + if (styleStr) res.css = parserCss.parse(styleStr); + } - e.stopPropagation(); + var result = this.parseNode(el); + if (result.length == 1) result = result[0]; + res.html = result; + return res; + } + }; +}); - if (!$(e.target).is("input")) { - e.preventDefault(); - } - }); +/***/ }), - if (boundElement.is(":disabled") || opts.disabled === true) { - disable(); - } +/***/ "./src/plugin_manager/config/config.js": +/*!*********************************************!*\ + !*** ./src/plugin_manager/config/config.js ***! + \*********************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // Prevent clicks from bubbling up to document. This would cause it to be hidden. - container.click(stopPropagation); +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony default export */ __webpack_exports__["default"] = ({ + plugins: [] +}); - // Handle user typed input - textInput.change(setFromTextInput); - textInput.bind("paste", function () { - setTimeout(setFromTextInput, 1); - }); - textInput.keydown(function (e) { - if (e.keyCode == 13) { - setFromTextInput(); - } - }); +/***/ }), - cancelButton.text(opts.cancelText); - cancelButton.bind("click.spectrum", function (e) { - e.stopPropagation(); - e.preventDefault(); - revert(); - hide(); - }); +/***/ "./src/plugin_manager/index.js": +/*!*************************************!*\ + !*** ./src/plugin_manager/index.js ***! + \*************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - clearButton.attr("title", opts.clearText); - clearButton.bind("click.spectrum", function (e) { - e.stopPropagation(); - e.preventDefault(); - isEmpty = true; - move(); +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _config_config__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./config/config */ "./src/plugin_manager/config/config.js"); - if (flat) { - //for the flat style, this is a change event - updateOriginalInput(true); - } - }); +/* harmony default export */ __webpack_exports__["default"] = (function (config) { + var c = config || {}; // Set default options - chooseButton.text(opts.chooseText); - chooseButton.bind("click.spectrum", function (e) { - e.stopPropagation(); - e.preventDefault(); + for (var name in _config_config__WEBPACK_IMPORTED_MODULE_0__["default"]) { + if (!(name in c)) c[name] = _config_config__WEBPACK_IMPORTED_MODULE_0__["default"][name]; + } - if (IE && textInput.is(":focus")) { - textInput.trigger('change'); - } + var plugins = {}; + return { + /** + * Add new plugin. Plugins could not be overwritten + * @param {string} id Plugin ID + * @param {Function} plugin Function which contains all plugin logic + * @return {Function} The plugin function + * @example + * PluginManager.add('some-plugin', function(editor){ + * editor.Commands.add('new-command', { + * run: function(editor, senderBtn){ + * console.log('Executed new-command'); + * } + * }) + * }); + */ + add: function add(id, plugin) { + if (plugins[id]) { + return plugins[id]; + } - if (isValid()) { - updateOriginalInput(true); - hide(); - } - }); + plugins[id] = plugin; + return plugin; + }, - toggleButton.text(opts.showPaletteOnly ? opts.togglePaletteMoreText : opts.togglePaletteLessText); - toggleButton.bind("click.spectrum", function (e) { - e.stopPropagation(); - e.preventDefault(); + /** + * Returns plugin by ID + * @param {string} id Plugin ID + * @return {Function|undefined} Plugin + * @example + * var plugin = PluginManager.get('some-plugin'); + * plugin(editor); + */ + get: function get(id) { + return plugins[id]; + }, - opts.showPaletteOnly = !opts.showPaletteOnly; + /** + * Returns object with all plugins + * @return {Object} + */ + getAll: function getAll() { + return plugins; + } + }; +}); - // To make sure the Picker area is drawn on the right, next to the - // Palette area (and not below the palette), first move the Palette - // to the left to make space for the picker, plus 5px extra. - // The 'applyOptions' function puts the whole container back into place - // and takes care of the button-text and the sp-palette-only CSS class. - if (!opts.showPaletteOnly && !flat) { - container.css('left', '-=' + (pickerContainer.outerWidth(true) + 5)); - } - applyOptions(); - }); +/***/ }), - draggable(alphaSlider, function (dragX, dragY, e) { - currentAlpha = dragX / alphaWidth; - isEmpty = false; - if (e.shiftKey) { - currentAlpha = Math.round(currentAlpha * 10) / 10; - } +/***/ "./src/rich_text_editor/config/config.js": +/*!***********************************************!*\ + !*** ./src/rich_text_editor/config/config.js ***! + \***********************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - move(); - }, dragStart, dragStop); +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony default export */ __webpack_exports__["default"] = ({ + stylePrefix: 'rte-', + // If true, moves the toolbar below the element when the top canvas + // edge is reached + adjustToolbar: 1, + // Default RTE actions + actions: ['bold', 'italic', 'underline', 'strikethrough', 'link'] +}); - draggable(slider, function (dragX, dragY) { - currentHue = parseFloat(dragY / slideHeight); - isEmpty = false; - if (!opts.showAlpha) { - currentAlpha = 1; - } - move(); - }, dragStart, dragStop); +/***/ }), - draggable(dragger, function (dragX, dragY, e) { +/***/ "./src/rich_text_editor/index.js": +/*!***************************************!*\ + !*** ./src/rich_text_editor/index.js ***! + \***************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // shift+drag should snap the movement to either the x or y axis. - if (!e.shiftKey) { - shiftMovementDirection = null; - } else if (!shiftMovementDirection) { - var oldDragX = currentSaturation * dragWidth; - var oldDragY = dragHeight - currentValue * dragHeight; - var furtherFromX = Math.abs(dragX - oldDragX) > Math.abs(dragY - oldDragY); +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _model_RichTextEditor__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./model/RichTextEditor */ "./src/rich_text_editor/model/RichTextEditor.js"); +/* harmony import */ var utils_mixins__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! utils/mixins */ "./src/utils/mixins.js"); +/* harmony import */ var _config_config__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./config/config */ "./src/rich_text_editor/config/config.js"); - shiftMovementDirection = furtherFromX ? "x" : "y"; - } - var setSaturation = !shiftMovementDirection || shiftMovementDirection === "x"; - var setValue = !shiftMovementDirection || shiftMovementDirection === "y"; +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - if (setSaturation) { - currentSaturation = parseFloat(dragX / dragWidth); - } - if (setValue) { - currentValue = parseFloat((dragHeight - dragY) / dragHeight); - } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - isEmpty = false; - if (!opts.showAlpha) { - currentAlpha = 1; - } +/** + * This module allows to customize the built-in toolbar of the Rich Text Editor and use commands from the [HTML Editing APIs](https://developer.mozilla.org/en-US/docs/Web/API/Document/execCommand). + * It's highly recommended to keep this toolbar as small as possible, especially from styling commands (eg. 'fontSize') and leave this task to the Style Manager + * + * You can customize the initial state of the module from the editor initialization, by passing the following [Configuration Object](https://github.com/artf/grapesjs/blob/master/src/rich_text_editor/config/config.js) + * ```js + * const editor = grapesjs.init({ + * richTextEditor: { + * // options + * } + * }) + * ``` + * + * Once the editor is instantiated you can use its API. Before using these methods you should get the module from the instance + * + * ```js + * const rte = editor.RichTextEditor; + * ``` + * + * * [add](#add) + * * [get](#get) + * * [getAll](#getall) + * * [remove](#remove) + * * [getToolbarEl](#gettoolbarel) + * + * @module RichTextEditor + */ - move(); - }, dragStart, dragStop); - if (!!initialColor) { - _set(initialColor); - // In case color was black - update the preview UI and set the format - // since the set function will not run (default color is black). - updateUI(); - currentPreferredFormat = opts.preferredFormat || tinycolor(initialColor).format; +/* harmony default export */ __webpack_exports__["default"] = (function () { + var config = {}; + var toolbar, actions, lastEl, globalRte; - addColorToSelectionPalette(initialColor); - } else { - updateUI(); - } + var hideToolbar = function hideToolbar() { + var style = toolbar.style; + var size = '-1000px'; + style.top = size; + style.left = size; + style.display = 'none'; + }; - if (flat) { - show(); - } + return { + customRte: null, - function paletteElementClick(e) { - if (e.data && e.data.ignore) { - _set($(e.target).closest(".sp-thumb-el").data("color")); - move(); - } else { - _set($(e.target).closest(".sp-thumb-el").data("color")); - move(); - updateOriginalInput(true); - if (opts.hideAfterPaletteSelect) { - hide(); - } - } + /** + * Name of the module + * @type {String} + * @private + */ + name: 'RichTextEditor', + getConfig: function getConfig() { + return config; + }, - return false; - } + /** + * Initialize module. Automatically called with a new instance of the editor + * @param {Object} opts Options + * @private + */ + init: function init() { + var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + config = _objectSpread({}, _config_config__WEBPACK_IMPORTED_MODULE_3__["default"], {}, opts); + var ppfx = config.pStylePrefix; - var paletteEvent = IE ? "mousedown.spectrum" : "click.spectrum touchstart.spectrum"; - paletteContainer.delegate(".sp-thumb-el", paletteEvent, paletteElementClick); - initialColorContainer.delegate(".sp-thumb-el:nth-child(1)", paletteEvent, { ignore: true }, paletteElementClick); - } + if (ppfx) { + config.stylePrefix = ppfx + config.stylePrefix; + } - function updateSelectionPaletteFromStorage() { + this.pfx = config.stylePrefix; + actions = config.actions || []; + toolbar = document.createElement('div'); + toolbar.className = "".concat(ppfx, "rte-toolbar ").concat(ppfx, "one-bg"); + globalRte = this.initRte(document.createElement('div')); //Avoid closing on toolbar clicking - if (localStorageKey && window.localStorage) { + Object(utils_mixins__WEBPACK_IMPORTED_MODULE_2__["on"])(toolbar, 'mousedown', function (e) { + return e.stopPropagation(); + }); + return this; + }, - // Migrate old palettes over to new format. May want to remove this eventually. - try { - var oldPalette = window.localStorage[localStorageKey].split(",#"); - if (oldPalette.length > 1) { - delete window.localStorage[localStorageKey]; - $.each(oldPalette, function (i, c) { - addColorToSelectionPalette(c); - }); - } - } catch (e) {} + /** + * Post render callback + * @param {View} ev + * @private + */ + postRender: function postRender(ev) { + var canvas = ev.model.get('Canvas'); + toolbar.style.pointerEvents = 'all'; + hideToolbar(); + canvas.getToolsEl().appendChild(toolbar); + }, - try { - selectionPalette = window.localStorage[localStorageKey].split(";"); - } catch (e) {} - } - } + /** + * Init the built-in RTE + * @param {HTMLElement} el + * @return {RichTextEditor} + * @private + */ + initRte: function initRte(el) { + var pfx = this.pfx; + var actionbarContainer = toolbar; + var actionbar = this.actionbar; + var actions = this.actions || config.actions; + var classes = { + actionbar: "".concat(pfx, "actionbar"), + button: "".concat(pfx, "action"), + active: "".concat(pfx, "active") + }; + var rte = new _model_RichTextEditor__WEBPACK_IMPORTED_MODULE_1__["default"]({ + el: el, + classes: classes, + actions: actions, + actionbar: actionbar, + actionbarContainer: actionbarContainer + }); + globalRte && globalRte.setEl(el); - function addColorToSelectionPalette(color) { - if (showSelectionPalette) { - var rgb = tinycolor(color).toRgbString(); - if (!paletteLookup[rgb] && $.inArray(rgb, selectionPalette) === -1) { - selectionPalette.push(rgb); - while (selectionPalette.length > maxSelectionSize) { - selectionPalette.shift(); - } - } + if (rte.actionbar) { + this.actionbar = rte.actionbar; + } - if (localStorageKey && window.localStorage) { - try { - window.localStorage[localStorageKey] = selectionPalette.join(";"); - } catch (e) {} - } - } - } + if (rte.actions) { + this.actions = rte.actions; + } - function getUniqueSelectionPalette() { - var unique = []; - if (opts.showPalette) { - for (var i = 0; i < selectionPalette.length; i++) { - var rgb = tinycolor(selectionPalette[i]).toRgbString(); + return rte; + }, - if (!paletteLookup[rgb]) { - unique.push(selectionPalette[i]); - } - } - } + /** + * Add a new action to the built-in RTE toolbar + * @param {string} name Action name + * @param {Object} action Action options + * @example + * rte.add('bold', { + * icon: 'B', + * attributes: {title: 'Bold'}, + * result: rte => rte.exec('bold') + * }); + * rte.add('link', { + * icon: document.getElementById('t'), + * attributes: {title: 'Link',} + * // Example on it's easy to wrap a selected content + * result: rte => rte.insertHTML(`${rte.selection()}`) + * }); + * // An example with fontSize + * rte.add('fontSize', { + * icon: ``, + * // Bind the 'result' on 'change' listener + * event: 'change', + * result: (rte, action) => rte.exec('fontSize', action.btn.firstChild.value), + * // Callback on any input change (mousedown, keydown, etc..) + * update: (rte, action) => { + * const value = rte.doc.queryCommandValue(action.name); + * if (value != 'false') { // value is a string + * action.btn.firstChild.value = value; + * } + * } + * }) + */ + add: function add(name) { + var action = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + action.name = name; + globalRte.addAction(action, { + sync: 1 + }); + }, - return unique.reverse().slice(0, opts.maxSelectionSize); + /** + * Get the action by its name + * @param {string} name Action name + * @return {Object} + * @example + * const action = rte.get('bold'); + * // {name: 'bold', ...} + */ + get: function get(name) { + var result; + globalRte.getActions().forEach(function (action) { + if (action.name == name) { + result = action; } + }); + return result; + }, - function drawPalette() { - - var currentColor = get(); + /** + * Get all actions + * @return {Array} + */ + getAll: function getAll() { + return globalRte.getActions(); + }, - var html = $.map(paletteArray, function (palette, i) { - return paletteTemplate(palette, currentColor, "sp-palette-row sp-palette-row-" + i, opts); - }); + /** + * Remove the action from the toolbar + * @param {string} name + * @return {Object} Removed action + * @example + * const action = rte.remove('bold'); + * // {name: 'bold', ...} + */ + remove: function remove(name) { + var actions = this.getAll(); + var action = this.get(name); - updateSelectionPaletteFromStorage(); + if (action) { + var btn = action.btn; + var index = actions.indexOf(action); + btn.parentNode.removeChild(btn); + actions.splice(index, 1); + } - if (selectionPalette) { - html.push(paletteTemplate(getUniqueSelectionPalette(), currentColor, "sp-palette-row sp-palette-row-selection", opts)); - } + return action; + }, - paletteContainer.html(html.join("")); - } + /** + * Get the toolbar element + * @return {HTMLElement} + */ + getToolbarEl: function getToolbarEl() { + return toolbar; + }, - function drawInitial() { - if (opts.showInitial) { - var initial = colorOnShow; - var current = get(); - initialColorContainer.html(paletteTemplate([initial, current], current, "sp-palette-row-initial", opts)); - } - } + /** + * Triggered when the offset of the editor is changed + * @private + */ + updatePosition: function updatePosition() { + var un = 'px'; + var canvas = config.em.get('Canvas'); + var pos = canvas.getTargetToElementDim(toolbar, lastEl, { + event: 'rteToolbarPosUpdate' + }); - function dragStart() { - if (dragHeight <= 0 || dragWidth <= 0 || slideHeight <= 0) { - reflow(); - } - isDragging = true; - container.addClass(draggingClass); - shiftMovementDirection = null; - boundElement.trigger('dragstart.spectrum', [get()]); - } + if (pos) { + if (config.adjustToolbar) { + var frameOffset = canvas.getCanvasView().getFrameOffset(); // Move the toolbar down when the top canvas edge is reached - function dragStop() { - isDragging = false; - container.removeClass(draggingClass); - boundElement.trigger('dragstop.spectrum', [get()]); + if (pos.top <= pos.canvasTop && !(pos.elementHeight + pos.targetHeight >= frameOffset.height)) { + pos.top = pos.elementTop + pos.elementHeight; + } } - function setFromTextInput() { - - var value = textInput.val(); + var toolbarStyle = toolbar.style; + toolbarStyle.top = pos.top + un; + toolbarStyle.left = pos.left + un; + } + }, - if ((value === null || value === "") && allowEmpty) { - _set(null); - updateOriginalInput(true); - } else { - var tiny = tinycolor(value); - if (tiny.isValid()) { - _set(tiny); - updateOriginalInput(true); - } else { - textInput.addClass("sp-validation-error"); - } - } - } + /** + * Enable rich text editor on the element + * @param {View} view Component view + * @param {Object} rte The instance of already defined RTE + * @private + * */ + enable: function enable(view, rte) { + lastEl = view.el; + var em = config.em; + var el = view.getChildrenContainer(); + var customRte = this.customRte; + toolbar.style.display = ''; + rte = customRte ? customRte.enable(el, rte) : this.initRte(el).enable(); - function toggle() { - if (visible) { - hide(); - } else { - show(); - } - } + if (em) { + setTimeout(this.updatePosition.bind(this), 0); + var event = 'change:canvasOffset canvasScroll'; + em.off(event, this.updatePosition, this); + em.on(event, this.updatePosition, this); + em.trigger('rte:enable', view, rte); + } - function show() { - var event = $.Event('beforeShow.spectrum'); + return rte; + }, - if (visible) { - reflow(); - return; - } + /** + * Unbind rich text editor from the element + * @param {View} view + * @param {Object} rte The instance of already defined RTE + * @private + * */ + disable: function disable(view, rte) { + var em = config.em; + var customRte = this.customRte; + var el = view.getChildrenContainer(); - boundElement.trigger(event, [get()]); + if (customRte) { + customRte.disable(el, rte); + } else { + rte && rte.disable(); + } - if (callbacks.beforeShow(get()) === false || event.isDefaultPrevented()) { - return; - } + hideToolbar(); + em && em.trigger('rte:disable', view, rte); + } + }; +}); - hideAll(); - visible = true; +/***/ }), - var $doc = $(doc); - $doc.bind("keydown.spectrum", onkeydown); - $doc.bind("click.spectrum", clickout); - $(window).bind("resize.spectrum", resize); - replacer.addClass("sp-active"); - container.removeClass("sp-hidden"); +/***/ "./src/rich_text_editor/model/RichTextEditor.js": +/*!******************************************************!*\ + !*** ./src/rich_text_editor/model/RichTextEditor.js ***! + \******************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - reflow(); - updateUI(); +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "default", function() { return RichTextEditor; }); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "./node_modules/@babel/runtime/helpers/classCallCheck.js"); +/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "./node_modules/@babel/runtime/helpers/createClass.js"); +/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_2__); +/* harmony import */ var utils_mixins__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! utils/mixins */ "./src/utils/mixins.js"); - colorOnShow = get(); - drawInitial(); - callbacks.show(colorOnShow); - boundElement.trigger('show.spectrum', [colorOnShow]); - } - function onkeydown(e) { - // Close on ESC - if (e.keyCode === 27) { - hide(); - } - } - function clickout(e) { - // Return on right click. - if (e.button == 2) { - return; - } +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - // If a drag event was happening during the mouseup, don't hide - // on click. - if (isDragging) { - return; - } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - if (clickoutFiresChange) { - updateOriginalInput(true); - } else { - revert(); - } - hide(); - } +// The initial version of this RTE was borrowed from https://github.com/jaredreich/pell +// and adapted to the GrapesJS's need - function hide() { - // Return if hiding is unnecessary - if (!visible || flat) { - return; - } - visible = false; +var RTE_KEY = '_rte'; +var defActions = { + bold: { + name: 'bold', + icon: 'B', + attributes: { + title: 'Bold' + }, + result: function result(rte) { + return rte.exec('bold'); + } + }, + italic: { + name: 'italic', + icon: 'I', + attributes: { + title: 'Italic' + }, + result: function result(rte) { + return rte.exec('italic'); + } + }, + underline: { + name: 'underline', + icon: 'U', + attributes: { + title: 'Underline' + }, + result: function result(rte) { + return rte.exec('underline'); + } + }, + strikethrough: { + name: 'strikethrough', + icon: 'S', + attributes: { + title: 'Strike-through' + }, + result: function result(rte) { + return rte.exec('strikeThrough'); + } + }, + link: { + icon: "", + name: 'link', + attributes: { + style: 'font-size:1.4rem;padding:0 4px 2px;', + title: 'Link' + }, + result: function result(rte) { + var anchor = rte.selection().anchorNode; + var nextSibling = anchor && anchor.nextSibling; - $(doc).unbind("keydown.spectrum", onkeydown); - $(doc).unbind("click.spectrum", clickout); - $(window).unbind("resize.spectrum", resize); + if (nextSibling && nextSibling.nodeName == 'A') { + rte.exec('unlink'); + } else { + rte.insertHTML("".concat(rte.selection(), "")); + } + } + } +}; - replacer.removeClass("sp-active"); - container.addClass("sp-hidden"); +var RichTextEditor = +/*#__PURE__*/ +function () { + function RichTextEditor() { + var _this = this; - callbacks.hide(get()); - boundElement.trigger('hide.spectrum', [get()]); - } + var settings = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; - function revert() { - _set(colorOnShow, true); - } + _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_1___default()(this, RichTextEditor); - function _set(color, ignoreFormatChange) { - if (tinycolor.equals(color, get())) { - // Update UI just in case a validation error needs - // to be cleared. - updateUI(); - return; - } + var el = settings.el; - var newColor, newHsv; - if (!color && allowEmpty) { - isEmpty = true; - } else { - isEmpty = false; - newColor = tinycolor(color); - newHsv = newColor.toHsv(); - - currentHue = newHsv.h % 360 / 360; - currentSaturation = newHsv.s; - currentValue = newHsv.v; - currentAlpha = newHsv.a; - } - updateUI(); + if (el[RTE_KEY]) { + return el[RTE_KEY]; + } - if (newColor && newColor.isValid() && !ignoreFormatChange) { - currentPreferredFormat = opts.preferredFormat || newColor.getFormat(); - } - } + el[RTE_KEY] = this; + this.setEl(el); + this.updateActiveActions = this.updateActiveActions.bind(this); + var settAct = settings.actions || []; + settAct.forEach(function (action, i) { + if (typeof action === 'string') { + action = defActions[action]; + } else if (defActions[action.name]) { + action = _objectSpread({}, defActions[action.name], {}, action); + } - function get(opts) { - opts = opts || {}; + settAct[i] = action; + }); + var actions = settAct.length ? settAct : Object.keys(defActions).map(function (action) { + return defActions[action]; + }); + settings.classes = _objectSpread({}, { + actionbar: 'actionbar', + button: 'action', + active: 'active' + }, {}, settings.classes); + var classes = settings.classes; + var actionbar = settings.actionbar; + this.actionbar = actionbar; + this.settings = settings; + this.classes = classes; + this.actions = actions; - if (allowEmpty && isEmpty) { - return null; - } + if (!actionbar) { + var actionbarCont = settings.actionbarContainer; + actionbar = document.createElement('div'); + actionbar.className = classes.actionbar; + actionbarCont.appendChild(actionbar); + this.actionbar = actionbar; + actions.forEach(function (action) { + return _this.addAction(action); + }); + } - return tinycolor.fromRatio({ - h: currentHue, - s: currentSaturation, - v: currentValue, - a: Math.round(currentAlpha * 100) / 100 - }, { format: opts.format || currentPreferredFormat }); - } + settings.styleWithCSS && this.exec('styleWithCSS'); + this.syncActions(); + return this; + } - function isValid() { - return !textInput.hasClass("sp-validation-error"); - } + _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_2___default()(RichTextEditor, [{ + key: "setEl", + value: function setEl(el) { + this.el = el; + this.doc = el.ownerDocument; + } + }, { + key: "updateActiveActions", + value: function updateActiveActions() { + var _this2 = this; - function move() { - updateUI(); + this.getActions().forEach(function (action) { + var btn = action.btn; + var update = action.update; + var active = _this2.classes.active; + var name = action.name; + var doc = _this2.doc; + btn.className = btn.className.replace(active, '').trim(); // doc.queryCommandValue(name) != 'false' - callbacks.move(get()); - boundElement.trigger('move.spectrum', [get()]); + if (doc.queryCommandSupported(name) && doc.queryCommandState(name)) { + btn.className += " ".concat(active); } - function updateUI() { + update && update(_this2, action); + }); + } + }, { + key: "enable", + value: function enable() { + if (this.enabled) { + return this; + } - textInput.removeClass("sp-validation-error"); + this.actionbarEl().style.display = ''; + this.el.contentEditable = true; + Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["on"])(this.el, 'mouseup keyup', this.updateActiveActions); + this.syncActions(); + this.updateActiveActions(); + this.el.focus(); + this.enabled = 1; + return this; + } + }, { + key: "disable", + value: function disable() { + this.actionbarEl().style.display = 'none'; + this.el.contentEditable = false; + Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["off"])(this.el, 'mouseup keyup', this.updateActiveActions); + this.enabled = 0; + return this; + } + /** + * Sync actions with the current RTE + */ - updateHelperLocations(); + }, { + key: "syncActions", + value: function syncActions() { + var _this3 = this; - // Update dragger background color (gradients take care of saturation and value). - var flatColor = tinycolor.fromRatio({ h: currentHue, s: 1, v: 1 }); - dragger.css("background-color", flatColor.toHexString()); + this.getActions().forEach(function (action) { + var event = action.event || 'click'; - // Get a format that alpha will be included in (hex and names ignore alpha) - var format = currentPreferredFormat; - if (currentAlpha < 1 && !(currentAlpha === 0 && format === "name")) { - if (format === "hex" || format === "hex3" || format === "hex6" || format === "name") { - format = "rgb"; - } - } + action.btn["on".concat(event)] = function (e) { + action.result(_this3, action); - var realColor = get({ format: format }), - displayColor = ''; + _this3.updateActiveActions(); + }; + }); + } + /** + * Add new action to the actionbar + * @param {Object} action + * @param {Object} [opts={}] + */ - //reset background info for preview element - previewElement.removeClass("sp-clear-display"); - previewElement.css('background-color', 'transparent'); + }, { + key: "addAction", + value: function addAction(action) { + var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + var sync = opts.sync; + var btn = document.createElement('span'); + var icon = action.icon; + var attr = action.attributes || {}; + btn.className = this.classes.button; + action.btn = btn; - if (!realColor && allowEmpty) { - // Update the replaced elements background with icon indicating no color selection - previewElement.addClass("sp-clear-display"); - } else { - var realHex = realColor.toHexString(), - realRgb = realColor.toRgbString(); - - // Update the replaced elements background color (with actual selected color) - if (rgbaSupport || realColor.alpha === 1) { - previewElement.css("background-color", realRgb); - } else { - previewElement.css("background-color", "transparent"); - previewElement.css("filter", realColor.toFilter()); - } + for (var key in attr) { + btn.setAttribute(key, attr[key]); + } - if (opts.showAlpha) { - var rgb = realColor.toRgb(); - rgb.a = 0; - var realAlpha = tinycolor(rgb).toRgbString(); - var gradient = "linear-gradient(left, " + realAlpha + ", " + realHex + ")"; - - if (IE) { - alphaSliderInner.css("filter", tinycolor(realAlpha).toFilter({ gradientType: 1 }, realHex)); - } else { - alphaSliderInner.css("background", "-webkit-" + gradient); - alphaSliderInner.css("background", "-moz-" + gradient); - alphaSliderInner.css("background", "-ms-" + gradient); - // Use current syntax gradient on unprefixed property. - alphaSliderInner.css("background", "linear-gradient(to right, " + realAlpha + ", " + realHex + ")"); - } - } + if (typeof icon == 'string') { + btn.innerHTML = icon; + } else { + btn.appendChild(icon); + } - displayColor = realColor.toString(format); - } + this.actionbarEl().appendChild(btn); - // Update the text entry input as it changes happen - if (opts.showInput) { - textInput.val(displayColor); - } + if (sync) { + this.actions.push(action); + this.syncActions(); + } + } + /** + * Get the array of current actions + * @return {Array} + */ - if (opts.showPalette) { - drawPalette(); - } + }, { + key: "getActions", + value: function getActions() { + return this.actions; + } + /** + * Returns the Selection instance + * @return {Selection} + */ - drawInitial(); - } + }, { + key: "selection", + value: function selection() { + return this.doc.getSelection(); + } + /** + * Execute the command + * @param {string} command Command name + * @param {any} [value=null Command's arguments + */ - function updateHelperLocations() { - var s = currentSaturation; - var v = currentValue; + }, { + key: "exec", + value: function exec(command) { + var value = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null; + this.doc.execCommand(command, false, value); + } + /** + * Get the actionbar element + * @return {HTMLElement} + */ - if (allowEmpty && isEmpty) { - //if selected color is empty, hide the helpers - alphaSlideHelper.hide(); - slideHelper.hide(); - dragHelper.hide(); - } else { - //make sure helpers are visible - alphaSlideHelper.show(); - slideHelper.show(); - dragHelper.show(); - - // Where to show the little circle in that displays your current selected color - var dragX = s * dragWidth; - var dragY = dragHeight - v * dragHeight; - dragX = Math.max(-dragHelperHeight, Math.min(dragWidth - dragHelperHeight, dragX - dragHelperHeight)); - dragY = Math.max(-dragHelperHeight, Math.min(dragHeight - dragHelperHeight, dragY - dragHelperHeight)); - dragHelper.css({ - "top": dragY + "px", - "left": dragX + "px" - }); - - var alphaX = currentAlpha * alphaWidth; - alphaSlideHelper.css({ - "left": alphaX - alphaSlideHelperWidth / 2 + "px" - }); - - // Where to show the bar that displays your current selected hue - var slideY = currentHue * slideHeight; - slideHelper.css({ - "top": slideY - slideHelperHeight + "px" - }); - } - } + }, { + key: "actionbarEl", + value: function actionbarEl() { + return this.actionbar; + } + /** + * Set custom HTML to the selection, useful as the default 'insertHTML' command + * doesn't work in the same way on all browsers + * @param {string} value HTML string + */ - function updateOriginalInput(fireCallback) { - var color = get(), - displayColor = '', - hasChanged = !tinycolor.equals(color, colorOnShow); + }, { + key: "insertHTML", + value: function insertHTML(value) { + var lastNode; + var doc = this.doc; + var sel = doc.getSelection(); - if (color) { - displayColor = color.toString(currentPreferredFormat); - // Update the selection palette with the current color - addColorToSelectionPalette(color); - } + if (sel && sel.rangeCount) { + var node = doc.createElement('div'); + var range = sel.getRangeAt(0); + range.deleteContents(); + node.innerHTML = value; + Array.prototype.slice.call(node.childNodes).forEach(function (nd) { + range.insertNode(nd); + lastNode = nd; + }); + sel.removeAllRanges(); + sel.addRange(range); + this.el.focus(); + } + } + }]); - if (isInput) { - boundElement.val(displayColor); - } + return RichTextEditor; +}(); - if (fireCallback && hasChanged) { - callbacks.change(color); - boundElement.trigger('change', [color]); - } - } - function reflow() { - if (!visible) { - return; // Calculations would be useless and wouldn't be reliable anyways - } - dragWidth = dragger.width(); - dragHeight = dragger.height(); - dragHelperHeight = dragHelper.height(); - slideWidth = slider.width(); - slideHeight = slider.height(); - slideHelperHeight = slideHelper.height(); - alphaWidth = alphaSlider.width(); - alphaSlideHelperWidth = alphaSlideHelper.width(); - - if (!flat) { - container.css("position", "absolute"); - if (opts.offset) { - container.offset(opts.offset); - } else { - container.offset(getOffset(container, offsetElement)); - } - } - updateHelperLocations(); +/***/ }), - if (opts.showPalette) { - drawPalette(); - } +/***/ "./src/selector_manager/config/config.js": +/*!***********************************************!*\ + !*** ./src/selector_manager/config/config.js ***! + \***********************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - boundElement.trigger('reflow.spectrum'); - } +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony default export */ __webpack_exports__["default"] = ({ + // Style prefix + stylePrefix: 'clm-', + // Specify the element to use as a container, string (query) or HTMLElement + // With the empty value, nothing will be rendered + appendTo: '', + // Default selectors + selectors: [], + // Label for selectors + label: 'Classes', + // Label for states + statesLabel: '- State -', + selectedLabel: 'Selected', + // States + states: [{ + name: 'hover', + label: 'Hover' + }, { + name: 'active', + label: 'Click' + }, { + name: 'nth-of-type(2n)', + label: 'Even/Odd' + }], + // Custom selector name escaping strategy, eg. + // name => name.replace(' ', '_') + escapeName: 0 +}); - function destroy() { - boundElement.show(); - offsetElement.unbind("click.spectrum touchstart.spectrum"); - container.remove(); - replacer.remove(); - spectrums[spect.id] = null; - } +/***/ }), - function option(optionName, optionValue) { - if (optionName === undefined) { - return $.extend({}, opts); - } - if (optionValue === undefined) { - return opts[optionName]; - } +/***/ "./src/selector_manager/index.js": +/*!***************************************!*\ + !*** ./src/selector_manager/index.js ***! + \***************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - opts[optionName] = optionValue; +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var _config_config__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./config/config */ "./src/selector_manager/config/config.js"); +/* harmony import */ var _model_Selector__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./model/Selector */ "./src/selector_manager/model/Selector.js"); +/* harmony import */ var _model_Selectors__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./model/Selectors */ "./src/selector_manager/model/Selectors.js"); +/* harmony import */ var _view_ClassTagsView__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./view/ClassTagsView */ "./src/selector_manager/view/ClassTagsView.js"); - if (optionName === "preferredFormat") { - currentPreferredFormat = opts.preferredFormat; - } - applyOptions(); - } - function enable() { - disabled = false; - boundElement.attr("disabled", false); - offsetElement.removeClass("sp-disabled"); - } +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - function disable() { - hide(); - disabled = true; - boundElement.attr("disabled", true); - offsetElement.addClass("sp-disabled"); - } - - function setOffset(coord) { - opts.offset = coord; - reflow(); - } - - initialize(); - - var spect = { - show: show, - hide: hide, - toggle: toggle, - reflow: reflow, - option: option, - enable: enable, - disable: disable, - offset: setOffset, - set: function set(c) { - _set(c); - updateOriginalInput(); - }, - get: get, - destroy: destroy, - container: container - }; +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - spect.id = spectrums.push(spect) - 1; +/** + * Selectors in GrapesJS are used in CSS Composer inside Rules and in Components as classes. To illustrate this concept let's take + * a look at this code: + * + * ```css + * span > #send-btn.btn{ + * ... + * } + * ``` + * ```html + * + * + * + * ``` + * + * In this scenario we get: + * * span -> selector of type `tag` + * * send-btn -> selector of type `id` + * * btn -> selector of type `class` + * + * So, for example, being `btn` the same class entity it'll be easier to refactor and track things. + * + * You can customize the initial state of the module from the editor initialization, by passing the following [Configuration Object](https://github.com/artf/grapesjs/blob/master/src/selector_manager/config/config.js) + * ```js + * const editor = grapesjs.init({ + * selectorManager: { + * // options + * } + * }) + * ``` + * + * Once the editor is instantiated you can use its API. Before using these methods you should get the module from the instance + * + * ```js + * const selectorManager = editor.SelectorManager; + * ``` + * + * * [getConfig](#getconfig) + * * [add](#add) + * * [addClass](#addclass) + * * [get](#get) + * * [getAll](#getAll) + * + * @module SelectorManager + */ - return spect; - } - /** - * checkOffset - get the offset below/above and left/right element depending on screen position - * Thanks https://github.com/jquery/jquery-ui/blob/master/ui/jquery.ui.datepicker.js - */ - function getOffset(picker, input) { - var extraY = 0; - var dpWidth = picker.outerWidth(); - var dpHeight = picker.outerHeight(); - var inputHeight = input.outerHeight(); - var doc = picker[0].ownerDocument; - var docElem = doc.documentElement; - var cW = docElem.clientWidth; - var cH = docElem.clientHeight; - var scL = $(doc).scrollLeft(); - var scT = $(doc).scrollTop(); - var viewWidth = cW + scL; - var viewHeight = cH + scT; - var offset = input.offset(); - offset.top += inputHeight; - offset.left -= Math.min(offset.left, offset.left + dpWidth > viewWidth && viewWidth > dpWidth ? Math.abs(offset.left + dpWidth - viewWidth) : 0); - offset.top -= Math.min(offset.top, offset.top + dpHeight > viewHeight && viewHeight > dpHeight ? Math.abs(dpHeight + inputHeight - extraY) : extraY); - return offset; - } +var isId = function isId(str) { + return Object(underscore__WEBPACK_IMPORTED_MODULE_1__["isString"])(str) && str[0] == '#'; +}; - /** - * noop - do nothing - */ - function noop() {} +var isClass = function isClass(str) { + return Object(underscore__WEBPACK_IMPORTED_MODULE_1__["isString"])(str) && str[0] == '.'; +}; - /** - * stopPropagation - makes the code only doing this a little easier to read in line - */ - function stopPropagation(e) { - e.stopPropagation(); - } +/* harmony default export */ __webpack_exports__["default"] = (function (config) { + var c = config || {}; + var selectors, selectorTags; + return { + Selector: _model_Selector__WEBPACK_IMPORTED_MODULE_3__["default"], + Selectors: _model_Selectors__WEBPACK_IMPORTED_MODULE_4__["default"], /** - * Create a function bound to a given object - * Thanks to underscore.js - */ - function bind(func, obj) { - var slice = Array.prototype.slice; - var args = slice.call(arguments, 2); - return function () { - return func.apply(obj, args.concat(slice.call(arguments))); - }; - } + * Name of the module + * @type {String} + * @private + */ + name: 'SelectorManager', /** - * Lightweight drag helper. Handles containment within the element, so that - * when dragging, the x is within [0,element.width] and y is within [0,element.height] - */ - function draggable(element, onmove, onstart, onstop) { - onmove = onmove || function () {}; - onstart = onstart || function () {}; - onstop = onstop || function () {}; - var doc = document; - var dragging = false; - var offset = {}; - var maxHeight = 0; - var maxWidth = 0; - var hasTouch = 'ontouchstart' in window; - - var duringDragEvents = {}; - duringDragEvents["selectstart"] = prevent; - duringDragEvents["dragstart"] = prevent; - duringDragEvents["touchmove mousemove"] = move; - duringDragEvents["touchend mouseup"] = stop; - - function prevent(e) { - if (e.stopPropagation) { - e.stopPropagation(); - } - if (e.preventDefault) { - e.preventDefault(); - } - e.returnValue = false; - } - - function move(e) { - if (dragging) { - // Mouseup happened outside of window - if (IE && doc.documentMode < 9 && !e.button) { - return stop(); - } + * Get configuration object + * @return {Object} + */ + getConfig: function getConfig() { + return c; + }, - var t0 = e.originalEvent && e.originalEvent.touches && e.originalEvent.touches[0]; - var pageX = t0 && t0.pageX || e.pageX; - var pageY = t0 && t0.pageY || e.pageY; + /** + * Initialize module. Automatically called with a new instance of the editor + * @param {Object} config Configurations + * @return {this} + * @private + */ + init: function init() { + var conf = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + c = _objectSpread({}, _config_config__WEBPACK_IMPORTED_MODULE_2__["default"], {}, conf); + var em = c.em; + var ppfx = c.pStylePrefix; - var dragX = Math.max(0, Math.min(pageX - offset.left, maxWidth)); - var dragY = Math.max(0, Math.min(pageY - offset.top, maxHeight)); + if (ppfx) { + c.stylePrefix = ppfx + c.stylePrefix; + } - if (hasTouch) { - // Stop scrolling in iOS - prevent(e); - } + selectorTags = new _view_ClassTagsView__WEBPACK_IMPORTED_MODULE_5__["default"]({ + collection: new _model_Selectors__WEBPACK_IMPORTED_MODULE_4__["default"]([], { + em: em, + config: c + }), + config: c + }); // Global selectors container - onmove.apply(element, [dragX, dragY, e]); - } - } + selectors = new _model_Selectors__WEBPACK_IMPORTED_MODULE_4__["default"](c.selectors); + selectors.on('add', function (model) { + return em.trigger('selector:add', model); + }); + return this; + }, + postRender: function postRender() { + var elTo = this.getConfig().appendTo; - function start(e) { - var rightclick = e.which ? e.which == 3 : e.button == 2; + if (elTo) { + var el = Object(underscore__WEBPACK_IMPORTED_MODULE_1__["isElement"])(elTo) ? elTo : document.querySelector(elTo); + el.appendChild(this.render([])); + } + }, + addSelector: function addSelector(name) { + var opt = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; - if (!rightclick && !dragging) { - if (onstart.apply(element, arguments) !== false) { - dragging = true; - maxHeight = $(element).height(); - maxWidth = $(element).width(); - offset = $(element).offset(); + var opts = _objectSpread({}, opt); - $(doc).bind(duringDragEvents); - $(doc.body).addClass("sp-dragging"); + if (Object(underscore__WEBPACK_IMPORTED_MODULE_1__["isObject"])(name)) { + opts = name; + } else { + opts.name = name; + } - move(e); + if (isId(opts.name)) { + opts.name = opts.name.substr(1); + opts.type = _model_Selector__WEBPACK_IMPORTED_MODULE_3__["default"].TYPE_ID; + } else if (isClass(opts.name)) { + opts.name = opts.name.substr(1); + } - prevent(e); - } - } - } + if (opts.label && !opts.name) { + opts.name = this.escapeName(opts.label); + } - function stop() { - if (dragging) { - $(doc).unbind(duringDragEvents); - $(doc.body).removeClass("sp-dragging"); + var cname = opts.name; + var selector = cname ? this.get(cname, opts.type) : selectors.where(opts)[0]; - // Wait a tick before notifying observers to allow the click event - // to fire in Chrome. - setTimeout(function () { - onstop.apply(element, arguments); - }, 0); - } - dragging = false; - } + if (!selector) { + return selectors.add(opts, { + config: c + }); + } - $(element).bind("touchstart mousedown", start); - } + return selector; + }, + getSelector: function getSelector(name) { + var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : _model_Selector__WEBPACK_IMPORTED_MODULE_3__["default"].TYPE_CLASS; - function throttle(func, wait, debounce) { - var timeout; - return function () { - var context = this, - args = arguments; - var throttler = function throttler() { - timeout = null; - func.apply(context, args); - }; - if (debounce) clearTimeout(timeout); - if (debounce || !timeout) timeout = setTimeout(throttler, wait); - }; - } + if (isId(name)) { + name = name.substr(1); + type = _model_Selector__WEBPACK_IMPORTED_MODULE_3__["default"].TYPE_ID; + } else if (isClass(name)) { + name = name.substr(1); + } - function inputTypeColorSupport() { - return $.fn.spectrum.inputTypeColorSupport(); - } + return selectors.where({ + name: name, + type: type + })[0]; + }, /** - * Define a jQuery plugin - */ - var dataID = "spectrum.id"; - $.fn.spectrum = function (opts, extra) { - - if (typeof opts == "string") { - - var returnValue = this; - var args = Array.prototype.slice.call(arguments, 1); - - this.each(function () { - var spect = spectrums[$(this).data(dataID)]; - if (spect) { - var method = spect[opts]; - if (!method) { - throw new Error("Spectrum: no such method: '" + opts + "'"); - } - - if (opts == "get") { - returnValue = spect.get(); - } else if (opts == "container") { - returnValue = spect.container; - } else if (opts == "option") { - returnValue = spect.option.apply(spect, args); - } else if (opts == "destroy") { - spect.destroy(); - $(this).removeData(dataID); - } else { - method.apply(spect, args); - } - } - }); + * Add a new selector to collection if it's not already exists. Class type is a default one + * @param {String|Array} name Selector/s name + * @param {Object} opts Selector options + * @param {String} [opts.label=''] Label for the selector, if it's not provided the label will be the same as the name + * @param {String} [opts.type=1] Type of the selector. At the moment, only 'class' (1) is available + * @return {Model|Array} + * @example + * const selector = selectorManager.add('selectorName'); + * // Same as + * const selector = selectorManager.add('selectorName', { + * type: 1, + * label: 'selectorName' + * }); + * // Multiple selectors + * const selectors = selectorManager.add(['.class1', '.class2', '#id1']); + * */ + add: function add(name) { + var _this = this; - return returnValue; - } + var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; - // Initializing a new instance of spectrum - return this.spectrum("destroy").each(function () { - var options = $.extend({}, opts, $(this).data()); - var spect = spectrum(this, options); - $(this).data(dataID, spect.id); + if (Object(underscore__WEBPACK_IMPORTED_MODULE_1__["isArray"])(name)) { + return name.map(function (item) { + return _this.addSelector(item, opts); }); - }; + } else { + return this.addSelector(name, opts); + } + }, - $.fn.spectrum.load = true; - $.fn.spectrum.loadOpts = {}; - $.fn.spectrum.draggable = draggable; - $.fn.spectrum.defaults = defaultOpts; - $.fn.spectrum.inputTypeColorSupport = function inputTypeColorSupport() { - if (typeof inputTypeColorSupport._cachedResult === "undefined") { - var colorInput = $("")[0]; // if color element is supported, value will default to not null - inputTypeColorSupport._cachedResult = colorInput.type === "color" && colorInput.value !== ""; - } - return inputTypeColorSupport._cachedResult; - }; + /** + * Add class selectors + * @param {Array|string} classes Array or string of classes + * @return {Array} Array of added selectors + * @example + * sm.addClass('class1'); + * sm.addClass('class1 class2'); + * sm.addClass(['class1', 'class2']); + * // -> [SelectorObject, ...] + */ + addClass: function addClass(classes) { + var _this2 = this; - $.spectrum = {}; - $.spectrum.localization = {}; - $.spectrum.palettes = {}; + var added = []; - $.fn.spectrum.processNativeColorInputs = function () { - var colorInputs = $("input[type=color]"); - if (colorInputs.length && !inputTypeColorSupport()) { - colorInputs.spectrum({ - preferredFormat: "hex6" - }); - } - }; + if (Object(underscore__WEBPACK_IMPORTED_MODULE_1__["isString"])(classes)) { + classes = classes.trim().split(' '); + } - // TinyColor v1.1.2 - // https://github.com/bgrins/TinyColor - // Brian Grinstead, MIT License + classes.forEach(function (name) { + return added.push(_this2.addSelector(name)); + }); + return added; + }, - //(function() { + /** + * Get the selector by its name + * @param {String|Array} name Selector name + * @param {String} type Selector type + * @return {Model|Array} + * @example + * const selector = selectorManager.get('selectorName'); + * // or get an array + * const selectors = selectorManager.get(['class1', 'class2']); + * */ + get: function get(name, type) { + var _this3 = this; - var trimLeft = /^[\s,#]+/, - trimRight = /\s+$/, - tinyCounter = 0, - math = Math, - mathRound = math.round, - mathMin = math.min, - mathMax = math.max, - mathRandom = math.random; + if (Object(underscore__WEBPACK_IMPORTED_MODULE_1__["isArray"])(name)) { + var result = []; - var tinycolor = function tinycolor(color, opts) { + var _selectors = name.map(function (item) { + return _this3.getSelector(item); + }).filter(function (item) { + return item; + }); - color = color ? color : ''; - opts = opts || {}; + _selectors.forEach(function (item) { + return result.indexOf(item) < 0 && result.push(item); + }); - // If input is already a tinycolor, return itself - if (color instanceof tinycolor) { - return color; - } - // If we are called as a function, call using new instead - if (!(this instanceof tinycolor)) { - return new tinycolor(color, opts); - } + return result; + } else { + return this.getSelector(name, type); + } + }, - var rgb = inputToRGB(color); - this._originalInput = color, this._r = rgb.r, this._g = rgb.g, this._b = rgb.b, this._a = rgb.a, this._roundA = mathRound(100 * this._a) / 100, this._format = opts.format || rgb.format; - this._gradientType = opts.gradientType; + /** + * Get all selectors + * @return {Collection} + * */ + getAll: function getAll() { + return selectors; + }, - // Don't let the range of [0,255] come back in [0,1]. - // Potentially lose a little bit of precision here, but will fix issues where - // .5 gets interpreted as half of the total, instead of half of 1 - // If it was supposed to be 128, this was already taken care of by `inputToRgb` - if (this._r < 1) { - this._r = mathRound(this._r); - } - if (this._g < 1) { - this._g = mathRound(this._g); - } - if (this._b < 1) { - this._b = mathRound(this._b); - } + /** + * Return escaped selector name + * @param {String} name Selector name to escape + * @returns {String} Escaped name + */ + escapeName: function escapeName(name) { + var _c = c, + escapeName = _c.escapeName; + return escapeName ? escapeName(name) : _model_Selector__WEBPACK_IMPORTED_MODULE_3__["default"].escapeName(name); + }, - this._ok = rgb.ok; - this._tc_id = tinyCounter++; - }; + /** + * Render class selectors. If an array of selectors is provided a new instance of the collection will be rendered + * @param {Array} selectors + * @return {HTMLElement} + * @private + */ + render: function render(selectors) { + if (selectors) { + var view = new _view_ClassTagsView__WEBPACK_IMPORTED_MODULE_5__["default"]({ + collection: new _model_Selectors__WEBPACK_IMPORTED_MODULE_4__["default"](selectors), + config: c + }); + return view.render().el; + } else return selectorTags.render().el; + } + }; +}); - tinycolor.prototype = { - isDark: function isDark() { - return this.getBrightness() < 128; - }, - isLight: function isLight() { - return !this.isDark(); - }, - isValid: function isValid() { - return this._ok; - }, - getOriginalInput: function getOriginalInput() { - return this._originalInput; - }, - getFormat: function getFormat() { - return this._format; - }, - getAlpha: function getAlpha() { - return this._a; - }, - getBrightness: function getBrightness() { - var rgb = this.toRgb(); - return (rgb.r * 299 + rgb.g * 587 + rgb.b * 114) / 1000; - }, - setAlpha: function setAlpha(value) { - this._a = boundAlpha(value); - this._roundA = mathRound(100 * this._a) / 100; - return this; - }, - toHsv: function toHsv() { - var hsv = rgbToHsv(this._r, this._g, this._b); - return { h: hsv.h * 360, s: hsv.s, v: hsv.v, a: this._a }; - }, - toHsvString: function toHsvString() { - var hsv = rgbToHsv(this._r, this._g, this._b); - var h = mathRound(hsv.h * 360), - s = mathRound(hsv.s * 100), - v = mathRound(hsv.v * 100); - return this._a == 1 ? "hsv(" + h + ", " + s + "%, " + v + "%)" : "hsva(" + h + ", " + s + "%, " + v + "%, " + this._roundA + ")"; - }, - toHsl: function toHsl() { - var hsl = rgbToHsl(this._r, this._g, this._b); - return { h: hsl.h * 360, s: hsl.s, l: hsl.l, a: this._a }; - }, - toHslString: function toHslString() { - var hsl = rgbToHsl(this._r, this._g, this._b); - var h = mathRound(hsl.h * 360), - s = mathRound(hsl.s * 100), - l = mathRound(hsl.l * 100); - return this._a == 1 ? "hsl(" + h + ", " + s + "%, " + l + "%)" : "hsla(" + h + ", " + s + "%, " + l + "%, " + this._roundA + ")"; - }, - toHex: function toHex(allow3Char) { - return rgbToHex(this._r, this._g, this._b, allow3Char); - }, - toHexString: function toHexString(allow3Char) { - return '#' + this.toHex(allow3Char); - }, - toHex8: function toHex8() { - return rgbaToHex(this._r, this._g, this._b, this._a); - }, - toHex8String: function toHex8String() { - return '#' + this.toHex8(); - }, - toRgb: function toRgb() { - return { r: mathRound(this._r), g: mathRound(this._g), b: mathRound(this._b), a: this._a }; - }, - toRgbString: function toRgbString() { - return this._a == 1 ? "rgb(" + mathRound(this._r) + ", " + mathRound(this._g) + ", " + mathRound(this._b) + ")" : "rgba(" + mathRound(this._r) + ", " + mathRound(this._g) + ", " + mathRound(this._b) + ", " + this._roundA + ")"; - }, - toPercentageRgb: function toPercentageRgb() { - return { r: mathRound(bound01(this._r, 255) * 100) + "%", g: mathRound(bound01(this._g, 255) * 100) + "%", b: mathRound(bound01(this._b, 255) * 100) + "%", a: this._a }; - }, - toPercentageRgbString: function toPercentageRgbString() { - return this._a == 1 ? "rgb(" + mathRound(bound01(this._r, 255) * 100) + "%, " + mathRound(bound01(this._g, 255) * 100) + "%, " + mathRound(bound01(this._b, 255) * 100) + "%)" : "rgba(" + mathRound(bound01(this._r, 255) * 100) + "%, " + mathRound(bound01(this._g, 255) * 100) + "%, " + mathRound(bound01(this._b, 255) * 100) + "%, " + this._roundA + ")"; - }, - toName: function toName() { - if (this._a === 0) { - return "transparent"; - } +/***/ }), - if (this._a < 1) { - return false; - } +/***/ "./src/selector_manager/model/Selector.js": +/*!************************************************!*\ + !*** ./src/selector_manager/model/Selector.js ***! + \************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - return hexNames[rgbToHex(this._r, this._g, this._b, true)] || false; - }, - toFilter: function toFilter(secondColor) { - var hex8String = '#' + rgbaToHex(this._r, this._g, this._b, this._a); - var secondHex8String = hex8String; - var gradientType = this._gradientType ? "GradientType = 1, " : ""; - - if (secondColor) { - var s = tinycolor(secondColor); - secondHex8String = s.toHex8String(); - } +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); - return "progid:DXImageTransform.Microsoft.gradient(" + gradientType + "startColorstr=" + hex8String + ",endColorstr=" + secondHex8String + ")"; - }, - toString: function toString(format) { - var formatSet = !!format; - format = format || this._format; - - var formattedString = false; - var hasAlpha = this._a < 1 && this._a >= 0; - var needsAlphaFormat = !formatSet && hasAlpha && (format === "hex" || format === "hex6" || format === "hex3" || format === "name"); - - if (needsAlphaFormat) { - // Special case for "transparent", all other non-alpha formats - // will return rgba when there is transparency. - if (format === "name" && this._a === 0) { - return this.toName(); - } - return this.toRgbString(); - } - if (format === "rgb") { - formattedString = this.toRgbString(); - } - if (format === "prgb") { - formattedString = this.toPercentageRgbString(); - } - if (format === "hex" || format === "hex6") { - formattedString = this.toHexString(); - } - if (format === "hex3") { - formattedString = this.toHexString(true); - } - if (format === "hex8") { - formattedString = this.toHex8String(); - } - if (format === "name") { - formattedString = this.toName(); - } - if (format === "hsl") { - formattedString = this.toHslString(); - } - if (format === "hsv") { - formattedString = this.toHsvString(); - } +var TYPE_CLASS = 1; +var TYPE_ID = 2; +var Selector = backbone__WEBPACK_IMPORTED_MODULE_0___default.a.Model.extend({ + idAttribute: 'name', + defaults: { + name: '', + label: '', + // Type of the selector + type: TYPE_CLASS, + // If not active it's not selectable by the style manager (uncheckboxed) + active: true, + // Can't be seen by the style manager, therefore even by the user + // Will be rendered only in export code + private: false, + // If true, can't be removed from the attacched element + protected: false + }, + initialize: function initialize(props) { + var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + var _opts$config = opts.config, + config = _opts$config === void 0 ? {} : _opts$config; + var name = this.get('name'); + var label = this.get('label'); - return formattedString || this.toHexString(); - }, + if (!name) { + this.set('name', label); + } else if (!label) { + this.set('label', name); + } - _applyModification: function _applyModification(fn, args) { - var color = fn.apply(null, [this].concat([].slice.call(args))); - this._r = color._r; - this._g = color._g; - this._b = color._b; - this.setAlpha(color._a); - return this; - }, - lighten: function lighten() { - return this._applyModification(_lighten, arguments); - }, - brighten: function brighten() { - return this._applyModification(_brighten, arguments); - }, - darken: function darken() { - return this._applyModification(_darken, arguments); - }, - desaturate: function desaturate() { - return this._applyModification(_desaturate, arguments); - }, - saturate: function saturate() { - return this._applyModification(_saturate, arguments); - }, - greyscale: function greyscale() { - return this._applyModification(_greyscale, arguments); - }, - spin: function spin() { - return this._applyModification(_spin, arguments); - }, + var namePreEsc = this.get('name'); + var escapeName = config.escapeName; + var nameEsc = escapeName ? escapeName(namePreEsc) : Selector.escapeName(namePreEsc); + this.set('name', nameEsc); + }, - _applyCombination: function _applyCombination(fn, args) { - return fn.apply(null, [this].concat([].slice.call(args))); - }, - analogous: function analogous() { - return this._applyCombination(_analogous, arguments); - }, - complement: function complement() { - return this._applyCombination(_complement, arguments); - }, - monochromatic: function monochromatic() { - return this._applyCombination(_monochromatic, arguments); - }, - splitcomplement: function splitcomplement() { - return this._applyCombination(_splitcomplement, arguments); - }, - triad: function triad() { - return this._applyCombination(_triad, arguments); - }, - tetrad: function tetrad() { - return this._applyCombination(_tetrad, arguments); - } - }; + /** + * Get full selector name + * @return {string} + */ + getFullName: function getFullName() { + var init = ''; - // If input is an object, force 1 into "1.0" to handle ratios properly - // String input requires "1.0" as input, so 1 will be treated as 1 - tinycolor.fromRatio = function (color, opts) { - if ((typeof color === "undefined" ? "undefined" : _typeof(color)) == "object") { - var newColor = {}; - for (var i in color) { - if (color.hasOwnProperty(i)) { - if (i === "a") { - newColor[i] = color[i]; - } else { - newColor[i] = convertToPercentage(color[i]); - } - } - } - color = newColor; - } + switch (this.get('type')) { + case TYPE_CLASS: + init = '.'; + break; - return tinycolor(color, opts); - }; + case TYPE_ID: + init = '#'; + break; + } - // Given a string or object, convert that input to RGB - // Possible string inputs: - // - // "red" - // "#f00" or "f00" - // "#ff0000" or "ff0000" - // "#ff000000" or "ff000000" - // "rgb 255 0 0" or "rgb (255, 0, 0)" - // "rgb 1.0 0 0" or "rgb (1, 0, 0)" - // "rgba (255, 0, 0, 1)" or "rgba 255, 0, 0, 1" - // "rgba (1.0, 0, 0, 1)" or "rgba 1.0, 0, 0, 1" - // "hsl(0, 100%, 50%)" or "hsl 0 100% 50%" - // "hsla(0, 100%, 50%, 1)" or "hsla 0 100% 50%, 1" - // "hsv(0, 100%, 100%)" or "hsv 0 100% 100%" - // - function inputToRGB(color) { - - var rgb = { r: 0, g: 0, b: 0 }; - var a = 1; - var ok = false; - var format = false; - - if (typeof color == "string") { - color = stringInputToObject(color); - } - - if ((typeof color === "undefined" ? "undefined" : _typeof(color)) == "object") { - if (color.hasOwnProperty("r") && color.hasOwnProperty("g") && color.hasOwnProperty("b")) { - rgb = rgbToRgb(color.r, color.g, color.b); - ok = true; - format = String(color.r).substr(-1) === "%" ? "prgb" : "rgb"; - } else if (color.hasOwnProperty("h") && color.hasOwnProperty("s") && color.hasOwnProperty("v")) { - color.s = convertToPercentage(color.s); - color.v = convertToPercentage(color.v); - rgb = hsvToRgb(color.h, color.s, color.v); - ok = true; - format = "hsv"; - } else if (color.hasOwnProperty("h") && color.hasOwnProperty("s") && color.hasOwnProperty("l")) { - color.s = convertToPercentage(color.s); - color.l = convertToPercentage(color.l); - rgb = hslToRgb(color.h, color.s, color.l); - ok = true; - format = "hsl"; - } + return init + this.get('name'); + } +}, { + // All type selectors: https://developer.mozilla.org/it/docs/Web/CSS/CSS_Selectors + // Here I define only what I need + TYPE_CLASS: TYPE_CLASS, + TYPE_ID: TYPE_ID, - if (color.hasOwnProperty("a")) { - a = color.a; - } - } + /** + * Escape string + * @param {string} name + * @return {string} + * @private + */ + escapeName: function escapeName(name) { + return "".concat(name).trim().replace(/([^a-z0-9\w-\:]+)/gi, '-'); + } +}); +/* harmony default export */ __webpack_exports__["default"] = (Selector); - a = boundAlpha(a); +/***/ }), - return { - ok: ok, - format: color.format || format, - r: mathMin(255, mathMax(rgb.r, 0)), - g: mathMin(255, mathMax(rgb.g, 0)), - b: mathMin(255, mathMax(rgb.b, 0)), - a: a - }; - } +/***/ "./src/selector_manager/model/Selectors.js": +/*!*************************************************!*\ + !*** ./src/selector_manager/model/Selectors.js ***! + \*************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // Conversion Functions - // -------------------- +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var _Selector__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./Selector */ "./src/selector_manager/model/Selector.js"); - // `rgbToHsl`, `rgbToHsv`, `hslToRgb`, `hsvToRgb` modified from: - // - // `rgbToRgb` - // Handle bounds / percentage checking to conform to CSS color spec - // - // *Assumes:* r, g, b in [0, 255] or [0, 1] - // *Returns:* { r, g, b } in [0, 255] - function rgbToRgb(r, g, b) { - return { - r: bound01(r, 255) * 255, - g: bound01(g, 255) * 255, - b: bound01(b, 255) * 255 - }; - } - // `rgbToHsl` - // Converts an RGB color value to HSL. - // *Assumes:* r, g, and b are contained in [0, 255] or [0, 1] - // *Returns:* { h, s, l } in [0,1] - function rgbToHsl(r, g, b) { +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_1___default.a.Collection.extend({ + model: _Selector__WEBPACK_IMPORTED_MODULE_2__["default"], + modelId: function modelId(attr) { + return "".concat(attr.name, "_").concat(attr.type || _Selector__WEBPACK_IMPORTED_MODULE_2__["default"].TYPE_CLASS); + }, + getStyleable: function getStyleable() { + return Object(underscore__WEBPACK_IMPORTED_MODULE_0__["filter"])(this.models, function (item) { + return item.get('active') && !item.get('private'); + }); + }, + getValid: function getValid() { + return Object(underscore__WEBPACK_IMPORTED_MODULE_0__["filter"])(this.models, function (item) { + return !item.get('private'); + }); + }, + getFullString: function getFullString(collection) { + var result = []; + var coll = collection || this; + coll.forEach(function (selector) { + return result.push(selector.getFullName()); + }); + return result.join('').trim(); + } +})); - r = bound01(r, 255); - g = bound01(g, 255); - b = bound01(b, 255); +/***/ }), - var max = mathMax(r, g, b), - min = mathMin(r, g, b); - var h, - s, - l = (max + min) / 2; +/***/ "./src/selector_manager/view/ClassTagView.js": +/*!***************************************************!*\ + !*** ./src/selector_manager/view/ClassTagView.js ***! + \***************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - if (max == min) { - h = s = 0; // achromatic - } else { - var d = max - min; - s = l > 0.5 ? d / (2 - max - min) : d / (max + min); - switch (max) { - case r: - h = (g - b) / d + (g < b ? 6 : 0);break; - case g: - h = (b - r) / d + 2;break; - case b: - h = (r - g) / d + 4;break; - } +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); - h /= 6; - } +var inputProp = 'contentEditable'; +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_0___default.a.View.extend({ + template: function template() { + var pfx = this.pfx; + var ppfx = this.ppfx; + var label = this.model.get('label') || ''; + return "\n \n ").concat(label, "\n \n ⨯\n \n "); + }, + events: { + 'click [data-tag-remove]': 'removeTag', + 'click [data-tag-status]': 'changeStatus', + 'dblclick [data-tag-name]': 'startEditTag', + 'focusout [data-tag-name]': 'endEditTag' + }, + initialize: function initialize(o) { + var config = o.config || {}; + this.config = config; + this.coll = o.coll || null; + this.pfx = config.stylePrefix || ''; + this.ppfx = config.pStylePrefix || ''; + this.em = config.em; + this.listenTo(this.model, 'change:active', this.updateStatus); + }, - return { h: h, s: s, l: l }; + /** + * Returns the element which containes the anme of the tag + * @return {HTMLElement} + */ + getInputEl: function getInputEl() { + if (!this.inputEl) { + this.inputEl = this.el.querySelector('[data-tag-name]'); } - // `hslToRgb` - // Converts an HSL color value to RGB. - // *Assumes:* h is contained in [0, 1] or [0, 360] and s and l are contained [0, 1] or [0, 100] - // *Returns:* { r, g, b } in the set [0, 255] - function hslToRgb(h, s, l) { - var r, g, b; + return this.inputEl; + }, - h = bound01(h, 360); - s = bound01(s, 100); - l = bound01(l, 100); + /** + * Start editing tag + * @private + */ + startEditTag: function startEditTag() { + var em = this.em; + var inputEl = this.getInputEl(); + inputEl[inputProp] = true; + inputEl.focus(); + em && em.setEditing(1); + }, - function hue2rgb(p, q, t) { - if (t < 0) t += 1; - if (t > 1) t -= 1; - if (t < 1 / 6) return p + (q - p) * 6 * t; - if (t < 1 / 2) return q; - if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6; - return p; - } + /** + * End editing tag. If the class typed already exists the + * old one will be restored otherwise will be changed + * @private + */ + endEditTag: function endEditTag() { + var model = this.model; + var inputEl = this.getInputEl(); + var label = inputEl.textContent; + var em = this.em; + var sm = em && em.get('SelectorManager'); + inputEl[inputProp] = false; + em && em.setEditing(0); - if (s === 0) { - r = g = b = l; // achromatic - } else { - var q = l < 0.5 ? l * (1 + s) : l + s - l * s; - var p = 2 * l - q; - r = hue2rgb(p, q, h + 1 / 3); - g = hue2rgb(p, q, h); - b = hue2rgb(p, q, h - 1 / 3); - } + if (sm) { + var name = sm.escapeName(label); - return { r: r * 255, g: g * 255, b: b * 255 }; + if (sm.get(name)) { + inputEl.innerText = model.get('label'); + } else { + model.set({ + name: name, + label: label + }); + } } + }, - // `rgbToHsv` - // Converts an RGB color value to HSV - // *Assumes:* r, g, and b are contained in the set [0, 255] or [0, 1] - // *Returns:* { h, s, v } in [0,1] - function rgbToHsv(r, g, b) { - - r = bound01(r, 255); - g = bound01(g, 255); - b = bound01(b, 255); + /** + * Update status of the tag + * @private + */ + changeStatus: function changeStatus() { + var model = this.model; + model.set('active', !model.get('active')); + }, - var max = mathMax(r, g, b), - min = mathMin(r, g, b); - var h, - s, - v = max; + /** + * Remove tag from the selected component + * @param {Object} e + * @private + */ + removeTag: function removeTag() { + var em = this.em, + model = this.model; + var sel = em && em.getSelected(); + if (!model.get('protected') && sel) sel.getSelectors().remove(model); + }, - var d = max - min; - s = max === 0 ? 0 : d / max; + /** + * Update status of the checkbox + * @private + */ + updateStatus: function updateStatus() { + var model = this.model, + $el = this.$el; + var chkOn = 'fa-check-square-o'; + var chkOff = 'fa-square-o'; + var $chk = $el.find('[data-tag-status]'); - if (max == min) { - h = 0; // achromatic - } else { - switch (max) { - case r: - h = (g - b) / d + (g < b ? 6 : 0);break; - case g: - h = (b - r) / d + 2;break; - case b: - h = (r - g) / d + 4;break; - } - h /= 6; - } - return { h: h, s: s, v: v }; + if (model.get('active')) { + $chk.removeClass(chkOff).addClass(chkOn); + $el.removeClass('opac50'); + } else { + $chk.removeClass(chkOn).addClass(chkOff); + $el.addClass('opac50'); } + }, + render: function render() { + var pfx = this.pfx; + var ppfx = this.ppfx; + this.$el.html(this.template()); + this.$el.attr('class', "".concat(pfx, "tag ").concat(ppfx, "three-bg")); + this.updateStatus(); + return this; + } +})); - // `hsvToRgb` - // Converts an HSV color value to RGB. - // *Assumes:* h is contained in [0, 1] or [0, 360] and s and v are contained in [0, 1] or [0, 100] - // *Returns:* { r, g, b } in the set [0, 255] - function hsvToRgb(h, s, v) { +/***/ }), - h = bound01(h, 360) * 6; - s = bound01(s, 100); - v = bound01(v, 100); +/***/ "./src/selector_manager/view/ClassTagsView.js": +/*!****************************************************!*\ + !*** ./src/selector_manager/view/ClassTagsView.js ***! + \****************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - var i = math.floor(h), - f = h - i, - p = v * (1 - s), - q = v * (1 - f * s), - t = v * (1 - (1 - f) * s), - mod = i % 6, - r = [v, q, p, p, t, v][mod], - g = [t, v, v, q, p, p][mod], - b = [p, p, t, v, v, q][mod]; +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var _ClassTagView__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./ClassTagView */ "./src/selector_manager/view/ClassTagView.js"); - return { r: r * 255, g: g * 255, b: b * 255 }; - } - // `rgbToHex` - // Converts an RGB color to hex - // Assumes r, g, and b are contained in the set [0, 255] - // Returns a 3 or 6 character hex - function rgbToHex(r, g, b, allow3Char) { - var hex = [pad2(mathRound(r).toString(16)), pad2(mathRound(g).toString(16)), pad2(mathRound(b).toString(16))]; +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_1___default.a.View.extend({ + template: Object(underscore__WEBPACK_IMPORTED_MODULE_0__["template"])("\n
up\">\n
label\"><%= label %>
\n
status-c\">\n input-c\">\n
field <%= ppfx %>select\">\n input-holder\">\n \n \n
sel-arrow\">\n
d-s-arrow\">
\n
\n
\n
\n
\n
\n
tags-field\" class=\"<%= ppfx %>field\">\n
tags-c\">
\n new\" />\n add-tag\" class=\"fa fa-plus\">\n
\n
sel-help\">\n
label\"><%= selectedLabel %>
\n
sel\">
\n
\n
"), + events: {}, + initialize: function initialize() { + var o = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + this.config = o.config || {}; + this.pfx = this.config.stylePrefix || ''; + this.ppfx = this.config.pStylePrefix || ''; + this.className = this.pfx + 'tags'; + this.addBtnId = this.pfx + 'add-tag'; + this.newInputId = this.pfx + 'new'; + this.stateInputId = this.pfx + 'states'; + this.stateInputC = this.pfx + 'input-c'; + this.states = this.config.states || []; + this.events['click #' + this.addBtnId] = 'startNewTag'; + this.events['blur #' + this.newInputId] = 'endNewTag'; + this.events['keyup #' + this.newInputId] = 'onInputKeyUp'; + this.events['change #' + this.stateInputId] = 'stateChanged'; + var em = this.config.em; + var emitter = this.getStyleEmitter(); + this.target = this.config.em; + this.em = em; + this.listenTo(emitter, 'styleManager:update', this.componentChanged); + this.listenTo(em, 'component:toggled component:update:classes', this.componentChanged); + this.listenTo(em, 'component:update:classes', this.updateSelector); + this.listenTo(this.collection, 'add', this.addNew); + this.listenTo(this.collection, 'reset', this.renderClasses); + this.listenTo(this.collection, 'remove', this.tagRemoved); + this.delegateEvents(); + }, + getStyleEmitter: function getStyleEmitter() { + var em = this.em; + var sm = em && em.get('StyleManager'); + var emitter = sm && sm.getEmitter(); + return emitter || {}; + }, - // Return a 3 character hex if possible - if (allow3Char && hex[0].charAt(0) == hex[0].charAt(1) && hex[1].charAt(0) == hex[1].charAt(1) && hex[2].charAt(0) == hex[2].charAt(1)) { - return hex[0].charAt(0) + hex[1].charAt(0) + hex[2].charAt(0); - } + /** + * Triggered when a tag is removed from collection + * @param {Object} model Removed model + * @private + */ + tagRemoved: function tagRemoved(model) { + this.updateStateVis(); + }, + + /** + * Create select input with states + * @return {string} String of options + * @private + */ + getStateOptions: function getStateOptions() { + var strInput = ''; - return hex.join(""); + for (var i = 0; i < this.states.length; i++) { + strInput += ''; } - // `rgbaToHex` - // Converts an RGBA color plus alpha transparency to hex - // Assumes r, g, b and a are contained in the set [0, 255] - // Returns an 8 character hex - function rgbaToHex(r, g, b, a) { - var hex = [pad2(convertDecimalToHex(a)), pad2(mathRound(r).toString(16)), pad2(mathRound(g).toString(16)), pad2(mathRound(b).toString(16))]; + return strInput; + }, - return hex.join(""); - } + /** + * Add new model + * @param {Object} model + * @private + */ + addNew: function addNew(model) { + this.addToClasses(model); + }, - // `equals` - // Can be called with any tinycolor input - tinycolor.equals = function (color1, color2) { - if (!color1 || !color2) { - return false; - } - return tinycolor(color1).toRgbString() == tinycolor(color2).toRgbString(); - }; - tinycolor.random = function () { - return tinycolor.fromRatio({ - r: mathRandom(), - g: mathRandom(), - b: mathRandom() - }); - }; + /** + * Start tag creation + * @param {Object} e + * @private + */ + startNewTag: function startNewTag(e) { + this.$addBtn.get(0).style.display = 'none'; + this.$input.show().focus(); + }, + + /** + * End tag creation + * @param {Object} e + * @private + */ + endNewTag: function endNewTag(e) { + this.$addBtn.get(0).style.display = ''; + this.$input.hide().val(''); + }, - // Modification Functions - // ---------------------- - // Thanks to less.js for some of the basics here - // + /** + * Checks what to do on keyup event + * @param {Object} e + * @private + */ + onInputKeyUp: function onInputKeyUp(e) { + if (e.keyCode === 13) this.addNewTag(this.$input.val());else if (e.keyCode === 27) this.endNewTag(); + }, - function _desaturate(color, amount) { - amount = amount === 0 ? 0 : amount || 10; - var hsl = tinycolor(color).toHsl(); - hsl.s -= amount / 100; - hsl.s = clamp01(hsl.s); - return tinycolor(hsl); - } + /** + * Triggered when component is changed + * @param {Object} e + * @private + */ + componentChanged: Object(underscore__WEBPACK_IMPORTED_MODULE_0__["debounce"])(function (target) { + target = target || this.getTarget(); + this.compTarget = target; + var validSelectors = []; - function _saturate(color, amount) { - amount = amount === 0 ? 0 : amount || 10; - var hsl = tinycolor(color).toHsl(); - hsl.s += amount / 100; - hsl.s = clamp01(hsl.s); - return tinycolor(hsl); + if (target) { + var state = target.get('state'); + state && this.getStates().val(state); + var selectors = target.getSelectors(); + validSelectors = selectors.getValid(); } - function _greyscale(color) { - return tinycolor(color).desaturate(100); + this.collection.reset(validSelectors); + this.updateStateVis(target); + }), + getTarget: function getTarget() { + return this.target.getSelected(); + }, + + /** + * Update states visibility. Hides states in case there is no tags + * inside collection + * @private + */ + updateStateVis: function updateStateVis(target) { + var em = this.em; + var avoidInline = em && em.getConfig('avoidInlineStyle'); + var display = this.collection.length || avoidInline ? 'block' : 'none'; + this.getStatesC().css('display', display); + this.updateSelector(target); + }, + + /** + * Update selector helper + * @return {this} + * @private + */ + updateSelector: function updateSelector(target) { + var pfx = this.pfx, + collection = this.collection, + el = this.el; + var selected = target || this.getTarget(); + this.compTarget = selected; + if (!selected || !selected.get) return; + var state = selected.get('state'); + var coll = collection; + var result = coll.getFullString(selected.getSelectors().getStyleable()); + result = result || selected.get('selectorsAdd') || (selected.getId ? "#".concat(selected.getId()) : ''); + result += state ? ":".concat(state) : ''; + var elSel = el.querySelector("#".concat(pfx, "sel")); + elSel && (elSel.innerHTML = result); + }, + + /** + * Triggered when the select with states is changed + * @param {Object} e + * @private + */ + stateChanged: function stateChanged(e) { + if (this.compTarget) { + this.compTarget.set('state', this.$states.val()); + this.updateSelector(); } + }, - function _lighten(color, amount) { - amount = amount === 0 ? 0 : amount || 10; - var hsl = tinycolor(color).toHsl(); - hsl.l += amount / 100; - hsl.l = clamp01(hsl.l); - return tinycolor(hsl); - } + /** + * Add new tag to collection, if possible, and to the component + * @param {Object} e + * @private + */ + addNewTag: function addNewTag(label) { + var target = this.target; + var component = this.compTarget; - function _brighten(color, amount) { - amount = amount === 0 ? 0 : amount || 10; - var rgb = tinycolor(color).toRgb(); - rgb.r = mathMax(0, mathMin(255, rgb.r - mathRound(255 * -(amount / 100)))); - rgb.g = mathMax(0, mathMin(255, rgb.g - mathRound(255 * -(amount / 100)))); - rgb.b = mathMax(0, mathMin(255, rgb.b - mathRound(255 * -(amount / 100)))); - return tinycolor(rgb); + if (!label.trim()) { + return; } - function _darken(color, amount) { - amount = amount === 0 ? 0 : amount || 10; - var hsl = tinycolor(color).toHsl(); - hsl.l -= amount / 100; - hsl.l = clamp01(hsl.l); - return tinycolor(hsl); - } + if (target) { + var sm = target.get('SelectorManager'); + var model = sm.add({ + label: label + }); - // Spin takes a positive or negative amount within [-360, 360] indicating the change of hue. - // Values outside of this range will be wrapped into this range. - function _spin(color, amount) { - var hsl = tinycolor(color).toHsl(); - var hue = (mathRound(hsl.h) + amount) % 360; - hsl.h = hue < 0 ? 360 + hue : hue; - return tinycolor(hsl); + if (component) { + var compCls = component.getSelectors(); + compCls.add(model); + this.collection.add(model); + this.updateStateVis(); + } } - // Combination Functions - // --------------------- - // Thanks to jQuery xColor for some of the ideas behind these - // - - function _complement(color) { - var hsl = tinycolor(color).toHsl(); - hsl.h = (hsl.h + 180) % 360; - return tinycolor(hsl); - } + this.endNewTag(); + }, - function _triad(color) { - var hsl = tinycolor(color).toHsl(); - var h = hsl.h; - return [tinycolor(color), tinycolor({ h: (h + 120) % 360, s: hsl.s, l: hsl.l }), tinycolor({ h: (h + 240) % 360, s: hsl.s, l: hsl.l })]; - } + /** + * Add new object to collection + * @param {Object} model Model + * @param {Object} fragmentEl Fragment collection + * @return {Object} Object created + * @private + * */ + addToClasses: function addToClasses(model) { + var fragmentEl = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null; + var fragment = fragmentEl; + var classes = this.getClasses(); + var rendered = new _ClassTagView__WEBPACK_IMPORTED_MODULE_2__["default"]({ + model: model, + config: this.config, + coll: this.collection + }).render().el; + fragment ? fragment.appendChild(rendered) : classes.append(rendered); + return rendered; + }, - function _tetrad(color) { - var hsl = tinycolor(color).toHsl(); - var h = hsl.h; - return [tinycolor(color), tinycolor({ h: (h + 90) % 360, s: hsl.s, l: hsl.l }), tinycolor({ h: (h + 180) % 360, s: hsl.s, l: hsl.l }), tinycolor({ h: (h + 270) % 360, s: hsl.s, l: hsl.l })]; - } + /** + * Render the collection of classes + * @private + */ + renderClasses: function renderClasses() { + var _this = this; - function _splitcomplement(color) { - var hsl = tinycolor(color).toHsl(); - var h = hsl.h; - return [tinycolor(color), tinycolor({ h: (h + 72) % 360, s: hsl.s, l: hsl.l }), tinycolor({ h: (h + 216) % 360, s: hsl.s, l: hsl.l })]; - } + var frag = document.createDocumentFragment(); + var classes = this.getClasses(); + classes.empty(); + this.collection.each(function (model) { + return _this.addToClasses(model, frag); + }); + classes.append(frag); + }, - function _analogous(color, results, slices) { - results = results || 6; - slices = slices || 30; + /** + * Return classes element + * @return {HTMLElement} + * @private + */ + getClasses: function getClasses() { + return this.$el.find("#".concat(this.pfx, "tags-c")); + }, - var hsl = tinycolor(color).toHsl(); - var part = 360 / slices; - var ret = [tinycolor(color)]; + /** + * Return states element + * @return {HTMLElement} + * @private + */ + getStates: function getStates() { + if (!this.$states) this.$states = this.$el.find('#' + this.stateInputId); + return this.$states; + }, - for (hsl.h = (hsl.h - (part * results >> 1) + 720) % 360; --results;) { - hsl.h = (hsl.h + part) % 360; - ret.push(tinycolor(hsl)); - } - return ret; - } + /** + * Return states container element + * @return {HTMLElement} + * @private + */ + getStatesC: function getStatesC() { + if (!this.$statesC) this.$statesC = this.$el.find('#' + this.stateInputC); + return this.$statesC; + }, + render: function render() { + var ppfx = this.ppfx; + var config = this.config; + var $el = this.$el; + $el.html(this.template({ + selectedLabel: config.selectedLabel, + statesLabel: config.statesLabel, + label: config.label, + pfx: this.pfx, + ppfx: this.ppfx + })); + this.$input = $el.find('input#' + this.newInputId); + this.$addBtn = $el.find('#' + this.addBtnId); + this.$classes = $el.find('#' + this.pfx + 'tags-c'); + this.$states = $el.find('#' + this.stateInputId); + this.$statesC = $el.find('#' + this.stateInputC); + this.$states.append(this.getStateOptions()); + this.renderClasses(); + $el.attr('class', "".concat(this.className, " ").concat(ppfx, "one-bg ").concat(ppfx, "two-color")); + return this; + } +})); - function _monochromatic(color, results) { - results = results || 6; - var hsv = tinycolor(color).toHsv(); - var h = hsv.h, - s = hsv.s, - v = hsv.v; - var ret = []; - var modification = 1 / results; +/***/ }), - while (results--) { - ret.push(tinycolor({ h: h, s: s, v: v })); - v = (v + modification) % 1; - } +/***/ "./src/storage_manager/config/config.js": +/*!**********************************************!*\ + !*** ./src/storage_manager/config/config.js ***! + \**********************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - return ret; - } +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony default export */ __webpack_exports__["default"] = ({ + // Prefix identifier that will be used inside storing and loading + id: 'gjs-', + // Enable/Disable autosaving + autosave: 1, + // Indicates if load data inside editor after init + autoload: 1, + // Indicates which storage to use. Available: local | remote + type: 'local', + // If autosave enabled, indicates how many steps (general changes to structure) + // need to be done before save. Useful with remoteStorage to reduce remote calls + stepsBeforeSave: 1, + //Enable/Disable components model (JSON format) + storeComponents: 1, + //Enable/Disable styles model (JSON format) + storeStyles: 1, + //Enable/Disable saving HTML template + storeHtml: 1, + //Enable/Disable saving CSS template + storeCss: 1, + // ONLY FOR LOCAL STORAGE + // If enabled, checks if browser supports Local Storage + checkLocal: 1, + // ONLY FOR REMOTE STORAGE + // Custom parameters to pass with the remote storage request, eg. csrf token + params: {}, + // Custom headers for the remote storage request + headers: {}, + // Endpoint where to save all stuff + urlStore: '', + // Endpoint where to fetch data + urlLoad: '', + //Callback before request + beforeSend: function beforeSend(jqXHR, settings) {}, + //Callback after request + onComplete: function onComplete(jqXHR, status) {}, + // set contentType paramater of $.ajax + // true: application/json; charset=utf-8' + // false: 'x-www-form-urlencoded' + contentTypeJson: true, + credentials: 'include', + // Pass custom options to fetch API (remote storage) + // You can pass a simple object: { someOption: 'someValue' } + // or a function wich returns and object to add: + // currentOpts => { + // return currentOpts.method === 'post' ? { method: 'patch' } : {}; + // } + fetchOptions: '' +}); - // Utility Functions - // --------------------- +/***/ }), - tinycolor.mix = function (color1, color2, amount) { - amount = amount === 0 ? 0 : amount || 50; +/***/ "./src/storage_manager/index.js": +/*!**************************************!*\ + !*** ./src/storage_manager/index.js ***! + \**************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - var rgb1 = tinycolor(color1).toRgb(); - var rgb2 = tinycolor(color2).toRgb(); +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _config_config__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./config/config */ "./src/storage_manager/config/config.js"); +/* harmony import */ var _model_LocalStorage__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./model/LocalStorage */ "./src/storage_manager/model/LocalStorage.js"); +/* harmony import */ var _model_RemoteStorage__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./model/RemoteStorage */ "./src/storage_manager/model/RemoteStorage.js"); - var p = amount / 100; - var w = p * 2 - 1; - var a = rgb2.a - rgb1.a; - var w1; +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - if (w * a == -1) { - w1 = w; - } else { - w1 = (w + a) / (1 + w * a); - } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - w1 = (w1 + 1) / 2; +/** + * You can customize the initial state of the module from the editor initialization, by passing the following [Configuration Object](https://github.com/artf/grapesjs/blob/master/src/storage_manager/config/config.js) + * ```js + * const editor = grapesjs.init({ + * storageManager: { + * // options + * } + * }) + * ``` + * + * Once the editor is instantiated you can use its API. Before using these methods you should get the module from the instance + * + * ```js + * const storageManager = editor.StorageManager; + * ``` + * + * * [getConfig](#getconfig) + * * [isAutosave](#isautosave) + * * [setAutosave](#setautosave) + * * [getStepsBeforeSave](#getstepsbeforesave) + * * [setStepsBeforeSave](#setstepsbeforesave) + * * [setStepsBeforeSave](#setstepsbeforesave) + * * [getStorages](#getstorages) + * * [getCurrent](#getcurrent) + * * [getCurrentStorage](#getcurrentstorage) + * * [setCurrent](#setcurrent) + * * [add](#add) + * * [get](#get) + * * [store](#store) + * * [load](#load) + * + * @module StorageManager + */ - var w2 = 1 - w1; - var rgba = { - r: rgb2.r * w1 + rgb1.r * w2, - g: rgb2.g * w1 + rgb1.g * w2, - b: rgb2.b * w1 + rgb1.b * w2, - a: rgb2.a * p + rgb1.a * (1 - p) - }; - return tinycolor(rgba); - }; +/* harmony default export */ __webpack_exports__["default"] = (function () { + var c = {}; + var em; + var storages = {}; + var defaultStorages = {}; + var eventStart = 'storage:start'; + var eventEnd = 'storage:end'; + var eventError = 'storage:error'; + return { + /** + * Name of the module + * @type {String} + * @private + */ + name: 'StorageManager', - // Readability Functions - // --------------------- - // - - // `readability` - // Analyze the 2 colors and returns an object with the following properties: - // `brightness`: difference in brightness between the two colors - // `color`: difference in color/hue between the two colors - tinycolor.readability = function (color1, color2) { - var c1 = tinycolor(color1); - var c2 = tinycolor(color2); - var rgb1 = c1.toRgb(); - var rgb2 = c2.toRgb(); - var brightnessA = c1.getBrightness(); - var brightnessB = c2.getBrightness(); - var colorDiff = Math.max(rgb1.r, rgb2.r) - Math.min(rgb1.r, rgb2.r) + Math.max(rgb1.g, rgb2.g) - Math.min(rgb1.g, rgb2.g) + Math.max(rgb1.b, rgb2.b) - Math.min(rgb1.b, rgb2.b); + /** + * Initialize module. Automatically called with a new instance of the editor + * @param {Object} config Configurations + * @param {string} [config.id='gjs-'] The prefix for the fields, useful to differentiate storing/loading + * with multiple editors on the same page. For example, in local storage, the item of HTML will be saved like 'gjs-html' + * @param {Boolean} [config.autosave=true] Indicates if autosave mode is enabled, works in conjunction with stepsBeforeSave + * @param {number} [config.stepsBeforeSave=1] If autosave enabled, indicates how many steps/changes are necessary + * before autosave is triggered + * @param {string} [config.type='local'] Default storage type. Available: 'local' | 'remote' | ''(do not store) + * @private + * @example + * ... + * { + * autosave: false, + * type: 'remote', + * } + * ... + */ + init: function init() { + var config = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + c = _objectSpread({}, _config_config__WEBPACK_IMPORTED_MODULE_1__["default"], {}, config); + em = c.em; + if (c._disable) c.type = 0; + defaultStorages.remote = new _model_RemoteStorage__WEBPACK_IMPORTED_MODULE_3__["default"](c); + defaultStorages.local = new _model_LocalStorage__WEBPACK_IMPORTED_MODULE_2__["default"](c); + c.currentStorage = c.type; + this.loadDefaultProviders().setCurrent(c.type); + return this; + }, - return { - brightness: Math.abs(brightnessA - brightnessB), - color: colorDiff - }; - }; + /** + * Get configuration object + * @return {Object} + * */ + getConfig: function getConfig() { + return c; + }, - // `readable` - // http://www.w3.org/TR/AERT#color-contrast - // Ensure that foreground and background color combinations provide sufficient contrast. - // *Example* - // tinycolor.isReadable("#000", "#111") => false - tinycolor.isReadable = function (color1, color2) { - var readability = tinycolor.readability(color1, color2); - return readability.brightness > 125 && readability.color > 500; - }; + /** + * Checks if autosave is enabled + * @return {Boolean} + * */ + isAutosave: function isAutosave() { + return !!c.autosave; + }, - // `mostReadable` - // Given a base color and a list of possible foreground or background - // colors for that base, returns the most readable color. - // *Example* - // tinycolor.mostReadable("#123", ["#fff", "#000"]) => "#000" - tinycolor.mostReadable = function (baseColor, colorList) { - var bestColor = null; - var bestScore = 0; - var bestIsReadable = false; - for (var i = 0; i < colorList.length; i++) { - - // We normalize both around the "acceptable" breaking point, - // but rank brightness constrast higher than hue. - - var readability = tinycolor.readability(baseColor, colorList[i]); - var readable = readability.brightness > 125 && readability.color > 500; - var score = 3 * (readability.brightness / 125) + readability.color / 500; - - if (readable && !bestIsReadable || readable && bestIsReadable && score > bestScore || !readable && !bestIsReadable && score > bestScore) { - bestIsReadable = readable; - bestScore = score; - bestColor = tinycolor(colorList[i]); - } - } - return bestColor; - }; + /** + * Set autosave value + * @param {Boolean} v + * @return {this} + * */ + setAutosave: function setAutosave(v) { + c.autosave = !!v; + return this; + }, - // Big List of Colors - // ------------------ - // - var names = tinycolor.names = { - aliceblue: "f0f8ff", - antiquewhite: "faebd7", - aqua: "0ff", - aquamarine: "7fffd4", - azure: "f0ffff", - beige: "f5f5dc", - bisque: "ffe4c4", - black: "000", - blanchedalmond: "ffebcd", - blue: "00f", - blueviolet: "8a2be2", - brown: "a52a2a", - burlywood: "deb887", - burntsienna: "ea7e5d", - cadetblue: "5f9ea0", - chartreuse: "7fff00", - chocolate: "d2691e", - coral: "ff7f50", - cornflowerblue: "6495ed", - cornsilk: "fff8dc", - crimson: "dc143c", - cyan: "0ff", - darkblue: "00008b", - darkcyan: "008b8b", - darkgoldenrod: "b8860b", - darkgray: "a9a9a9", - darkgreen: "006400", - darkgrey: "a9a9a9", - darkkhaki: "bdb76b", - darkmagenta: "8b008b", - darkolivegreen: "556b2f", - darkorange: "ff8c00", - darkorchid: "9932cc", - darkred: "8b0000", - darksalmon: "e9967a", - darkseagreen: "8fbc8f", - darkslateblue: "483d8b", - darkslategray: "2f4f4f", - darkslategrey: "2f4f4f", - darkturquoise: "00ced1", - darkviolet: "9400d3", - deeppink: "ff1493", - deepskyblue: "00bfff", - dimgray: "696969", - dimgrey: "696969", - dodgerblue: "1e90ff", - firebrick: "b22222", - floralwhite: "fffaf0", - forestgreen: "228b22", - fuchsia: "f0f", - gainsboro: "dcdcdc", - ghostwhite: "f8f8ff", - gold: "ffd700", - goldenrod: "daa520", - gray: "808080", - green: "008000", - greenyellow: "adff2f", - grey: "808080", - honeydew: "f0fff0", - hotpink: "ff69b4", - indianred: "cd5c5c", - indigo: "4b0082", - ivory: "fffff0", - khaki: "f0e68c", - lavender: "e6e6fa", - lavenderblush: "fff0f5", - lawngreen: "7cfc00", - lemonchiffon: "fffacd", - lightblue: "add8e6", - lightcoral: "f08080", - lightcyan: "e0ffff", - lightgoldenrodyellow: "fafad2", - lightgray: "d3d3d3", - lightgreen: "90ee90", - lightgrey: "d3d3d3", - lightpink: "ffb6c1", - lightsalmon: "ffa07a", - lightseagreen: "20b2aa", - lightskyblue: "87cefa", - lightslategray: "789", - lightslategrey: "789", - lightsteelblue: "b0c4de", - lightyellow: "ffffe0", - lime: "0f0", - limegreen: "32cd32", - linen: "faf0e6", - magenta: "f0f", - maroon: "800000", - mediumaquamarine: "66cdaa", - mediumblue: "0000cd", - mediumorchid: "ba55d3", - mediumpurple: "9370db", - mediumseagreen: "3cb371", - mediumslateblue: "7b68ee", - mediumspringgreen: "00fa9a", - mediumturquoise: "48d1cc", - mediumvioletred: "c71585", - midnightblue: "191970", - mintcream: "f5fffa", - mistyrose: "ffe4e1", - moccasin: "ffe4b5", - navajowhite: "ffdead", - navy: "000080", - oldlace: "fdf5e6", - olive: "808000", - olivedrab: "6b8e23", - orange: "ffa500", - orangered: "ff4500", - orchid: "da70d6", - palegoldenrod: "eee8aa", - palegreen: "98fb98", - paleturquoise: "afeeee", - palevioletred: "db7093", - papayawhip: "ffefd5", - peachpuff: "ffdab9", - peru: "cd853f", - pink: "ffc0cb", - plum: "dda0dd", - powderblue: "b0e0e6", - purple: "800080", - rebeccapurple: "663399", - red: "f00", - rosybrown: "bc8f8f", - royalblue: "4169e1", - saddlebrown: "8b4513", - salmon: "fa8072", - sandybrown: "f4a460", - seagreen: "2e8b57", - seashell: "fff5ee", - sienna: "a0522d", - silver: "c0c0c0", - skyblue: "87ceeb", - slateblue: "6a5acd", - slategray: "708090", - slategrey: "708090", - snow: "fffafa", - springgreen: "00ff7f", - steelblue: "4682b4", - tan: "d2b48c", - teal: "008080", - thistle: "d8bfd8", - tomato: "ff6347", - turquoise: "40e0d0", - violet: "ee82ee", - wheat: "f5deb3", - white: "fff", - whitesmoke: "f5f5f5", - yellow: "ff0", - yellowgreen: "9acd32" - }; + /** + * Returns number of steps required before trigger autosave + * @return {number} + * */ + getStepsBeforeSave: function getStepsBeforeSave() { + return c.stepsBeforeSave; + }, - // Make it easy to access colors via `hexNames[hex]` - var hexNames = tinycolor.hexNames = flip(names); + /** + * Set steps required before trigger autosave + * @param {number} v + * @return {this} + * */ + setStepsBeforeSave: function setStepsBeforeSave(v) { + c.stepsBeforeSave = v; + return this; + }, - // Utilities - // --------- + /** + * Add new storage + * @param {string} id Storage ID + * @param {Object} storage Storage wrapper + * @param {Function} storage.load Load method + * @param {Function} storage.store Store method + * @return {this} + * @example + * storageManager.add('local2', { + * load: function(keys, clb, clbErr) { + * var res = {}; + * for (var i = 0, len = keys.length; i < len; i++){ + * var v = localStorage.getItem(keys[i]); + * if(v) res[keys[i]] = v; + * } + * clb(res); // might be called inside some async method + * // In case of errors... + * // clbErr('Went something wrong'); + * }, + * store: function(data, clb, clbErr) { + * for(var key in data) + * localStorage.setItem(key, data[key]); + * clb(); // might be called inside some async method + * } + * }); + * */ + add: function add(id, storage) { + storages[id] = storage; + return this; + }, - // `{ 'name1': 'val1' }` becomes `{ 'val1': 'name1' }` - function flip(o) { - var flipped = {}; - for (var i in o) { - if (o.hasOwnProperty(i)) { - flipped[o[i]] = i; - } - } - return flipped; - } + /** + * Returns storage by id + * @param {string} id Storage ID + * @return {Object|null} + * */ + get: function get(id) { + return storages[id] || null; + }, - // Return a valid alpha value [0,1] with all invalid values being set to 1 - function boundAlpha(a) { - a = parseFloat(a); + /** + * Returns all storages + * @return {Array} + * */ + getStorages: function getStorages() { + return storages; + }, - if (isNaN(a) || a < 0 || a > 1) { - a = 1; - } + /** + * Returns current storage type + * @return {string} + * */ + getCurrent: function getCurrent() { + return c.currentStorage; + }, - return a; - } + /** + * Set current storage type + * @param {string} id Storage ID + * @return {this} + * */ + setCurrent: function setCurrent(id) { + c.currentStorage = id; + return this; + }, - // Take input from [0, n] and return it as [0, 1] - function bound01(n, max) { - if (isOnePointZero(n)) { - n = "100%"; - } + /** + * Store key-value resources in the current storage + * @param {Object} data Data in key-value format, eg. {item1: value1, item2: value2} + * @param {Function} clb Callback function + * @return {Object|null} + * @example + * storageManager.store({item1: value1, item2: value2}); + * */ + store: function store(data, clb) { + var _this = this; - var processPercent = isPercentage(n); - n = mathMin(max, mathMax(0, parseFloat(n))); + var st = this.get(this.getCurrent()); + var toStore = {}; + this.onStart('store', data); - // Automatically convert percentage into number - if (processPercent) { - n = parseInt(n * max, 10) / 100; - } + for (var key in data) { + toStore[c.id + key] = data[key]; + } - // Handle floating point rounding errors - if (math.abs(n - max) < 0.000001) { - return 1; - } + return st ? st.store(toStore, function (res) { + clb && clb(res); - // Convert into [0, 1] range if it isn't already - return n % max / parseFloat(max); - } + _this.onEnd('store', res); + }, function (err) { + _this.onError('store', err); + }) : null; + }, - // Force a number between 0 and 1 - function clamp01(val) { - return mathMin(1, mathMax(0, val)); - } + /** + * Load resource from the current storage by keys + * @param {string|Array} keys Keys to load + * @param {Function} clb Callback function + * @example + * storageManager.load(['item1', 'item2'], res => { + * // res -> {item1: value1, item2: value2} + * }); + * storageManager.load('item1', res => { + * // res -> {item1: value1} + * }); + * */ + load: function load(keys, clb) { + var _this2 = this; - // Parse a base-16 hex value into a base-10 integer - function parseIntFromHex(val) { - return parseInt(val, 16); - } + var st = this.get(this.getCurrent()); + var keysF = []; + var result = {}; + if (typeof keys === 'string') keys = [keys]; + this.onStart('load', keys); - // Need to handle 1.0 as 100%, since once it is a number, there is no difference between it and 1 - // - function isOnePointZero(n) { - return typeof n == "string" && n.indexOf('.') != -1 && parseFloat(n) === 1; - } + for (var i = 0, len = keys.length; i < len; i++) { + keysF.push(c.id + keys[i]); + } - // Check to see if string passed in is a percentage - function isPercentage(n) { - return typeof n === "string" && n.indexOf('%') != -1; - } + if (st) { + st.load(keysF, function (res) { + // Restore keys name + var reg = new RegExp('^' + c.id + ''); - // Force a hex value to have 2 characters - function pad2(c) { - return c.length == 1 ? '0' + c : '' + c; - } + for (var itemKey in res) { + var itemKeyR = itemKey.replace(reg, ''); + result[itemKeyR] = res[itemKey]; + } - // Replace a decimal with it's percentage value - function convertToPercentage(n) { - if (n <= 1) { - n = n * 100 + "%"; - } + clb && clb(result); - return n; - } + _this2.onEnd('load', result); + }, function (err) { + clb && clb(result); - // Converts a decimal to a hex value - function convertDecimalToHex(d) { - return Math.round(parseFloat(d) * 255).toString(16); - } - // Converts a hex value to a decimal - function convertHexToDecimal(h) { - return parseIntFromHex(h) / 255; - } + _this2.onError('load', err); + }); + } else { + clb && clb(result); + } + }, - var matchers = function () { + /** + * Load default storages + * @return {this} + * @private + * */ + loadDefaultProviders: function loadDefaultProviders() { + for (var id in defaultStorages) { + this.add(id, defaultStorages[id]); + } - // - var CSS_INTEGER = "[-\\+]?\\d+%?"; + return this; + }, - // - var CSS_NUMBER = "[-\\+]?\\d*\\.\\d+%?"; + /** + * Get current storage + * @return {Storage} + * */ + getCurrentStorage: function getCurrentStorage() { + return this.get(this.getCurrent()); + }, - // Allow positive/negative integer/number. Don't capture the either/or, just the entire outcome. - var CSS_UNIT = "(?:" + CSS_NUMBER + ")|(?:" + CSS_INTEGER + ")"; + /** + * On start callback + * @private + */ + onStart: function onStart(ctx, data) { + if (em) { + em.trigger(eventStart); + ctx && em.trigger("".concat(eventStart, ":").concat(ctx), data); + } + }, - // Actual matching. - // Parentheses and commas are optional, but not required. - // Whitespace can take the place of commas or opening paren - var PERMISSIVE_MATCH3 = "[\\s|\\(]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")\\s*\\)?"; - var PERMISSIVE_MATCH4 = "[\\s|\\(]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")[,|\\s]+(" + CSS_UNIT + ")\\s*\\)?"; + /** + * On end callback + * @private + */ + onEnd: function onEnd(ctx, data) { + if (em) { + em.trigger(eventEnd); + ctx && em.trigger("".concat(eventEnd, ":").concat(ctx), data); + } + }, - return { - rgb: new RegExp("rgb" + PERMISSIVE_MATCH3), - rgba: new RegExp("rgba" + PERMISSIVE_MATCH4), - hsl: new RegExp("hsl" + PERMISSIVE_MATCH3), - hsla: new RegExp("hsla" + PERMISSIVE_MATCH4), - hsv: new RegExp("hsv" + PERMISSIVE_MATCH3), - hsva: new RegExp("hsva" + PERMISSIVE_MATCH4), - hex3: /^([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/, - hex6: /^([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/, - hex8: /^([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/ - }; - }(); - - // `stringInputToObject` - // Permissive string parsing. Take in a number of formats, and output an object - // based on detected format. Returns `{ r, g, b }` or `{ h, s, l }` or `{ h, s, v}` - function stringInputToObject(color) { - - color = color.replace(trimLeft, '').replace(trimRight, '').toLowerCase(); - var named = false; - if (names[color]) { - color = names[color]; - named = true; - } else if (color == 'transparent') { - return { r: 0, g: 0, b: 0, a: 0, format: "name" }; - } - - // Try to match string input using regular expressions. - // Keep most of the number bounding out of this function - don't worry about [0,1] or [0,100] or [0,360] - // Just return an object and let the conversion functions handle that. - // This way the result will be the same whether the tinycolor is initialized with string or object. - var match; - if (match = matchers.rgb.exec(color)) { - return { r: match[1], g: match[2], b: match[3] }; - } - if (match = matchers.rgba.exec(color)) { - return { r: match[1], g: match[2], b: match[3], a: match[4] }; - } - if (match = matchers.hsl.exec(color)) { - return { h: match[1], s: match[2], l: match[3] }; - } - if (match = matchers.hsla.exec(color)) { - return { h: match[1], s: match[2], l: match[3], a: match[4] }; - } - if (match = matchers.hsv.exec(color)) { - return { h: match[1], s: match[2], v: match[3] }; - } - if (match = matchers.hsva.exec(color)) { - return { h: match[1], s: match[2], v: match[3], a: match[4] }; - } - if (match = matchers.hex8.exec(color)) { - return { - a: convertHexToDecimal(match[1]), - r: parseIntFromHex(match[2]), - g: parseIntFromHex(match[3]), - b: parseIntFromHex(match[4]), - format: named ? "name" : "hex8" - }; - } - if (match = matchers.hex6.exec(color)) { - return { - r: parseIntFromHex(match[1]), - g: parseIntFromHex(match[2]), - b: parseIntFromHex(match[3]), - format: named ? "name" : "hex" - }; - } - if (match = matchers.hex3.exec(color)) { - return { - r: parseIntFromHex(match[1] + '' + match[1]), - g: parseIntFromHex(match[2] + '' + match[2]), - b: parseIntFromHex(match[3] + '' + match[3]), - format: named ? "name" : "hex" - }; - } + /** + * On error callback + * @private + */ + onError: function onError(ctx, data) { + if (em) { + em.trigger(eventError, data); + ctx && em.trigger("".concat(eventError, ":").concat(ctx), data); + this.onEnd(ctx, data); + } + }, - return false; + /** + * Check if autoload is possible + * @return {Boolean} + * @private + * */ + canAutoload: function canAutoload() { + var storage = this.getCurrentStorage(); + return storage && this.getConfig().autoload; } - - window.tinycolor = tinycolor; - //})(); - - $(function () { - if ($.fn.spectrum.load) { - $.fn.spectrum.processNativeColorInputs(); - } - }); + }; }); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(0))) /***/ }), -/* 125 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; +/***/ "./src/storage_manager/model/LocalStorage.js": +/*!***************************************************!*\ + !*** ./src/storage_manager/model/LocalStorage.js ***! + \***************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { -var Backbone = __webpack_require__(0); -var LayerView = __webpack_require__(126); +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); -module.exports = Backbone.View.extend({ - initialize: function initialize(o) { - this.config = o.config || {}; - this.stackModel = o.stackModel; - this.preview = o.preview; - this.pfx = this.config.stylePrefix || ''; - this.ppfx = this.config.pStylePrefix || ''; - this.propsConfig = o.propsConfig; - var pfx = this.pfx; - var ppfx = this.ppfx; - var collection = this.collection; - this.className = pfx + 'layers ' + ppfx + 'field'; - this.listenTo(collection, 'add', this.addTo); - this.listenTo(collection, 'deselectAll', this.deselectAll); - this.listenTo(collection, 'reset', this.render); +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_0___default.a.Model.extend({ + defaults: { + checkLocal: true + }, - var em = this.config.em || ''; - var utils = em ? em.get('Utils') : ''; + /** + * @private + */ + store: function store(data, clb) { + this.checkStorageEnvironment(); - this.sorter = utils ? new utils.Sorter({ - container: this.el, - ignoreViewChildren: 1, - containerSel: '.' + pfx + 'layers', - itemSel: '.' + pfx + 'layer', - pfx: this.config.pStylePrefix - }) : ''; + for (var key in data) { + localStorage.setItem(key, data[key]); + } - // For the Sorter - collection.view = this; - this.$el.data('model', collection); - this.$el.data('collection', collection); + if (typeof clb == 'function') { + clb(); + } }, - /** - * Add to collection - * @param Object Model - * - * @return Object - * */ - addTo: function addTo(model) { - var i = this.collection.indexOf(model); - this.addToCollection(model, null, i); - }, - + * @private + */ + load: function load(keys, clb) { + this.checkStorageEnvironment(); + var result = {}; - /** - * Add new object to collection - * @param Object Model - * @param Object Fragment collection - * @param {number} index Index of append - * - * @return Object Object created - * */ - addToCollection: function addToCollection(model, fragmentEl, index) { - var fragment = fragmentEl || null; - var stackModel = this.stackModel; - var config = this.config; - var sorter = this.sorter; - var propsConfig = this.propsConfig; + for (var i = 0, len = keys.length; i < len; i++) { + var value = localStorage.getItem(keys[i]); + if (value) result[keys[i]] = value; + } - if (typeof this.preview !== 'undefined') { - model.set('preview', this.preview); + if (typeof clb == 'function') { + clb(result); } - var view = new LayerView({ - model: model, - config: config, - sorter: sorter, - stackModel: stackModel, - propsConfig: propsConfig - }); - var rendered = view.render().el; + return result; + }, - if (fragment) { - fragment.appendChild(rendered); - } else { - if (typeof index != 'undefined') { - var method = 'before'; - // If the added model is the last of collection - // need to change the logic of append - if (this.$el.children().length == index) { - index--; - method = 'after'; - } - // In case the added is new in the collection index will be -1 - if (index < 0) { - this.$el.append(rendered); - } else this.$el.children().eq(index)[method](rendered); - } else this.$el.append(rendered); - } + /** + * @private + */ + remove: function remove(keys) { + this.checkStorageEnvironment(); - return rendered; + for (var i = 0, len = keys.length; i < len; i++) { + localStorage.removeItem(keys[i]); + } }, - /** - * Deselect all - * - * @return void + * Check storage environment + * @private * */ - deselectAll: function deselectAll() { - this.$el.find('.' + this.pfx + 'layer').removeClass(this.pfx + 'active'); - }, - render: function render() { - var fragment = document.createDocumentFragment(); - this.$el.empty(); - - this.collection.each(function (model) { - this.addToCollection(model, fragment); - }, this); - - this.$el.append(fragment); - this.$el.attr('class', this.className); - - if (this.sorter) this.sorter.plh = null; - - return this; + checkStorageEnvironment: function checkStorageEnvironment() { + if (this.get('checkLocal') && !localStorage) console.warn("Your browser doesn't support localStorage"); } -}); +})); /***/ }), -/* 126 */ -/***/ (function(module, exports, __webpack_require__) { + +/***/ "./src/storage_manager/model/RemoteStorage.js": +/*!****************************************************!*\ + !*** ./src/storage_manager/model/RemoteStorage.js ***! + \****************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; -/* WEBPACK VAR INJECTION */(function(Backbone) { +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var utils_fetch__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! utils/fetch */ "./src/utils/fetch.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_3__); -module.exports = Backbone.View.extend({ - events: { - click: 'active', - 'click [data-close-layer]': 'remove', - 'mousedown [data-move-layer]': 'initSorter' - }, +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - template: function template(model) { - var pfx = this.pfx; - var label = 'Layer ' + model.get('index'); +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - return '\n
\n \n
\n
' + label + '
\n
\n \t
\n
\n
\n ⨯\n
\n
\n
\n '; - }, - initialize: function initialize() { - var o = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; - var model = this.model; - this.stackModel = o.stackModel || {}; - this.config = o.config || {}; - this.pfx = this.config.stylePrefix || ''; - this.sorter = o.sorter || null; - this.propsConfig = o.propsConfig || {}; - this.customPreview = o.onPreview; - this.listenTo(model, 'destroy remove', this.remove); - this.listenTo(model, 'change:active', this.updateVisibility); - this.listenTo(model.get('properties'), 'change', this.updatePreview); - if (!model.get('preview')) { - this.$el.addClass(this.pfx + 'no-preview'); - } - // For the sorter - model.view = this; - model.set({ droppable: 0, draggable: 1 }); - this.$el.data('model', model); +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_1___default.a.Model.extend({ + fetch: utils_fetch__WEBPACK_IMPORTED_MODULE_2__["default"], + defaults: { + urlStore: '', + urlLoad: '', + params: {}, + beforeSend: function beforeSend() {}, + onComplete: function onComplete() {}, + contentTypeJson: false, + credentials: 'include', + fetchOptions: '' }, - /** - * Delegate sorting - * @param {Event} e - * */ - initSorter: function initSorter(e) { - if (this.sorter) this.sorter.startSort(this.el); + * Triggered before the request is started + * @private + */ + onStart: function onStart() { + var em = this.get('em'); + var before = this.get('beforeSend'); + before && before(); }, - remove: function remove(e) { - if (e && e.stopPropagation) e.stopPropagation(); - var model = this.model; - var collection = model.collection; - var stackModel = this.stackModel; + /** + * Triggered on request error + * @param {Object} err Error + * @param {Function} [clbErr] Error callback + * @private + */ + onError: function onError(err, clbErr) { + if (clbErr) { + clbErr(err); + } else { + var em = this.get('em'); + console.error(err); + em && em.trigger('storage:error', err); + } + }, - Backbone.View.prototype.remove.apply(this, arguments); + /** + * Triggered on request response + * @param {string} text Response text + * @private + */ + onResponse: function onResponse(text, clb) { + var em = this.get('em'); + var complete = this.get('onComplete'); + var typeJson = this.get('contentTypeJson'); + var parsable = text && typeof text === 'string'; + var res = typeJson && parsable ? JSON.parse(text) : text; + complete && complete(res); + clb && clb(res); + em && em.trigger('storage:response', res); + }, + store: function store(data, clb, clbErr) { + var body = {}; - if (collection.contains(model)) { - collection.remove(model); + for (var key in data) { + body[key] = data[key]; } - if (stackModel && stackModel.set) { - stackModel.set({ stackIndex: null }, { silent: true }); - stackModel.trigger('updateValue'); - } + this.request(this.get('urlStore'), { + body: body + }, clb, clbErr); + }, + load: function load(keys, clb, clbErr) { + this.request(this.get('urlLoad'), { + method: 'get' + }, clb, clbErr); }, - /** - * Default method for changing preview box - * @param {Collection} props - * @param {Element} $el + * Execute remote request + * @param {string} url Url + * @param {Object} [opts={}] Options + * @param {Function} [clb=null] Callback + * @param {Function} [clbErr=null] Error callback + * @private */ - onPreview: function onPreview(value) { - var values = value.split(' '); - var lim = 3; - var result = []; - this.model.get('properties').each(function (prop, index) { - var value = values[index] || ''; + request: function request(url) { + var _this = this; - if (value) { - if (prop.get('type') == 'integer') { - var valueInt = parseInt(value, 10); - var unit = value.replace(valueInt, ''); - valueInt = !isNaN(valueInt) ? valueInt : 0; - valueInt = valueInt > lim ? lim : valueInt; - valueInt = valueInt < -lim ? -lim : valueInt; - value = valueInt + unit; - } - } + var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + var clb = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : null; + var clbErr = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : null; + var typeJson = this.get('contentTypeJson'); + var headers = this.get('headers') || {}; + var params = this.get('params'); + var reqHead = 'X-Requested-With'; + var typeHead = 'Content-Type'; + var bodyObj = opts.body || {}; + var fetchOptions; + var body; - result.push(value); - }); + for (var param in params) { + bodyObj[param] = params[param]; + } - return result.join(' '); - }, - updatePreview: function updatePreview() { - var stackModel = this.stackModel; - var customPreview = this.customPreview; - var previewEl = this.getPreviewEl(); - var value = this.model.getFullValue(); - var preview = customPreview ? customPreview(value) : this.onPreview(value); + if (Object(underscore__WEBPACK_IMPORTED_MODULE_3__["isUndefined"])(headers[reqHead])) { + headers[reqHead] = 'XMLHttpRequest'; + } // With `fetch`, have to send FormData without any 'Content-Type' + // https://stackoverflow.com/questions/39280438/fetch-missing-boundary-in-multipart-form-data-post - if (preview && stackModel && previewEl) { - previewEl.style[stackModel.get('property')] = preview; + + if (Object(underscore__WEBPACK_IMPORTED_MODULE_3__["isUndefined"])(headers[typeHead]) && typeJson) { + headers[typeHead] = 'application/json; charset=utf-8'; } - }, - getPropertiesWrapper: function getPropertiesWrapper() { - if (!this.propsWrapEl) { - this.propsWrapEl = this.el.querySelector('[data-properties]'); + + if (typeJson) { + body = JSON.stringify(bodyObj); + } else { + body = new FormData(); + + for (var bodyKey in bodyObj) { + body.append(bodyKey, bodyObj[bodyKey]); + } } - return this.propsWrapEl; - }, - getPreviewEl: function getPreviewEl() { - if (!this.previewEl) { - this.previewEl = this.el.querySelector('[data-preview]'); + + fetchOptions = { + method: opts.method || 'post', + credentials: this.get('credentials'), + headers: headers + }; // Body should only be included on POST method + + if (fetchOptions.method === 'post') { + fetchOptions.body = body; } - return this.previewEl; - }, - active: function active() { - var model = this.model; - var collection = model.collection; - collection.active(collection.indexOf(model)); - }, - updateVisibility: function updateVisibility() { - var pfx = this.pfx; - var wrapEl = this.getPropertiesWrapper(); - var active = this.model.get('active'); - wrapEl.style.display = active ? '' : 'none'; - this.$el[active ? 'addClass' : 'removeClass'](pfx + 'active'); - }, - render: function render() { - var PropertiesView = __webpack_require__(13); - var propsConfig = this.propsConfig; - var className = this.pfx + 'layer'; - var model = this.model; - var el = this.el; - var properties = new PropertiesView({ - collection: model.get('properties'), - config: this.config, - target: propsConfig.target, - customValue: propsConfig.customValue, - propTarget: propsConfig.propTarget, - onChange: propsConfig.onChange - }).render().el; - el.innerHTML = this.template(model); - el.className = className; - this.getPropertiesWrapper().appendChild(properties); - this.updateVisibility(); - this.updatePreview(); - return this; + + var fetchOpts = this.get('fetchOptions') || {}; + var addOpts = Object(underscore__WEBPACK_IMPORTED_MODULE_3__["isFunction"])(fetchOpts) ? fetchOpts(fetchOptions) : fetchOptions; + this.onStart(); + this.fetch(url, _objectSpread({}, fetchOptions, {}, addOpts || {})).then(function (res) { + return (res.status / 200 | 0) == 1 ? res.text() : res.text().then(function (text) { + return Promise.reject(text); + }); + }).then(function (text) { + return _this.onResponse(text, clb); + }).catch(function (err) { + return _this.onError(err, clbErr); + }); } +})); + +/***/ }), + +/***/ "./src/style_manager/config/config.js": +/*!********************************************!*\ + !*** ./src/style_manager/config/config.js ***! + \********************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony default export */ __webpack_exports__["default"] = ({ + stylePrefix: 'sm-', + sectors: [], + // Specify the element to use as a container, string (query) or HTMLElement + // With the empty value, nothing will be rendered + appendTo: '', + // Text to show in case no element selected + textNoElement: 'Select an element before using Style Manager', + // Text for layers + textLayer: 'Layer', + // Hide the property in case it's not stylable for the + // selected component (each component has 'stylable' property) + hideNotStylable: true, + // Highlight changed properties of the selected component + highlightChanged: true, + // Highlight computed properties of the selected component + highlightComputed: true, + // Show computed properties of the selected component, if this value + // is set to false, highlightComputed will not take effect + showComputed: true, + // Adds the possibility to clear property value from the target style + clearProperties: 0, + // Properties not to take in account for computed styles + avoidComputed: ['width', 'height'] }); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(0))) /***/ }), -/* 127 */ -/***/ (function(module, exports, __webpack_require__) { -"use strict"; +/***/ "./src/style_manager/index.js": +/*!************************************!*\ + !*** ./src/style_manager/index.js ***! + \************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var _config_config__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./config/config */ "./src/style_manager/config/config.js"); +/* harmony import */ var _model_Sectors__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./model/Sectors */ "./src/style_manager/model/Sectors.js"); +/* harmony import */ var _model_Properties__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./model/Properties */ "./src/style_manager/model/Properties.js"); +/* harmony import */ var _view_SectorsView__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./view/SectorsView */ "./src/style_manager/view/SectorsView.js"); + + +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } + +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } +/** + * With Style Manager you build categories (called sectors) of CSS properties which could be used to customize the style of components. + * You can customize the initial state of the module from the editor initialization, by passing the following [Configuration Object](https://github.com/artf/grapesjs/blob/master/src/style_manager/config/config.js) + * ```js + * const editor = grapesjs.init({ + * styleManager: { + * // options + * } + * }) + * ``` + * + * Once the editor is instantiated you can use its API. Before using these methods you should get the module from the instance + * + * ```js + * const styleManager = editor.StyleManager; + * ``` + * + * * [getConfig](#getconfig) + * * [addSector](#addsector) + * * [getSector](#getsector) + * * [removeSector](#removesector) + * * [getSectors](#getsectors) + * * [addProperty](#addproperty) + * * [getProperty](#getproperty) + * * [removeProperty](#removeproperty) + * * [getProperties](#getproperties) + * * [getModelToStyle](#getmodeltostyle) + * * [addType](#addtype) + * * [getType](#gettype) + * * [getTypes](#gettypes) + * * [createType](#createtype) + * + * @module StyleManager + */ -var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; -var Property = __webpack_require__(42); -module.exports = Property.extend({ - defaults: _extends({}, Property.prototype.defaults, { - showInput: 1 - }) -}); +/* harmony default export */ __webpack_exports__["default"] = (function () { + var c = {}; + var properties; + var sectors, SectView; + return { + /** + * Name of the module + * @type {String} + * @private + */ + name: 'StyleManager', -/***/ }), -/* 128 */ -/***/ (function(module, exports, __webpack_require__) { + /** + * Get configuration object + * @return {Object} + */ + getConfig: function getConfig() { + return c; + }, -"use strict"; + /** + * Initialize module. Automatically called with a new instance of the editor + * @param {Object} config Configurations + * @private + */ + init: function init(config) { + c = _objectSpread({}, _config_config__WEBPACK_IMPORTED_MODULE_2__["default"], {}, config); + var ppfx = c.pStylePrefix; + this.em = c.em; + if (ppfx) c.stylePrefix = ppfx + c.stylePrefix; + properties = new _model_Properties__WEBPACK_IMPORTED_MODULE_4__["default"](); + sectors = new _model_Sectors__WEBPACK_IMPORTED_MODULE_3__["default"]([], c); + SectView = new _view_SectorsView__WEBPACK_IMPORTED_MODULE_5__["default"]({ + collection: sectors, + target: c.em, + config: c + }); + return this; + }, + onLoad: function onLoad() { + sectors.add(c.sectors); + }, + postRender: function postRender() { + var elTo = this.getConfig().appendTo; + if (elTo) { + var el = Object(underscore__WEBPACK_IMPORTED_MODULE_1__["isElement"])(elTo) ? elTo : document.querySelector(elTo); + el.appendChild(this.render()); + } + }, -var Property = __webpack_require__(14); + /** + * Add new sector to the collection. If the sector with the same id already exists, + * that one will be returned + * @param {string} id Sector id + * @param {Object} sector Object representing sector + * @param {string} [sector.name=''] Sector's label + * @param {Boolean} [sector.open=true] Indicates if the sector should be opened + * @param {Array} [sector.properties=[]] Array of properties + * @param {Object} [options={}] Options + * @return {Sector} Added Sector + * @example + * var sector = styleManager.addSector('mySector',{ + * name: 'My sector', + * open: true, + * properties: [{ name: 'My property'}] + * }, { at: 0 }); + * // With `at: 0` we place the new sector at the beginning of the collection + * */ + addSector: function addSector(id, sector) { + var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + var result = this.getSector(id); -module.exports = Property.extend({ + if (!result) { + sector.id = id; + result = sectors.add(sector, opts); + } - events: { - 'change [type=range]': 'inputValueChanged', - 'input [type=range]': 'inputValueChangedSoft' - }, + return result; + }, - templateInput: function templateInput(model) { - var ppfx = this.ppfx; - return '\n
\n \n
\n '; - }, - getSliderEl: function getSliderEl() { - if (!this.slider) { - this.slider = this.el.querySelector('input[type=range]'); - } + /** + * Get sector by id + * @param {string} id Sector id + * @return {Sector|null} + * @example + * var sector = styleManager.getSector('mySector'); + * */ + getSector: function getSector(id) { + var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + var res = sectors.where({ + id: id + })[0]; + !res && opts.warn && this._logNoSector(id); + return res; + }, - return this.slider; - }, - inputValueChanged: function inputValueChanged() { - var model = this.model; - var step = model.get('step'); - this.getInputEl().value = this.getSliderEl().value; - var value = this.getInputValue() - step; - model.set('value', value, { avoidStore: 1 }).set('value', value + step); - this.elementUpdated(); - }, - inputValueChangedSoft: function inputValueChangedSoft() { - this.getInputEl().value = this.getSliderEl().value; - this.model.set('value', this.getInputValue(), { avoidStore: 1 }); - this.elementUpdated(); - }, - setValue: function setValue(value) { - this.getSliderEl().value = value; - this.inputInst.setValue(value, { silent: 1 }); - }, - onRender: function onRender() { - Property.prototype.onRender.apply(this, arguments); + /** + * Remove a sector by id + * @param {string} id Sector id + * @return {Sector} Removed sector + * @example + * const removed = styleManager.removeSector('mySector'); + */ + removeSector: function removeSector(id) { + return this.getSectors().remove(this.getSector(id, { + warn: 1 + })); + }, - if (!this.model.get('showInput')) { - this.inputInst.el.style.display = 'none'; - } - } -}); + /** + * Get all sectors + * @return {Sectors} Collection of sectors + * */ + getSectors: function getSectors() { + return sectors; + }, -/***/ }), -/* 129 */ -/***/ (function(module, exports, __webpack_require__) { + /** + * Add property to the sector identified by id + * @param {string} sectorId Sector id + * @param {Object} property Property object + * @param {string} [property.name=''] Name of the property + * @param {string} [property.property=''] CSS property, eg. `min-height` + * @param {string} [property.type=''] Type of the property: integer | radio | select | color | file | composite | stack + * @param {Array} [property.units=[]] Unit of measure available, eg. ['px','%','em']. Only for integer type + * @param {string} [property.unit=''] Default selected unit from `units`. Only for integer type + * @param {number} [property.min=null] Min possible value. Only for integer type + * @param {number} [property.max=null] Max possible value. Only for integer type + * @param {string} [property.defaults=''] Default value + * @param {string} [property.info=''] Some description + * @param {string} [property.icon=''] Class name. If exists no text will be displayed + * @param {Boolean} [property.preview=false] Show layers preview. Only for stack type + * @param {string} [property.functionName=''] Indicates if value need to be wrapped in some function, for istance `transform: rotate(90deg)` + * @param {Array} [property.properties=[]] Nested properties for composite and stack type + * @param {Array} [property.layers=[]] Layers for stack properties + * @param {Array} [property.list=[]] List of possible options for radio and select types + * @param {Object} [options={}] Options + * @return {Property|null} Added Property or `null` in case sector doesn't exist + * @example + * var property = styleManager.addProperty('mySector',{ + * name: 'Minimum height', + * property: 'min-height', + * type: 'select', + * defaults: '100px', + * list: [{ + * value: '100px', + * name: '100', + * },{ + * value: '200px', + * name: '200', + * }], + * }, { at: 0 }); + * // With `at: 0` we place the new property at the beginning of the collection + */ + addProperty: function addProperty(sectorId, property) { + var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + var sector = this.getSector(sectorId, { + warn: 1 + }); + var prop = null; + if (sector) prop = sector.get('properties').add(property, opts); + return prop; + }, -"use strict"; + /** + * Get property by its CSS name and sector id + * @param {string} sectorId Sector id + * @param {string} name CSS property name, eg. 'min-height' + * @return {Property|null} + * @example + * var property = styleManager.getProperty('mySector','min-height'); + */ + getProperty: function getProperty(sectorId, name) { + var sector = this.getSector(sectorId, { + warn: 1 + }); + var prop = null; + if (sector) { + prop = sector.get('properties').where({ + property: name + }); + prop = prop.length == 1 ? prop[0] : prop; + } -var Backbone = __webpack_require__(0); + return prop; + }, -module.exports = function () { - return { /** - * Build props object by their name - * @param {Array|string} props Array of properties name - * @return {Array} + * Remove a property from the sector + * @param {string} sectorId Sector id + * @param {string} name CSS property name, eg. 'min-height' + * @return {Property} Removed property + * @example + * const property = styleManager.removeProperty('mySector', 'min-height'); */ - build: function build(props) { - var objs = []; - var dftFixedValues = ['initial', 'inherit']; + removeProperty: function removeProperty(sectorId, name) { + var props = this.getProperties(sectorId); + return props && props.remove(this.getProperty(sectorId, name)); + }, - if (typeof props === 'string') props = [props]; + /** + * Get properties of the sector + * @param {string} sectorId Sector id + * @return {Properties} Collection of properties + * @example + * var properties = styleManager.getProperties('mySector'); + */ + getProperties: function getProperties(sectorId) { + var props = null; + var sector = this.getSector(sectorId, { + warn: 1 + }); + if (sector) props = sector.get('properties'); + return props; + }, - for (var i = 0, len = props.length; i < len; i++) { - var obj = {}; - var prop = props[i]; - obj.property = prop; + /** + * Get what to style inside Style Manager. If you select the component + * without classes the entity is the Component itself and all changes will + * go inside its 'style' property. Otherwise, if the selected component has + * one or more classes, the function will return the corresponding CSS Rule + * @param {Model} model + * @return {Model} + */ + getModelToStyle: function getModelToStyle(model) { + var em = c.em; + var classes = model.get('classes'); + var id = model.getId(); - // Property - switch (prop) { - case 'border-radius-c': - obj.property = 'border-radius'; - break; - } + if (em) { + var config = em.getConfig(); + var um = em.get('UndoManager'); + var cssC = em.get('CssComposer'); + var state = !config.devicePreviewMode ? model.get('state') : ''; + var valid = classes.getStyleable(); + var hasClasses = valid.length; + var opts = { + state: state + }; + var rule; // I stop undo manager here as after adding the CSSRule (generally after + // selecting the component) and calling undo() it will remove the rule from + // the collection, therefore updating it in style manager will not affect it + // #268 - // Fixed values - switch (prop) { - case 'margin-top':case 'margin-right':case 'margin-bottom':case 'margin-left': - case 'padding-top':case 'padding-right':case 'padding-bottom':case 'padding-left': - case 'width':case 'max-width':case 'min-width': - case 'height':case 'max-height':case 'min-height': - obj.fixedValues = ['initial', 'inherit', 'auto']; - break; - case 'font-size': - obj.fixedValues = ['medium', 'xx-small', 'x-small', 'small', 'large', 'x-large', 'xx-large', 'smaller', 'larger', 'length', 'initial', 'inherit']; - break; - case 'letter-spacing':case 'line-height': - obj.fixedValues = ['normal', 'initial', 'inherit']; - break; - } + um.stop(); - // Type - switch (prop) { - case 'float':case 'position': - case 'text-align': - obj.type = 'radio'; - break; - case 'display':case 'font-family': - case 'font-weight': - case 'border-style': - case 'box-shadow-type': - case 'background-repeat':case 'background-position':case 'background-attachment':case 'background-size': - case 'transition-property':case 'transition-timing-function': - case 'cursor': - case 'overflow': - obj.type = 'select'; - break; - case 'top':case 'right':case 'bottom':case 'left': - case 'margin-top':case 'margin-right':case 'margin-bottom':case 'margin-left': - case 'padding-top':case 'padding-right':case 'padding-bottom':case 'padding-left': - case 'min-height':case 'min-width':case 'max-height':case 'max-width': - case 'width':case 'height': - case 'font-size':case 'letter-spacing':case 'line-height': - case 'text-shadow-h':case 'text-shadow-v':case 'text-shadow-blur': - case 'border-radius-c': - case 'border-top-left-radius':case 'border-top-right-radius':case 'border-bottom-left-radius':case 'border-bottom-right-radius': - case 'border-width': - case 'box-shadow-h':case 'box-shadow-v':case 'box-shadow-blur':case 'box-shadow-spread': - case 'transition-duration': - case 'perspective': - case 'transform-rotate-x':case 'transform-rotate-y':case 'transform-rotate-z': - case 'transform-scale-x':case 'transform-scale-y':case 'transform-scale-z': - obj.type = 'integer'; - break; - case 'margin':case 'padding': - case 'border-radius': - case 'border': - case 'transform': - obj.type = 'composite'; - break; - case 'color':case 'text-shadow-color': - case 'background-color':case 'border-color':case 'box-shadow-color': - obj.type = 'color'; - break; - case 'text-shadow':case 'box-shadow':case 'background': - case 'transition': - obj.type = 'stack'; - break; - case 'background-image': - obj.type = 'file'; - break; - } + if (hasClasses) { + var deviceW = em.getCurrentMedia(); + rule = cssC.get(valid, state, deviceW); - // Defaults - switch (prop) { - case 'float':case 'background-color': - case 'background-image':case 'text-shadow': - obj.defaults = 'none'; - break; - case 'display': - obj.defaults = 'block'; - break; - case 'position': - obj.defaults = 'static'; - break; - case 'top':case 'right':case 'bottom':case 'left': - case 'margin-top':case 'margin-right':case 'margin-bottom':case 'margin-left': - case 'padding-top':case 'padding-right':case 'padding-bottom':case 'padding-left': - case 'text-shadow-h':case 'text-shadow-v':case 'text-shadow-blur': - case 'border-radius-c': - case 'border-top-left-radius':case 'border-top-right-radius':case 'border-bottom-left-radius':case 'border-bottom-right-radius': - case 'box-shadow-h':case 'box-shadow-v':case 'box-shadow-spread': - case 'perspective': - case 'transform-rotate-x':case 'transform-rotate-y':case 'transform-rotate-z': - obj.defaults = 0; - break; - case 'transform-scale-x':case 'transform-scale-y':case 'transform-scale-z': - obj.defaults = 1; - break; - case 'box-shadow-blur': - obj.defaults = '5px'; - break; - case 'min-height':case 'min-width':case 'max-height':case 'max-width': - case 'width':case 'height': - case 'background-size': - case 'cursor': - obj.defaults = 'auto'; - break; - case 'font-family': - obj.defaults = 'Arial, Helvetica, sans-serif'; - break; - case 'font-size':case 'border-width': - obj.defaults = 'medium'; - break; - case 'font-weight': - obj.defaults = '400'; - break; - case 'letter-spacing':case 'line-height': - obj.defaults = 'normal'; - break; - case 'color':case 'text-shadow-color': - case 'border-color':case 'box-shadow-color': - obj.defaults = 'black'; - break; - case 'text-align': - obj.defaults = 'left'; - break; - case 'border-style': - obj.defaults = 'solid'; - break; - case 'box-shadow-type': - obj.defaults = ''; - break; - case 'background-repeat': - obj.defaults = 'repeat'; - break; - case 'background-position': - obj.defaults = 'left top'; - break; - case 'background-attachment': - obj.defaults = 'scroll'; - break; - case 'transition-property': - obj.defaults = 'width'; - break; - case 'transition-duration': - obj.defaults = '2'; - break; - case 'transition-timing-function': - obj.defaults = 'ease'; - break; - case 'overflow': - obj.defaults = 'visible'; - break; + if (!rule) { + rule = cssC.add(valid, state, deviceW); + } + } else if (config.avoidInlineStyle) { + rule = cssC.getIdRule(id, opts); + !rule && (rule = cssC.setIdRule(id, {}, opts)); + if (model.is('wrapper')) rule.set('wrapper', 1); } - // Units - switch (prop) { - case 'top':case 'right':case 'bottom':case 'left': - case 'margin-top':case 'margin-right':case 'margin-bottom':case 'margin-left': - case 'padding-top':case 'padding-right':case 'padding-bottom':case 'padding-left': - case 'min-height':case 'min-width':case 'max-height':case 'max-width': - case 'width':case 'height': - case 'text-shadow-h':case 'text-shadow-v':case 'text-shadow-blur': - case 'border-radius-c': - case 'border-top-left-radius':case 'border-top-right-radius':case 'border-bottom-left-radius':case 'border-bottom-right-radius': - case 'box-shadow-h':case 'box-shadow-v': - obj.units = ['px', '%']; - break; - case 'font-size':case 'letter-spacing':case 'line-height': - obj.units = ['px', 'em', 'rem', '%']; - break; - case 'border-width': - obj.units = ['px', 'em']; - break; - case 'box-shadow-blur':case 'box-shadow-spread': - case 'perspective': - obj.units = ['px']; - break; - case 'transition-duration': - obj.units = ['s']; - break; - case 'transform-rotate-x':case 'transform-rotate-y':case 'transform-rotate-z': - obj.units = ['deg']; - break; - } + rule && (model = rule); + um.start(); + } - // Min/Max - switch (prop) { - case 'padding-top':case 'padding-right':case 'padding-bottom':case 'padding-left': - case 'min-height':case 'min-width':case 'max-height':case 'max-width': - case 'width':case 'height': - case 'font-size': - case 'text-shadow-blur': - case 'border-radius-c': - case 'border-top-left-radius':case 'border-top-right-radius':case 'border-bottom-left-radius':case 'border-bottom-right-radius': - case 'border-width': - case 'box-shadow-blur': - case 'transition-duration': - case 'perspective': - obj.min = 0; - break; - } + return model; + }, - // Preview - switch (prop) { - case 'text-shadow':case 'box-shadow':case 'background': - obj.preview = true; - break; - } + /** + * Add new property type + * @param {string} id Type ID + * @param {Object} definition Definition of the type. Each definition contains + * `model` (business logic), `view` (presentation logic) + * and `isType` function which recognize the type of the + * passed entity + *@example + * styleManager.addType('my-type', { + * model: {}, + * view: {}, + * isType: (value) => { + * if (value && value.type == 'my-type') { + * return value; + * } + * }, + * }) + */ + addType: function addType(id, definition) { + properties.addType(id, definition); + }, - // Detached - switch (prop) { - case 'background': - obj.detached = true; - break; - } + /** + * Get type + * @param {string} id Type ID + * @return {Object} Type definition + */ + getType: function getType(id) { + return properties.getType(id); + }, - // Functions - switch (prop) { - case 'transform-rotate-x': - obj.functionName = 'rotateX'; - break; - case 'transform-rotate-y': - obj.functionName = 'rotateY'; - break; - case 'transform-rotate-z': - obj.functionName = 'rotateZ'; - break; - case 'transform-scale-x': - obj.functionName = 'scaleX'; - break; - case 'transform-scale-y': - obj.functionName = 'scaleY'; - break; - case 'transform-scale-z': - obj.functionName = 'scaleZ'; - break; - case 'background-image': - obj.functionName = 'url'; - break; - } + /** + * Get all types + * @return {Array} + */ + getTypes: function getTypes() { + return properties.getTypes(); + }, - // Options - switch (prop) { - case 'float': - obj.list = [{ value: 'none' }, { value: 'left' }, { value: 'right' }]; - break; - case 'display': - obj.list = [{ value: 'block' }, { value: 'inline' }, { value: 'inline-block' }, { value: 'none' }]; - break; - case 'position': - obj.list = [{ value: 'static' }, { value: 'relative' }, { value: 'absolute' }, { value: 'fixed' }]; - break; - case 'font-family': - var ss = ', sans-serif'; - var fonts = ['Arial, Helvetica' + ss, 'Arial Black, Gadget' + ss, 'Brush Script MT' + ss, 'Comic Sans MS, cursive' + ss, 'Courier New, Courier, monospace', 'Georgia, serif', 'Helvetica, serif', 'Impact, Charcoal' + ss, 'Lucida Sans Unicode, Lucida Grande' + ss, 'Tahoma, Geneva' + ss, 'Times New Roman, Times, serif', 'Trebuchet MS, Helvetica' + ss, 'Verdana, Geneva' + ss]; - obj.list = []; - for (var j = 0, l = fonts.length; j < l; j++) { - var font = {}; - font.value = fonts[j]; - font.name = fonts[j].split(',')[0]; - obj.list.push(font); - } - break; - case 'font-weight': - obj.list = [{ value: '100', name: 'Thin' }, { value: '200', name: 'Extra-Light' }, { value: '300', name: 'Light' }, { value: '400', name: 'Normal' }, { value: '500', name: 'Medium' }, { value: '600', name: 'Semi-Bold' }, { value: '700', name: 'Bold' }, { value: '800', name: 'Extra-Bold' }, { value: '900', name: 'Ultra-Bold' }]; - break; - case 'text-align': - obj.list = [{ value: 'left' }, { value: 'center' }, { value: 'right' }, { value: 'justify' }]; - break; - case 'border-style': - obj.list = [{ value: 'none' }, { value: 'solid' }, { value: 'dotted' }, { value: 'dashed' }, { value: 'double' }, { value: 'groove' }, { value: 'ridge' }, { value: 'inset' }, { value: 'outset' }]; - break; - case 'box-shadow-type': - obj.list = [{ value: '', name: 'Outside' }, { value: 'inset', name: 'Inside' }]; - break; - case 'background-repeat': - obj.list = [{ value: 'repeat' }, { value: 'repeat-x' }, { value: 'repeat-y' }, { value: 'no-repeat' }]; - break; - case 'background-position': - obj.list = [{ value: 'left top' }, { value: 'left center' }, { value: 'left bottom' }, { value: 'right top' }, { value: 'right center' }, { value: 'right bottom' }, { value: 'center top' }, { value: 'center center' }, { value: 'center bottom' }]; - break; - case 'background-attachment': - obj.list = [{ value: 'scroll' }, { value: 'fixed' }, { value: 'local' }]; - break; - case 'background-size': - obj.list = [{ value: 'auto' }, { value: 'cover' }, { value: 'contain' }]; - break; - case 'transition-property': - obj.list = [{ value: 'all' }, { value: 'width' }, { value: 'height' }, { value: 'background-color' }, { value: 'transform' }, { value: 'box-shadow' }, { value: 'opacity' }]; - break; - case 'transition-timing-function': - obj.list = [{ value: 'linear' }, { value: 'ease' }, { value: 'ease-in' }, { value: 'ease-out' }, { value: 'ease-in-out' }]; - break; - case 'cursor': - obj.list = [{ value: 'auto' }, { value: 'pointer' }, { value: 'copy' }, { value: 'crosshair' }, { value: 'grab' }, { value: 'grabbing' }, { value: 'help' }, { value: 'move' }, { value: 'text' }]; - break; - case 'overflow': - obj.list = [{ value: 'visible' }, { value: 'hidden' }, { value: 'scroll' }, { value: 'auto' }]; - break; - } + /** + * Create new property from type + * @param {string} id Type ID + * @param {Object} [options={}] Options + * @param {Object} [options.model={}] Custom model object + * @param {Object} [options.view={}] Custom view object + * @return {PropertyView} + * @example + * const propView = styleManager.createType('integer', { + * model: {units: ['px', 'rem']} + * }); + * propView.render(); + * propView.model.on('change:value', ...); + * someContainer.appendChild(propView.el); + */ + createType: function createType(id) { + var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}, + _ref$model = _ref.model, + model = _ref$model === void 0 ? {} : _ref$model, + _ref$view = _ref.view, + view = _ref$view === void 0 ? {} : _ref$view; - // Properties - switch (prop) { - case 'margin': - obj.properties = this.build(['margin-top', 'margin-right', 'margin-bottom', 'margin-left']); - break; - case 'padding': - obj.properties = this.build(['padding-top', 'padding-right', 'padding-bottom', 'padding-left']); - break; - case 'text-shadow': - obj.properties = this.build(['text-shadow-h', 'text-shadow-v', 'text-shadow-blur', 'text-shadow-color']); - break; - case 'border': - obj.properties = this.build(['border-width', 'border-style', 'border-color']); - break; - case 'border-radius': - obj.properties = this.build(['border-top-left-radius', 'border-top-right-radius', 'border-bottom-left-radius', 'border-bottom-right-radius']); - break; - case 'box-shadow': - obj.properties = this.build(['box-shadow-h', 'box-shadow-v', 'box-shadow-blur', 'box-shadow-spread', 'box-shadow-color', 'box-shadow-type']); - break; - case 'background': - obj.properties = this.build(['background-image', 'background-repeat', 'background-position', 'background-attachment', 'background-size']); - break; - case 'transition': - obj.properties = this.build(['transition-property', 'transition-duration', 'transition-timing-function']); - break; - case 'transform': - obj.properties = this.build(['transform-rotate-x', 'transform-rotate-y', 'transform-rotate-z', 'transform-scale-x', 'transform-scale-y', 'transform-scale-z']); - break; - } + var type = this.getType(id); - objs.push(obj); + if (type) { + return new type.view(_objectSpread({ + model: new type.model(model), + config: c + }, view)); } + }, - return objs; + /** + * Select different target for the Style Manager. + * It could be a Component, CSSRule, or a string of any CSS selector + * @param {Component|CSSRule|String} target + * @return {Styleable} A Component or CSSRule + */ + setTarget: function setTarget(target, opts) { + return SectView.setTarget(target, opts); + }, + getEmitter: function getEmitter() { + return SectView.propTarget; + }, + + /** + * Render sectors and properties + * @return {HTMLElement} + * @private + * */ + render: function render() { + return SectView.render().el; + }, + _logNoSector: function _logNoSector(sectorId) { + var em = this.em; + em && em.logWarning("'".concat(sectorId, "' sector not found")); } }; -}; +}); /***/ }), -/* 130 */ -/***/ (function(module, exports, __webpack_require__) { + +/***/ "./src/style_manager/model/Layer.js": +/*!******************************************!*\ + !*** ./src/style_manager/model/Layer.js ***! + \******************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; -/* WEBPACK VAR INJECTION */(function(Backbone) { +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _Properties__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Properties */ "./src/style_manager/model/Properties.js"); -var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; -var _underscore = __webpack_require__(1); +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_0___default.a.Model.extend({ + defaults: { + index: '', + value: '', + values: {}, + active: false, + preview: false, + properties: [] + }, + initialize: function initialize() { + var _this = this; -var SectorView = __webpack_require__(131); + var properties = this.get('properties'); + var value = this.get('value'); + this.set('properties', properties instanceof _Properties__WEBPACK_IMPORTED_MODULE_1__["default"] ? properties : new _Properties__WEBPACK_IMPORTED_MODULE_1__["default"](properties)); + this.get('properties').forEach(function (item) { + var collection = _this.collection; + item.parent = collection && collection.property; + }); // If there is no value I'll try to get it from values + // I need value setted to make preview working -module.exports = Backbone.View.extend({ - initialize: function initialize(o) { - this.config = o.config || {}; - this.pfx = this.config.stylePrefix || ''; - this.target = o.target || {}; + if (!value) { + var val = ''; + var values = this.get('values'); - // The target that will emit events for properties - var target = {}; - (0, _underscore.extend)(target, Backbone.Events); - var body = document.body; - var dummy = document.createElement('el-' + new Date().getTime()); - body.appendChild(dummy); - target.computedDefault = _extends({}, window.getComputedStyle(dummy)); - body.removeChild(dummy); - this.propTarget = target; - var coll = this.collection; - var events = 'change:selectedComponent component:update:classes change:device'; - this.listenTo(coll, 'add', this.addTo); - this.listenTo(coll, 'reset', this.render); - this.listenTo(this.target, events, this.targetUpdated); - }, + for (var prop in values) { + val += ' ' + values[prop]; + } + this.set('value', val.trim()); + } + }, /** - * Add to collection - * @param {Object} model Model + * Get property at some index + * @param {Number} index * @return {Object} + */ + getPropertyAt: function getPropertyAt(index) { + return this.get('properties').at(index); + }, + getPropertyValue: function getPropertyValue(property) { + var result = ''; + this.get('properties').each(function (prop) { + if (prop.get('property') == property) { + result = prop.getFullValue(); + } + }); + return result; + }, + getFullValue: function getFullValue() { + var result = []; + this.get('properties').each(function (prop) { + return result.push(prop.getFullValue()); + }); + return result.join(' '); + } +})); + +/***/ }), + +/***/ "./src/style_manager/model/Layers.js": +/*!*******************************************!*\ + !*** ./src/style_manager/model/Layers.js ***! + \*******************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var _Layer__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./Layer */ "./src/style_manager/model/Layer.js"); + + +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } + +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } + + + +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_1___default.a.Collection.extend({ + model: _Layer__WEBPACK_IMPORTED_MODULE_2__["default"], + initialize: function initialize() { + this.idx = 1; + this.on('add', this.onAdd); + this.on('reset', this.onReset); + }, + onAdd: function onAdd(model, c, opts) { + if (!opts.noIncrement) model.set('index', this.idx++); + }, + onReset: function onReset() { + this.idx = 1; + }, + getSeparator: function getSeparator() { + var property = this.property; + return property ? property.get('layerSeparator') : ', '; + }, + + /** + * Get layers from a value string (for not detached properties), + * example of input: + * `layer1Value, layer2Value, layer3Value, ...` + * @param {string} value + * @return {Array} * @private - * */ - addTo: function addTo(model) { - this.addToCollection(model); + */ + getLayersFromValue: function getLayersFromValue(value) { + var _this = this; + + var layers = []; // Remove spaces inside functions, eg: + // From: 1px 1px rgba(2px, 2px, 2px), 2px 2px rgba(3px, 3px, 3px) + // To: 1px 1px rgba(2px,2px,2px), 2px 2px rgba(3px,3px,3px) + + value.replace(/\(([\w\s,.]*)\)/g, function (match) { + var cleaned = match.replace(/,\s*/g, ','); + value = value.replace(match, cleaned); + }); + var layerValues = value ? value.split(this.getSeparator()) : []; + layerValues.forEach(function (layerValue) { + layers.push({ + properties: _this.properties.parseValue(layerValue) + }); + }); + return layers; + }, + + /** + * Get layers from a style object (for detached properties), + * example of input: + * { + * subPropname1: sub-propvalue11, sub-propvalue12, sub-propvalue13, ... + * subPropname2: sub-propvalue21, sub-propvalue22, sub-propvalue23, ... + * subPropname3: sub-propvalue31, sub-propvalue32, sub-propvalue33, ... + * } + * @param {Object} styleObj + * @return {Array} + * @private + */ + getLayersFromStyle: function getLayersFromStyle(styleObj) { + var layers = []; + var properties = this.properties; + var propNames = properties.pluck('property'); + properties.each(function (propModel) { + var style = styleObj[propModel.get('property')]; + var values = style ? style.split(', ') : []; + values.forEach(function (value, i) { + value = propModel.parseValue(value.trim()).value; + var layer = layers[i]; + + var propertyObj = _objectSpread({}, propModel.attributes, {}, { + value: value + }); + + if (layer) { + layer.properties.push(propertyObj); + } else { + layers[i] = { + properties: [propertyObj] + }; + } + }); + }); // Now whit all layers in, will check missing properties + + layers.forEach(function (layer) { + var layerProprs = layer.properties.map(function (prop) { + return prop.property; + }); + properties.each(function (propModel) { + var propertyName = propModel.get('property'); + + if (layerProprs.indexOf(propertyName) < 0) { + layer.properties.push(_objectSpread({}, propModel.attributes)); + } + }); + }); + return layers; }, + active: function active(index) { + this.each(function (layer) { + return layer.set('active', 0); + }); + var layer = this.at(index); + layer && layer.set('active', 1); + }, + getFullValue: function getFullValue() { + var result = []; + this.each(function (layer) { + return result.push(layer.getFullValue()); + }); + return result.join(this.getSeparator()); + }, + getPropertyValues: function getPropertyValues(property) { + var result = []; + this.each(function (layer) { + var value = layer.getPropertyValue(property); + value && result.push(value); + }); + return result.join(', '); + } +})); + +/***/ }), + +/***/ "./src/style_manager/model/Properties.js": +/*!***********************************************!*\ + !*** ./src/style_manager/model/Properties.js ***! + \***********************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var domain_abstract_model_TypeableCollection__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! domain_abstract/model/TypeableCollection */ "./src/domain_abstract/model/TypeableCollection.js"); +/* harmony import */ var _Property__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./Property */ "./src/style_manager/model/Property.js"); +/* harmony import */ var _PropertyStack__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./PropertyStack */ "./src/style_manager/model/PropertyStack.js"); +/* harmony import */ var _view_PropertyStackView__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./../view/PropertyStackView */ "./src/style_manager/view/PropertyStackView.js"); +/* harmony import */ var _PropertyComposite__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./PropertyComposite */ "./src/style_manager/model/PropertyComposite.js"); +/* harmony import */ var _view_PropertyCompositeView__WEBPACK_IMPORTED_MODULE_7__ = __webpack_require__(/*! ./../view/PropertyCompositeView */ "./src/style_manager/view/PropertyCompositeView.js"); +/* harmony import */ var _view_PropertyFileView__WEBPACK_IMPORTED_MODULE_8__ = __webpack_require__(/*! ./../view/PropertyFileView */ "./src/style_manager/view/PropertyFileView.js"); +/* harmony import */ var _view_PropertyColorView__WEBPACK_IMPORTED_MODULE_9__ = __webpack_require__(/*! ./../view/PropertyColorView */ "./src/style_manager/view/PropertyColorView.js"); +/* harmony import */ var _PropertySelect__WEBPACK_IMPORTED_MODULE_10__ = __webpack_require__(/*! ./PropertySelect */ "./src/style_manager/model/PropertySelect.js"); +/* harmony import */ var _view_PropertySelectView__WEBPACK_IMPORTED_MODULE_11__ = __webpack_require__(/*! ./../view/PropertySelectView */ "./src/style_manager/view/PropertySelectView.js"); +/* harmony import */ var _PropertyRadio__WEBPACK_IMPORTED_MODULE_12__ = __webpack_require__(/*! ./PropertyRadio */ "./src/style_manager/model/PropertyRadio.js"); +/* harmony import */ var _view_PropertyRadioView__WEBPACK_IMPORTED_MODULE_13__ = __webpack_require__(/*! ./../view/PropertyRadioView */ "./src/style_manager/view/PropertyRadioView.js"); +/* harmony import */ var _PropertySlider__WEBPACK_IMPORTED_MODULE_14__ = __webpack_require__(/*! ./PropertySlider */ "./src/style_manager/model/PropertySlider.js"); +/* harmony import */ var _view_PropertySliderView__WEBPACK_IMPORTED_MODULE_15__ = __webpack_require__(/*! ./../view/PropertySliderView */ "./src/style_manager/view/PropertySliderView.js"); +/* harmony import */ var _PropertyInteger__WEBPACK_IMPORTED_MODULE_16__ = __webpack_require__(/*! ./PropertyInteger */ "./src/style_manager/model/PropertyInteger.js"); +/* harmony import */ var _view_PropertyIntegerView__WEBPACK_IMPORTED_MODULE_17__ = __webpack_require__(/*! ./../view/PropertyIntegerView */ "./src/style_manager/view/PropertyIntegerView.js"); +/* harmony import */ var _view_PropertyView__WEBPACK_IMPORTED_MODULE_18__ = __webpack_require__(/*! ./../view/PropertyView */ "./src/style_manager/view/PropertyView.js"); + + +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } + +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } + + - /** - * Fired when target is updated - * @private - */ - targetUpdated: function targetUpdated() { - var em = this.target; - var model = em.getSelected(); - var um = em.get('UndoManager'); - var cc = em.get('CssComposer'); - var avoidInline = em.getConfig('avoidInlineStyle'); - if (!model) { - return; - } - var id = model.getId(); - var config = em.get('Config'); - var classes = model.get('classes'); - var pt = this.propTarget; - var state = !config.devicePreviewMode ? model.get('state') : ''; - var opts = { state: state }; - var stateStr = state ? ':' + state : null; - var view = model.view; - var media = em.getCurrentMedia(); - pt.helper = null; - if (view) { - pt.computed = window.getComputedStyle(view.el, state ? ':' + state : null); - } - var appendStateRule = function appendStateRule() { - var style = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; - var sm = em.get('SelectorManager'); - var helperClass = sm.add('hc-state'); - var helperRule = cc.get([helperClass]); - if (!helperRule) { - helperRule = cc.add([helperClass]); - } else { - // I will make it last again, otherwise it could be overridden - var rules = cc.getAll(); - rules.remove(helperRule); - rules.add(helperRule); - } - helperRule.set('important', 1); - helperRule.setStyle(style); - pt.helper = helperRule; - }; - // If true the model will be always a rule - if (avoidInline) { - var ruleId = cc.getIdRule(id, opts); - if (!ruleId) { - model = cc.setIdRule(id, {}, opts); - } else { - model = ruleId; - } - } - if (classes.length) { - var valid = classes.getStyleable(); - var iContainer = cc.get(valid, state, media); - if (!iContainer && valid.length) { - // I stop undo manager here as after adding the CSSRule (generally after - // selecting the component) and calling undo() it will remove the rule from - // the collection, therefore updating it in style manager will not affect it - // #268 - um.stop(); - iContainer = cc.add(valid, state, media); - iContainer.setStyle(model.getStyle()); - model.setStyle({}); - um.start(); - } - if (!iContainer) { - // In this case it's just a Component without any valid selector - pt.model = model; - pt.trigger('update'); - return; - } - // If the state is not empty, there should be a helper rule in play - // The helper rule will get the same style of the iContainer - state && appendStateRule(iContainer.getStyle()); - pt.model = iContainer; - pt.trigger('update'); - return; - } - if (state) { - var ruleState = cc.getIdRule(id, opts); - state && appendStateRule(ruleState && ruleState.getStyle()); +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_1___default.a.Collection.extend(domain_abstract_model_TypeableCollection__WEBPACK_IMPORTED_MODULE_2__["default"]).extend({ + types: [{ + id: 'stack', + model: _PropertyStack__WEBPACK_IMPORTED_MODULE_4__["default"], + view: _view_PropertyStackView__WEBPACK_IMPORTED_MODULE_5__["default"], + isType: function isType(value) { + if (value && value.type == 'stack') { + return value; + } } - - pt.model = model; - pt.trigger('update'); + }, { + id: 'composite', + model: _PropertyComposite__WEBPACK_IMPORTED_MODULE_6__["default"], + view: _view_PropertyCompositeView__WEBPACK_IMPORTED_MODULE_7__["default"], + isType: function isType(value) { + if (value && value.type == 'composite') { + return value; + } + } + }, { + id: 'file', + model: _Property__WEBPACK_IMPORTED_MODULE_3__["default"], + view: _view_PropertyFileView__WEBPACK_IMPORTED_MODULE_8__["default"], + isType: function isType(value) { + if (value && value.type == 'file') { + return value; + } + } + }, { + id: 'color', + model: _Property__WEBPACK_IMPORTED_MODULE_3__["default"], + view: _view_PropertyColorView__WEBPACK_IMPORTED_MODULE_9__["default"], + isType: function isType(value) { + if (value && value.type == 'color') { + return value; + } + } + }, { + id: 'select', + model: _PropertySelect__WEBPACK_IMPORTED_MODULE_10__["default"], + view: _view_PropertySelectView__WEBPACK_IMPORTED_MODULE_11__["default"], + isType: function isType(value) { + if (value && value.type == 'select') { + return value; + } + } + }, { + id: 'radio', + model: _PropertyRadio__WEBPACK_IMPORTED_MODULE_12__["default"], + view: _view_PropertyRadioView__WEBPACK_IMPORTED_MODULE_13__["default"], + isType: function isType(value) { + if (value && value.type == 'radio') { + return value; + } + } + }, { + id: 'slider', + model: _PropertySlider__WEBPACK_IMPORTED_MODULE_14__["default"], + view: _view_PropertySliderView__WEBPACK_IMPORTED_MODULE_15__["default"], + isType: function isType(value) { + if (value && value.type == 'slider') { + return value; + } + } + }, { + id: 'integer', + model: _PropertyInteger__WEBPACK_IMPORTED_MODULE_16__["default"], + view: _view_PropertyIntegerView__WEBPACK_IMPORTED_MODULE_17__["default"], + isType: function isType(value) { + if (value && value.type == 'integer') { + return value; + } + } + }, { + id: 'base', + model: _Property__WEBPACK_IMPORTED_MODULE_3__["default"], + view: _view_PropertyView__WEBPACK_IMPORTED_MODULE_18__["default"], + isType: function isType(value) { + value.type = 'base'; + return value; + } + }], + deepClone: function deepClone() { + var collection = this.clone(); + collection.reset(collection.map(function (model) { + var cloned = model.clone(); + cloned.typeView = model.typeView; + return cloned; + })); + return collection; }, - /** - * Add new object to collection - * @param {Object} model Model - * @param {Object} fragmentEl collection - * @return {Object} Object created - * @private - * */ - addToCollection: function addToCollection(model, fragmentEl) { - var fragment = fragmentEl || null; - var view = new SectorView({ - model: model, - id: this.pfx + model.get('name').replace(' ', '_').toLowerCase(), - name: model.get('name'), - properties: model.get('properties'), - target: this.target, - propTarget: this.propTarget, - config: this.config - }); - var rendered = view.render().el; + * Parse a value and return an array splitted by properties + * @param {string} value + * @return {Array} + * @return + */ + parseValue: function parseValue(value) { + var _this = this; - if (fragment) { - fragment.appendChild(rendered); - } else { - this.$el.append(rendered); - } + var properties = []; + var values = value.split(' '); + values.forEach(function (value, i) { + var property = _this.at(i); - return rendered; + if (!property) return; + properties.push(_objectSpread({}, property.attributes, {}, { + value: value + })); + }); + return properties; }, - render: function render() { - var fragment = document.createDocumentFragment(); - this.$el.empty(); - - this.collection.each(function (model) { - this.addToCollection(model, fragment); - }, this); - - this.$el.attr('id', this.pfx + 'sectors'); - this.$el.append(fragment); - return this; + getFullValue: function getFullValue() { + var result = ''; + this.each(function (model) { + return result += "".concat(model.getFullValue(), " "); + }); + return result.trim(); } -}); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(0))) +})); /***/ }), -/* 131 */ -/***/ (function(module, exports, __webpack_require__) { + +/***/ "./src/style_manager/model/Property.js": +/*!*********************************************!*\ + !*** ./src/style_manager/model/Property.js ***! + \*********************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; -/* WEBPACK VAR INJECTION */(function(_) { +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_2__); +/* harmony import */ var utils_mixins__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! utils/mixins */ "./src/utils/mixins.js"); -var Backbone = __webpack_require__(0); -var PropertiesView = __webpack_require__(13); -module.exports = Backbone.View.extend({ +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - template: _.template('\n
\n \n <%= label %>\n
'), +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - events: { - 'click [data-sector-title]': 'toggle' - }, - initialize: function initialize(o) { - this.config = o.config || {}; - this.pfx = this.config.stylePrefix || ''; - this.target = o.target || {}; - this.propTarget = o.propTarget || {}; - this.caretR = 'fa-caret-right'; - this.caretD = 'fa-caret-down'; - var model = this.model; - this.listenTo(model, 'change:open', this.updateOpen); - this.listenTo(model, 'updateVisibility', this.updateVisibility); - this.listenTo(model, 'destroy remove', this.remove); - }, - /** - * If all properties are hidden this will hide the sector - */ - updateVisibility: function updateVisibility() { - var show; - this.model.get('properties').each(function (prop) { - if (prop.get('visible')) { - show = 1; - } - }); - this.el.style.display = show ? 'block' : 'none'; +var Property = backbone__WEBPACK_IMPORTED_MODULE_1___default.a.Model.extend({ + defaults: { + name: '', + property: '', + type: '', + defaults: '', + info: '', + value: '', + icon: '', + functionName: '', + status: '', + visible: true, + fixedValues: ['initial', 'inherit'], + // If true, the property will be forced to be full width + full: 0, + // If true to the value will be added '!important' + important: 0, + // If true, will be hidden by default and will show up only for targets + // which require this property (via `stylable-require`) + // Use case: + // you can add all SVG CSS properties with toRequire as true + // and then require them on SVG Components + toRequire: 0, + // Specifies dependency on other properties of the selected object. + // Property is shown only when all conditions are matched. + // + // example: { display: ['flex', 'block'], position: ['absolute'] }; + // in this case the property is only shown when display is + // of value 'flex' or 'block' AND position is 'absolute' + requires: null, + // Specifies dependency on properties of the parent of the selected object. + // Property is shown only when all conditions are matched. + requiresParent: null }, - - - /** - * Update visibility - */ - updateOpen: function updateOpen() { - if (this.model.get('open')) this.show();else this.hide(); + initialize: function initialize() { + var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + var id = this.get('id') || ''; + var name = this.get('name') || ''; + !this.get('property') && this.set('property', (name || id).replace(/ /g, '-')); + var prop = this.get('property'); + !this.get('id') && this.set('id', prop); + !name && this.set('name', Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["capitalize"])(prop).replace(/-/g, ' ')); + Property.callInit(this, props, opts); }, - + init: function init() {}, /** - * Show the content of the sector - * */ - show: function show() { - this.$el.addClass(this.pfx + "open"); - this.getPropertiesEl().style.display = ''; - this.$caret.removeClass(this.caretR).addClass(this.caretD); + * Clear the value + * @return {this} + */ + clearValue: function clearValue() { + var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + this.set({ + value: undefined + }, opts); + return this; }, - /** - * Hide the content of the sector - * */ - hide: function hide() { - this.$el.removeClass(this.pfx + "open"); - this.getPropertiesEl().style.display = 'none'; - this.$caret.removeClass(this.caretD).addClass(this.caretR); - }, - getPropertiesEl: function getPropertiesEl() { - return this.$el.find('.' + this.pfx + 'properties').get(0); - }, + * Update value + * @param {any} value + * @param {Boolen} [complete=true] Indicates if it's a final state + * @param {Object} [opts={}] Options + */ + setValue: function setValue(value) { + var complete = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1; + var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + var parsed = this.parseValue(value); + this.set(parsed, _objectSpread({}, opts, { + avoidStore: 1 + })); // It's important to set an empty value, otherwise the + // UndoManager won't see the change + if (complete) { + this.set('value', '', opts); + this.set(parsed, opts); + } + }, /** - * Toggle visibility - * */ - toggle: function toggle(e) { - var v = this.model.get('open') ? 0 : 1; - this.model.set('open', v); - }, - render: function render() { - this.$el.html(this.template({ - pfx: this.pfx, - label: this.model.get('name') + * Like `setValue` but, in addition, prevents the update of the input element + * as the changes should come from the input itself. + * This method is useful with the definition of custom properties + * @param {any} value + * @param {Boolen} [complete=true] Indicates if it's a final state + * @param {Object} [opts={}] Options + */ + setValueFromInput: function setValueFromInput(value, complete) { + var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + this.setValue(value, complete, _objectSpread({}, opts, { + fromInput: 1 })); - this.$caret = this.$el.find('#' + this.pfx + 'caret'); - this.renderProperties(); - this.$el.attr('class', this.pfx + 'sector no-select'); - this.updateOpen(); - return this; }, - renderProperties: function renderProperties() { - var objs = this.model.get('properties'); - if (objs) { - var view = new PropertiesView({ - collection: objs, - target: this.target, - propTarget: this.propTarget, - config: this.config - }); - this.$el.append(view.render().el); - } - } -}); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(1))) + /** + * Parse a raw value, generally fetched from the target, for this property + * @param {string} value Raw value string + * @return {Object} + * @example + * // example with an Input type + * prop.parseValue('translateX(10deg)'); + * // -> { value: 10, unit: 'deg', functionName: 'translateX' } + * + */ + parseValue: function parseValue(value) { + var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + var result = { + value: value + }; + var imp = '!important'; -/***/ }), -/* 132 */ -/***/ (function(module, exports, __webpack_require__) { + if (Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isString"])(value) && value.indexOf(imp) !== -1) { + result.value = value.replace(imp, '').trim(); + result.important = 1; + } -"use strict"; + if (!this.get('functionName') && !opts.complete) { + return result; + } + var args = []; + var valueStr = "".concat(result.value); + var start = valueStr.indexOf('(') + 1; + var end = valueStr.lastIndexOf(')'); + var functionName = valueStr.substring(0, start - 1); + if (functionName) result.functionName = functionName; + args.push(start); // Will try even if the last closing parentheses is not found -/** - * * [add](#add) - * * [get](#get) - * * [getAll](#getall) - * * [getAllVisible](#getallvisible) - * * [remove](#remove) - * * [getContainer](#getcontainer) - * * [getAssetsEl](#getassetsel) - * * [addType](#addtype) - * * [getType](#gettype) - * * [getTypes](#gettypes) - * * [store](#store) - * * [load](#load) - * - * Before using this methods you should get first the module from the editor instance, in this way: - * - * ```js - * var assetManager = editor.AssetManager; - * ``` - * - * @module AssetManager - * @param {Object} config Configurations - * @param {Array} [config.assets=[]] Default assets - * @param {String} [config.uploadText='Drop files here or click to upload'] Upload text - * @param {String} [config.addBtnText='Add image'] Text for the add button - * @param {String} [config.upload=''] Where to send upload data. Expects as return a JSON with asset/s object - * as: {data: [{src:'...'}, {src:'...'}]} - * @return {this} - * @example - * ... - * { - * assets: [ - * {src:'path/to/image.png'}, - * ... - * ], - * upload: 'http://dropbox/path', // Set to false to disable it - * uploadText: 'Drop files here or click to upload', - * } - */ + if (end >= 0) { + args.push(end); + } -module.exports = function () { - var c = {}; - var defaults = __webpack_require__(133); - var Assets = __webpack_require__(134); - var AssetsView = __webpack_require__(137); - var FileUpload = __webpack_require__(45); - var assets = void 0, - am = void 0, - fu = void 0; + result.value = String.prototype.substring.apply(valueStr, args); - return { + if (opts.numeric) { + var num = parseFloat(result.value); + result.unit = result.value.replace(num, ''); + result.value = num; + } - /** - * Name of the module - * @type {String} - * @private - */ - name: 'AssetManager', + return result; + }, - /** - * Mandatory for the storage manager - * @type {String} - * @private - */ - storageKey: 'assets', + /** + * Get the default value + * @return {string} + * @private + */ + getDefaultValue: function getDefaultValue() { + return this.get('defaults'); + }, - getConfig: function getConfig() { - return c; - }, + /** + * Get a complete value of the property. + * This probably will replace the getValue when all + * properties models will be splitted + * @param {string} val Custom value to replace the one on the model + * @return {string} + * @private + */ + getFullValue: function getFullValue(val) { + var fn = this.get('functionName'); + var value = Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isUndefined"])(val) ? this.get('value') : val; + var hasValue = !Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isUndefined"])(value); + if (fn && hasValue) { + value = "".concat(fn, "(").concat(value, ")"); + } - /** - * Initialize module - * @param {Object} config Configurations - * @private - */ - init: function init(config) { - var _this = this; + if (hasValue && this.get('important')) { + value = "".concat(value, " !important"); + } - c = config || {}; + return value || ''; + } +}, { + callParentInit: function callParentInit(property, ctx, props) { + var opts = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {}; + property.prototype.initialize.apply(ctx, [props, _objectSpread({}, opts, { + skipInit: 1 + })]); + }, + callInit: function callInit(context, props) { + var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + !opts.skipInit && context.init(props, opts); + } +}); +/* harmony default export */ __webpack_exports__["default"] = (Property); - for (var name in defaults) { - if (!(name in c)) c[name] = defaults[name]; - } +/***/ }), - var ppfx = c.pStylePrefix; - var em = c.em; +/***/ "./src/style_manager/model/PropertyComposite.js": +/*!******************************************************!*\ + !*** ./src/style_manager/model/PropertyComposite.js ***! + \******************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - if (ppfx) { - c.stylePrefix = ppfx + c.stylePrefix; - } +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _Property__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Property */ "./src/style_manager/model/Property.js"); - // Global assets collection - assets = new Assets([]); - var obj = { - // Collection visible in asset manager - collection: new Assets([]), - globalCollection: assets, - config: c - }; - fu = new FileUpload(obj); - obj.fu = fu; - am = new AssetsView(obj); - // Setup the sync between the global and public collections - assets.listenTo(assets, 'add', function (model) { - _this.getAllVisible().add(model); - em && em.trigger('asset:add', model); - }); +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - assets.listenTo(assets, 'remove', function (model) { - _this.getAllVisible().remove(model); - em && em.trigger('asset:remove', model); - }); +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - return this; - }, +/* harmony default export */ __webpack_exports__["default"] = (_Property__WEBPACK_IMPORTED_MODULE_1__["default"].extend({ + defaults: _objectSpread({}, _Property__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.defaults, { + // 'background' is a good example where to make a difference + // between detached and not + // + // - NOT detached (default) + // background: url(..) no-repeat center ...; + // - Detached + // background-image: url(); + // background-repeat: repeat; + // ... + detached: 0, + // Array of sub properties + properties: [], + // Separator between properties + separator: ' ' + }), + initialize: function initialize() { + var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + _Property__WEBPACK_IMPORTED_MODULE_1__["default"].callParentInit(_Property__WEBPACK_IMPORTED_MODULE_1__["default"], this, props, opts); + var properties = this.get('properties') || []; - /** - * Add new asset/s to the collection. URLs are supposed to be unique - * @param {string|Object|Array|Array} asset URL strings or an objects representing the resource. - * @param {Object} [opts] Options - * @return {Model} - * @example - * // In case of strings, would be interpreted as images - * assetManager.add('http://img.jpg'); - * assetManager.add(['http://img.jpg', './path/to/img.png']); - * - * // Using objects you could indicate the type and other meta informations - * assetManager.add({ - * src: 'http://img.jpg', - * //type: 'image', //image is default - * height: 300, - * width: 200, - * }); - * assetManager.add([{ - * src: 'http://img.jpg', - * },{ - * src: './path/to/img.png', - * }]); - */ - add: function add(asset) { - var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + var Properties = __webpack_require__(/*! ./Properties */ "./src/style_manager/model/Properties.js").default; + this.set('properties', new Properties(properties)); + this.listenTo(this, 'change:value', this.updateValues); + _Property__WEBPACK_IMPORTED_MODULE_1__["default"].callInit(this, props, opts); + }, - // Put the model at the beginning - if (typeof opts.at == 'undefined') { - opts.at = 0; - } + /** + * Clear the value + * @return {this} + */ + clearValue: function clearValue() { + var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + this.get('properties').each(function (property) { + return property.clearValue(); + }); + return _Property__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.clearValue.apply(this, arguments); + }, - return assets.add(asset, opts); - }, + /** + * Update property values + */ + updateValues: function updateValues() { + var values = this.getFullValue().split(this.getSplitSeparator()); + this.get('properties').each(function (property, i) { + var len = values.length; // Try to get value from a shorthand: + // 11px -> 11px 11px 11px 11xp + // 11px 22px -> 11px 22px 11px 22xp + var value = values[i] || values[i % len + (len != 1 && len % 2 ? 1 : 0)]; // There some issue with UndoManager + //property.setValue(value, 0, {fromParent: 1}); + }); + }, - /** - * Returns the asset by URL - * @param {string} src URL of the asset - * @return {Object} Object representing the asset - * @example - * var asset = assetManager.get('http://img.jpg'); - */ - get: function get(src) { - return assets.where({ src: src })[0]; - }, + /** + * Split by sperator but avoid it inside parenthesis + * @return {RegExp} + */ + getSplitSeparator: function getSplitSeparator() { + return new RegExp("".concat(this.get('separator'), "(?![^\\(]*\\))")); + }, + /** + * Returns default value + * @param {Boolean} defaultProps Force to get defaults from properties + * @return {string} + */ + getDefaultValue: function getDefaultValue(defaultProps) { + var value = this.get('defaults'); - /** - * Return the global collection, containing all the assets - * @return {Collection} - */ - getAll: function getAll() { - return assets; - }, + if (value && !defaultProps) { + return value; + } + value = ''; + var properties = this.get('properties'); + properties.each(function (prop, index) { + return value += "".concat(prop.getDefaultValue(), " "); + }); + return value.trim(); + }, + getFullValue: function getFullValue() { + if (this.get('detached')) { + return ''; + } - /** - * Return the visible collection, which containes assets actually rendered - * @return {Collection} - */ - getAllVisible: function getAllVisible() { - return am.collection; - }, + return this.get('properties').getFullValue(); + }, + /** + * Get property at some index + * @param {Number} index + * @return {Object} + */ + getPropertyAt: function getPropertyAt(index) { + return this.get('properties').at(index); + } +})); - /** - * Remove the asset by its URL - * @param {string} src URL of the asset - * @return {this} - * @example - * assetManager.remove('http://img.jpg'); - */ - remove: function remove(src) { - var asset = this.get(src); - this.getAll().remove(asset); - return this; - }, +/***/ }), +/***/ "./src/style_manager/model/PropertyFactory.js": +/*!****************************************************!*\ + !*** ./src/style_manager/model/PropertyFactory.js ***! + \****************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony default export */ __webpack_exports__["default"] = (function () { + return { /** - * Store assets data to the selected storage - * @param {Boolean} noStore If true, won't store - * @return {Object} Data to store - * @example - * var assets = assetManager.store(); + * Build props object by their name + * @param {Array|string} props Array of properties name + * @return {Array} */ - store: function store(noStore) { - var obj = {}; - var assets = JSON.stringify(this.getAll().toJSON()); - obj[this.storageKey] = assets; - if (!noStore && c.stm) c.stm.store(obj); - return obj; - }, + build: function build(props) { + var objs = []; + var dftFixedValues = ['initial', 'inherit']; + if (typeof props === 'string') props = [props]; + for (var i = 0, len = props.length; i < len; i++) { + var obj = {}; + var prop = props[i]; + obj.property = prop; // Property - /** - * Load data from the passed object. - * The fetched data will be added to the collection. - * @param {Object} data Object of data to load - * @return {Object} Loaded assets - * @example - * var assets = assetManager.load({ - * assets: [...] - * }) - * - */ - load: function load() { - var data = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + switch (prop) { + case 'border-radius-c': + obj.property = 'border-radius'; + break; + } // Fixed values - var name = this.storageKey; - var assets = data[name] || []; - if (typeof assets == 'string') { - try { - assets = JSON.parse(data[name]); - } catch (err) {} - } + switch (prop) { + case 'top': + case 'right': + case 'bottom': + case 'left': + case 'margin-top': + case 'margin-right': + case 'margin-bottom': + case 'margin-left': + case 'padding-top': + case 'padding-right': + case 'padding-bottom': + case 'padding-left': + case 'width': + case 'max-width': + case 'min-width': + case 'height': + case 'max-height': + case 'min-height': + case 'flex-basis': + obj.fixedValues = ['initial', 'inherit', 'auto']; + break; - if (assets && assets.length) { - this.getAll().reset(assets); - } + case 'font-size': + obj.fixedValues = ['medium', 'xx-small', 'x-small', 'small', 'large', 'x-large', 'xx-large', 'smaller', 'larger', 'length', 'initial', 'inherit']; + break; - return assets; - }, + case 'letter-spacing': + case 'line-height': + obj.fixedValues = ['normal', 'initial', 'inherit']; + break; + } // Type - /** - * Return the Asset Manager Container - * @return {HTMLElement} - */ - getContainer: function getContainer() { - return am.el; - }, + switch (prop) { + case 'float': + case 'position': + case 'text-align': + obj.type = 'radio'; + break; + case 'display': + case 'flex-direction': + case 'flex-wrap': + case 'justify-content': + case 'align-items': + case 'align-content': + case 'align-self': + case 'font-family': + case 'font-weight': + case 'border-style': + case 'box-shadow-type': + case 'background-repeat': + case 'background-position': + case 'background-attachment': + case 'background-size': + case 'transition-property': + case 'transition-timing-function': + case 'cursor': + case 'overflow': + case 'overflow-x': + case 'overflow-y': + obj.type = 'select'; + break; - /** - * Get assets element container - * @return {HTMLElement} - */ - getAssetsEl: function getAssetsEl() { - return am.el.querySelector('[data-el=assets]'); - }, + case 'top': + case 'right': + case 'bottom': + case 'left': + case 'margin-top': + case 'margin-right': + case 'margin-bottom': + case 'margin-left': + case 'padding-top': + case 'padding-right': + case 'padding-bottom': + case 'padding-left': + case 'min-height': + case 'min-width': + case 'max-height': + case 'max-width': + case 'width': + case 'height': + case 'font-size': + case 'letter-spacing': + case 'line-height': + case 'text-shadow-h': + case 'text-shadow-v': + case 'text-shadow-blur': + case 'border-radius-c': + case 'border-top-left-radius': + case 'border-top-right-radius': + case 'border-bottom-left-radius': + case 'border-bottom-right-radius': + case 'border-width': + case 'box-shadow-h': + case 'box-shadow-v': + case 'box-shadow-blur': + case 'box-shadow-spread': + case 'transition-duration': + case 'perspective': + case 'transform-rotate-x': + case 'transform-rotate-y': + case 'transform-rotate-z': + case 'transform-scale-x': + case 'transform-scale-y': + case 'transform-scale-z': + case 'order': + case 'flex-grow': + case 'flex-shrink': + case 'flex-basis': + obj.type = 'integer'; + break; + case 'margin': + case 'padding': + case 'border-radius': + case 'border': + case 'transform': + obj.type = 'composite'; + break; - /** - * Render assets - * @param {array} assets Assets to render, without the argument will render - * all global assets - * @return {HTMLElement} - * @example - * // Render all assets - * assetManager.render(); - * - * // Render some of the assets - * const assets = assetManager.getAll(); - * assetManager.render(assets.filter( - * asset => asset.get('category') == 'cats' - * )); - */ - render: function render(assets) { - var toRender = assets || this.getAll().models; + case 'color': + case 'text-shadow-color': + case 'background-color': + case 'border-color': + case 'box-shadow-color': + obj.type = 'color'; + break; - if (!am.rendered) { - am.render(); - } + case 'text-shadow': + case 'box-shadow': + case 'background': + case 'transition': + obj.type = 'stack'; + break; - am.collection.reset(toRender); - return this.getContainer(); - }, + case 'background-image': + obj.type = 'file'; + break; + } // Defaults - /** - * Add new type - * @param {string} id Type ID - * @param {Object} definition Definition of the type. Each definition contains - * `model` (business logic), `view` (presentation logic) - * and `isType` function which recognize the type of the - * passed entity - * addType('my-type', { - * model: {}, - * view: {}, - * isType: (value) => {}, - * }) - */ - addType: function addType(id, definition) { - this.getAll().addType(id, definition); - }, + switch (prop) { + case 'float': + case 'background-color': + case 'background-image': + case 'text-shadow': + obj.defaults = 'none'; + break; + case 'display': + obj.defaults = 'block'; + break; - /** - * Get type - * @param {string} id Type ID - * @return {Object} Type definition - */ - getType: function getType(id) { - return this.getAll().getType(id); - }, + case 'flex-direction': + obj.defaults = 'row'; + break; + case 'flex-wrap': + obj.defaults = 'nowrap'; + break; - /** - * Get types - * @return {Array} - */ - getTypes: function getTypes() { - return this.getAll().getTypes(); - }, + case 'justify-content': + obj.defaults = 'flex-start'; + break; + case 'align-items': + obj.defaults = 'stretch'; + break; - //------- + case 'align-content': + obj.defaults = 'stretch'; + break; - AssetsView: function AssetsView() { - return am; - }, - FileUploader: function FileUploader() { - return fu; - }, - onLoad: function onLoad() { - this.getAll().reset(c.assets); - }, - postRender: function postRender(editorView) { - c.dropzone && fu.initDropzone(editorView); - }, + case 'align-self': + obj.defaults = 'auto'; + break; + case 'position': + obj.defaults = 'static'; + break; - /** - * Set new target - * @param {Object} m Model - * @private - * */ - setTarget: function setTarget(m) { - am.collection.target = m; - }, + case 'margin-top': + case 'margin-right': + case 'margin-bottom': + case 'margin-left': + case 'padding-top': + case 'padding-right': + case 'padding-bottom': + case 'padding-left': + case 'text-shadow-h': + case 'text-shadow-v': + case 'text-shadow-blur': + case 'border-radius-c': + case 'box-shadow-h': + case 'box-shadow-v': + case 'box-shadow-spread': + case 'perspective': + case 'transform-rotate-x': + case 'transform-rotate-y': + case 'transform-rotate-z': + case 'order': + case 'flex-grow': + obj.defaults = 0; + break; + case 'border-top-left-radius': + case 'border-top-right-radius': + case 'border-bottom-left-radius': + case 'border-bottom-right-radius': + obj.defaults = '0px'; + break; - /** - * Set callback after asset was selected - * @param {Object} f Callback function - * @private - * */ - onSelect: function onSelect(f) { - am.collection.onSelect = f; - }, + case 'transform-scale-x': + case 'transform-scale-y': + case 'transform-scale-z': + case 'flex-shrink': + obj.defaults = 1; + break; + case 'box-shadow-blur': + obj.defaults = '5px'; + break; - /** - * Set callback to fire when the asset is clicked - * @param {function} func - * @private - */ - onClick: function onClick(func) { - c.onClick = func; - }, + case 'top': + case 'right': + case 'bottom': + case 'left': + case 'min-height': + case 'min-width': + case 'max-height': + case 'max-width': + case 'width': + case 'height': + case 'background-size': + case 'cursor': + case 'flex-basis': + obj.defaults = 'auto'; + break; + case 'font-family': + obj.defaults = 'Arial, Helvetica, sans-serif'; + break; - /** - * Set callback to fire when the asset is double clicked - * @param {function} func - * @private - */ - onDblClick: function onDblClick(func) { - c.onDblClick = func; - } - }; -}; + case 'font-size': + case 'border-width': + obj.defaults = 'medium'; + break; -/***/ }), -/* 133 */ -/***/ (function(module, exports, __webpack_require__) { + case 'font-weight': + obj.defaults = '400'; + break; -"use strict"; + case 'letter-spacing': + case 'line-height': + obj.defaults = 'normal'; + break; + case 'color': + case 'text-shadow-color': + case 'border-color': + case 'box-shadow-color': + obj.defaults = 'black'; + break; -module.exports = { - // Default assets - // eg. [ - // 'https://...image1.png', - // 'https://...image2.png', - // {type: 'image', src: 'https://...image3.png', someOtherCustomProp: 1}, - // .. - // ] - assets: [], + case 'text-align': + obj.defaults = 'left'; + break; - // Content to add where there is no assets to show - // eg. 'No assets here, drag to upload' - noAssets: '', + case 'border-style': + obj.defaults = 'solid'; + break; - // Style prefix - stylePrefix: 'am-', + case 'box-shadow-type': + obj.defaults = ''; + break; - // Upload endpoint, set `false` to disable upload - // upload: 'https://endpoint/upload/assets', - // upload: false, - upload: 0, + case 'background-repeat': + obj.defaults = 'repeat'; + break; - // The name used in POST to pass uploaded files - uploadName: 'files', + case 'background-position': + obj.defaults = 'left top'; + break; - // Custom headers to pass with the upload request - headers: {}, + case 'background-attachment': + obj.defaults = 'scroll'; + break; - // Custom parameters to pass with the upload request, eg. csrf token - params: {}, + case 'transition-property': + obj.defaults = 'width'; + break; - // If true, tries to add automatically uploaded assets. - // To make it work the server should respond with a JSON containing assets - // in a data key, eg: - // { - // data: [ - // 'https://.../image.png', - // ... - // {src: 'https://.../image2.png'}, - // ... - // ] - // } - autoAdd: 1, + case 'transition-duration': + obj.defaults = '2'; + break; - // Text on upload input - uploadText: 'Drop files here or click to upload', + case 'transition-timing-function': + obj.defaults = 'ease'; + break; - // Label for the add button - addBtnText: 'Add image', + case 'overflow': + case 'overflow-x': + case 'overflow-y': + obj.defaults = 'visible'; + break; + } + /* + * Add styleable dependency on other properties. Allows properties to be + * dynamically hidden or shown based on values of other properties. + * + * Property will be styleable if all of the properties (keys) in the + * requires object have any of the values specified in the array. + */ - // Custom uploadFile function - // @example - // uploadFile: (e) => { - // var files = e.dataTransfer ? e.dataTransfer.files : e.target.files; - // // ...send somewhere - // } - uploadFile: '', - // Handle the image url submit from the built-in 'Add image' form - // @example - // handleAdd: (textFromInput) => { - // // some check... - // editor.AssetManager.add(textFromInput); - // } - handleAdd: '', + switch (prop) { + case 'flex-direction': + case 'flex-wrap': + case 'justify-content': + case 'align-items': + case 'align-content': + obj.requires = { + display: ['flex'] + }; + break; - // Enable an upload dropzone on the entire editor (not document) when dragging - // files over it - // If active the dropzone disable/hide the upload dropzone in asset modal, - // otherwise you will get double drops (#507) - dropzone: 0, + case 'order': + case 'flex-basis': + case 'flex-grow': + case 'flex-shrink': + case 'align-self': + obj.requiresParent = { + display: ['flex'] + }; + break; + } // Units - // Open the asset manager once files are been dropped via the dropzone - openAssetsOnDrop: 1, - // Any dropzone content to append inside dropzone element - dropzoneContent: '', + switch (prop) { + case 'top': + case 'bottom': + case 'margin-top': + case 'margin-bottom': + case 'padding-top': + case 'padding-bottom': + case 'min-height': + case 'max-height': + case 'height': + obj.units = ['px', '%', 'vh']; + break; - // Default title for the asset manager modal - modalTitle: 'Select Image', + case 'right': + case 'left': + case 'margin-right': + case 'margin-left': + case 'padding-right': + case 'padding-left': + case 'min-width': + case 'max-width': + case 'width': + obj.units = ['px', '%', 'vw']; + break; - //Default placeholder for input - inputPlaceholder: 'http://path/to/the/image.jpg' -}; + case 'flex-basis': + obj.units = ['px', '%', 'vw', 'vh']; + break; -/***/ }), -/* 134 */ -/***/ (function(module, exports, __webpack_require__) { + case 'text-shadow-v': + case 'text-shadow-h': + case 'text-shadow-blur': + case 'border-radius-c': + case 'border-top-left-radius': + case 'border-top-right-radius': + case 'border-bottom-left-radius': + case 'border-bottom-right-radius': + case 'box-shadow-h': + case 'box-shadow-v': + obj.units = ['px', '%']; + break; -"use strict"; + case 'font-size': + case 'letter-spacing': + case 'line-height': + obj.units = ['px', 'em', 'rem', '%']; + break; + + case 'border-width': + obj.units = ['px', 'em']; + break; + case 'box-shadow-blur': + case 'box-shadow-spread': + case 'perspective': + obj.units = ['px']; + break; -var _TypeableCollection = __webpack_require__(32); + case 'transition-duration': + obj.units = ['s']; + break; -var _TypeableCollection2 = _interopRequireDefault(_TypeableCollection); + case 'transform-rotate-x': + case 'transform-rotate-y': + case 'transform-rotate-z': + obj.units = ['deg']; + break; + } // Min/Max -function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } -module.exports = __webpack_require__(0).Collection.extend(_TypeableCollection2.default).extend({ - types: [{ - id: 'image', - model: __webpack_require__(135), - view: __webpack_require__(43), - isType: function isType(value) { - if (typeof value == 'string') { - return { - type: 'image', - src: value - }; - } - return value; - } - }] -}); + switch (prop) { + case 'padding-top': + case 'padding-right': + case 'padding-bottom': + case 'padding-left': + case 'min-height': + case 'min-width': + case 'max-height': + case 'max-width': + case 'width': + case 'height': + case 'font-size': + case 'text-shadow-blur': + case 'border-radius-c': + case 'border-top-left-radius': + case 'border-top-right-radius': + case 'border-bottom-left-radius': + case 'border-bottom-right-radius': + case 'border-width': + case 'box-shadow-blur': + case 'transition-duration': + case 'perspective': + case 'flex-basis': + obj.min = 0; + break; + } // Preview -/***/ }), -/* 135 */ -/***/ (function(module, exports, __webpack_require__) { -"use strict"; + switch (prop) { + case 'text-shadow': + case 'box-shadow': + case 'background': + obj.preview = true; + break; + } // Detached -var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; + switch (prop) { + case 'background': + obj.detached = true; + break; + } // Functions -var Asset = __webpack_require__(136); -module.exports = Asset.extend({ + switch (prop) { + case 'transform-rotate-x': + obj.functionName = 'rotateX'; + break; - defaults: _extends({}, Asset.prototype.defaults, { - type: 'image', - unitDim: 'px', - height: 0, - width: 0 - }) + case 'transform-rotate-y': + obj.functionName = 'rotateY'; + break; -}); + case 'transform-rotate-z': + obj.functionName = 'rotateZ'; + break; -/***/ }), -/* 136 */ -/***/ (function(module, exports, __webpack_require__) { + case 'transform-scale-x': + obj.functionName = 'scaleX'; + break; -"use strict"; + case 'transform-scale-y': + obj.functionName = 'scaleY'; + break; + case 'transform-scale-z': + obj.functionName = 'scaleZ'; + break; -module.exports = __webpack_require__(0).Model.extend({ + case 'background-image': + obj.functionName = 'url'; + break; + } // Options - idAttribute: 'src', - defaults: { - type: '', - src: '' - }, + switch (prop) { + case 'float': + obj.list = [{ + value: 'none' + }, { + value: 'left' + }, { + value: 'right' + }]; + break; - /** - * Get filename of the asset - * @return {string} - * @private - * */ - getFilename: function getFilename() { - return this.get('src').split('/').pop(); - }, + case 'display': + obj.list = [{ + value: 'block' + }, { + value: 'inline' + }, { + value: 'inline-block' + }, { + value: 'flex' + }, { + value: 'none' + }]; + break; + case 'flex-direction': + obj.list = [{ + value: 'row' + }, { + value: 'row-reverse' + }, { + value: 'column' + }, { + value: 'column-reverse' + }]; + break; - /** - * Get extension of the asset - * @return {string} - * @private - * */ - getExtension: function getExtension() { - return this.getFilename().split('.').pop(); - } -}); + case 'flex-wrap': + obj.list = [{ + value: 'nowrap' + }, { + value: 'wrap' + }, { + value: 'wrap-reverse' + }]; + break; -/***/ }), -/* 137 */ -/***/ (function(module, exports, __webpack_require__) { + case 'justify-content': + obj.list = [{ + value: 'flex-start' + }, { + value: 'flex-end' + }, { + value: 'center' + }, { + value: 'space-between' + }, { + value: 'space-around' + }, { + value: 'space-evenly' + }]; + break; -"use strict"; -/* WEBPACK VAR INJECTION */(function(Backbone) { + case 'align-items': + obj.list = [{ + value: 'flex-start' + }, { + value: 'flex-end' + }, { + value: 'center' + }, { + value: 'baseline' + }, { + value: 'stretch' + }]; + break; -var AssetView = __webpack_require__(44); -var AssetImageView = __webpack_require__(43); -var FileUploader = __webpack_require__(45); + case 'align-content': + obj.list = [{ + value: 'flex-start' + }, { + value: 'flex-end' + }, { + value: 'center' + }, { + value: 'space-between' + }, { + value: 'space-around' + }, { + value: 'stretch' + }]; + break; -module.exports = Backbone.View.extend({ + case 'align-self': + obj.list = [{ + value: 'auto' + }, { + value: 'flex-start' + }, { + value: 'flex-end' + }, { + value: 'center' + }, { + value: 'baseline' + }, { + value: 'stretch' + }]; + break; - events: { - submit: 'handleSubmit' - }, + case 'position': + obj.list = [{ + value: 'static' + }, { + value: 'relative' + }, { + value: 'absolute' + }, { + value: 'fixed' + }]; + break; - template: function template(view) { - var pfx = view.pfx; - var ppfx = view.ppfx; - return '\n
\n
\n
\n
\n \n
\n \n
\n
\n \n
\n
\n
\n
\n '; - }, - initialize: function initialize(o) { - this.options = o; - this.config = o.config; - this.pfx = this.config.stylePrefix || ''; - this.ppfx = this.config.pStylePrefix || ''; - var coll = this.collection; - this.listenTo(coll, 'reset', this.renderAssets); - this.listenTo(coll, 'add', this.addToAsset); - this.listenTo(coll, 'remove', this.removedAsset); - this.listenTo(coll, 'deselectAll', this.deselectAll); - }, + case 'font-family': + var ss = ', sans-serif'; + var fonts = ['Arial, Helvetica' + ss, 'Arial Black, Gadget' + ss, 'Brush Script MT' + ss, 'Comic Sans MS, cursive' + ss, 'Courier New, Courier, monospace', 'Georgia, serif', 'Helvetica, serif', 'Impact, Charcoal' + ss, 'Lucida Sans Unicode, Lucida Grande' + ss, 'Tahoma, Geneva' + ss, 'Times New Roman, Times, serif', 'Trebuchet MS, Helvetica' + ss, 'Verdana, Geneva' + ss]; + obj.list = []; + for (var j = 0, l = fonts.length; j < l; j++) { + var font = {}; + font.value = fonts[j]; + font.name = fonts[j].split(',')[0]; + obj.list.push(font); + } - /** - * Add new asset to the collection via string - * @param {Event} e Event object - * @return {this} - * @private - */ - handleSubmit: function handleSubmit(e) { - e.preventDefault(); - var input = this.getAddInput(); - var url = input.value.trim(); - var handleAdd = this.config.handleAdd; + break; - if (!url) { - return; - } + case 'font-weight': + obj.list = [{ + value: '100', + name: 'Thin' + }, { + value: '200', + name: 'Extra-Light' + }, { + value: '300', + name: 'Light' + }, { + value: '400', + name: 'Normal' + }, { + value: '500', + name: 'Medium' + }, { + value: '600', + name: 'Semi-Bold' + }, { + value: '700', + name: 'Bold' + }, { + value: '800', + name: 'Extra-Bold' + }, { + value: '900', + name: 'Ultra-Bold' + }]; + break; - input.value = ''; - this.getAssetsEl().scrollTop = 0; + case 'text-align': + obj.list = [{ + value: 'left' + }, { + value: 'center' + }, { + value: 'right' + }, { + value: 'justify' + }]; + break; - if (handleAdd) { - handleAdd(url); - } else { - this.options.globalCollection.add(url, { at: 0 }); - } - }, + case 'border-style': + obj.list = [{ + value: 'none' + }, { + value: 'solid' + }, { + value: 'dotted' + }, { + value: 'dashed' + }, { + value: 'double' + }, { + value: 'groove' + }, { + value: 'ridge' + }, { + value: 'inset' + }, { + value: 'outset' + }]; + break; + case 'box-shadow-type': + obj.list = [{ + value: '', + name: 'Outside' + }, { + value: 'inset', + name: 'Inside' + }]; + break; - /** - * Returns assets element - * @return {HTMLElement} - * @private - */ - getAssetsEl: function getAssetsEl() { - //if(!this.assets) // Not able to cache as after the rerender it losses the ref - return this.el.querySelector('.' + this.pfx + 'assets'); - }, + case 'background-repeat': + obj.list = [{ + value: 'repeat' + }, { + value: 'repeat-x' + }, { + value: 'repeat-y' + }, { + value: 'no-repeat' + }]; + break; + case 'background-position': + obj.list = [{ + value: 'left top' + }, { + value: 'left center' + }, { + value: 'left bottom' + }, { + value: 'right top' + }, { + value: 'right center' + }, { + value: 'right bottom' + }, { + value: 'center top' + }, { + value: 'center center' + }, { + value: 'center bottom' + }]; + break; - /** - * Returns input url element - * @return {HTMLElement} - * @private - */ - getAddInput: function getAddInput() { - if (!this.inputUrl || !this.inputUrl.value) this.inputUrl = this.el.querySelector('.' + this.pfx + 'add-asset input'); - return this.inputUrl; - }, + case 'background-attachment': + obj.list = [{ + value: 'scroll' + }, { + value: 'fixed' + }, { + value: 'local' + }]; + break; + case 'background-size': + obj.list = [{ + value: 'auto' + }, { + value: 'cover' + }, { + value: 'contain' + }]; + break; - /** - * Triggered when an asset is removed - * @param {Asset} model Removed asset - * @private - */ - removedAsset: function removedAsset(model) { - if (!this.collection.length) { - this.toggleNoAssets(); - } - }, + case 'transition-property': + obj.list = [{ + value: 'all' + }, { + value: 'width' + }, { + value: 'height' + }, { + value: 'background-color' + }, { + value: 'transform' + }, { + value: 'box-shadow' + }, { + value: 'opacity' + }]; + break; + case 'transition-timing-function': + obj.list = [{ + value: 'linear' + }, { + value: 'ease' + }, { + value: 'ease-in' + }, { + value: 'ease-out' + }, { + value: 'ease-in-out' + }]; + break; - /** - * Add asset to collection - * @private - * */ - addToAsset: function addToAsset(model) { - if (this.collection.length == 1) { - this.toggleNoAssets(1); - } - this.addAsset(model); - }, + case 'cursor': + obj.list = [{ + value: 'auto' + }, { + value: 'pointer' + }, { + value: 'copy' + }, { + value: 'crosshair' + }, { + value: 'grab' + }, { + value: 'grabbing' + }, { + value: 'help' + }, { + value: 'move' + }, { + value: 'text' + }]; + break; + case 'overflow': + case 'overflow-x': + case 'overflow-y': + obj.list = [{ + value: 'visible' + }, { + value: 'hidden' + }, { + value: 'scroll' + }, { + value: 'auto' + }]; + break; + } // Properties - /** - * Add new asset to collection - * @param Object Model - * @param Object Fragment collection - * @return Object Object created - * @private - * */ - addAsset: function addAsset(model) { - var fragmentEl = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null; - var fragment = fragmentEl; - var collection = this.collection; - var config = this.config; - var rendered = new model.typeView({ - model: model, - collection: collection, - config: config - }).render().el; + switch (prop) { + case 'margin': + obj.properties = this.build(['margin-top', 'margin-right', 'margin-bottom', 'margin-left']); + break; - if (fragment) { - fragment.appendChild(rendered); - } else { - var assetsEl = this.getAssetsEl(); - if (assetsEl) { - assetsEl.insertBefore(rendered, assetsEl.firstChild); - } - } + case 'padding': + obj.properties = this.build(['padding-top', 'padding-right', 'padding-bottom', 'padding-left']); + break; - return rendered; - }, + case 'text-shadow': + obj.properties = this.build(['text-shadow-h', 'text-shadow-v', 'text-shadow-blur', 'text-shadow-color']); + break; + case 'border': + obj.properties = this.build(['border-width', 'border-style', 'border-color']); + break; - /** - * Checks if to show noAssets - * @param {Boolean} hide - * @private - */ - toggleNoAssets: function toggleNoAssets(hide) { - var assetsEl = this.$el.find('.' + this.pfx + 'assets'); + case 'border-radius': + obj.properties = this.build(['border-top-left-radius', 'border-top-right-radius', 'border-bottom-right-radius', 'border-bottom-left-radius']); + break; - if (hide) { - assetsEl.empty(); - } else { - var noAssets = this.config.noAssets; - noAssets && assetsEl.append(noAssets); - } - }, + case 'box-shadow': + obj.properties = this.build(['box-shadow-h', 'box-shadow-v', 'box-shadow-blur', 'box-shadow-spread', 'box-shadow-color', 'box-shadow-type']); + break; + case 'background': + obj.properties = this.build(['background-image', 'background-repeat', 'background-position', 'background-attachment', 'background-size']); + break; - /** - * Deselect all assets - * @private - * */ - deselectAll: function deselectAll() { - var pfx = this.pfx; - this.$el.find('.' + pfx + 'highlight').removeClass(pfx + 'highlight'); - }, - renderAssets: function renderAssets() { - var _this = this; + case 'transition': + obj.properties = this.build(['transition-property', 'transition-duration', 'transition-timing-function']); + break; - var fragment = document.createDocumentFragment(); - var assets = this.$el.find('.' + this.pfx + 'assets'); - assets.empty(); - this.toggleNoAssets(this.collection.length); - this.collection.each(function (model) { - return _this.addAsset(model, fragment); - }); - assets.append(fragment); - }, - render: function render() { - var fuRendered = this.options.fu.render().el; - this.$el.empty(); - this.$el.append(fuRendered).append(this.template(this)); - this.el.className = this.ppfx + 'asset-manager'; - this.renderAssets(); - this.rendered = 1; - return this; - } + case 'transform': + obj.properties = this.build(['transform-rotate-x', 'transform-rotate-y', 'transform-rotate-z', 'transform-scale-x', 'transform-scale-y', 'transform-scale-z']); + break; + } + + objs.push(obj); + } + + return objs; + } + }; }); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(0))) /***/ }), -/* 138 */ -/***/ (function(module, exports, __webpack_require__) { -"use strict"; +/***/ "./src/style_manager/model/PropertyInteger.js": +/*!****************************************************!*\ + !*** ./src/style_manager/model/PropertyInteger.js ***! + \****************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var _Property__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./Property */ "./src/style_manager/model/Property.js"); +/* harmony import */ var domain_abstract_ui_InputNumber__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! domain_abstract/ui/InputNumber */ "./src/domain_abstract/ui/InputNumber.js"); -var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; -/** - * This module contains and manage CSS rules for the template inside the canvas - * Before using the methods you should get first the module from the editor instance, in this way: - * - * ```js - * var cssComposer = editor.CssComposer; - * ``` - * - * @module CssComposer - * @param {Object} config Configurations - * @param {string|Array} [config.rules=[]] CSS string or an array of rule objects - * @example - * ... - * CssComposer: { - * rules: '.myClass{ color: red}', - * } - */ +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } -module.exports = function () { - var em = void 0; - var c = {}, - defaults = __webpack_require__(139), - CssRule = __webpack_require__(46), - CssRules = __webpack_require__(140), - CssRulesView = __webpack_require__(141); - var Selectors = __webpack_require__(10); - var Selector = __webpack_require__(7); +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - var rules, rulesView; - return { - Selectors: Selectors, - /** - * Name of the module - * @type {String} - * @private - */ - name: 'CssComposer', +/* harmony default export */ __webpack_exports__["default"] = (_Property__WEBPACK_IMPORTED_MODULE_2__["default"].extend({ + defaults: _objectSpread({}, _Property__WEBPACK_IMPORTED_MODULE_2__["default"].prototype.defaults, { + // Array of units, eg. ['px', '%'] + units: [], + // Selected unit, eg. 'px' + unit: '', + // Integer value steps + step: 1, + // Minimum value + min: '', + // Maximum value + max: '' + }), + init: function init() { + var unit = this.get('unit'); + var units = this.get('units'); + this.input = new domain_abstract_ui_InputNumber__WEBPACK_IMPORTED_MODULE_3__["default"]({ + model: this + }); - /** - * Mandatory for the storage manager - * @type {String} - * @private - */ - storageKey: function storageKey() { - var keys = []; - var smc = c.stm && c.stm.getConfig() || {}; - if (smc.storeCss) keys.push('css'); - if (smc.storeStyles) keys.push('styles'); - return keys; - }, + if (units.length && !unit) { + this.set('unit', units[0]); + } + }, + clearValue: function clearValue() { + var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + this.set({ + value: undefined, + unit: undefined + }, opts); + return this; + }, + parseValue: function parseValue(val) { + var parsed = _Property__WEBPACK_IMPORTED_MODULE_2__["default"].prototype.parseValue.apply(this, arguments); + var _this$input$validateI = this.input.validateInputValue(parsed.value, { + deepCheck: 1 + }), + value = _this$input$validateI.value, + unit = _this$input$validateI.unit; - /** - * Initializes module. Automatically called with a new instance of the editor - * @param {Object} config Configurations - * @private - */ - init: function init(config) { - c = config || {}; - for (var name in defaults) { - if (!(name in c)) c[name] = defaults[name]; - } + parsed.value = value; + parsed.unit = unit; + return parsed; + }, + getFullValue: function getFullValue() { + var value = this.get('value'); + var unit = this.get('unit'); + value = !Object(underscore__WEBPACK_IMPORTED_MODULE_1__["isUndefined"])(value) ? value : ''; + unit = !Object(underscore__WEBPACK_IMPORTED_MODULE_1__["isUndefined"])(unit) && value ? unit : ''; + value = "".concat(value).concat(unit); + return _Property__WEBPACK_IMPORTED_MODULE_2__["default"].prototype.getFullValue.apply(this, [value]); + } +})); - var ppfx = c.pStylePrefix; - if (ppfx) c.stylePrefix = ppfx + c.stylePrefix; +/***/ }), - var elStyle = c.em && c.em.config.style || ''; - c.rules = elStyle || c.rules; +/***/ "./src/style_manager/model/PropertyRadio.js": +/*!**************************************************!*\ + !*** ./src/style_manager/model/PropertyRadio.js ***! + \**************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - c.sm = c.em; - em = c.em; - rules = new CssRules([], c); - rulesView = new CssRulesView({ - collection: rules, - config: c - }); - return this; - }, +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/toConsumableArray */ "./node_modules/@babel/runtime/helpers/toConsumableArray.js"); +/* harmony import */ var _babel_runtime_helpers_toConsumableArray__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_toConsumableArray__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var _Property__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./Property */ "./src/style_manager/model/Property.js"); - /** - * On load callback - * @private - */ - onLoad: function onLoad() { - rules.add(c.rules); - }, +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - /** - * Do stuff after load - * @param {Editor} em - * @private - */ - postLoad: function postLoad(em) { - var _this = this; +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_1___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - var ev = 'add remove'; - var rules = this.getAll(); - em.stopListening(rules, ev, this.handleChange); - em.listenTo(rules, ev, this.handleChange); - rules.each(function (rule) { - return _this.handleChange(rule); - }); - }, +/* harmony default export */ __webpack_exports__["default"] = (_Property__WEBPACK_IMPORTED_MODULE_2__["default"].extend({ + defaults: function defaults() { + return _objectSpread({}, _Property__WEBPACK_IMPORTED_MODULE_2__["default"].prototype.defaults, { + // Array of options, eg. [{name: 'Label ', value: '100'}] + options: [], + full: 1 + }); + }, + initialize: function initialize() { + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; + } - /** - * Handle rule changes - * @private - */ - handleChange: function handleChange(model) { - var ev = 'change:style'; - var um = em.get('UndoManager'); - um && um.add(model); - var handleUpdates = em.handleUpdates.bind(em); - em.stopListening(model, ev, handleUpdates); - em.listenTo(model, ev, handleUpdates); - }, + _Property__WEBPACK_IMPORTED_MODULE_2__["default"].prototype.initialize.apply(this, args); + this.listenTo(this, 'change:options', this.onOptionChange); + }, + onOptionChange: function onOptionChange() { + this.set('list', this.get('options')); + }, + getOptions: function getOptions() { + var _this$attributes = this.attributes, + options = _this$attributes.options, + list = _this$attributes.list; + return options && options.length ? options : list; + }, + setOptions: function setOptions() { + var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : []; + this.set('options', opts); + return this; + }, + addOption: function addOption(opt) { + if (opt) { + var opts = this.getOptions(); + this.setOptions([].concat(_babel_runtime_helpers_toConsumableArray__WEBPACK_IMPORTED_MODULE_0___default()(opts), [opt])); + } + return this; + } +})); - /** - * Load data from the passed object, if the object is empty will try to fetch them - * autonomously from the storage manager. - * The fetched data will be added to the collection - * @param {Object} data Object of data to load - * @return {Object} Loaded rules - */ - load: function load(data) { - var d = data || ''; +/***/ }), - if (!d && c.stm) { - d = c.em.getCacheLoad(); - } +/***/ "./src/style_manager/model/PropertySelect.js": +/*!***************************************************!*\ + !*** ./src/style_manager/model/PropertySelect.js ***! + \***************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - var obj = d.styles || ''; +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _PropertyRadio__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./PropertyRadio */ "./src/style_manager/model/PropertyRadio.js"); - if (d.styles) { - try { - obj = JSON.parse(d.styles); - } catch (err) {} - } else if (d.css) { - obj = c.em.get('Parser').parseCss(d.css); - } - if (obj) { - rules.reset(obj); - } +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - return obj; - }, +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - /** - * Store data to the selected storage - * @param {Boolean} noStore If true, won't store - * @return {Object} Data to store - */ - store: function store(noStore) { - if (!c.stm) return; - var obj = {}; - var keys = this.storageKey(); - if (keys.indexOf('css') >= 0) obj.css = c.em.getCss(); - if (keys.indexOf('styles') >= 0) obj.styles = JSON.stringify(rules); - if (!noStore) c.stm.store(obj); - return obj; - }, +/* harmony default export */ __webpack_exports__["default"] = (_PropertyRadio__WEBPACK_IMPORTED_MODULE_1__["default"].extend({ + defaults: function defaults() { + return _objectSpread({}, _PropertyRadio__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.defaults, { + full: 0 + }); + } +})); +/***/ }), - /** - * Add new rule to the collection, if not yet exists with the same selectors - * @param {Array} selectors Array of selectors - * @param {String} state Css rule state - * @param {String} width For which device this style is oriented - * @param {Object} opts Other options for the rule - * @return {Model} - * @example - * var sm = editor.SelectorManager; - * var sel1 = sm.add('myClass1'); - * var sel2 = sm.add('myClass2'); - * var rule = cssComposer.add([sel1, sel2], 'hover'); - * rule.set('style', { - * width: '100px', - * color: '#fff', - * }); - * */ - add: function add(selectors, state, width, opts) { - var s = state || ''; - var w = width || ''; - var opt = opts || {}; - var rule = this.get(selectors, s, w, opt); - if (rule) return rule;else { - opt.state = s; - opt.mediaText = w; - opt.selectors = ''; - rule = new CssRule(opt, c); - rule.get('selectors').add(selectors); - rules.add(rule); - return rule; - } - }, +/***/ "./src/style_manager/model/PropertySlider.js": +/*!***************************************************!*\ + !*** ./src/style_manager/model/PropertySlider.js ***! + \***************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _PropertyInteger__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./PropertyInteger */ "./src/style_manager/model/PropertyInteger.js"); - /** - * Get the rule - * @param {Array} selectors Array of selectors - * @param {String} state Css rule state - * @param {String} width For which device this style is oriented - * @param {Object} ruleProps Other rule props - * @return {Model|null} - * @example - * var sm = editor.SelectorManager; - * var sel1 = sm.add('myClass1'); - * var sel2 = sm.add('myClass2'); - * var rule = cssComposer.get([sel1, sel2], 'hover'); - * // Update the style - * rule.set('style', { - * width: '300px', - * color: '#000', - * }); - * */ - get: function get(selectors, state, width, ruleProps) { - var rule = null; - rules.each(function (m) { - if (rule) return; - if (m.compare(selectors, state, width, ruleProps)) rule = m; - }); - return rule; - }, +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - /** - * Get the collection of rules - * @return {Collection} - * */ - getAll: function getAll() { - return rules; - }, +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - /** - * Remove all rules - * @return {this} - */ - clear: function clear() { - this.getAll().reset(); - return this; - }, +/* harmony default export */ __webpack_exports__["default"] = (_PropertyInteger__WEBPACK_IMPORTED_MODULE_1__["default"].extend({ + defaults: _objectSpread({}, _PropertyInteger__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.defaults, { + showInput: 1 + }) +})); +/***/ }), - /** - * Add a raw collection of rule objects - * This method overrides styles, in case, of already defined rule - * @param {Array} data Array of rule objects, eg . [{selectors: ['class1'], style: {....}}, ..] - * @param {Object} opts Options - * @return {Array} - * @private - */ - addCollection: function addCollection(data) { - var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; +/***/ "./src/style_manager/model/PropertyStack.js": +/*!**************************************************!*\ + !*** ./src/style_manager/model/PropertyStack.js ***! + \**************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - var result = []; - var d = data instanceof Array ? data : [data]; +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _PropertyComposite__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./PropertyComposite */ "./src/style_manager/model/PropertyComposite.js"); +/* harmony import */ var _Layers__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./Layers */ "./src/style_manager/model/Layers.js"); - for (var i = 0, l = d.length; i < l; i++) { - var rule = d[i] || {}; - if (!rule.selectors) continue; - var sm = c.em && c.em.get('SelectorManager'); - if (!sm) console.warn('Selector Manager not found'); - var sl = rule.selectors; - var sels = sl instanceof Array ? sl : [sl]; - var newSels = []; - for (var j = 0, le = sels.length; j < le; j++) { - var selec = sm.add(sels[j]); - newSels.push(selec); - } +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - var modelExists = this.get(newSels, rule.state, rule.mediaText, rule); - var model = this.add(newSels, rule.state, rule.mediaText, rule); - var updateStyle = !modelExists || !opts.avoidUpdateStyle; - var style = rule.style || {}; +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - if (updateStyle) { - var styleUpdate = opts.extend ? _extends({}, model.get('style'), style) : style; - model.set('style', styleUpdate); - } - result.push(model); - } - return result; - }, +/* harmony default export */ __webpack_exports__["default"] = (_PropertyComposite__WEBPACK_IMPORTED_MODULE_1__["default"].extend({ + defaults: _objectSpread({}, _PropertyComposite__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.defaults, { + // Array of layers (which contain properties) + layers: [], + // The separator used to join layer values + layerSeparator: ', ', + // Layer preview + preview: 0 + }), + initialize: function initialize() { + var props = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + _PropertyComposite__WEBPACK_IMPORTED_MODULE_1__["default"].callParentInit(_PropertyComposite__WEBPACK_IMPORTED_MODULE_1__["default"], this, props, opts); + var layers = this.get('layers'); + var layersColl = new _Layers__WEBPACK_IMPORTED_MODULE_2__["default"](layers); + layersColl.property = this; + layersColl.properties = this.get('properties'); + this.set('layers', layersColl); + _PropertyComposite__WEBPACK_IMPORTED_MODULE_1__["default"].callInit(this, props, opts); + }, + getLayers: function getLayers() { + return this.get('layers'); + }, + getCurrentLayer: function getCurrentLayer() { + return this.getLayers().filter(function (layer) { + return layer.get('active'); + })[0]; + }, + getFullValue: function getFullValue() { + return this.get('detached') ? '' : this.get('layers').getFullValue(); + }, + /** + * This method allows to customize layers returned from the target + * @param {Object} target + * @return {Array} Should return an array of layers + * @example + * // return example + * [ + * { + * properties: [ + * { property: 'width', ... } + * { property: 'height', ... } + * ] + * } + * ] + */ + getLayersFromTarget: function getLayersFromTarget(target) { + return; + } +})); - /** - * Add/update the CSS rule with id selector - * @param {string} name Id selector name, eg. 'my-id' - * @param {Object} style Style properties and values - * @param {Object} [opts={}] Custom options, like `state` and `mediaText` - * @return {CssRule} The new/updated rule - * @example - * const rule = cc.setIdRule('myid', { color: 'red' }); - * const ruleHover = cc.setIdRule('myid', { color: 'blue' }, { state: 'hover' }); - * // This will add current CSS: - * // #myid { color: red } - * // #myid:hover { color: blue } - */ - setIdRule: function setIdRule(name) { - var style = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; - var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; +/***/ }), - var state = opts.state || ''; - var media = opts.mediaText || em.getCurrentMedia(); - var sm = em.get('SelectorManager'); - var selector = sm.add({ name: name, type: Selector.TYPE_ID }); - var rule = this.add(selector, state, media); - rule.setStyle(style, opts); - return rule; - }, +/***/ "./src/style_manager/model/Sector.js": +/*!*******************************************!*\ + !*** ./src/style_manager/model/Sector.js ***! + \*******************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var _Properties__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./Properties */ "./src/style_manager/model/Properties.js"); +/* harmony import */ var _PropertyFactory__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./PropertyFactory */ "./src/style_manager/model/PropertyFactory.js"); - /** - * Get the CSS rule by id selector - * @param {string} name Id selector name, eg. 'my-id' - * @param {Object} [opts={}] Custom options, like `state` and `mediaText` - * @return {CssRule} - * @example - * const rule = cc.getIdRule('myid'); - * const ruleHover = cc.setIdRule('myid', { state: 'hover' }); - */ - getIdRule: function getIdRule(name) { - var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; - var state = opts.state || ''; - var media = opts.mediaText || em.getCurrentMedia(); - var selector = em.get('SelectorManager').get(name, Selector.TYPE_ID); - return selector && this.get(selector, state, media); - }, - /** - * Add/update the CSS rule with class selector - * @param {string} name Class selector name, eg. 'my-class' - * @param {Object} style Style properties and values - * @param {Object} [opts={}] Custom options, like `state` and `mediaText` - * @return {CssRule} The new/updated rule - * @example - * const rule = cc.setClassRule('myclass', { color: 'red' }); - * const ruleHover = cc.setClassRule('myclass', { color: 'blue' }, { state: 'hover' }); - * // This will add current CSS: - * // .myclass { color: red } - * // .myclass:hover { color: blue } - */ - setClassRule: function setClassRule(name) { - var style = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; - var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_0___default.a.Model.extend({ + defaults: { + id: '', + name: '', + open: true, + buildProps: '', + extendBuilded: 1, + properties: [] + }, + initialize: function initialize(opts) { + var o = opts || {}; + var builded = this.buildProperties(o.buildProps); + var name = this.get('name') || ''; + var props = []; + !this.get('id') && this.set('id', name.replace(/ /g, '_').toLowerCase()); + if (!builded) props = this.get('properties');else props = this.extendProperties(builded); + var propsModel = new _Properties__WEBPACK_IMPORTED_MODULE_2__["default"](props); + propsModel.sector = this; + this.set('properties', propsModel); + }, - var state = opts.state || ''; - var media = opts.mediaText || em.getCurrentMedia(); - var sm = em.get('SelectorManager'); - var selector = sm.add({ name: name, type: Selector.TYPE_CLASS }); - var rule = this.add(selector, state, media); - rule.setStyle(style, opts); - return rule; - }, + /** + * Extend properties + * @param {Array} props Start properties + * @param {Array} moProps Model props + * @param {Boolean} ex Returns the same amount of passed model props + * @return {Array} Final props + * @private + */ + extendProperties: function extendProperties(props, moProps, ex) { + var pLen = props.length; + var mProps = moProps || this.get('properties'); + var ext = this.get('extendBuilded'); + var isolated = []; + for (var i = 0, len = mProps.length; i < len; i++) { + var mProp = mProps[i]; + var found = 0; - /** - * Get the CSS rule by class selector - * @param {string} name Class selector name, eg. 'my-class' - * @param {Object} [opts={}] Custom options, like `state` and `mediaText` - * @return {CssRule} - * @example - * const rule = cc.getClassRule('myclass'); - * const ruleHover = cc.getClassRule('myclass', { state: 'hover' }); - */ - getClassRule: function getClassRule(name) { - var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + for (var j = 0; j < pLen; j++) { + var prop = props[j]; - var state = opts.state || ''; - var media = opts.mediaText || em.getCurrentMedia(); - var selector = em.get('SelectorManager').get(name, Selector.TYPE_CLASS); - return selector && this.get(selector, state, media); - }, + if (mProp.property == prop.property || mProp.id == prop.property) { + // Check for nested properties + var mPProps = mProp.properties; + if (mPProps && mPProps.length) { + mProp.properties = this.extendProperties(prop.properties || [], mPProps, 1); + } - /** - * Render the block of CSS rules - * @return {HTMLElement} - * @private - */ - render: function render() { - return rulesView.render().el; - } - }; -}; + props[j] = ext ? Object(underscore__WEBPACK_IMPORTED_MODULE_1__["extend"])(prop, mProp) : mProp; + isolated[j] = props[j]; + found = 1; + continue; + } + } -/***/ }), -/* 139 */ -/***/ (function(module, exports, __webpack_require__) { + if (!found) { + props.push(mProp); + isolated.push(mProp); + } + } -"use strict"; + return ex ? isolated.filter(function (i) { + return i; + }) : props; + }, + /** + * Build properties + * @param {Array} propr Array of props as sting + * @return {Array} + * @private + */ + buildProperties: function buildProperties(props) { + var r; + var buildP = props || []; + if (!buildP.length) return; + if (!this.propFactory) this.propFactory = new _PropertyFactory__WEBPACK_IMPORTED_MODULE_3__["default"](); + r = this.propFactory.build(buildP); + return r; + } +})); -module.exports = { +/***/ }), - // Style prefix - stylePrefix: 'css-', +/***/ "./src/style_manager/model/Sectors.js": +/*!********************************************!*\ + !*** ./src/style_manager/model/Sectors.js ***! + \********************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // Custom CSS string to render on top - 'staticRules': '', +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _Sector__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Sector */ "./src/style_manager/model/Sector.js"); - // Default CSS style - rules: [] -}; +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_0___default.a.Collection.extend({ + model: _Sector__WEBPACK_IMPORTED_MODULE_1__["default"] +})); /***/ }), -/* 140 */ -/***/ (function(module, exports, __webpack_require__) { + +/***/ "./src/style_manager/view/LayerView.js": +/*!*********************************************!*\ + !*** ./src/style_manager/view/LayerView.js ***! + \*********************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _PropertiesView__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./PropertiesView */ "./src/style_manager/view/PropertiesView.js"); + + +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_0___default.a.View.extend({ + events: { + click: 'active', + 'click [data-close-layer]': 'remove', + 'mousedown [data-move-layer]': 'initSorter', + 'touchstart [data-move-layer]': 'initSorter' + }, + template: function template(model) { + var pfx = this.pfx, + ppfx = this.ppfx, + config = this.config; + var label = "".concat(config.textLayer, " ").concat(model.get('index')); + return "\n
\n \n
\n
").concat(label, "
\n
\n \t
\n
\n
\n ⨯\n
\n
\n
\n "); + }, + initialize: function initialize() { + var o = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var model = this.model; + this.stackModel = o.stackModel || {}; + this.config = o.config || {}; + this.pfx = this.config.stylePrefix || ''; + this.ppfx = this.config.pStylePrefix || ''; + this.sorter = o.sorter || null; + this.propsConfig = o.propsConfig || {}; + this.customPreview = o.onPreview; + this.listenTo(model, 'destroy remove', this.remove); + this.listenTo(model, 'change:active', this.updateVisibility); + this.listenTo(model.get('properties'), 'change', this.updatePreview); // For the sorter + model.view = this; + model.set({ + droppable: 0, + draggable: 1 + }); + this.$el.data('model', model); + }, -var Backbone = __webpack_require__(0); -var CssRule = __webpack_require__(46); + /** + * Delegate sorting + * @param {Event} e + * */ + initSorter: function initSorter(e) { + if (this.sorter) this.sorter.startSort(this.el); + }, + remove: function remove(e) { + if (e && e.stopPropagation) e.stopPropagation(); + var model = this.model; + var collection = model.collection; + var stackModel = this.stackModel; + backbone__WEBPACK_IMPORTED_MODULE_0___default.a.View.prototype.remove.apply(this, arguments); -module.exports = Backbone.Collection.extend({ - initialize: function initialize(models, opt) { - // Inject editor - if (opt && opt.sm) this.editor = opt.sm; + if (collection.contains(model)) { + collection.remove(model); + } - // Not used - this.model = function (attrs, options) { - var model; + if (stackModel && stackModel.set) { + stackModel.set({ + stackIndex: null + }, { + silent: true + }); + stackModel.trigger('updateValue'); + } + }, - if (!options.sm && opt && opt.sm) options.sm = opt.sm; + /** + * Default method for changing preview box + * @param {Collection} props + * @param {Element} $el + */ + onPreview: function onPreview(value) { + var values = value.split(' '); + var lim = 3; + var result = []; + this.model.get('properties').each(function (prop, index) { + var value = values[index] || ''; - switch (1) { - default: - model = new CssRule(attrs, options); + if (value) { + if (prop.get('type') == 'integer') { + var valueInt = parseInt(value, 10); + var unit = value.replace(valueInt, ''); + valueInt = !isNaN(valueInt) ? valueInt : 0; + valueInt = valueInt > lim ? lim : valueInt; + valueInt = valueInt < -lim ? -lim : valueInt; + value = valueInt + unit; + } } - return model; - }; + result.push(value); + }); + return result.join(' '); }, - add: function add(models) { - var opt = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + updatePreview: function updatePreview() { + var stackModel = this.stackModel; + var customPreview = this.customPreview; + var previewEl = this.getPreviewEl(); + var value = this.model.getFullValue(); + var preview = customPreview ? customPreview(value) : this.onPreview(value); - if (typeof models === 'string') { - models = this.editor.get('Parser').parseCss(models); + if (preview && stackModel && previewEl) { + previewEl.style[stackModel.get('property')] = preview; } - opt.em = this.editor; - return Backbone.Collection.prototype.add.apply(this, [models, opt]); + }, + getPropertiesWrapper: function getPropertiesWrapper() { + if (!this.propsWrapEl) { + this.propsWrapEl = this.el.querySelector('[data-properties]'); + } + + return this.propsWrapEl; + }, + getPreviewEl: function getPreviewEl() { + if (!this.previewEl) { + this.previewEl = this.el.querySelector('[data-preview]'); + } + + return this.previewEl; + }, + active: function active() { + var model = this.model; + var collection = model.collection; + collection.active(collection.indexOf(model)); + }, + updateVisibility: function updateVisibility() { + var pfx = this.pfx; + var wrapEl = this.getPropertiesWrapper(); + var active = this.model.get('active'); + wrapEl.style.display = active ? '' : 'none'; + this.$el[active ? 'addClass' : 'removeClass']("".concat(pfx, "active")); + }, + render: function render() { + var propsConfig = this.propsConfig; + var model = this.model, + el = this.el, + pfx = this.pfx; + var preview = model.get('preview'); + var properties = new _PropertiesView__WEBPACK_IMPORTED_MODULE_1__["default"]({ + collection: model.get('properties'), + config: this.config, + target: propsConfig.target, + customValue: propsConfig.customValue, + propTarget: propsConfig.propTarget, + onChange: propsConfig.onChange + }).render().el; + el.innerHTML = this.template(model); + el.className = "".concat(pfx, "layer").concat(!preview ? " ".concat(pfx, "no-preview") : ''); + this.getPropertiesWrapper().appendChild(properties); + this.updateVisibility(); + this.updatePreview(); + return this; } -}); +})); /***/ }), -/* 141 */ -/***/ (function(module, exports, __webpack_require__) { -"use strict"; +/***/ "./src/style_manager/view/LayersView.js": +/*!**********************************************!*\ + !*** ./src/style_manager/view/LayersView.js ***! + \**********************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _LayerView__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./LayerView */ "./src/style_manager/view/LayerView.js"); -var Backbone = __webpack_require__(0); -var CssRuleView = __webpack_require__(142); -module.exports = Backbone.View.extend({ +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_0___default.a.View.extend({ initialize: function initialize(o) { - var config = o.config || {}; - this.config = config; - this.em = config.em; - this.pfx = config.stylePrefix || ''; - this.className = this.pfx + 'rules'; - var coll = this.collection; - this.listenTo(coll, 'add', this.addTo); - this.listenTo(coll, 'reset', this.render); - }, + this.config = o.config || {}; + this.stackModel = o.stackModel; + this.preview = o.preview; + this.pfx = this.config.stylePrefix || ''; + this.ppfx = this.config.pStylePrefix || ''; + this.propsConfig = o.propsConfig; + var pfx = this.pfx; + var ppfx = this.ppfx; + var collection = this.collection; + this.className = "".concat(pfx, "layers ").concat(ppfx, "field"); + this.listenTo(collection, 'add', this.addTo); + this.listenTo(collection, 'deselectAll', this.deselectAll); + this.listenTo(collection, 'reset', this.render); + var em = this.config.em || ''; + var utils = em ? em.get('Utils') : ''; + this.sorter = utils ? new utils.Sorter({ + container: this.el, + ignoreViewChildren: 1, + containerSel: ".".concat(pfx, "layers"), + itemSel: ".".concat(pfx, "layer"), + pfx: this.config.pStylePrefix + }) : ''; // For the Sorter + collection.view = this; + this.$el.data('model', collection); + this.$el.data('collection', collection); + }, /** * Add to collection - * @param {Object} model - * @private + * @param Object Model + * + * @return Object * */ addTo: function addTo(model) { - this.addToCollection(model); + var i = this.collection.indexOf(model); + this.addToCollection(model, null, i); }, - /** * Add new object to collection - * @param {Object} model - * @param {Object} fragmentEl - * @return {Object} - * @private + * @param Object Model + * @param Object Fragment collection + * @param {number} index Index of append + * + * @return Object Object created * */ - addToCollection: function addToCollection(model, fragmentEl) { + addToCollection: function addToCollection(model, fragmentEl, index) { var fragment = fragmentEl || null; - var viewObject = CssRuleView; + var stackModel = this.stackModel; + var config = this.config; + var sorter = this.sorter; + var propsConfig = this.propsConfig; - var view = new viewObject({ + if (typeof this.preview !== 'undefined') { + model.set('preview', this.preview); + } + + var view = new _LayerView__WEBPACK_IMPORTED_MODULE_1__["default"]({ model: model, - config: this.config + config: config, + sorter: sorter, + stackModel: stackModel, + propsConfig: propsConfig }); var rendered = view.render().el; - if (fragment) fragment.appendChild(rendered);else this.$el.append(rendered); + if (fragment) { + fragment.appendChild(rendered); + } else { + if (typeof index != 'undefined') { + var method = 'before'; // If the added model is the last of collection + // need to change the logic of append + + if (this.$el.children().length == index) { + index--; + method = 'after'; + } // In case the added is new in the collection index will be -1 + + + if (index < 0) { + this.$el.append(rendered); + } else this.$el.children().eq(index)[method](rendered); + } else this.$el.append(rendered); + } return rendered; }, - render: function render() { - var _this = this; - var $el = this.$el; - var frag = document.createDocumentFragment(); - $el.empty(); + /** + * Deselect all + * + * @return void + * */ + deselectAll: function deselectAll() { + this.$el.find('.' + this.pfx + 'layer').removeClass(this.pfx + 'active'); + }, + render: function render() { + var fragment = document.createDocumentFragment(); + this.$el.empty(); this.collection.each(function (model) { - return _this.addToCollection(model, frag); - }); - $el.append(frag); - $el.attr('class', this.className); + this.addToCollection(model, fragment); + }, this); + this.$el.append(fragment); + this.$el.attr('class', this.className); + if (this.sorter) this.sorter.plh = null; return this; } -}); +})); /***/ }), -/* 142 */ -/***/ (function(module, exports, __webpack_require__) { + +/***/ "./src/style_manager/view/PropertiesView.js": +/*!**************************************************!*\ + !*** ./src/style_manager/view/PropertiesView.js ***! + \**************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var utils_dom__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! utils/dom */ "./src/utils/dom.js"); -module.exports = __webpack_require__(0).View.extend({ - tagName: 'style', +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_0___default.a.View.extend({ + initialize: function initialize(o) { + this.config = o.config || {}; + this.pfx = this.config.stylePrefix || ''; + this.target = o.target || {}; + this.propTarget = o.propTarget || {}; + this.onChange = o.onChange; + this.onInputRender = o.onInputRender || {}; + this.customValue = o.customValue || {}; + this.properties = []; + var coll = this.collection; + this.listenTo(coll, 'add', this.addTo); + this.listenTo(coll, 'reset', this.render); + }, + addTo: function addTo(model, coll, opts) { + this.add(model, null, opts); + }, + add: function add(model, frag) { + var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + var appendTo = frag || this.el; + var view = new model.typeView({ + model: model, + name: model.get('name'), + id: this.pfx + model.get('property'), + target: this.target, + propTarget: this.propTarget, + onChange: this.onChange, + onInputRender: this.onInputRender, + config: this.config + }); - initialize: function initialize() { - var o = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + if (model.get('type') != 'composite') { + view.customValue = this.customValue; + } - this.config = o.config || {}; - var model = this.model; - var toTrack = 'change:style change:state change:mediaText'; - this.listenTo(model, toTrack, this.render); - this.listenTo(model, 'destroy remove', this.remove); - this.listenTo(model.get('selectors'), 'change', this.render); + view.render(); + var rendered = view.el; + this.properties.push(view); + Object(utils_dom__WEBPACK_IMPORTED_MODULE_1__["appendAtIndex"])(appendTo, rendered, opts.at); }, render: function render() { - var model = this.model; - var important = model.get('important'); - this.el.innerHTML = this.model.toCSS({ important: important }); + var _this = this; + + this.properties = []; + var fragment = document.createDocumentFragment(); + this.collection.each(function (model) { + return _this.add(model, fragment); + }); + this.$el.append(fragment); + this.$el.attr('class', "".concat(this.pfx, "properties")); return this; } -}); +})); /***/ }), -/* 143 */ -/***/ (function(module, exports, __webpack_require__) { -"use strict"; +/***/ "./src/style_manager/view/PropertyColorView.js": +/*!*****************************************************!*\ + !*** ./src/style_manager/view/PropertyColorView.js ***! + \*****************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _PropertyIntegerView__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./PropertyIntegerView */ "./src/style_manager/view/PropertyIntegerView.js"); +/* harmony import */ var domain_abstract_ui_InputColor__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! domain_abstract/ui/InputColor */ "./src/domain_abstract/ui/InputColor.js"); -var _underscore = __webpack_require__(1); -module.exports = function () { - var c = {}; - var defaultOpts = __webpack_require__(144); - var TraitsView = __webpack_require__(145); - var TraitsViewer = void 0; +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - return { +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - TraitsView: TraitsView, - /** - * Name of the module - * @type {String} - * @private - */ - name: 'TraitManager', - /** - * Get configuration object - * @return {Object} - * @private - */ - getConfig: function getConfig() { - return c; - }, +/* harmony default export */ __webpack_exports__["default"] = (_PropertyIntegerView__WEBPACK_IMPORTED_MODULE_1__["default"].extend({ + setValue: function setValue(value) { + var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + opts = _objectSpread({}, opts, { + silent: 1 + }); + this.inputInst.setValue(value, opts); + }, + onRender: function onRender() { + if (!this.input) { + var ppfx = this.ppfx; + var inputColor = new domain_abstract_ui_InputColor__WEBPACK_IMPORTED_MODULE_2__["default"]({ + target: this.target, + model: this.model, + ppfx: ppfx + }); + var input = inputColor.render(); + this.el.querySelector(".".concat(ppfx, "fields")).appendChild(input.el); + this.$input = input.inputEl; + this.$color = input.colorEl; + this.input = this.$input.get(0); + this.inputInst = input; + } + } +})); +/***/ }), - /** - * Initialize module. Automatically called with a new instance of the editor - * @param {Object} config Configurations - */ - init: function init() { - var config = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; +/***/ "./src/style_manager/view/PropertyCompositeView.js": +/*!*********************************************************!*\ + !*** ./src/style_manager/view/PropertyCompositeView.js ***! + \*********************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - c = config; - (0, _underscore.defaults)(c, defaultOpts); - var ppfx = c.pStylePrefix; - ppfx && (c.stylePrefix = '' + ppfx + c.stylePrefix); - TraitsViewer = new TraitsView({ - collection: [], - editor: c.em, - config: c - }); - return this; - }, +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _PropertyView__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./PropertyView */ "./src/style_manager/view/PropertyView.js"); - /** - * - * Get Traits viewer - * @private - */ - getTraitsViewer: function getTraitsViewer() { - return TraitsViewer; - }, +var $ = backbone__WEBPACK_IMPORTED_MODULE_0___default.a.$; +/* harmony default export */ __webpack_exports__["default"] = (_PropertyView__WEBPACK_IMPORTED_MODULE_1__["default"].extend({ + templateInput: function templateInput() { + var pfx = this.pfx; + return "\n
\n \n
\n "); + }, + inputValueChanged: function inputValueChanged() { + // If it's not detached (eg. 'padding: 1px 2px 3px 4px;') it will follow + // the same flow of PropertyView + if (!this.model.get('detached')) { + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; + } + _PropertyView__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.inputValueChanged.apply(this, args); + } + }, + clear: function clear(e) { + var props = this.properties; + props && props.forEach(function (propView) { + return propView.clear(); + }); + _PropertyView__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.clear.apply(this, arguments); + }, - /** - * Add new trait type - * @param {string} name Type name - * @param {Object} methods Object representing the trait - */ - addType: function addType(name, trait) { - var itemView = TraitsViewer.itemView; - TraitsViewer.itemsView[name] = itemView.extend(trait); - }, + /** + * Renders input + * */ + onRender: function onRender() { + var model = this.model; + var props = model.get('properties') || []; + var self = this; + this.properties = []; + if (props.length) { + if (!this.$input) { + this.$input = $(''); + this.input = this.$input.get(0); + } - /** - * Get trait type - * @param {string} name Type name - * @return {Object} - */ - getType: function getType(name) { - return TraitsViewer.itemsView[name]; - } - }; -}; + if (!this.props) { + this.props = model.get('properties'); + } -/***/ }), -/* 144 */ -/***/ (function(module, exports, __webpack_require__) { + if (!this.$props) { + //Not yet supported nested composite + this.props.each(function (prop, index) { + if (prop && prop.get('type') == 'composite') { + this.props.remove(prop); + console.warn('Nested composite types not yet allowed.'); + } -"use strict"; + prop.parent = model; + }, this); + var PropertiesView = __webpack_require__(/*! ./PropertiesView */ "./src/style_manager/view/PropertiesView.js").default; -module.exports = { + var propsView = new PropertiesView(this.getPropsConfig()); + this.$props = propsView.render().$el; + this.properties = propsView.properties; + this.$el.find("#".concat(this.pfx, "input-holder")).append(this.$props); + } + } + }, - stylePrefix: 'trt-', + /** + * Returns configurations that should be past to properties + * @param {Object} opts + * @return {Object} + */ + getPropsConfig: function getPropsConfig(opts) { + var that = this; + var model = this.model; + var result = { + config: this.config, + collection: this.props, + target: this.target, + propTarget: this.propTarget, + // On any change made to children I need to update composite value + onChange: function onChange(el, view, opts) { + model.set('value', model.getFullValue(), opts); + }, + // Each child property will receive a full composite string, eg. '0px 0px 10px 0px' + // I need to extract from that string the corresponding one to that property. + customValue: function customValue(property, mIndex) { + return that.valueOnIndex(mIndex, property); + } + }; // If detached let follow its standard flow - labelContainer: 'Component settings', + if (model.get('detached')) { + delete result.onChange; + } - // Placeholder label for text input types - labelPlhText: 'eg. Text here', + return result; + }, - // Placeholder label for href input - labelPlhHref: 'eg. https://google.com', + /** + * Extract string from composite value + * @param {number} index Index + * @param {Object} view Property view + * @return {string} + * */ + valueOnIndex: function valueOnIndex(index, view) { + var value; + var targetValue = this.getTargetValue({ + ignoreDefault: 1 + }); // If the target value of the composite is not empty I'll fetch + // the corresponding value from the requested index, otherwise try + // to get the value of the sub-property - // Default options for the target input - optionsTarget: [{ value: '', name: 'This window' }, { value: '_blank', name: 'New window' }] + if (targetValue) { + var values = targetValue.split(this.model.getSplitSeparator()); + value = values[index]; + } else { + value = view && view.getTargetValue({ + ignoreCustomValue: 1, + ignoreDefault: 1 + }); + } -}; + return value; + }, + clearCached: function clearCached() { + _PropertyView__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.clearCached.apply(this, arguments); + this.$input = null; + this.props = null; + this.$props = null; + } +})); /***/ }), -/* 145 */ -/***/ (function(module, exports, __webpack_require__) { + +/***/ "./src/style_manager/view/PropertyFileView.js": +/*!****************************************************!*\ + !*** ./src/style_manager/view/PropertyFileView.js ***! + \****************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var _PropertyView__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./PropertyView */ "./src/style_manager/view/PropertyView.js"); -var DomainViews = __webpack_require__(48); -var TraitView = __webpack_require__(8); -var TraitSelectView = __webpack_require__(146); -var TraitCheckboxView = __webpack_require__(147); -var TraitNumberView = __webpack_require__(148); -var TraitColorView = __webpack_require__(149); -module.exports = DomainViews.extend({ +var $ = backbone__WEBPACK_IMPORTED_MODULE_1___default.a.$; +/* harmony default export */ __webpack_exports__["default"] = (_PropertyView__WEBPACK_IMPORTED_MODULE_2__["default"].extend({ + templateInput: function templateInput() { + var pfx = this.pfx; + var ppfx = this.ppfx; + var assetsLabel = this.config.assetsLabel || 'Images'; + return "\n
\n
\n
\n \n
\n
\n
\n
\n
\n
\n
\n
\n "); + }, + init: function init() { + var em = this.em; + this.modal = em.get('Modal'); + this.am = em.get('AssetManager'); + this.events['click #' + this.pfx + 'close'] = 'removeFile'; + this.events['click #' + this.pfx + 'images'] = 'openAssetManager'; + this.delegateEvents(); + }, + onRender: function onRender() { + if (!this.$input) { + var plh = this.model.getDefaultValue(); + this.$input = $("")); + } - itemView: TraitView, + if (!this.$preview) { + this.$preview = this.$el.find('#' + this.pfx + 'preview-file'); + } - itemsView: { - 'text': TraitView, - 'number': TraitNumberView, - 'select': TraitSelectView, - 'checkbox': TraitCheckboxView, - 'color': TraitColorView + if (!this.$previewBox) { + this.$previewBox = this.$el.find('#' + this.pfx + 'preview-box'); + } + + this.setValue(this.componentValue, 0); + }, + clearCached: function clearCached() { + _PropertyView__WEBPACK_IMPORTED_MODULE_2__["default"].prototype.clearCached.apply(this, arguments); + this.$preview = null; + this.$previewBox = null; + }, + setValue: function setValue(value, f) { + _PropertyView__WEBPACK_IMPORTED_MODULE_2__["default"].prototype.setValue.apply(this, arguments); + this.setPreviewView(value && value != this.model.getDefaultValue()); + this.setPreview(value); }, - initialize: function initialize(o) { - this.config = o.config || {}; - this.em = o.editor; - this.pfx = this.config.stylePrefix || ''; - this.className = this.pfx + 'traits'; - this.listenTo(this.em, 'change:selectedComponent', this.updatedCollection); - this.updatedCollection(); + /** + * Change visibility of the preview box + * @param bool Visibility + * + * @return void + * */ + setPreviewView: function setPreviewView(v) { + var pv = this.$previewBox; + pv && pv[v ? 'addClass' : 'removeClass']("".concat(this.pfx, "show")); + }, + + /** + * Spread url + * @param string Url + * + * @return void + * */ + spreadUrl: function spreadUrl(url) { + this.model.set('value', url); + this.setPreviewView(1); + }, + + /** + * Shows file preview + * @param string Value + * */ + setPreview: function setPreview(value) { + var preview = this.$preview; + value = value && value.indexOf('url(') < 0 ? "url(".concat(value, ")") : value; + preview && preview.css('background-image', value); }, + /** @inheritdoc */ + cleanValue: function cleanValue() { + this.setPreviewView(0); + this.model.set({ + value: '' + }, { + silent: true + }); + }, /** - * Update view collection - * @private - */ - updatedCollection: function updatedCollection() { - this.el.className = this.className; - var comp = this.em.get('selectedComponent'); - if (comp) { - this.collection = comp.get('traits'); - this.render(); - } - } -}); - -/***/ }), -/* 146 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; -/* WEBPACK VAR INJECTION */(function(Backbone, _) { + * Remove file from input + * + * @return void + * */ + removeFile: function removeFile() { + this.model.set('value', this.model.getDefaultValue()); -var TraitView = __webpack_require__(8); -var $ = Backbone.$; + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; + } -module.exports = TraitView.extend({ - initialize: function initialize(o) { - TraitView.prototype.initialize.apply(this, arguments); - var ppfx = this.ppfx; - this.tmpl = '
' + '
'; + _PropertyView__WEBPACK_IMPORTED_MODULE_2__["default"].prototype.cleanValue.apply(this, args); + this.setPreviewView(0); }, - /** - * Returns input element - * @return {HTMLElement} - * @private - */ - getInputEl: function getInputEl() { - if (!this.$input) { - var md = this.model; - var opts = md.get('options') || []; - var input = ''; - this.input = input; - this.$input = $(this.input); + * Open dialog for image selecting + * @param {Object} e Event + * + * @return void + * */ + openAssetManager: function openAssetManager(e) { + var _this = this; - var target = this.target; - var name = md.get('name'); - var val = md.get('value'); + var em = this.em, + modal = this.modal; + var editor = em ? em.get('Editor') : ''; - if (md.get('changeProp')) { - val = val || target.get(name); - } else { - var attrs = target.get('attributes'); - val = attrs[name]; - } + if (editor) { + editor.runCommand('open-assets', { + types: ['image'], + accept: 'image/*', + target: this.getTargetModel(), + onClick: function onClick() {}, + onDblClick: function onDblClick() {}, + onSelect: function onSelect(asset) { + modal.close(); + var url = Object(underscore__WEBPACK_IMPORTED_MODULE_0__["isString"])(asset) ? asset : asset.get('src'); - if (val) this.$input.val(val); + _this.spreadUrl(url); + } + }); } - - return this.$input.get(0); } -}); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(0), __webpack_require__(1))) +})); /***/ }), -/* 147 */ -/***/ (function(module, exports, __webpack_require__) { + +/***/ "./src/style_manager/view/PropertyIntegerView.js": +/*!*******************************************************!*\ + !*** ./src/style_manager/view/PropertyIntegerView.js ***! + \*******************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _PropertyView__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./PropertyView */ "./src/style_manager/view/PropertyView.js"); -var TraitView = __webpack_require__(8); +var $ = backbone__WEBPACK_IMPORTED_MODULE_0___default.a.$; +/* harmony default export */ __webpack_exports__["default"] = (_PropertyView__WEBPACK_IMPORTED_MODULE_1__["default"].extend({ + templateInput: function templateInput() { + return ''; + }, + init: function init() { + var model = this.model; + this.listenTo(model, 'change:unit', this.modelValueChanged); + this.listenTo(model, 'el:change', this.elementUpdated); + this.listenTo(model, 'change:units', this.render); + }, + setValue: function setValue(value) { + var parsed = this.model.parseValue(value); + value = "".concat(parsed.value).concat(parsed.unit); + this.inputInst.setValue(value, { + silent: 1 + }); + }, + onRender: function onRender() { + var ppfx = this.ppfx; -module.exports = TraitView.extend({ - initialize: function initialize(o) { - TraitView.prototype.initialize.apply(this, arguments); - var iconCls = this.ppfx + 'chk-icon'; - this.tmpl = '
'; + if (!this.input) { + var input = this.model.input; + input.ppfx = ppfx; + input.render(); + var fields = this.el.querySelector(".".concat(ppfx, "fields")); + fields.appendChild(input.el); + this.$input = input.inputEl; + this.unit = input.unitEl; + this.$unit = $(this.unit); + this.input = this.$input.get(0); + this.inputInst = input; + } }, + clearCached: function clearCached() { + _PropertyView__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.clearCached.apply(this, arguments); + this.unit = null; + this.$unit = null; + } +})); +/***/ }), - /** - * Fires when the input is changed - * @private - */ - onChange: function onChange() { - this.model.set('value', this.getInputEl().checked); - }, +/***/ "./src/style_manager/view/PropertyRadioView.js": +/*!*****************************************************!*\ + !*** ./src/style_manager/view/PropertyRadioView.js ***! + \*****************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _PropertyView__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./PropertyView */ "./src/style_manager/view/PropertyView.js"); - /** - * Returns input element - * @return {HTMLElement} - * @private - */ - getInputEl: function getInputEl() { - var first; - if (!this.$input) first = 1; +/* harmony default export */ __webpack_exports__["default"] = (_PropertyView__WEBPACK_IMPORTED_MODULE_0__["default"].extend({ + templateInput: function templateInput() { + var pfx = this.pfx; + var ppfx = this.ppfx; + return "\n
\n
\n "); + }, + onRender: function onRender() { + var pfx = this.pfx; + var ppfx = this.ppfx; + var itemCls = "".concat(ppfx, "radio-item-label"); + var model = this.model; + var prop = model.get('property'); + var options = model.get('list') || model.get('options') || []; - for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) { - args[_key] = arguments[_key]; + if (!this.input) { + if (options && options.length) { + var inputStr = ''; + options.forEach(function (el) { + var cl = el.className ? "".concat(el.className, " ").concat(pfx, "icon ").concat(itemCls) : ''; + var id = "".concat(prop, "-").concat(el.value); + var labelTxt = el.name || el.value; + var titleAttr = el.title ? "title=\"".concat(el.title, "\"") : ''; + inputStr += "\n
\n \n \n
\n "); + }); + var inputHld = this.el.querySelector(".".concat(ppfx, "field")); + inputHld.innerHTML = "
").concat(inputStr, "
"); + this.input = inputHld.firstChild; + } } + }, + getInputValue: function getInputValue() { + var inputChk = this.getCheckedEl(); + return inputChk ? inputChk.value : ''; + }, + getCheckedEl: function getCheckedEl() { + var input = this.getInputEl(); + return input ? input.querySelector('input:checked') : ''; + }, + setValue: function setValue(value) { + var model = this.model; + var val = value || model.get('value') || model.getDefaultValue(); + var input = this.getInputEl(); + var inputIn = input ? input.querySelector("[value=\"".concat(val, "\"]")) : ''; - var el = TraitView.prototype.getInputEl.apply(this, args); - if (first) { - var md = this.model; - var name = md.get('name'); - var target = this.target; - if (md.get('changeProp')) { - el.checked = target.get(name); - } else { - var attrs = target.get('attributes'); - el.checked = !!attrs[name]; - } + if (inputIn) { + inputIn.checked = true; + } else { + var inputChk = this.getCheckedEl(); + inputChk && (inputChk.checked = false); } - return el; } -}); +})); /***/ }), -/* 148 */ -/***/ (function(module, exports, __webpack_require__) { -"use strict"; +/***/ "./src/style_manager/view/PropertySelectView.js": +/*!******************************************************!*\ + !*** ./src/style_manager/view/PropertySelectView.js ***! + \******************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _PropertyView__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./PropertyView */ "./src/style_manager/view/PropertyView.js"); -var TraitView = __webpack_require__(8); -var InputNumber = __webpack_require__(18); -module.exports = TraitView.extend({ - getValueForTarget: function getValueForTarget() { - var model = this.model; - var value = model.get('value'); - var unit = model.get('unit'); - return value ? value + unit : ''; +var $ = backbone__WEBPACK_IMPORTED_MODULE_0___default.a.$; +/* harmony default export */ __webpack_exports__["default"] = (_PropertyView__WEBPACK_IMPORTED_MODULE_1__["default"].extend({ + templateInput: function templateInput() { + var pfx = this.pfx; + var ppfx = this.ppfx; + return "\n
\n \n
\n
\n
\n
\n "); }, - - - /** - * Returns input element - * @return {HTMLElement} - * @private - */ - getInputEl: function getInputEl() { - if (!this.$input) { - var value = this.getModelValue(); - var inputNumber = new InputNumber({ - contClass: this.ppfx + 'field-int', - model: this.model, - ppfx: this.ppfx - }); - this.input = inputNumber.render(); - this.$input = this.input.inputEl; - this.$unit = this.input.unitEl; - this.model.set('value', value); - this.$input.val(value); + initialize: function initialize() { + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; } - return this.$input.get(0); - }, + _PropertyView__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.initialize.apply(this, args); + this.listenTo(this.model, 'change:options', this.updateOptions); + }, + updateOptions: function updateOptions() { + this.input = null; + this.onRender(); + }, + onRender: function onRender() { + var pfx = this.pfx; + var options = this.model.getOptions(); - /** - * Renders input - * @private - * */ - renderField: function renderField() { - if (!this.$input) { - this.$el.append(this.tmpl); - this.getInputEl(); - this.$el.find('.' + this.inputhClass).prepend(this.input.el); + if (!this.input) { + var optionsStr = ''; + options.forEach(function (option) { + var name = option.name || option.value; + var style = option.style ? option.style.replace(/"/g, '"') : ''; + var styleAttr = style ? "style=\"".concat(style, "\"") : ''; + var value = option.value.replace(/"/g, '"'); + optionsStr += ""); + }); + var inputH = this.el.querySelector("#".concat(pfx, "input-holder")); + inputH.innerHTML = ""); + this.input = inputH.firstChild; } } -}); +})); /***/ }), -/* 149 */ -/***/ (function(module, exports, __webpack_require__) { + +/***/ "./src/style_manager/view/PropertySliderView.js": +/*!******************************************************!*\ + !*** ./src/style_manager/view/PropertySliderView.js ***! + \******************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _PropertyIntegerView__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./PropertyIntegerView */ "./src/style_manager/view/PropertyIntegerView.js"); -var TraitView = __webpack_require__(8); -var InputColor = __webpack_require__(39); +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } -module.exports = TraitView.extend({ - /** - * Returns input element - * @return {HTMLElement} - * @private - */ - getInputEl: function getInputEl() { - if (!this.$input) { - var value = this.getModelValue(); - var inputNumber = new InputColor({ - target: this.config.em, - contClass: this.ppfx + 'field-color', - model: this.model, - ppfx: this.ppfx - }); - this.input = inputNumber.render(); - this.$input = this.input.colorEl; - value = value || ''; - this.model.set('value', value).trigger('change:value'); - } - return this.$input.get(0); +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } + + +/* harmony default export */ __webpack_exports__["default"] = (_PropertyIntegerView__WEBPACK_IMPORTED_MODULE_1__["default"].extend({ + events: function events() { + return _objectSpread({}, _PropertyIntegerView__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.events, { + 'change [type=range]': 'inputValueChanged', + 'input [type=range]': 'inputValueChangedSoft', + change: '' + }); + }, + templateInput: function templateInput(model) { + var ppfx = this.ppfx; + return "\n
\n \n
\n "); }, + getSliderEl: function getSliderEl() { + if (!this.slider) { + this.slider = this.el.querySelector('input[type=range]'); + } + return this.slider; + }, + inputValueChanged: function inputValueChanged() { + var model = this.model; + var step = model.get('step'); + this.getInputEl().value = this.getSliderEl().value; + var value = this.getInputValue() - step; + model.set('value', value, { + avoidStore: 1 + }).set('value', value + step); + this.elementUpdated(); + }, + inputValueChangedSoft: function inputValueChangedSoft() { + this.getInputEl().value = this.getSliderEl().value; + this.model.set('value', this.getInputValue(), { + avoidStore: 1 + }); + this.elementUpdated(); + }, + setValue: function setValue(value) { + var parsed = this.model.parseValue(value); + this.getSliderEl().value = parseFloat(parsed.value); + _PropertyIntegerView__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.setValue.apply(this, arguments); + }, + onRender: function onRender() { + _PropertyIntegerView__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.onRender.apply(this, arguments); - /** - * Renders input - * @private - * */ - renderField: function renderField() { - if (!this.$input) { - this.getInputEl(); - this.$el.append(this.input.el); + if (!this.model.get('showInput')) { + this.inputInst.el.style.display = 'none'; } + }, + clearCached: function clearCached() { + _PropertyIntegerView__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.clearCached.apply(this, arguments); + this.slider = null; } -}); +})); /***/ }), -/* 150 */ -/***/ (function(module, exports, __webpack_require__) { + +/***/ "./src/style_manager/view/PropertyStackView.js": +/*!*****************************************************!*\ + !*** ./src/style_manager/view/PropertyStackView.js ***! + \*****************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _PropertyCompositeView__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./PropertyCompositeView */ "./src/style_manager/view/PropertyCompositeView.js"); +/* harmony import */ var _LayersView__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./LayersView */ "./src/style_manager/view/LayersView.js"); -var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; +/* harmony default export */ __webpack_exports__["default"] = (_PropertyCompositeView__WEBPACK_IMPORTED_MODULE_0__["default"].extend({ + templateInput: function templateInput() { + var pfx = this.pfx; + var ppfx = this.ppfx; + return "\n
\n \n
\n
\n "); + }, + init: function init() { + var model = this.model; + var pfx = this.pfx; + model.set('stackIndex', null); + this.events["click [data-add-layer]"] = 'addLayer'; + this.listenTo(model, 'change:stackIndex', this.indexChanged); + this.listenTo(model, 'updateValue', this.inputValueChanged); + this.delegateEvents(); + }, + clear: function clear(e) { + e && e.stopPropagation(); + this.model.get('layers').reset(); + this.model.clearValue(); + this.targetUpdated(); + }, -/** - * - * * [getWrapper](#getwrapper) - * * [getComponents](#getcomponents) - * * [addComponent](#addcomponent) - * * [clear](#clear) - * * [load](#load) - * * [store](#store) - * * [render](#render) - * - * With this module is possible to manage components inside the canvas. - * Before using methods you should get first the module from the editor instance, in this way: - * - * ```js - * var domComponents = editor.DomComponents; - * ``` - * - * @module DomComponents - * @param {Object} config Configurations - * @param {string|Array} [config.components=[]] HTML string or an array of possible components - * @example - * ... - * domComponents: { - * components: '
Hello world!
', - * } - * // Or - * domComponents: { - * components: [ - * { tagName: 'span', style: {color: 'red'}, content: 'Hello'}, - * { style: {width: '100px', content: 'world!'}} - * ], - * } - * ... - */ -module.exports = function () { - var c = {}; - var em = void 0; - var defaults = __webpack_require__(151); - var Component = __webpack_require__(4); - var ComponentView = __webpack_require__(3); - var Components = __webpack_require__(49); - var ComponentsView = __webpack_require__(50); + /** + * Fired when the target is updated. + * With detached mode the component will be always empty as its value + * so we gonna check all props and find if it has any difference + * */ + targetUpdated: function targetUpdated() { + if (!this.model.get('detached')) { + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { + args[_key] = arguments[_key]; + } - var component, componentView; - var componentTypes = [{ - id: 'cell', - model: __webpack_require__(155), - view: __webpack_require__(156) - }, { - id: 'row', - model: __webpack_require__(157), - view: __webpack_require__(158) - }, { - id: 'table', - model: __webpack_require__(159), - view: __webpack_require__(160) - }, { - id: 'thead', - model: __webpack_require__(161), - view: __webpack_require__(162) - }, { - id: 'tbody', - model: __webpack_require__(19), - view: __webpack_require__(163) - }, { - id: 'tfoot', - model: __webpack_require__(164), - view: __webpack_require__(165) - }, { - id: 'map', - model: __webpack_require__(166), - view: __webpack_require__(167) - }, { - id: 'link', - model: __webpack_require__(168), - view: __webpack_require__(169) - }, { - id: 'video', - model: __webpack_require__(170), - view: __webpack_require__(171) - }, { - id: 'image', - model: __webpack_require__(20), - view: __webpack_require__(15) - }, { - id: 'script', - model: __webpack_require__(172), - view: __webpack_require__(173) - }, { - id: 'svg', - model: __webpack_require__(174), - view: __webpack_require__(175) - }, { - id: 'textnode', - model: __webpack_require__(176), - view: __webpack_require__(177) - }, { - id: 'text', - model: __webpack_require__(51), - view: __webpack_require__(52) - }, { - id: 'default', - model: Component, - view: ComponentView - }]; + _PropertyCompositeView__WEBPACK_IMPORTED_MODULE_0__["default"].prototype.targetUpdated.apply(this, args); + } else { + this.checkVisibility(); + } - return { + this.refreshLayers(); + }, - Components: Components, + /** + * Returns the collection of layers + * @return {Collection} + */ + getLayers: function getLayers() { + return this.model.get('layers'); + }, - ComponentsView: ComponentsView, + /** + * Triggered when another layer has been selected. + * This allow to move all rendered properties to a new + * selected layer + * @param {Event} + * + * @return {Object} + * */ + indexChanged: function indexChanged(e) { + var model = this.model; + this.getLayers().active(model.get('stackIndex')); + }, + addLayer: function addLayer() { + var model = this.model; + var layers = this.getLayers(); + var properties = model.get('properties').deepClone(); + properties.each(function (property) { + return property.set('value', ''); + }); + var layer = layers.add({ + properties: properties + }); // In detached mode inputValueChanged will add new 'layer value' + // to all subprops - componentTypes: componentTypes, + this.inputValueChanged(); // This will set subprops with a new default values - /** - * Name of the module - * @type {String} - * @private - */ - name: 'DomComponents', + model.set('stackIndex', layers.indexOf(layer)); + }, + inputValueChanged: function inputValueChanged() { + var model = this.model; + this.elementUpdated(); // If not detached I'll just put all the values from layers to property + // eg. background: layer1Value, layer2Value, layer3Value, ... - /** - * Returns config - * @return {Object} Config object - * @private - */ - getConfig: function getConfig() { - return c; - }, + if (!model.get('detached')) { + model.set('value', this.getLayerValues()); + } else { + model.get('properties').each(function (prop) { + return prop.trigger('change:value'); + }); + } + }, + /** + * There is no need to handle input update by the property itself, + * this will be done by layers + * @private + */ + setValue: function setValue() {}, - /** - * Mandatory for the storage manager - * @type {String} - * @private - */ - storageKey: function storageKey() { - var keys = []; - var smc = c.stm && c.stm.getConfig() || {}; - if (smc.storeHtml) keys.push('html'); - if (smc.storeComponents) keys.push('components'); - return keys; - }, + /** + * Create value by layers + * @return string + * */ + getLayerValues: function getLayerValues() { + return this.getLayers().getFullValue(); + }, + /** + * Refresh layers + * */ + refreshLayers: function refreshLayers() { + var layersObj = []; + var model = this.model; + var layers = this.getLayers(); + var detached = model.get('detached'); + var target = this.getTarget(); // With detached layers values will be assigned to their properties - /** - * Initialize module. Called on a new instance of the editor with configurations passed - * inside 'domComponents' field - * @param {Object} config Configurations - * @private - */ - init: function init(config) { - c = config || {}; - em = c.em; + if (detached) { + var style = target ? target.getStyle() : {}; + layersObj = layers.getLayersFromStyle(style); + } else { + var value = this.getTargetValue(); + value = value == model.getDefaultValue() ? '' : value; + layersObj = layers.getLayersFromValue(value); + } - if (em) { - c.components = em.config.components || c.components; - } + var toAdd = model.getLayersFromTarget(target) || layersObj; + layers.reset(); + layers.add(toAdd); + model.set({ + stackIndex: null + }, { + silent: true + }); + }, + onRender: function onRender() { + var self = this; + var model = this.model; + var fieldEl = this.el.querySelector('[data-layers-wrapper]'); - for (var name in defaults) { - if (!(name in c)) c[name] = defaults[name]; - } + var PropertiesView = __webpack_require__(/*! ./PropertiesView */ "./src/style_manager/view/PropertiesView.js").default; - var ppfx = c.pStylePrefix; - if (ppfx) c.stylePrefix = ppfx + c.stylePrefix; + var propsConfig = { + target: this.target, + propTarget: this.propTarget, + // Things to do when a single sub-property is changed + onChange: function onChange(el, view, opt) { + var subModel = view.model; - // Load dependencies - if (em) { - c.modal = em.get('Modal') || ''; - c.am = em.get('AssetManager') || ''; - em.get('Parser').compTypes = componentTypes; - em.on('change:selectedComponent', this.componentChanged, this); + if (model.get('detached')) { + var subProp = subModel.get('property'); + var values = self.getLayers().getPropertyValues(subProp); + view.updateTargetStyle(values, null, opt); + } else { + model.set('value', model.getFullValue(), opt); + } } + }; + var layers = new _LayersView__WEBPACK_IMPORTED_MODULE_1__["default"]({ + collection: this.getLayers(), + stackModel: model, + preview: model.get('preview'), + config: this.config, + propsConfig: propsConfig + }).render().el; // Will use it to propogate changes - // Build wrapper - var components = c.components; - var wrapper = _extends({}, c.wrapper); - wrapper['custom-name'] = c.wrapperName; - wrapper.wrapper = 1; + new PropertiesView({ + target: this.target, + collection: this.model.get('properties'), + stackModel: model, + config: this.config, + onChange: propsConfig.onChange, + propTarget: propsConfig.propTarget, + customValue: propsConfig.customValue + }).render(); //model.get('properties') - // Components might be a wrapper - if (components && components.constructor === Object && components.wrapper) { - wrapper = _extends({}, components); - components = components.components || []; - wrapper.components = []; + fieldEl.appendChild(layers); + } +})); - // Have to put back the real object of components - if (em) { - em.config.components = components; - c.components = components; - } - } +/***/ }), + +/***/ "./src/style_manager/view/PropertyView.js": +/*!************************************************!*\ + !*** ./src/style_manager/view/PropertyView.js ***! + \************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_2__); +/* harmony import */ var utils_mixins__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! utils/mixins */ "./src/utils/mixins.js"); - component = new Component(wrapper, { - sm: em, - config: c, - componentTypes: componentTypes - }); - component.set({ attributes: { id: 'wrapper' } }); - componentView = new ComponentView({ - model: component, - config: c, - componentTypes: componentTypes - }); - return this; - }, - /** - * On load callback - * @private - */ - onLoad: function onLoad() { - this.getComponents().reset(c.components); - }, +var clearProp = 'data-clear-style'; +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_1___default.a.View.extend({ + template: function template(model) { + var pfx = this.pfx; + return "\n
\n ").concat(this.templateLabel(model), "\n
\n
\n ").concat(this.templateInput(model), "\n
\n "); + }, + templateLabel: function templateLabel(model) { + var pfx = this.pfx; + var icon = model.get('icon') || ''; + var info = model.get('info') || ''; + var parent = model.parent; + return "\n \n ").concat(model.get('name'), "\n \n ").concat(!parent ? "") : '', "\n "); + }, + templateInput: function templateInput(model) { + return "\n
\n \n
\n "); + }, + events: _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()({ + change: 'inputValueChanged' + }, "click [".concat(clearProp, "]"), 'clear'), + initialize: function initialize() { + var _this = this; - /** - * Do stuff after load - * @param {Editor} em - * @private - */ - postLoad: function postLoad(em) { - this.handleChanges(this.getWrapper(), null, { avoidStore: 1 }); - }, + var o = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + Object(underscore__WEBPACK_IMPORTED_MODULE_2__["bindAll"])(this, 'targetUpdated'); + this.config = o.config || {}; + var em = this.config.em; + this.em = em; + this.pfx = this.config.stylePrefix || ''; + this.ppfx = this.config.pStylePrefix || ''; + this.target = o.target || {}; + this.propTarget = o.propTarget || {}; + this.onChange = o.onChange; + this.onInputRender = o.onInputRender || {}; + this.customValue = o.customValue || {}; + var model = this.model; + this.property = model.get('property'); + this.input = null; + var pfx = this.pfx; + this.inputHolderId = '#' + pfx + 'input-holder'; + this.sector = model.collection && model.collection.sector; + model.view = this; + if (!model.get('value')) { + model.set('value', model.getDefaultValue()); + } - /** - * Handle component changes - * @private - */ - handleChanges: function handleChanges(model, value) { - var _this = this; + em && em.on("update:component:style:".concat(this.property), this.targetUpdated); //em && em.on(`styleable:change:${this.property}`, this.targetUpdated); + // Listening to changes of properties in this.requires, so that styleable + // changes based on other properties are propagated - var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + var requires = model.get('requires'); + requires && Object.keys(requires).forEach(function (property) { + em && em.on("component:styleUpdate:".concat(property), _this.targetUpdated); + }); + this.listenTo(this.propTarget, 'update styleManager:update', this.targetUpdated); + this.listenTo(model, 'destroy remove', this.remove); + this.listenTo(model, 'change:value', this.modelValueChanged); + this.listenTo(model, 'targetUpdated', this.targetUpdated); + this.listenTo(model, 'change:visible', this.updateVisibility); + this.listenTo(model, 'change:status', this.updateStatus); + var init = this.init && this.init.bind(this); + init && init(); + }, - var comps = model.components(); - var um = em.get('UndoManager'); - var handleUpdates = em.handleUpdates.bind(em); - var handleChanges = this.handleChanges.bind(this); - var handleRemoves = this.handleRemoves.bind(this); - um && um.add(model); - um && comps && um.add(comps); - var evn = 'change:style change:content change:attributes change:src'; + /** + * Triggers when the status changes. The status indicates if the value of + * the proprerty is changed or inherited + * @private + */ + updateStatus: function updateStatus() { + var model = this.model; + var status = model.get('status'); + var parent = model.parent; + var pfx = this.pfx; + var ppfx = this.ppfx; + var config = this.config; + var updatedCls = "".concat(ppfx, "four-color"); + var computedCls = "".concat(ppfx, "color-warn"); + var labelEl = this.$el.children(".".concat(pfx, "label")); + var clearStyleEl = this.getClearEl(); + var clearStyle = clearStyleEl ? clearStyleEl.style : {}; + labelEl.removeClass("".concat(updatedCls, " ").concat(computedCls)); + clearStyle.display = 'none'; - [[model, evn, handleUpdates], [comps, 'add', handleChanges], [comps, 'remove', handleRemoves], [model.get('classes'), 'add remove', handleUpdates]].forEach(function (els) { - em.stopListening(els[0], els[1], els[2]); - em.listenTo(els[0], els[1], els[2]); - }); + switch (status) { + case 'updated': + !parent && labelEl.addClass(updatedCls); - !opts.avoidStore && handleUpdates('', '', opts); - comps.each(function (model) { - return _this.handleChanges(model, value, opts); - }); - }, + if (config.clearProperties) { + clearStyle.display = 'inline'; + } + break; - /** - * Triggered when some component is removed - * @private - * */ - handleRemoves: function handleRemoves(model, value) { - var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + case 'computed': + labelEl.addClass(computedCls); + break; + } + }, - !opts.avoidStore && em.handleUpdates(model, value, opts); - }, + /** + * Clear the property from the target + */ + clear: function clear(e) { + var _this2 = this; + e && e.stopPropagation(); + this.model.clearValue(); // Skip one stack with setTimeout to avoid inconsistencies - /** - * Load components from the passed object, if the object is empty will try to fetch them - * autonomously from the selected storage - * The fetched data will be added to the collection - * @param {Object} data Object of data to load - * @return {Object} Loaded data - */ - load: function load() { - var data = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : ''; + setTimeout(function () { + return _this2.targetUpdated(); + }); + }, - var result = ''; + /** + * Get clear element + * @return {HTMLElement} + */ + getClearEl: function getClearEl() { + if (!this.clearEl) { + this.clearEl = this.el.querySelector("[".concat(clearProp, "]")); + } - if (!data && c.stm) { - data = c.em.getCacheLoad(); - } + return this.clearEl; + }, - if (data.components) { - try { - result = JSON.parse(data.components); - } catch (err) {} - } else if (data.html) { - result = data.html; - } + /** + * Returns selected target which should have 'style' property + * @return {Model|null} + */ + getTarget: function getTarget() { + return this.getTargetModel(); + }, - var isObj = result && result.constructor === Object; + /** + * Returns Styleable model + * @return {Model|null} + */ + getTargetModel: function getTargetModel() { + return this.propTarget && this.propTarget.model; + }, - if (result && result.length || isObj) { - this.clear(); - this.getComponents().reset(); + /** + * Returns helper Styleable model + * @return {Model|null} + */ + getHelperModel: function getHelperModel() { + return this.propTarget && this.propTarget.helper; + }, - // If the result is an object I consider it the wrapper - if (isObj) { - this.getWrapper().set(result).initComponents().initClasses().loadTraits(); - } else { - this.getComponents().add(result); - } - } + /** + * Triggers when the value of element input/s is changed, so have to update + * the value of the model which will propogate those changes to the target + */ + inputValueChanged: function inputValueChanged(e) { + e && e.stopPropagation(); + this.model.setValue(this.getInputValue(), 1, { + fromInput: 1 + }); + this.elementUpdated(); + }, - return result; - }, + /** + * Fired when the element of the property is updated + */ + elementUpdated: function elementUpdated() { + this.setStatus('updated'); + }, + setStatus: function setStatus(value) { + this.model.set('status', value); + var parent = this.model.parent; + parent && value && parent.set('status', value); + }, + emitUpdateTarget: Object(underscore__WEBPACK_IMPORTED_MODULE_2__["debounce"])(function () { + var em = this.config.em; + em && em.trigger('styleManager:update:target', this.getTarget()); + }), + /** + * Fired when the target is changed + * */ + targetUpdated: function targetUpdated() { + this.emitUpdateTarget(); - /** - * Store components on the selected storage - * @param {Boolean} noStore If true, won't store - * @return {Object} Data to store - */ - store: function store(noStore) { - if (!c.stm) { - return; - } + if (!this.checkVisibility()) { + return; + } - var obj = {}; - var keys = this.storageKey(); + var config = this.config; + var em = config.em; + var model = this.model; + var property = model.get('property'); + var value = ''; + var status = ''; + var targetValue = this.getTargetValue({ + ignoreDefault: 1 + }); + var defaultValue = model.getDefaultValue(); + var computedValue = this.getComputedValue(); - if (keys.indexOf('html') >= 0) { - obj.html = c.em.getHtml(); - } + if (targetValue) { + value = targetValue; - if (keys.indexOf('components') >= 0) { - var toStore = c.storeWrapper ? this.getWrapper() : this.getComponents(); - obj.components = JSON.stringify(toStore); + if (config.highlightChanged) { + status = 'updated'; } + } else if (computedValue && config.showComputed && computedValue != defaultValue) { + value = computedValue; - if (!noStore) { - c.stm.store(obj); + if (config.highlightComputed) { + status = 'computed'; } + } else { + value = defaultValue; + status = ''; + } - return obj; - }, - - - /** - * Returns privately the main wrapper - * @return {Object} - * @private - */ - getComponent: function getComponent() { - return component; - }, + model.setValue(value, 0, { + fromTarget: 1 + }); + this.setStatus(status); + if (em) { + em.trigger('styleManager:change', this, property, value); + em.trigger("styleManager:change:".concat(property), this, value); + } + }, + checkVisibility: function checkVisibility() { + var result = 1; // Check if need to hide the property - /** - * Returns root component inside the canvas. Something like inside HTML page - * The wrapper doesn't differ from the original Component Model - * @return {Component} Root Component - * @example - * // Change background of the wrapper and set some attribute - * var wrapper = domComponents.getWrapper(); - * wrapper.set('style', {'background-color': 'red'}); - * wrapper.set('attributes', {'title': 'Hello!'}); - */ - getWrapper: function getWrapper() { - return this.getComponent(); - }, + if (this.config.hideNotStylable) { + if (!this.isTargetStylable() || !this.isComponentStylable()) { + this.hide(); + result = 0; + } else { + this.show(); + } // Sector is not passed to Composite and Stack types - /** - * Returns wrapper's children collection. Once you have the collection you can - * add other Components(Models) inside. Each component can have several nested - * components inside and you can nest them as more as you wish. - * @return {Components} Collection of components - * @example - * // Let's add some component - * var wrapperChildren = domComponents.getComponents(); - * var comp1 = wrapperChildren.add({ - * style: { 'background-color': 'red'} - * }); - * var comp2 = wrapperChildren.add({ - * tagName: 'span', - * attributes: { title: 'Hello!'} - * }); - * // Now let's add an other one inside first component - * // First we have to get the collection inside. Each - * // component has 'components' property - * var comp1Children = comp1.get('components'); - * // Procede as before. You could also add multiple objects - * comp1Children.add([ - * { style: { 'background-color': 'blue'}}, - * { style: { height: '100px', width: '100px'}} - * ]); - * // Remove comp2 - * wrapperChildren.remove(comp2); - */ - getComponents: function getComponents() { - return this.getWrapper().get('components'); - }, + if (this.sector) { + this.sector.trigger('updateVisibility'); + } + } + return result; + }, - /** - * Add new components to the wrapper's children. It's the same - * as 'domComponents.getComponents().add(...)' - * @param {Object|Component|Array} component Component/s to add - * @param {string} [component.tagName='div'] Tag name - * @param {string} [component.type=''] Type of the component. Available: ''(default), 'text', 'image' - * @param {boolean} [component.removable=true] If component is removable - * @param {boolean} [component.draggable=true] If is possible to move the component around the structure - * @param {boolean} [component.droppable=true] If is possible to drop inside other components - * @param {boolean} [component.badgable=true] If the badge is visible when the component is selected - * @param {boolean} [component.stylable=true] If is possible to style component - * @param {boolean} [component.copyable=true] If is possible to copy&paste the component - * @param {string} [component.content=''] String inside component - * @param {Object} [component.style={}] Style object - * @param {Object} [component.attributes={}] Attribute object - * @return {Component|Array} Component/s added - * @example - * // Example of a new component with some extra property - * var comp1 = domComponents.addComponent({ - * tagName: 'div', - * removable: true, // Can't remove it - * draggable: true, // Can't move it - * copyable: true, // Disable copy/past - * content: 'Content text', // Text inside component - * style: { color: 'red'}, - * attributes: { title: 'here' } - * }); - */ - addComponent: function addComponent(component) { - return this.getComponents().add(component); - }, + /** + * Get the value of this property from the target (eg, Component, CSSRule) + * @param {Object} [opts] Options + * @param {Boolean} [options.fetchFromFunction] + * @param {Boolean} [options.ignoreDefault] + * @return string + * @private + */ + getTargetValue: function getTargetValue() { + var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var result; + var model = this.model; + var target = this.getTargetModel(); + var customFetchValue = this.customValue; + if (!target) { + return result; + } - /** - * Render and returns wrapper element with all components inside. - * Once the wrapper is rendered, and it's what happens when you init the editor, - * the all new components will be added automatically and property changes are all - * updated immediately - * @return {HTMLElement} - */ - render: function render() { - return componentView.render().el; - }, + result = target.getStyle()[model.get('property')]; + if (!result && !opts.ignoreDefault) { + result = model.getDefaultValue(); + } - /** - * Remove all components - * @return {this} - */ - clear: function clear() { - var c = this.getComponents(); - for (var i = 0, len = c.length; i < len; i++) { - c.pop(); - }return this; - }, + if (typeof customFetchValue == 'function' && !opts.ignoreCustomValue) { + var index = model.collection.indexOf(model); + var customValue = customFetchValue(this, index); + if (customValue) { + result = customValue; + } + } - /** - * Set components - * @param {Object|string} components HTML string or components model - * @return {this} - * @private - */ - setComponents: function setComponents(components) { - this.clear().addComponent(components); - }, + return result; + }, + + /** + * Returns computed value + * @return {String} + * @private + */ + getComputedValue: function getComputedValue() { + var target = this.propTarget; + var computed = target.computed || {}; + var computedDef = target.computedDefault || {}; + var avoid = this.config.avoidComputed || []; + var property = this.model.get('property'); + var notToSkip = avoid.indexOf(property) < 0; + var value = computed[property]; + var valueDef = computedDef[Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["camelCase"])(property)]; + return computed && notToSkip && valueDef !== value && value; + }, + /** + * Returns value from input + * @return {string} + */ + getInputValue: function getInputValue() { + var input = this.getInputEl(); + return input ? input.value : ''; + }, - /** - * Add new component type - * @param {string} type - * @param {Object} methods - * @private - */ - addType: function addType(type, methods) { - var compType = this.getType(type); - if (compType) { - compType.model = methods.model; - compType.view = methods.view; - } else { - methods.id = type; - componentTypes.unshift(methods); - } - }, + /** + * Triggers when the `value` of the model changes, so the target and + * the input element should be updated + * @param {Object} e Event + * @param {Mixed} val Value + * @param {Object} opt Options + * */ + modelValueChanged: function modelValueChanged(e, val) { + var opt = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + var em = this.config.em; + var model = this.model; + var value = model.getFullValue(); + var target = this.getTarget(); + var prop = model.get('property'); + var onChange = this.onChange; // Avoid element update if the change comes from it + if (!opt.fromInput) { + this.setValue(value); + } // Check if component is allowed to be styled - /** - * Get component type - * @param {string} type - * @private - */ - getType: function getType(type) { - var df = componentTypes; - for (var it = 0; it < df.length; it++) { - var dfId = df[it].id; - if (dfId == type) { - return df[it]; - } - } + if (!target || !this.isTargetStylable() || !this.isComponentStylable()) { return; - }, + } // Avoid target update if the changes comes from it - /** - * Triggered when the selected component is changed - * @private - */ - componentChanged: function componentChanged() { - var em = c.em; - var model = em.get('selectedComponent'); - var previousModel = em.previous('selectedComponent'); - - // Deselect the previous component - if (previousModel) { - previousModel.set({ - status: '', - state: '' - }); + if (!opt.fromTarget) { + // The onChange is used by Composite/Stack properties, so I'd avoid sending + // it back if the change comes from one of those + if (onChange && !opt.fromParent) { + onChange(target, this, opt); + } else { + this.updateTargetStyle(value, null, opt); } - - model && model.set('status', 'selected'); } - }; -}; - -/***/ }), -/* 151 */ -/***/ (function(module, exports, __webpack_require__) { -"use strict"; + var component = em && em.getSelected(); + if (em && component) { + em.trigger('component:update', component); + em.trigger('component:styleUpdate', component, prop); + em.trigger("component:styleUpdate:".concat(prop), component); + } + }, -module.exports = { - stylePrefix: 'comp-', + /** + * Update target style + * @param {string} value + * @param {string} name + * @param {Object} opts + */ + updateTargetStyle: function updateTargetStyle(value) { + var name = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : ''; + var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + var property = name || this.model.get('property'); + var target = this.getTarget(); + var style = target.getStyle(); - wrapperId: 'wrapper', + if (value) { + style[property] = value; + } else { + delete style[property]; + } - wrapperName: 'Body', + target.setStyle(style, opts); // Helper is used by `states` like ':hover' to show its preview - // Default wrapper configuration - wrapper: { - removable: false, - copyable: false, - draggable: false, - components: [], - traits: [], - stylable: ['background', 'background-color', 'background-image', 'background-repeat', 'background-attachment', 'background-position', 'background-size'] + var helper = this.getHelperModel(); + helper && helper.setStyle(style, opts); }, - // Could be used for default components - components: [], - - // Class for new image component - imageCompClass: 'fa fa-picture-o', - - // Open assets manager on create of image component - oAssetsOnCreate: true, + /** + * Check if target is stylable with this property + * The target could be the Component as the CSS Rule + * @return {Boolean} + */ + isTargetStylable: function isTargetStylable(target) { + var trg = target || this.getTarget(); + var model = this.model; + var id = model.get('id'); + var property = model.get('property'); + var toRequire = model.get('toRequire'); + var unstylable = trg.get('unstylable'); + var stylableReq = trg.get('stylable-require'); + var requires = model.get('requires'); + var requiresParent = model.get('requiresParent'); + var sectors = this.sector ? this.sector.collection : null; + var selected = this.em ? this.em.getSelected() : null; + var stylable = trg.get('stylable'); // Stylable could also be an array indicating with which property + // the target could be styled - // TODO to remove - // Editor should also store the wrapper informations, but as this change might - // break stuff I set ii as an opt-in option, for now. - storeWrapper: 0, + if (Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isArray"])(stylable)) { + stylable = stylable.indexOf(property) >= 0; + } // Check if the property was signed as unstylable - // List of void elements - voidElements: ['area', 'base', 'br', 'col', 'embed', 'hr', 'img', 'input', 'keygen', 'link', 'menuitem', 'meta', 'param', 'source', 'track', 'wbr'] -}; -/***/ }), -/* 152 */ -/***/ (function(module, exports, __webpack_require__) { + if (Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isArray"])(unstylable)) { + stylable = unstylable.indexOf(property) < 0; + } // Check if the property is available only if requested -"use strict"; + if (toRequire) { + stylable = !target || stylableReq && (stylableReq.indexOf(id) >= 0 || stylableReq.indexOf(property) >= 0); + } // Check if the property is available based on other property's values -var _underscore = __webpack_require__(1); -var Backbone = __webpack_require__(0); -var Trait = __webpack_require__(153); -var TraitFactory = __webpack_require__(154); + if (sectors && requires) { + var properties = Object.keys(requires); + sectors.each(function (sector) { + sector.get('properties').each(function (model) { + if (Object(underscore__WEBPACK_IMPORTED_MODULE_2__["includes"])(properties, model.id)) { + var values = requires[model.id]; + stylable = stylable && Object(underscore__WEBPACK_IMPORTED_MODULE_2__["includes"])(values, model.get('value')); + } + }); + }); + } // Check if the property is available based on parent's property values -module.exports = Backbone.Collection.extend({ - model: Trait, + if (requiresParent) { + var parent = selected && selected.parent(); + var parentEl = parent && parent.getEl(); - initialize: function initialize(coll) { - var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + if (parentEl) { + var styles = window.getComputedStyle(parentEl); + Object(underscore__WEBPACK_IMPORTED_MODULE_2__["each"])(requiresParent, function (values, property) { + stylable = stylable && styles[property] && Object(underscore__WEBPACK_IMPORTED_MODULE_2__["includes"])(values, styles[property]); + }); + } else { + stylable = false; + } + } - this.em = options.em || ''; - }, - setTarget: function setTarget(target) { - this.target = target; + return stylable; }, - add: function add(models, opt) { + + /** + * Check if the selected component is stylable with this property + * The target could be the Component as the CSS Rule + * @return {Boolean} + */ + isComponentStylable: function isComponentStylable() { var em = this.em; + var component = em && em.getSelected(); - // Use TraitFactory if necessary - if ((0, _underscore.isString)(models) || (0, _underscore.isArray)(models)) { - var tm = em && em.get && em.get('TraitManager'); - var tmOpts = tm && tm.getConfig(); - var tf = TraitFactory(tmOpts); + if (!component) { + return true; + } - if ((0, _underscore.isString)(models)) { - models = [models]; - } + return this.isTargetStylable(component); + }, - for (var i = 0, len = models.length; i < len; i++) { - var str = models[i]; - var model = (0, _underscore.isString)(str) ? tf.build(str)[0] : str; - model.target = this.target; - models[i] = model; - } + /** + * Passed a raw value you have to update the input element, generally + * is the value fetched from targets, so you can receive values with + * functions, units, etc. (eg. `rotateY(45deg)`) + * get also + * @param {string} value + * @private + */ + setRawValue: function setRawValue(value) { + this.setValue(this.model.parseValue(value)); + }, + + /** + * Update the element input. + * Usually the value is a result of `model.getFullValue()` + * @param {String} value The value from the model + * */ + setValue: function setValue(value) { + var model = this.model; + var val = Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isUndefined"])(value) ? model.getDefaultValue() : value; + var input = this.getInputEl(); + input && (input.value = val); + }, + getInputEl: function getInputEl() { + if (!this.input) { + this.input = this.el.querySelector('input'); } - return Backbone.Collection.prototype.add.apply(this, [models, opt]); + return this.input; + }, + updateVisibility: function updateVisibility() { + this.el.style.display = this.model.get('visible') ? 'block' : 'none'; + }, + show: function show() { + this.model.set('visible', 1); + }, + hide: function hide() { + this.model.set('visible', 0); + }, + + /** + * Clean input + * */ + cleanValue: function cleanValue() { + this.setValue(''); + }, + clearCached: function clearCached() { + this.clearEl = null; + this.input = null; + this.$input = null; + }, + render: function render() { + this.clearCached(); + var pfx = this.pfx; + var model = this.model; + var el = this.el; + var property = model.get('property'); + var full = model.get('full'); + var className = "".concat(pfx, "property"); + el.innerHTML = this.template(model); + el.className = "".concat(className, " ").concat(pfx).concat(model.get('type'), " ").concat(className, "__").concat(property); + el.className += full ? " ".concat(className, "--full") : ''; + this.updateStatus(); + var onRender = this.onRender && this.onRender.bind(this); + onRender && onRender(); + this.setValue(model.get('value'), { + targetUpdate: 1 + }); } -}); +})); /***/ }), -/* 153 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; -var _underscore = __webpack_require__(1); +/***/ "./src/style_manager/view/SectorView.js": +/*!**********************************************!*\ + !*** ./src/style_manager/view/SectorView.js ***! + \**********************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { -module.exports = __webpack_require__(0).Model.extend({ +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var _PropertiesView__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./PropertiesView */ "./src/style_manager/view/PropertiesView.js"); - defaults: { - type: 'text', // text, number, range, select - label: '', - name: '', - min: '', - max: '', - unit: '', - step: 1, - value: '', - target: '', - default: '', - placeholder: '', - changeProp: 0, - options: [] - }, - initialize: function initialize() { - var target = this.get('target'); - var name = this.get('name'); - var changeProp = this.get('changeProp'); - if (target) { - this.target = target; - this.unset('target'); - var targetEvent = changeProp ? 'change:' + name : 'change:attributes:' + name; - this.listenTo(target, targetEvent, this.targetUpdated); - } - }, - targetUpdated: function targetUpdated() { - var value = this.getTargetValue(); - !(0, _underscore.isUndefined)(value) && this.set({ value: value }, { fromTarget: 1 }); +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_0___default.a.View.extend({ + template: Object(underscore__WEBPACK_IMPORTED_MODULE_1__["template"])("\n
title\" data-sector-title>\n caret\" class=\"fa\">\n <%= label %>\n
"), + events: { + 'click [data-sector-title]': 'toggle' }, - getTargetValue: function getTargetValue() { - var name = this.get('name'); - var target = this.target; - var prop = this.get('changeProp'); - if (target) return prop ? target.get(name) : target.getAttributes()[name]; + initialize: function initialize(o) { + this.config = o.config || {}; + this.pfx = this.config.stylePrefix || ''; + this.target = o.target || {}; + this.propTarget = o.propTarget || {}; + this.caretR = 'fa-caret-right'; + this.caretD = 'fa-caret-down'; + var model = this.model; + this.listenTo(model, 'change:open', this.updateOpen); + this.listenTo(model, 'updateVisibility', this.updateVisibility); + this.listenTo(model, 'destroy remove', this.remove); }, - setTargetValue: function setTargetValue(value) { - var target = this.target; - var name = this.get('name'); - if ((0, _underscore.isUndefined)(value)) return; - if (this.get('changeProp')) { - target.set(name, value); - } else { - var attrs = _extends({}, target.get('attributes')); - attrs[name] = value; - target.set('attributes', attrs); - } + /** + * If all properties are hidden this will hide the sector + */ + updateVisibility: function updateVisibility() { + var show; + this.model.get('properties').each(function (prop) { + if (prop.get('visible')) { + show = 1; + } + }); + this.el.style.display = show ? 'block' : 'none'; }, - /** - * Get the initial value of the trait - * @return {string} + * Update visibility */ - getInitValue: function getInitValue() { - var target = this.target; - var name = this.get('name'); - var value = void 0; - - if (target) { - var attrs = target.get('attributes'); - value = this.get('changeProp') ? target.get(name) : attrs[name]; - } - - return value || this.get('value') || this.get('default'); - } -}); - -/***/ }), -/* 154 */ -/***/ (function(module, exports, __webpack_require__) { + updateOpen: function updateOpen() { + if (this.model.get('open')) this.show();else this.hide(); + }, -"use strict"; + /** + * Show the content of the sector + * */ + show: function show() { + this.$el.addClass(this.pfx + 'open'); + this.getPropertiesEl().style.display = ''; + this.$caret.removeClass(this.caretR).addClass(this.caretD); + }, + /** + * Hide the content of the sector + * */ + hide: function hide() { + this.$el.removeClass(this.pfx + 'open'); + this.getPropertiesEl().style.display = 'none'; + this.$caret.removeClass(this.caretD).addClass(this.caretR); + }, + getPropertiesEl: function getPropertiesEl() { + return this.$el.find(".".concat(this.pfx, "properties")).get(0); + }, -module.exports = function () { - var config = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; - return { - /** - * Build props object by their name - * @param {Array|string} props Array of properties name - * @return {Array} - */ - build: function build(props) { - var objs = []; + /** + * Toggle visibility + * */ + toggle: function toggle(e) { + var v = this.model.get('open') ? 0 : 1; + this.model.set('open', v); + }, + render: function render() { + var pfx = this.pfx, + model = this.model; + var id = model.attributes.id; + this.$el.html(this.template({ + pfx: pfx, + label: model.get('name') + })); + this.$caret = this.$el.find("#".concat(pfx, "caret")); + this.renderProperties(); + this.$el.attr('class', "".concat(pfx, "sector ").concat(pfx, "sector__").concat(id, " no-select")); + this.updateOpen(); + return this; + }, + renderProperties: function renderProperties() { + var objs = this.model.get('properties'); - if (typeof props === 'string') props = [props]; + if (objs) { + var view = new _PropertiesView__WEBPACK_IMPORTED_MODULE_2__["default"]({ + collection: objs, + target: this.target, + propTarget: this.propTarget, + config: this.config + }); + this.$el.append(view.render().el); + } + } +})); - for (var i = 0; i < props.length; i++) { - var obj = {}; - var prop = props[i]; - obj.name = prop; +/***/ }), - // Define type - switch (prop) { - case 'target': - obj.type = 'select'; - break; - } +/***/ "./src/style_manager/view/SectorsView.js": +/*!***********************************************!*\ + !*** ./src/style_manager/view/SectorsView.js ***! + \***********************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - // Define placeholder - switch (prop) { - case 'title':case 'alt':case 'id': - obj.placeholder = config.labelPlhText; - break; - case 'href': - obj.placeholder = config.labelPlhHref; - break; - } +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_2__); +/* harmony import */ var utils_mixins__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! utils/mixins */ "./src/utils/mixins.js"); +/* harmony import */ var utils_dom__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! utils/dom */ "./src/utils/dom.js"); +/* harmony import */ var _SectorView__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./SectorView */ "./src/style_manager/view/SectorView.js"); - // Define options - switch (prop) { - case 'target': - obj.options = config.optionsTarget; - break; - } - objs.push(obj); - } +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - return objs; - } - }; -}; +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } -/***/ }), -/* 155 */ -/***/ (function(module, exports, __webpack_require__) { -"use strict"; -var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; -var Component = __webpack_require__(4); -module.exports = Component.extend({ +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_1___default.a.View.extend({ + initialize: function initialize() { + var o = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var config = o.config || {}; + this.pfx = config.stylePrefix || ''; + this.ppfx = config.pStylePrefix || ''; + this.target = o.target || {}; + this.config = config; // The target that will emit events for properties - defaults: _extends({}, Component.prototype.defaults, { - type: 'cell', - tagName: 'td', - draggable: ['tr'] - }) + var target = {}; + Object(underscore__WEBPACK_IMPORTED_MODULE_2__["extend"])(target, backbone__WEBPACK_IMPORTED_MODULE_1___default.a.Events); + var body = document.body; + var dummy = document.createElement("el-".concat(new Date().getTime())); + body.appendChild(dummy); + target.computedDefault = _objectSpread({}, window.getComputedStyle(dummy)); + body.removeChild(dummy); + this.propTarget = target; + var coll = this.collection; + var events = 'component:toggled component:update:classes component:update:state change:device'; + this.listenTo(coll, 'add', this.addTo); + this.listenTo(coll, 'reset', this.render); + this.listenTo(this.target, events, this.targetUpdated); + }, -}, { - isComponent: function isComponent(el) { - var result = ''; - var tag = el.tagName; + /** + * Add to collection + * @param {Object} model Model + * @return {Object} + * @private + * */ + addTo: function addTo(model, coll) { + var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + this.addToCollection(model, null, opts); + }, - if (tag == 'TD' || tag == 'TH') { - result = { - type: 'cell', - tagName: tag.toLowerCase() - }; - } + /** + * Fired when target is updated + * @private + */ + targetUpdated: function targetUpdated() { + var em = this.target; + var pt = this.propTarget; + var model = em.getSelected(); + if (!model) return; + var config = em.get('Config'); + var state = !config.devicePreviewMode ? model.get('state') : ''; + var el = model.getEl(); + pt.helper = null; // Create computed style container - return result; - } -}); + if (el && Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["isTaggableNode"])(el)) { + var stateStr = state ? ":".concat(state) : null; + pt.computed = window.getComputedStyle(el, stateStr); + } // Create a new rule for the state as a helper -/***/ }), -/* 156 */ -/***/ (function(module, exports, __webpack_require__) { -"use strict"; + var appendStateRule = function appendStateRule() { + var style = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var cc = em.get('CssComposer'); + var helperCls = 'hc-state'; + var rules = cc.getAll(); + var helperRule = cc.getClassRule(helperCls); + if (!helperRule) { + helperRule = cc.setClassRule(helperCls); + } else { + // I will make it last again, otherwise it could be overridden + rules.remove(helperRule); + rules.add(helperRule); + } -var Backbone = __webpack_require__(0); -var ComponentView = __webpack_require__(3); + helperRule.set('important', 1); + helperRule.setStyle(style); + pt.helper = helperRule; + }; -module.exports = ComponentView.extend({}); + model = em.get('StyleManager').getModelToStyle(model); + state && appendStateRule(model.getStyle()); + pt.model = model; + pt.trigger('update'); + }, -/***/ }), -/* 157 */ -/***/ (function(module, exports, __webpack_require__) { + /** + * Select different target for the Style Manager. + * It could be a Component, CSSRule, or a string of any CSS selector + * @param {Component|CSSRule|String} target + * @return {Styleable} A Component or CSSRule + */ + setTarget: function setTarget(target) { + var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + var em = this.target; + var config = em.get('Config'); + var targetIsClass = opts.targetIsClass, + stylable = opts.stylable; + var model = target; -"use strict"; + if (Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isString"])(target)) { + var rule; + var rules = em.get('CssComposer').getAll(); + if (targetIsClass) { + rule = rules.filter(function (rule) { + return rule.get('selectors').getFullString() === target; + })[0]; + } -var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; + if (!rule) { + rule = rules.filter(function (rule) { + return rule.get('selectorsAdd') === target; + })[0]; + } -var Component = __webpack_require__(4); + if (!rule) { + rule = rules.add({ + selectors: [], + selectorsAdd: target + }); + } -module.exports = Component.extend({ + stylable && rule.set({ + stylable: stylable + }); + model = rule; + } - defaults: _extends({}, Component.prototype.defaults, { - type: 'row', - tagName: 'tr', - draggable: ['thead', 'tbody', 'tfoot'], - droppable: ['th', 'td'] - }), + var state = !config.devicePreviewMode ? model.get('state') : ''; + var pt = this.propTarget; + pt.model = model; + pt.trigger('styleManager:update', model); + return model; + }, - initialize: function initialize(o, opt) { - Component.prototype.initialize.apply(this, arguments); + /** + * Add new object to collection + * @param {Object} model Model + * @param {Object} fragmentEl collection + * @return {Object} Object created + * @private + * */ + addToCollection: function addToCollection(model, fragmentEl) { + var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + var pfx = this.pfx, + target = this.target, + propTarget = this.propTarget, + config = this.config, + el = this.el; + var appendTo = fragmentEl || el; + var rendered = new _SectorView__WEBPACK_IMPORTED_MODULE_5__["default"]({ + model: model, + id: "".concat(pfx).concat(model.get('id')), + name: model.get('name'), + properties: model.get('properties'), + target: target, + propTarget: propTarget, + config: config + }).render().el; + Object(utils_dom__WEBPACK_IMPORTED_MODULE_4__["appendAtIndex"])(appendTo, rendered, opts.at); + return rendered; + }, + render: function render() { + var _this = this; - // Clean the row from non cell components - var cells = []; - var components = this.get('components'); - components.each(function (model) { - return model.is('cell') && cells.push(model); + var frag = document.createDocumentFragment(); + var $el = this.$el; + var pfx = this.pfx; + var ppfx = this.ppfx; + $el.empty(); + this.collection.each(function (model) { + return _this.addToCollection(model, frag); }); - components.reset(cells); + $el.append(frag); + $el.addClass("".concat(pfx, "sectors ").concat(ppfx, "one-bg ").concat(ppfx, "two-color")); + return this; } -}, { - isComponent: function isComponent(el) { - var result = ''; +})); - if (el.tagName == 'TR') { - result = { type: 'row' }; - } +/***/ }), - return result; - } +/***/ "./src/trait_manager/config/config.js": +/*!********************************************!*\ + !*** ./src/trait_manager/config/config.js ***! + \********************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony default export */ __webpack_exports__["default"] = ({ + stylePrefix: 'trt-', + // Specify the element to use as a container, string (query) or HTMLElement + // With the empty value, nothing will be rendered + appendTo: '', + labelContainer: 'Component settings', + // Placeholder label for text input types + labelPlhText: 'eg. Text here', + // Placeholder label for href input + labelPlhHref: 'eg. https://google.com', + // Default options for the target input + optionsTarget: [{ + value: '', + name: 'This window' + }, { + value: '_blank', + name: 'New window' + }], + // Text to show in case no element selected + textNoElement: 'Select an element before using Trait Manager' }); /***/ }), -/* 158 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; +/***/ "./src/trait_manager/index.js": +/*!************************************!*\ + !*** ./src/trait_manager/index.js ***! + \************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { -var Backbone = __webpack_require__(0); -var ComponentView = __webpack_require__(3); +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _config_config__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./config/config */ "./src/trait_manager/config/config.js"); +/* harmony import */ var _view_TraitsView__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./view/TraitsView */ "./src/trait_manager/view/TraitsView.js"); -module.exports = ComponentView.extend({}); -/***/ }), -/* 159 */ -/***/ (function(module, exports, __webpack_require__) { -"use strict"; +/* harmony default export */ __webpack_exports__["default"] = (function () { + var c = {}; + var TraitsViewer; + return { + TraitsView: _view_TraitsView__WEBPACK_IMPORTED_MODULE_2__["default"], + /** + * Name of the module + * @type {String} + * @private + */ + name: 'TraitManager', -var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; + /** + * Get configuration object + * @return {Object} + * @private + */ + getConfig: function getConfig() { + return c; + }, -var Component = __webpack_require__(4); + /** + * Initialize module. Automatically called with a new instance of the editor + * @param {Object} config Configurations + */ + init: function init() { + var config = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + c = config; + Object(underscore__WEBPACK_IMPORTED_MODULE_0__["defaults"])(c, _config_config__WEBPACK_IMPORTED_MODULE_1__["default"]); + var ppfx = c.pStylePrefix; + ppfx && (c.stylePrefix = "".concat(ppfx).concat(c.stylePrefix)); + TraitsViewer = new _view_TraitsView__WEBPACK_IMPORTED_MODULE_2__["default"]({ + collection: [], + editor: c.em, + config: c + }); + return this; + }, + postRender: function postRender() { + var elTo = this.getConfig().appendTo; -module.exports = Component.extend({ + if (elTo) { + var el = Object(underscore__WEBPACK_IMPORTED_MODULE_0__["isElement"])(elTo) ? elTo : document.querySelector(elTo); + el.appendChild(this.render()); + } + }, - defaults: _extends({}, Component.prototype.defaults, { - type: 'table', - tagName: 'table', - droppable: ['tbody', 'thead', 'tfoot'] - }), + /** + * + * Get Traits viewer + * @private + */ + getTraitsViewer: function getTraitsViewer() { + return TraitsViewer; + }, - initialize: function initialize(o, opt) { - Component.prototype.initialize.apply(this, arguments); - var components = this.get('components'); - !components.length && components.add({ type: 'tbody' }); - } -}, { - isComponent: function isComponent(el) { - var result = ''; + /** + * Add new trait type + * @param {string} name Type name + * @param {Object} methods Object representing the trait + */ + addType: function addType(name, trait) { + var itemView = TraitsViewer.itemView; + TraitsViewer.itemsView[name] = itemView.extend(trait); + }, - if (el.tagName == 'TABLE') { - result = { type: 'table' }; + /** + * Get trait type + * @param {string} name Type name + * @return {Object} + */ + getType: function getType(name) { + return TraitsViewer.itemsView[name]; + }, + render: function render() { + return TraitsViewer.render().el; } - - return result; - } + }; }); /***/ }), -/* 160 */ -/***/ (function(module, exports, __webpack_require__) { + +/***/ "./src/trait_manager/model/Trait.js": +/*!******************************************!*\ + !*** ./src/trait_manager/model/Trait.js ***! + \******************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_2__); -var Backbone = __webpack_require__(0); -var ComponentView = __webpack_require__(3); +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } -module.exports = ComponentView.extend({ - events: {} -}); +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } -/***/ }), -/* 161 */ -/***/ (function(module, exports, __webpack_require__) { -"use strict"; +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_1___default.a.Model.extend({ + defaults: { + type: 'text', + // text, number, range, select + label: '', + name: '', + min: '', + max: '', + unit: '', + step: 1, + value: '', + target: '', + default: '', + placeholder: '', + changeProp: 0, + options: [] + }, + initialize: function initialize() { + var target = this.get('target'); + var name = this.get('name'); + var changeProp = this.get('changeProp'); -var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; + if (target) { + this.target = target; + this.unset('target'); + var targetEvent = changeProp ? "change:".concat(name) : "change:attributes:".concat(name); + this.listenTo(target, targetEvent, this.targetUpdated); + } + }, -var ComponentTableBody = __webpack_require__(19); + /** + * Return all the propeties + * @returns {Object} + */ + props: function props() { + return this.attributes; + }, + targetUpdated: function targetUpdated() { + var value = this.getTargetValue(); + this.set({ + value: value + }, { + fromTarget: 1 + }); + }, + getTargetValue: function getTargetValue() { + var name = this.get('name'); + var target = this.target; + var value; -module.exports = ComponentTableBody.extend({ + if (this.get('changeProp')) { + value = target.get(name); + } else { + value = target.getAttributes()[name]; + } - defaults: _extends({}, ComponentTableBody.prototype.defaults, { - type: 'thead', - tagName: 'thead' - }) + return !Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isUndefined"])(value) ? value : ''; + }, + setTargetValue: function setTargetValue(value) { + var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + var target = this.target; + var name = this.get('name'); + if (Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isUndefined"])(value)) return; -}, { - isComponent: function isComponent(el) { - var result = ''; + if (this.get('changeProp')) { + target.set(name, value, opts); + } else { + var attrs = _objectSpread({}, target.get('attributes')); - if (el.tagName == 'THEAD') { - result = { type: 'thead' }; + attrs[name] = value; + target.set('attributes', attrs, opts); } + }, + setValueFromInput: function setValueFromInput(value) { + var final = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1; + var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + var toSet = { + value: value + }; + this.set(toSet, _objectSpread({}, opts, { + avoidStore: 1 + })); // Have to trigger the change - return result; - } -}); - -/***/ }), -/* 162 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; + if (final) { + this.set('value', '', opts); + this.set(toSet, opts); + } + }, + /** + * Get the initial value of the trait + * @return {string} + */ + getInitValue: function getInitValue() { + var target = this.target; + var name = this.get('name'); + var value; -var Backbone = __webpack_require__(0); -var ComponentView = __webpack_require__(3); + if (target) { + var attrs = target.get('attributes'); + value = this.get('changeProp') ? target.get(name) : attrs[name]; + } -module.exports = ComponentView.extend({}); + return value || this.get('value') || this.get('default'); + } +})); /***/ }), -/* 163 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - -var Backbone = __webpack_require__(0); -var ComponentView = __webpack_require__(3); +/***/ "./src/trait_manager/model/TraitFactory.js": +/*!*************************************************!*\ + !*** ./src/trait_manager/model/TraitFactory.js ***! + \*************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { -module.exports = ComponentView.extend({}); +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony default export */ __webpack_exports__["default"] = (function () { + var config = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + return { + /** + * Build props object by their name + * @param {Array|string} props Array of properties name + * @return {Array} + */ + build: function build(props) { + var objs = []; + if (typeof props === 'string') props = [props]; -/***/ }), -/* 164 */ -/***/ (function(module, exports, __webpack_require__) { + for (var i = 0; i < props.length; i++) { + var obj = {}; + var prop = props[i]; + obj.name = prop; // Define type -"use strict"; + switch (prop) { + case 'target': + obj.type = 'select'; + break; + } // Define placeholder -var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; + switch (prop) { + case 'title': + case 'alt': + case 'id': + obj.placeholder = config.labelPlhText; + break; -var ComponentTableBody = __webpack_require__(19); + case 'href': + obj.placeholder = config.labelPlhHref; + break; + } // Define options -module.exports = ComponentTableBody.extend({ - defaults: _extends({}, ComponentTableBody.prototype.defaults, { - type: 'tfoot', - tagName: 'tfoot' - }) + switch (prop) { + case 'target': + obj.options = config.optionsTarget; + break; + } -}, { - isComponent: function isComponent(el) { - var result = ''; + objs.push(obj); + } - if (el.tagName == 'TFOOT') { - result = { type: 'tfoot' }; + return objs; } - - return result; - } + }; }); /***/ }), -/* 165 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - -var Backbone = __webpack_require__(0); -var ComponentView = __webpack_require__(3); - -module.exports = ComponentView.extend({}); - -/***/ }), -/* 166 */ -/***/ (function(module, exports, __webpack_require__) { +/***/ "./src/trait_manager/model/Traits.js": +/*!*******************************************!*\ + !*** ./src/trait_manager/model/Traits.js ***! + \*******************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; -/* WEBPACK VAR INJECTION */(function(_) { - -var Component = __webpack_require__(20); -var OComponent = __webpack_require__(4); - -module.exports = Component.extend({ - - defaults: _.extend({}, Component.prototype.defaults, { - type: 'map', - void: 0, - mapUrl: 'https://maps.google.com/maps', - tagName: 'iframe', - mapType: 'q', - address: '', - zoom: '1', - attributes: { frameborder: 0 }, - toolbar: OComponent.prototype.defaults.toolbar, - traits: [{ - label: 'Address', - name: 'address', - placeholder: 'eg. London, UK', - changeProp: 1 - }, { - type: 'select', - label: 'Map type', - name: 'mapType', - changeProp: 1, - options: [{ value: 'q', name: 'Roadmap' }, { value: 'w', name: 'Satellite' }] - }, { - label: 'Zoom', - name: 'zoom', - type: 'range', - min: '1', - max: '20', - changeProp: 1 - }] - }), - - initialize: function initialize(o, opt) { - if (this.get('src')) this.parseFromSrc();else this.updateSrc(); - Component.prototype.initialize.apply(this, arguments); - this.listenTo(this, 'change:address change:zoom change:mapType', this.updateSrc); - }, - updateSrc: function updateSrc() { - this.set('src', this.getMapUrl()); - }, - +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var _Trait__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./Trait */ "./src/trait_manager/model/Trait.js"); +/* harmony import */ var _TraitFactory__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./TraitFactory */ "./src/trait_manager/model/TraitFactory.js"); - /** - * Returns url of the map - * @return {string} - * @private - */ - getMapUrl: function getMapUrl() { - var md = this; - var addr = md.get('address'); - var zoom = md.get('zoom'); - var type = md.get('mapType'); - var size = ''; - addr = addr ? '&q=' + addr : ''; - zoom = zoom ? '&z=' + zoom : ''; - type = type ? '&t=' + type : ''; - var result = md.get('mapUrl') + '?' + addr + zoom + type; - result += '&output=embed'; - return result; - }, - /** - * Set attributes by src string - * @private - */ - parseFromSrc: function parseFromSrc() { - var uri = this.parseUri(this.get('src')); - var qr = uri.query; - if (qr.q) this.set('address', qr.q); - if (qr.z) this.set('zoom', qr.z); - if (qr.t) this.set('mapType', qr.t); - } -}, { - /** - * Detect if the passed element is a valid component. - * In case the element is valid an object abstracted - * from the element will be returned - * @param {HTMLElement} - * @return {Object} - * @private - */ - isComponent: function isComponent(el) { - var result = ''; - if (el.tagName == 'IFRAME' && /maps\.google\.com/.test(el.src)) { - result = { type: 'map', src: el.src }; - } - return result; - } -}); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(1))) +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_0___default.a.Collection.extend({ + model: _Trait__WEBPACK_IMPORTED_MODULE_2__["default"], + initialize: function initialize(coll) { + var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + this.em = options.em || ''; + this.listenTo(this, 'add', this.handleAdd); + this.listenTo(this, 'reset', this.handleReset); + }, + handleReset: function handleReset(coll) { + var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}, + _ref$previousModels = _ref.previousModels, + previousModels = _ref$previousModels === void 0 ? [] : _ref$previousModels; -/***/ }), -/* 167 */ -/***/ (function(module, exports, __webpack_require__) { + previousModels.forEach(function (model) { + return model.trigger('remove'); + }); + }, + handleAdd: function handleAdd(model) { + var target = this.target; -"use strict"; + if (target) { + model.target = target; + } + }, + setTarget: function setTarget(target) { + this.target = target; + }, + add: function add(models, opt) { + var em = this.em; // Use TraitFactory if necessary + if (Object(underscore__WEBPACK_IMPORTED_MODULE_1__["isString"])(models) || Object(underscore__WEBPACK_IMPORTED_MODULE_1__["isArray"])(models)) { + var tm = em && em.get && em.get('TraitManager'); + var tmOpts = tm && tm.getConfig(); + var tf = Object(_TraitFactory__WEBPACK_IMPORTED_MODULE_3__["default"])(tmOpts); -var Backbone = __webpack_require__(0); -var ComponentView = __webpack_require__(15); + if (Object(underscore__WEBPACK_IMPORTED_MODULE_1__["isString"])(models)) { + models = [models]; + } -module.exports = ComponentView.extend({ + for (var i = 0, len = models.length; i < len; i++) { + var str = models[i]; + var model = Object(underscore__WEBPACK_IMPORTED_MODULE_1__["isString"])(str) ? tf.build(str)[0] : str; + model.target = this.target; + models[i] = model; + } + } - tagName: 'div', + return backbone__WEBPACK_IMPORTED_MODULE_0___default.a.Collection.prototype.add.apply(this, [models, opt]); + } +})); - events: {}, +/***/ }), - initialize: function initialize(o) { - ComponentView.prototype.initialize.apply(this, arguments); - this.classEmpty = this.ppfx + 'plh-map'; - }, +/***/ "./src/trait_manager/view/TraitButtonView.js": +/*!***************************************************!*\ + !*** ./src/trait_manager/view/TraitButtonView.js ***! + \***************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _TraitView__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./TraitView */ "./src/trait_manager/view/TraitView.js"); - /** - * Update the map on the canvas - * @private - */ - updateSrc: function updateSrc() { - this.getIframe().src = this.model.get('src'); + +/* harmony default export */ __webpack_exports__["default"] = (_TraitView__WEBPACK_IMPORTED_MODULE_1__["default"].extend({ + events: { + 'click button': 'handleClick' }, - getIframe: function getIframe() { - if (!this.iframe) { - var ifrm = document.createElement("iframe"); - ifrm.src = this.model.get('src'); - ifrm.frameBorder = 0; - ifrm.style.height = '100%'; - ifrm.style.width = '100%'; - ifrm.className = this.ppfx + 'no-pointer'; - this.iframe = ifrm; + templateInput: '', + handleClick: function handleClick() { + var model = this.model, + em = this.em; + var command = model.get('command'); + + if (command) { + if (Object(underscore__WEBPACK_IMPORTED_MODULE_0__["isString"])(command)) { + em.get('Commands').run(command); + } else { + command(em.get('Editor'), model); + } } - return this.iframe; }, - render: function render() { - for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) { - args[_key] = arguments[_key]; + renderLabel: function renderLabel() { + if (this.model.get('label')) { + _TraitView__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.renderLabel.apply(this, arguments); } + }, + getInputEl: function getInputEl() { + var model = this.model, + ppfx = this.ppfx; - ComponentView.prototype.render.apply(this, args); - this.updateClasses(); - this.el.appendChild(this.getIframe()); - return this; + var _model$props = model.props(), + labelButton = _model$props.labelButton, + text = _model$props.text, + full = _model$props.full; + + var label = labelButton || text; + var className = "".concat(ppfx, "btn"); + var input = ""); + return input; } -}); +})); /***/ }), -/* 168 */ -/***/ (function(module, exports, __webpack_require__) { + +/***/ "./src/trait_manager/view/TraitCheckboxView.js": +/*!*****************************************************!*\ + !*** ./src/trait_manager/view/TraitCheckboxView.js ***! + \*****************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _TraitView__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./TraitView */ "./src/trait_manager/view/TraitView.js"); -var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; +/* harmony default export */ __webpack_exports__["default"] = (_TraitView__WEBPACK_IMPORTED_MODULE_1__["default"].extend({ + appendInput: 0, + templateInput: function templateInput() { + var ppfx = this.ppfx, + clsField = this.clsField; + return ""); + }, -var Component = __webpack_require__(51); + /** + * Fires when the input is changed + * @private + */ + onChange: function onChange() { + var value = this.getInputElem().checked; + this.model.set('value', this.getCheckedValue(value)); + }, + getCheckedValue: function getCheckedValue(checked) { + var result = checked; + var _this$model$attribute = this.model.attributes, + valueTrue = _this$model$attribute.valueTrue, + valueFalse = _this$model$attribute.valueFalse; -module.exports = Component.extend({ + if (result && !Object(underscore__WEBPACK_IMPORTED_MODULE_0__["isUndefined"])(valueTrue)) { + result = valueTrue; + } - defaults: _extends({}, Component.prototype.defaults, { - type: 'link', - tagName: 'a', - traits: ['title', 'href', 'target'] - }), + if (!result && !Object(underscore__WEBPACK_IMPORTED_MODULE_0__["isUndefined"])(valueFalse)) { + result = valueFalse; + } + + return result; + }, /** - * Returns object of attributes for HTML - * @return {Object} + * Returns input element + * @return {HTMLElement} * @private */ - getAttrToHTML: function getAttrToHTML() { - for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) { + getInputEl: function getInputEl() { + var toInit = !this.$input; + + for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) { args[_key] = arguments[_key]; } - var attr = Component.prototype.getAttrToHTML.apply(this, args); - delete attr.onmousedown; - return attr; - } -}, { - isComponent: function isComponent(el) { - var result = void 0; - var avoidEdit = void 0; - - if (el.tagName == 'A') { - result = { - type: 'link', - editable: 0 - }; + var el = _TraitView__WEBPACK_IMPORTED_MODULE_1__["default"].prototype.getInputEl.apply(this, args); - // The link is editable only if, at least, one of its - // children is a text node (not empty one) - var children = el.childNodes; - var len = children.length; - if (!len) delete result.editable; + if (toInit) { + var checked, targetValue; + var model = this.model, + target = this.target; + var _model$attributes = model.attributes, + valueTrue = _model$attributes.valueTrue, + valueFalse = _model$attributes.valueFalse; + var name = model.get('name'); - for (var i = 0; i < len; i++) { - var child = children[i]; + if (model.get('changeProp')) { + checked = target.get(name); + targetValue = checked; + } else { + targetValue = target.get('attributes')[name]; + checked = targetValue || targetValue === '' ? !0 : !1; + } - if (child.nodeType == 3 && child.textContent.trim() != '') { - delete result.editable; - break; - } + if (!Object(underscore__WEBPACK_IMPORTED_MODULE_0__["isUndefined"])(valueFalse) && targetValue === valueFalse) { + checked = !1; } + + el.checked = checked; } - return result; + return el; } -}); +})); /***/ }), -/* 169 */ -/***/ (function(module, exports, __webpack_require__) { + +/***/ "./src/trait_manager/view/TraitColorView.js": +/*!**************************************************!*\ + !*** ./src/trait_manager/view/TraitColorView.js ***! + \**************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _TraitView__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./TraitView */ "./src/trait_manager/view/TraitView.js"); +/* harmony import */ var domain_abstract_ui_InputColor__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! domain_abstract/ui/InputColor */ "./src/domain_abstract/ui/InputColor.js"); -var Backbone = __webpack_require__(0); -var ComponentView = __webpack_require__(52); +/* harmony default export */ __webpack_exports__["default"] = (_TraitView__WEBPACK_IMPORTED_MODULE_0__["default"].extend({ + templateInput: '', -module.exports = ComponentView.extend({ - render: function render() { - for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) { - args[_key] = arguments[_key]; + /** + * Returns input element + * @return {HTMLElement} + * @private + */ + getInputEl: function getInputEl() { + if (!this.input) { + var model = this.model; + var value = this.getModelValue(); + var inputColor = new domain_abstract_ui_InputColor__WEBPACK_IMPORTED_MODULE_1__["default"]({ + model: model, + target: this.config.em, + contClass: this.ppfx + 'field-color', + ppfx: this.ppfx + }); + var input = inputColor.render(); + input.setValue(value, { + fromTarget: 1 + }); + this.input = input.el; } - ComponentView.prototype.render.apply(this, args); - - // I need capturing instead of bubbling as bubbled clicks from other - // children will execute the link event - this.el.addEventListener('click', this.prevDef, true); - - return this; + return this.input; } -}); +})); /***/ }), -/* 170 */ -/***/ (function(module, exports, __webpack_require__) { + +/***/ "./src/trait_manager/view/TraitNumberView.js": +/*!***************************************************!*\ + !*** ./src/trait_manager/view/TraitNumberView.js ***! + \***************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _TraitView__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./TraitView */ "./src/trait_manager/view/TraitView.js"); +/* harmony import */ var domain_abstract_ui_InputNumber__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! domain_abstract/ui/InputNumber */ "./src/domain_abstract/ui/InputNumber.js"); -var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; +/* harmony default export */ __webpack_exports__["default"] = (_TraitView__WEBPACK_IMPORTED_MODULE_0__["default"].extend({ + getValueForTarget: function getValueForTarget() { + var model = this.model; + var _model$attributes = model.attributes, + value = _model$attributes.value, + unit = _model$attributes.unit; + return value ? value + unit : ''; + }, -var Component = __webpack_require__(20); -var OComponent = __webpack_require__(4); -var yt = 'yt'; -var vi = 'vi'; + /** + * Returns input element + * @return {HTMLElement} + * @private + */ + getInputEl: function getInputEl() { + if (!this.input) { + var value = this.getModelValue(); + var inputNumber = new domain_abstract_ui_InputNumber__WEBPACK_IMPORTED_MODULE_1__["default"]({ + contClass: this.ppfx + 'field-int', + model: this.model, + ppfx: this.ppfx + }); + this.input = inputNumber.render(); + this.$input = this.input.inputEl; + this.$unit = this.input.unitEl; + this.model.set('value', value); + this.$input.val(value); + this.input = inputNumber.el; + } -module.exports = Component.extend({ + return this.input; + } +})); - defaults: _extends({}, Component.prototype.defaults, { - type: 'video', - tagName: 'video', - videoId: '', - void: 0, - provider: '', // on change of provider, traits are switched - ytUrl: 'https://www.youtube.com/embed/', - viUrl: 'https://player.vimeo.com/video/', - loop: 0, - muted: 0, - autoplay: 0, - controls: 1, - color: '', - sources: [], - attributes: { allowfullscreen: 'allowfullscreen' }, - toolbar: OComponent.prototype.defaults.toolbar - }), +/***/ }), - initialize: function initialize(o, opt) { - var traits = []; - var prov = this.get('provider'); - switch (prov) { - case yt: - traits = this.getYoutubeTraits(); - break; - case vi: - traits = this.getVimeoTraits(); - break; - default: - traits = this.getSourceTraits(); - } - if (this.get('src')) this.parseFromSrc(); - this.set('traits', traits); - Component.prototype.initialize.apply(this, arguments); - this.listenTo(this, 'change:provider', this.updateTraits); - this.listenTo(this, 'change:videoId', this.updateSrc); - }, - initToolbar: function initToolbar() { - for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) { - args[_key] = arguments[_key]; - } +/***/ "./src/trait_manager/view/TraitSelectView.js": +/*!***************************************************!*\ + !*** ./src/trait_manager/view/TraitSelectView.js ***! + \***************************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var _TraitView__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./TraitView */ "./src/trait_manager/view/TraitView.js"); - OComponent.prototype.initToolbar.apply(this, args); - }, +var $ = backbone__WEBPACK_IMPORTED_MODULE_0___default.a.$; +/* harmony default export */ __webpack_exports__["default"] = (_TraitView__WEBPACK_IMPORTED_MODULE_2__["default"].extend({ + init: function init() { + this.listenTo(this.model, 'change:options', this.rerender); + }, + templateInput: function templateInput() { + var ppfx = this.ppfx, + clsField = this.clsField; + return "
\n
\n
\n
\n
\n
"); + }, + /** - * Set attributes by src string + * Returns input element + * @return {HTMLElement} + * @private */ - parseFromSrc: function parseFromSrc() { - var prov = this.get('provider'); - var uri = this.parseUri(this.get('src')); - var qr = uri.query; - switch (prov) { - case yt:case vi: - var videoId = uri.pathname.split('/').pop(); - this.set('videoId', videoId); - if (qr.autoplay) this.set('autoplay', 1); - if (qr.loop) this.set('loop', 1); - if (parseInt(qr.controls) === 0) this.set('controls', 0); - if (qr.color) this.set('color', qr.color); - break; - default: + getInputEl: function getInputEl() { + if (!this.$input) { + var model = this.model; + var opts = model.get('options') || []; + var input = ''; + this.$input = $(input); + var val = model.getTargetValue() || model.get('value'); + !Object(underscore__WEBPACK_IMPORTED_MODULE_1__["isUndefined"])(val) && this.$input.val(val); } - }, + + return this.$input.get(0); + } +})); + +/***/ }), + +/***/ "./src/trait_manager/view/TraitView.js": +/*!*********************************************!*\ + !*** ./src/trait_manager/view/TraitView.js ***! + \*********************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _babel_runtime_helpers_slicedToArray__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/slicedToArray */ "./node_modules/@babel/runtime/helpers/slicedToArray.js"); +/* harmony import */ var _babel_runtime_helpers_slicedToArray__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_slicedToArray__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_2__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_3__); +/* harmony import */ var utils_mixins__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! utils/mixins */ "./src/utils/mixins.js"); - /** - * Update src on change of video ID - * @private - */ - updateSrc: function updateSrc() { - var prov = this.get('provider'); - switch (prov) { - case yt: - this.set('src', this.getYoutubeSrc()); - break; - case vi: - this.set('src', this.getVimeoSrc()); - break; - } - }, +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - /** - * Returns object of attributes for HTML - * @return {Object} - * @private - */ - getAttrToHTML: function getAttrToHTML() { - for (var _len2 = arguments.length, args = Array(_len2), _key2 = 0; _key2 < _len2; _key2++) { - args[_key2] = arguments[_key2]; - } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - var attr = Component.prototype.getAttrToHTML.apply(this, args); - var prov = this.get('provider'); - switch (prov) { - case yt:case vi: - break; - default: - if (this.get('loop')) attr.loop = 'loop'; - if (this.get('autoplay')) attr.autoplay = 'autoplay'; - if (this.get('controls')) attr.controls = 'controls'; - } - return attr; - }, - /** - * Update traits by provider - * @private - */ - updateTraits: function updateTraits() { - var prov = this.get('provider'); - var traits = this.getSourceTraits(); - switch (prov) { - case yt: - this.set('tagName', 'iframe'); - traits = this.getYoutubeTraits(); - break; - case vi: - this.set('tagName', 'iframe'); - traits = this.getVimeoTraits(); - break; - default: - this.set('tagName', 'video'); - } - this.loadTraits(traits); - this.sm.trigger('change:selectedComponent'); + +var $ = backbone__WEBPACK_IMPORTED_MODULE_2___default.a.$; +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_2___default.a.View.extend({ + events: {}, + eventCapture: ['change'], + appendInput: 1, + attributes: function attributes() { + return this.model.get('attributes'); + }, + templateLabel: function templateLabel() { + var ppfx = this.ppfx; + var label = this.getLabel(); + return "
").concat(label, "
"); + }, + templateInput: function templateInput() { + var clsField = this.clsField; + return "
"); }, + initialize: function initialize() { + var _this = this; + var o = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var _o$config = o.config, + config = _o$config === void 0 ? {} : _o$config; + var model = this.model, + eventCapture = this.eventCapture; + var target = model.target; + var type = model.attributes.type; + this.config = config; + this.em = config.em; + this.pfx = config.stylePrefix || ''; + this.ppfx = config.pStylePrefix || ''; + this.target = target; + var ppfx = this.ppfx; + this.clsField = "".concat(ppfx, "field ").concat(ppfx, "field-").concat(type); + [['change:value', this.onValueChange], ['remove', this.removeView]].forEach(function (_ref) { + var _ref2 = _babel_runtime_helpers_slicedToArray__WEBPACK_IMPORTED_MODULE_1___default()(_ref, 2), + event = _ref2[0], + clb = _ref2[1]; - // Listen provider change and switch traits, in TraitView listen traits change + model.off(event, clb); - /** - * Return the provider trait - * @return {Object} - * @private - */ - getProviderTrait: function getProviderTrait() { + _this.listenTo(model, event, clb); + }); + model.view = this; + this.listenTo(model, 'change:label', this.render); + this.listenTo(model, 'change:placeholder', this.rerender); + eventCapture.forEach(function (event) { + return _this.events[event] = 'onChange'; + }); + this.delegateEvents(); + this.init(); + }, + getClbOpts: function getClbOpts() { return { - type: 'select', - label: 'Provider', - name: 'provider', - changeProp: 1, - value: this.get('provider'), - options: [{ value: 'so', name: 'HTML5 Source' }, { value: yt, name: 'Youtube' }, { value: vi, name: 'Vimeo' }] + component: this.target, + trait: this.model, + elInput: this.getInputElem() }; }, - - - /** - * Return traits for the source provider - * @return {Array} - * @private - */ - getSourceTraits: function getSourceTraits() { - return [this.getProviderTrait(), { - label: 'Source', - name: 'src', - placeholder: 'eg. ./media/video.mp4', - changeProp: 1 - }, this.getAutoplayTrait(), this.getLoopTrait(), this.getControlsTrait()]; + removeView: function removeView() { + this.remove(); + this.removed(); }, + init: function init() {}, + removed: function removed() {}, + onRender: function onRender() {}, + onUpdate: function onUpdate() {}, + onEvent: function onEvent() {}, /** - * Return traits for the source provider - * @return {Array} + * Fires when the input is changed * @private */ - getYoutubeTraits: function getYoutubeTraits() { - return [this.getProviderTrait(), { - label: 'Video ID', - name: 'videoId', - placeholder: 'eg. jNQXAC9IVRw', - changeProp: 1 - }, this.getAutoplayTrait(), this.getLoopTrait(), this.getControlsTrait()]; - }, + onChange: function onChange(event) { + var el = this.getInputElem(); + if (el && !Object(underscore__WEBPACK_IMPORTED_MODULE_3__["isUndefined"])(el.value)) { + this.model.set('value', el.value); + } - /** - * Return traits for the source provider - * @return {Array} - * @private - */ - getVimeoTraits: function getVimeoTraits() { - return [this.getProviderTrait(), { - label: 'Video ID', - name: 'videoId', - placeholder: 'eg. 123456789', - changeProp: 1 - }, { - label: 'Color', - name: 'color', - placeholder: 'eg. FF0000', - changeProp: 1 - }, this.getAutoplayTrait(), this.getLoopTrait(), this.getControlsTrait()]; + this.onEvent(_objectSpread({}, this.getClbOpts(), { + event: event + })); + }, + getValueForTarget: function getValueForTarget() { + return this.model.get('value'); + }, + setInputValue: function setInputValue(value) { + var el = this.getInputElem(); + el && (el.value = value); }, - /** - * Return object trait - * @return {Object} + * On change callback * @private */ - getAutoplayTrait: function getAutoplayTrait() { - return { - type: 'checkbox', - label: 'Autoplay', - name: 'autoplay', - changeProp: 1 - }; - }, + onValueChange: function onValueChange(model, value) { + var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + if (opts.fromTarget) { + this.setInputValue(model.get('value')); + this.postUpdate(); + } else { + var val = this.getValueForTarget(); + model.setTargetValue(val, opts); + } + }, /** - * Return object trait - * @return {Object} + * Render label * @private */ - getLoopTrait: function getLoopTrait() { - return { - type: 'checkbox', - label: 'Loop', - name: 'loop', - changeProp: 1 - }; - }, + renderLabel: function renderLabel() { + var $el = this.$el, + target = this.target; + var label = this.getLabel(); + var tpl = this.templateLabel(target); + if (this.createLabel) { + tpl = this.createLabel({ + label: label, + component: target, + trait: this + }) || ''; + } - /** - * Return object trait - * @return {Object} - * @private - */ - getControlsTrait: function getControlsTrait() { - return { - type: 'checkbox', - label: 'Controls', - name: 'controls', - changeProp: 1 - }; + $el.find('[data-label]').append(tpl); }, - /** - * Returns url to youtube video + * Returns label for the input * @return {string} * @private */ - getYoutubeSrc: function getYoutubeSrc() { - var url = this.get('ytUrl'); - url += this.get('videoId') + '?'; - url += this.get('autoplay') ? '&autoplay=1' : ''; - url += !this.get('controls') ? '&controls=0' : ''; - url += this.get('loop') ? '&loop=1' : ''; - return url; + getLabel: function getLabel() { + var _this$model$attribute = this.model.attributes, + label = _this$model$attribute.label, + name = _this$model$attribute.name; + return Object(utils_mixins__WEBPACK_IMPORTED_MODULE_4__["capitalize"])(label || name).replace(/-/g, ' '); }, - /** - * Returns url to vimeo video - * @return {string} - * @private + * Returns current target component */ - getVimeoSrc: function getVimeoSrc() { - var url = this.get('viUrl'); - url += this.get('videoId') + '?'; - url += this.get('autoplay') ? '&autoplay=1' : ''; - url += this.get('loop') ? '&loop=1' : ''; - url += !this.get('controls') ? '&title=0&portrait=0&badge=0' : ''; - url += this.get('color') ? '&color=' + this.get('color') : ''; - return url; - } -}, { + getComponent: function getComponent() { + return this.target; + }, /** - * Detect if the passed element is a valid component. - * In case the element is valid an object abstracted - * from the element will be returned - * @param {HTMLElement} - * @return {Object} + * Returns input element + * @return {HTMLElement} * @private */ - isComponent: function isComponent(el) { - var result = ''; - var isYtProv = /youtube\.com\/embed/.test(el.src); - var isViProv = /player\.vimeo\.com\/video/.test(el.src); - var isExtProv = isYtProv || isViProv; - if (el.tagName == 'VIDEO' || el.tagName == 'IFRAME' && isExtProv) { - result = { type: 'video' }; - if (el.src) result.src = el.src; - if (isExtProv) { - if (isYtProv) result.provider = yt;else if (isViProv) result.provider = vi; - } - } - return result; - } -}); - -/***/ }), -/* 171 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -var Backbone = __webpack_require__(0); -var ComponentView = __webpack_require__(15); -var OComponentView = __webpack_require__(3); - -module.exports = ComponentView.extend({ + getInputEl: function getInputEl() { + if (!this.$input) { + var md = this.model; + var plh = md.get('placeholder') || md.get('default') || ''; + var type = md.get('type') || 'text'; + var min = md.get('min'); + var max = md.get('max'); + var value = this.getModelValue(); + var input = $("")); - tagName: 'div', + if (!Object(underscore__WEBPACK_IMPORTED_MODULE_3__["isUndefined"])(value)) { + md.set({ + value: value + }, { + silent: true + }); + input.prop('value', value); + } - events: {}, + if (min) { + input.prop('min', min); + } - initialize: function initialize(o) { - OComponentView.prototype.initialize.apply(this, arguments); - this.listenTo(this.model, 'change:src', this.updateSrc); - this.listenTo(this.model, 'change:loop change:autoplay change:controls change:color', this.updateVideo); - this.listenTo(this.model, 'change:provider', this.updateProvider); - }, + if (max) { + input.prop('max', max); + } + this.$input = input; + } - /** - * Rerender on update of the provider - * @private - */ - updateProvider: function updateProvider() { - var prov = this.model.get('provider'); - this.el.innerHTML = ''; - this.el.appendChild(this.renderByProvider(prov)); + return this.$input.get(0); }, + getInputElem: function getInputElem() { + var input = this.input, + $input = this.$input; + return input || $input && $input.get && $input.get(0) || this.getElInput(); + }, + getModelValue: function getModelValue() { + var value; + var model = this.model; + var target = this.target; + var name = model.get('name'); - - /** - * Update the source of the video - * @private - */ - updateSrc: function updateSrc() { - var prov = this.model.get('provider'); - var src = this.model.get('src'); - switch (prov) { - case 'yt': - src = this.model.getYoutubeSrc(); - break; - case 'vi': - src = this.model.getVimeoSrc(); - break; + if (model.get('changeProp')) { + value = target.get(name); + } else { + var attrs = target.get('attributes'); + value = model.get('value') || attrs[name]; } - this.videoEl.src = src; - }, + return !Object(underscore__WEBPACK_IMPORTED_MODULE_3__["isUndefined"])(value) ? value : ''; + }, + getElInput: function getElInput() { + return this.elInput; + }, /** - * Update video parameters + * Renders input * @private - */ - updateVideo: function updateVideo() { - var prov = this.model.get('provider'); - var videoEl = this.videoEl; - var md = this.model; - switch (prov) { - case 'yt':case 'vi': - this.model.trigger('change:videoId'); - break; - default: - videoEl.loop = md.get('loop'); - videoEl.autoplay = md.get('autoplay'); - videoEl.controls = md.get('controls'); + * */ + renderField: function renderField() { + var $el = this.$el, + appendInput = this.appendInput, + model = this.model; + var inputs = $el.find('[data-input]'); + var el = inputs[inputs.length - 1]; + var tpl = model.el; + + if (!tpl) { + tpl = this.createInput ? this.createInput(this.getClbOpts()) : this.getInputEl(); } - }, - renderByProvider: function renderByProvider(prov) { - var videoEl; - switch (prov) { - case 'yt': - videoEl = this.renderYoutube(); - break; - case 'vi': - videoEl = this.renderVimeo(); - break; - default: - videoEl = this.renderSource(); + + if (Object(underscore__WEBPACK_IMPORTED_MODULE_3__["isString"])(tpl)) { + el.innerHTML = tpl; + this.elInput = el.firstChild; + } else { + appendInput ? el.appendChild(tpl) : el.insertBefore(tpl, el.firstChild); + this.elInput = tpl; } - this.videoEl = videoEl; - return videoEl; - }, - renderSource: function renderSource() { - var el = document.createElement('video'); - el.src = this.model.get('src'); - this.initVideoEl(el); - return el; + + model.el = this.elInput; }, - renderYoutube: function renderYoutube() { - var el = document.createElement('iframe'); - el.src = this.model.getYoutubeSrc(); - el.frameBorder = 0; - el.setAttribute('allowfullscreen', true); - this.initVideoEl(el); - return el; + hasLabel: function hasLabel() { + var label = this.model.attributes.label; + return !this.noLabel && label !== false; }, - renderVimeo: function renderVimeo() { - var el = document.createElement('iframe'); - el.src = this.model.getVimeoSrc(); - el.frameBorder = 0; - el.setAttribute('allowfullscreen', true); - this.initVideoEl(el); - return el; + rerender: function rerender() { + this.model.el = null; + this.render(); }, - initVideoEl: function initVideoEl(el) { - el.className = this.ppfx + 'no-pointer'; - el.style.height = '100%'; - el.style.width = '100%'; + postUpdate: function postUpdate() { + this.onUpdate(this.getClbOpts()); }, render: function render() { - for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) { - args[_key] = arguments[_key]; - } - - ComponentView.prototype.render.apply(this, args); - this.updateClasses(); - var prov = this.model.get('provider'); - this.el.appendChild(this.renderByProvider(prov)); + var $el = this.$el, + pfx = this.pfx, + ppfx = this.ppfx, + model = this.model; + var type = model.attributes.type; + var hasLabel = this.hasLabel && this.hasLabel(); + var cls = "".concat(pfx, "trait"); + this.$input = null; + var tmpl = "
\n ").concat(hasLabel ? "
") : '', "\n
\n ").concat(this.templateInput ? Object(underscore__WEBPACK_IMPORTED_MODULE_3__["isFunction"])(this.templateInput) ? this.templateInput(this.getClbOpts()) : this.templateInput : '', "\n
\n
"); + $el.empty().append(tmpl); + hasLabel && this.renderLabel(); + this.renderField(); + this.el.className = "".concat(cls, "__wrp"); + this.postUpdate(); + this.onRender(this.getClbOpts()); return this; } -}); +})); /***/ }), -/* 172 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; -/* WEBPACK VAR INJECTION */(function(_) { - -var Component = __webpack_require__(4); - -module.exports = Component.extend({ - - defaults: _.extend({}, Component.prototype.defaults, { - type: 'script', - droppable: false, - draggable: false, - layerable: false - }) - -}, { - isComponent: function isComponent(el) { - if (el.tagName == 'SCRIPT') { - var result = { type: 'script' }; - - if (el.src) { - result.src = el.src; - result.onload = el.onload; - } - - return result; - } - } -}); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(1))) -/***/ }), -/* 173 */ -/***/ (function(module, exports, __webpack_require__) { +/***/ "./src/trait_manager/view/TraitsView.js": +/*!**********************************************!*\ + !*** ./src/trait_manager/view/TraitsView.js ***! + \**********************************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var domain_abstract_view_DomainViews__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! domain_abstract/view/DomainViews */ "./src/domain_abstract/view/DomainViews.js"); +/* harmony import */ var _TraitView__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./TraitView */ "./src/trait_manager/view/TraitView.js"); +/* harmony import */ var _TraitSelectView__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./TraitSelectView */ "./src/trait_manager/view/TraitSelectView.js"); +/* harmony import */ var _TraitCheckboxView__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ./TraitCheckboxView */ "./src/trait_manager/view/TraitCheckboxView.js"); +/* harmony import */ var _TraitNumberView__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./TraitNumberView */ "./src/trait_manager/view/TraitNumberView.js"); +/* harmony import */ var _TraitColorView__WEBPACK_IMPORTED_MODULE_5__ = __webpack_require__(/*! ./TraitColorView */ "./src/trait_manager/view/TraitColorView.js"); +/* harmony import */ var _TraitButtonView__WEBPACK_IMPORTED_MODULE_6__ = __webpack_require__(/*! ./TraitButtonView */ "./src/trait_manager/view/TraitButtonView.js"); -var Backbone = __webpack_require__(0); -var ComponentView = __webpack_require__(15); -module.exports = ComponentView.extend({ - tagName: 'script', - events: {}, - render: function render() { - var model = this.model; - var src = model.get('src'); - var em = this.em; - var scriptCount = em && em.get('scriptCount') ? em.get('scriptCount') : 0; - var content = ''; - // If it's an external script - if (src) { - var onload = model.get('onload'); - var svar = 'script' + scriptCount; - var svarNext = 'script' + (scriptCount + 1); - content = "var " + svar + " = document.createElement('script');\n" + svar + ".onload = function(){\n" + (onload ? onload + "();\n" : '') + "typeof " + svarNext + "Start == 'function' && " + svarNext + "Start();\n" + "};\n" + svar + ".src = '" + src + "';\n" + "function " + svar + "Start() { document.body.appendChild(" + svar + "); };\n" + (!scriptCount ? svar + "Start();" : ''); - if (em) { - em.set('scriptCount', scriptCount + 1); - } - } else { - content = model.get('content'); - } +/* harmony default export */ __webpack_exports__["default"] = (domain_abstract_view_DomainViews__WEBPACK_IMPORTED_MODULE_0__["default"].extend({ + ns: 'Traits', + itemView: _TraitView__WEBPACK_IMPORTED_MODULE_1__["default"], + reuseView: 1, + itemsView: { + text: _TraitView__WEBPACK_IMPORTED_MODULE_1__["default"], + number: _TraitNumberView__WEBPACK_IMPORTED_MODULE_4__["default"], + select: _TraitSelectView__WEBPACK_IMPORTED_MODULE_2__["default"], + checkbox: _TraitCheckboxView__WEBPACK_IMPORTED_MODULE_3__["default"], + color: _TraitColorView__WEBPACK_IMPORTED_MODULE_5__["default"], + button: _TraitButtonView__WEBPACK_IMPORTED_MODULE_6__["default"] + }, + initialize: function initialize() { + var o = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var config = o.config || {}; + this.config = config; + this.em = o.editor; + this.pfx = config.stylePrefix || ''; + this.ppfx = config.pStylePrefix || ''; + this.className = this.pfx + 'traits'; + var toListen = 'component:toggled'; + this.listenTo(this.em, toListen, this.updatedCollection); + this.updatedCollection(); + }, - this.el.innerHTML = content; - return this; + /** + * Update view collection + * @private + */ + updatedCollection: function updatedCollection() { + var ppfx = this.ppfx; + var comp = this.em.getSelected(); + this.el.className = "".concat(this.className, " ").concat(ppfx, "one-bg ").concat(ppfx, "two-color"); + this.collection = comp ? comp.get('traits') : []; + this.render(); } -}); +})); /***/ }), -/* 174 */ -/***/ (function(module, exports, __webpack_require__) { + +/***/ "./src/undo_manager/index.js": +/*!***********************************!*\ + !*** ./src/undo_manager/index.js ***! + \***********************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var backbone_undo__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! backbone-undo */ "./node_modules/backbone-undo/Backbone.Undo.js"); +/* harmony import */ var backbone_undo__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(backbone_undo__WEBPACK_IMPORTED_MODULE_1__); -var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } -var Component = __webpack_require__(4); +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } -module.exports = Component.extend({ +/** + * This module allows to manage the stack of changes applied in canvas. + * Once the editor is instantiated you can use its API. Before using these methods you should get the module from the instance + * + * ```js + * const um = editor.UndoManager; + * ``` + * + * * [getConfig](#getconfig) + * * [add](#add) + * * [remove](#remove) + * * [removeAll](#removeall) + * * [start](#start) + * * [stop](#stop) + * * [undo](#undo) + * * [undoAll](#undoall) + * * [redo](#redo) + * * [redoAll](#redoall) + * * [hasUndo](#hasundo) + * * [hasRedo](#hasredo) + * * [getStack](#getstack) + * * [clear](#clear) + * + * @module UndoManager + */ - defaults: _extends({}, Component.prototype.defaults, { - highlightable: 0 - }), +/* harmony default export */ __webpack_exports__["default"] = (function () { + var em; + var um; + var config; + var beforeCache; + var configDef = {}; + return { + name: 'UndoManager', - getName: function getName() { - var name = this.get('tagName'); - var customName = this.get('custom-name'); - name = name.charAt(0).toUpperCase() + name.slice(1); - return customName || name; - } -}, { - isComponent: function isComponent(el) { - if (SVGElement && el instanceof SVGElement) { - // Some SVG elements require uppercase letters (eg. ) - var tagName = el.tagName; - // Make the root resizable - var resizable = tagName == 'svg' ? true : false; + /** + * Initialize module + * @param {Object} config Configurations + * @private + */ + init: function init() { + var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + config = _objectSpread({}, opts, {}, configDef); + em = config.em; + this.em = em; + um = new backbone_undo__WEBPACK_IMPORTED_MODULE_1___default.a({ + track: true, + register: [] + }); + um.changeUndoType('change', { + condition: false + }); + um.changeUndoType('add', { + on: function on(model, collection) { + var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + if (options.avoidStore) return; + return { + object: collection, + before: undefined, + after: model, + options: _objectSpread({}, options) + }; + } + }); + um.changeUndoType('remove', { + on: function on(model, collection) { + var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + if (options.avoidStore) return; + return { + object: collection, + before: model, + after: undefined, + options: _objectSpread({}, options) + }; + } + }); + var customUndoType = { + on: function on(object, value) { + var opt = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + !beforeCache && (beforeCache = object.previousAttributes()); - return { - tagName: tagName, - type: 'svg', - resizable: resizable + if (opt.avoidStore) { + return; + } else { + var result = { + object: object, + before: beforeCache, + after: object.toJSON() + }; + beforeCache = null; + return result; + } + }, + undo: function undo(model, bf, af, opt) { + model.set(bf); + }, + redo: function redo(model, bf, af, opt) { + model.set(af); + } }; - } - } -}); + var events = ['style', 'attributes', 'content', 'src']; + events.forEach(function (ev) { + return um.addUndoType("change:".concat(ev), customUndoType); + }); + um.on('undo redo', function () { + return em.trigger('component:toggled change:canvasOffset'); + }); + ['undo', 'redo'].forEach(function (ev) { + return um.on(ev, function () { + return em.trigger(ev); + }); + }); + return this; + }, -/***/ }), -/* 175 */ -/***/ (function(module, exports, __webpack_require__) { + /** + * Get module configurations + * @return {Object} Configuration object + * @example + * const config = um.getConfig(); + * // { ... } + */ + getConfig: function getConfig() { + return config; + }, -"use strict"; + /** + * Add an entity (Model/Collection) to track + * Note: New Components and CSSRules will be added automatically + * @param {Model|Collection} entity Entity to track + * @return {this} + * @example + * um.add(someModelOrCollection); + */ + add: function add(entity) { + um.register(entity); + return this; + }, + /** + * Remove and stop tracking the entity (Model/Collection) + * @param {Model|Collection} entity Entity to remove + * @return {this} + * @example + * um.remove(someModelOrCollection); + */ + remove: function remove(entity) { + um.unregister(entity); + return this; + }, -var ComponentView = __webpack_require__(3); + /** + * Remove all entities + * @return {this} + * @example + * um.removeAll(); + */ + removeAll: function removeAll() { + um.unregisterAll(); + return this; + }, -module.exports = ComponentView.extend({ + /** + * Start/resume tracking changes + * @return {this} + * @example + * um.start(); + */ + start: function start() { + um.startTracking(); + return this; + }, - _createElement: function _createElement(tagName) { - return document.createElementNS('http://www.w3.org/2000/svg', tagName); - } + /** + * Stop tracking changes + * @return {this} + * @example + * um.stop(); + */ + stop: function stop() { + um.stopTracking(); + return this; + }, -}); + /** + * Undo last change + * @return {this} + * @example + * um.undo(); + */ + undo: function undo() { + !em.isEditing() && um.undo(1); + return this; + }, -/***/ }), -/* 176 */ -/***/ (function(module, exports, __webpack_require__) { + /** + * Undo all changes + * @return {this} + * @example + * um.undoAll(); + */ + undoAll: function undoAll() { + um.undoAll(); + return this; + }, -"use strict"; -/* WEBPACK VAR INJECTION */(function(_) { + /** + * Redo last change + * @return {this} + * @example + * um.redo(); + */ + redo: function redo() { + !em.isEditing() && um.redo(1); + return this; + }, -var Component = __webpack_require__(4); + /** + * Redo all changes + * @return {this} + * @example + * um.redoAll(); + */ + redoAll: function redoAll() { + um.redoAll(); + return this; + }, -module.exports = Component.extend({ + /** + * Checks if exists an available undo + * @return {Boolean} + * @example + * um.hasUndo(); + */ + hasUndo: function hasUndo() { + return um.isAvailable('undo'); + }, - defaults: _.extend({}, Component.prototype.defaults, { - droppable: false, - editable: true - }), + /** + * Checks if exists an available redo + * @return {Boolean} + * @example + * um.hasRedo(); + */ + hasRedo: function hasRedo() { + return um.isAvailable('redo'); + }, - toHTML: function toHTML() { - return this.get('content'); - } -}, { - isComponent: function isComponent(el) { - var result = ''; - if (el.nodeType === 3) { - result = { - type: 'textnode', - content: el.textContent - }; + /** + * Get stack of changes + * @return {Collection} + * @example + * const stack = um.getStack(); + * stack.each(item => ...); + */ + getStack: function getStack() { + return um.stack; + }, + + /** + * Clear the stack + * @return {this} + * @example + * um.clear(); + */ + clear: function clear() { + um.clear(); + return this; + }, + getInstance: function getInstance() { + return um; } - return result; - } + }; }); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(1))) /***/ }), -/* 177 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; - - -var Backbone = __webpack_require__(0); - -module.exports = Backbone.View.extend({}); -/***/ }), -/* 178 */ -/***/ (function(module, exports, __webpack_require__) { +/***/ "./src/utils/ColorPicker.js": +/*!**********************************!*\ + !*** ./src/utils/ColorPicker.js ***! + \**********************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/typeof */ "./node_modules/@babel/runtime/helpers/typeof.js"); +/* harmony import */ var _babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0__); +// Without jquery I have to update few stuff +// +// Spectrum Colorpicker v1.8.0 +// https://github.com/bgrins/spectrum +// Author: Brian Grinstead +// License: MIT +/* harmony default export */ __webpack_exports__["default"] = (function ($, undefined) { + 'use strict'; + + var defaultOpts = { + // Callbacks + beforeShow: noop, + move: noop, + change: noop, + show: noop, + hide: noop, + // Options + color: false, + flat: false, + showInput: false, + allowEmpty: false, + showButtons: true, + clickoutFiresChange: true, + showInitial: false, + showPalette: false, + showPaletteOnly: false, + hideAfterPaletteSelect: false, + togglePaletteOnly: false, + showSelectionPalette: true, + localStorageKey: false, + appendTo: 'body', + maxSelectionSize: 7, + cancelText: 'cancel', + chooseText: 'choose', + togglePaletteMoreText: 'more', + togglePaletteLessText: 'less', + clearText: 'Clear Color Selection', + noColorSelectedText: 'No Color Selected', + preferredFormat: false, + className: '', + // Deprecated - use containerClassName and replacerClassName instead. + containerClassName: '', + replacerClassName: '', + showAlpha: false, + theme: 'sp-light', + palette: [['#ffffff', '#000000', '#ff0000', '#ff8000', '#ffff00', '#008000', '#0000ff', '#4b0082', '#9400d3']], + selectionPalette: [], + disabled: false, + offset: null + }, + spectrums = [], + IE = !!/msie/i.exec(window.navigator.userAgent), + rgbaSupport = function () { + function contains(str, substr) { + return !!~('' + str).indexOf(substr); + } + + var elem = document.createElement('div'); + var style = elem.style; + style.cssText = 'background-color:rgba(0,0,0,.5)'; + return contains(style.backgroundColor, 'rgba') || contains(style.backgroundColor, 'hsla'); + }(), + replaceInput = ["
", "
", "
", '
'].join(''), + markup = function () { + // IE does not support gradients with multiple stops, so we need to simulate + // that for the rainbow slider with 8 divs that each have a single gradient + var gradientFix = ''; + + if (IE) { + for (var i = 1; i <= 6; i++) { + gradientFix += "
"; + } + } + + return ["
", "
", "
", "
", "", '
', '
', "
", "
", "
", "
", "
", "
", "
", "
", '
', '
', '
', "
", '
', "
", "
", gradientFix, '
', '
', "
", '
', "
", "", '
', "
", "
", "", "", '
', '
', '
'].join(''); + }(); -var _mixins = __webpack_require__(2); - -module.exports = function () { - var c = {}, - defaults = __webpack_require__(179), - Canvas = __webpack_require__(180), - CanvasView = __webpack_require__(182); - var canvas; - var frameRect; - - return { + function paletteTemplate(p, color, className, opts) { + var html = []; - /** - * Used inside RTE - * @private - */ - getCanvasView: function getCanvasView() { - return CanvasView; - }, + for (var i = 0; i < p.length; i++) { + var current = p[i]; + if (current) { + var tiny = tinycolor(current); + var c = tiny.toHsl().l < 0.5 ? 'sp-thumb-el sp-thumb-dark' : 'sp-thumb-el sp-thumb-light'; + c += tinycolor.equals(color, current) ? ' sp-thumb-active' : ''; + var formattedString = tiny.toString(opts.preferredFormat || 'rgb'); + var swatchStyle = rgbaSupport ? 'background-color:' + tiny.toRgbString() : 'filter:' + tiny.toFilter(); + html.push(''); + } else { + var cls = 'sp-clear-display'; + html.push($('
').append($('').attr('title', opts.noColorSelectedText)).html()); + } + } - /** - * Name of the module - * @type {String} - * @private - */ - name: 'Canvas', + return "
" + html.join('') + '
'; + } - /** - * Initialize module. Automatically called with a new instance of the editor - * @param {Object} config Configurations - */ - init: function init(config) { - c = config || {}; - for (var name in defaults) { - if (!(name in c)) c[name] = defaults[name]; + function hideAll() { + for (var i = 0; i < spectrums.length; i++) { + if (spectrums[i]) { + spectrums[i].hide(); } + } + } - var ppfx = c.pStylePrefix; - if (ppfx) c.stylePrefix = ppfx + c.stylePrefix; + function instanceOptions(o, callbackContext) { + var opts = $.extend({}, defaultOpts, o); + opts.callbacks = { + move: bind(opts.move, callbackContext), + change: bind(opts.change, callbackContext), + show: bind(opts.show, callbackContext), + hide: bind(opts.hide, callbackContext), + beforeShow: bind(opts.beforeShow, callbackContext) + }; + return opts; + } + + function spectrum(element, o) { + var opts = instanceOptions(o, element), + flat = opts.flat, + showSelectionPalette = opts.showSelectionPalette, + localStorageKey = opts.localStorageKey, + theme = opts.theme, + callbacks = opts.callbacks, + resize = throttle(reflow, 10), + visible = false, + isDragging = false, + dragWidth = 0, + dragHeight = 0, + dragHelperHeight = 0, + slideHeight = 0, + slideWidth = 0, + alphaWidth = 0, + alphaSlideHelperWidth = 0, + slideHelperHeight = 0, + currentHue = 0, + currentSaturation = 0, + currentValue = 0, + currentAlpha = 1, + palette = [], + paletteArray = [], + paletteLookup = {}, + selectionPalette = opts.selectionPalette.slice(0), + maxSelectionSize = opts.maxSelectionSize, + draggingClass = 'sp-dragging', + shiftMovementDirection = null; + var doc = element.ownerDocument, + body = doc.body, + boundElement = $(element), + disabled = false, + container = $(markup, doc).addClass(theme), + pickerContainer = container.find('.sp-picker-container'), + dragger = container.find('.sp-color'), + dragHelper = container.find('.sp-dragger'), + slider = container.find('.sp-hue'), + slideHelper = container.find('.sp-slider'), + alphaSliderInner = container.find('.sp-alpha-inner'), + alphaSlider = container.find('.sp-alpha'), + alphaSlideHelper = container.find('.sp-alpha-handle'), + textInput = container.find('.sp-input'), + paletteContainer = container.find('.sp-palette'), + initialColorContainer = container.find('.sp-initial'), + cancelButton = container.find('.sp-cancel'), + clearButton = container.find('.sp-clear'), + chooseButton = container.find('.sp-choose'), + toggleButton = container.find('.sp-palette-toggle'), + isInput = boundElement.is('input'), + isInputTypeColor = isInput && boundElement.attr('type') === 'color' && inputTypeColorSupport(), + shouldReplace = isInput && !flat, + replacer = shouldReplace ? $(replaceInput).addClass(theme).addClass(opts.className).addClass(opts.replacerClassName) : $([]), + offsetElement = shouldReplace ? replacer : boundElement, + previewElement = replacer.find('.sp-preview-inner'), + initialColor = opts.color || isInput && boundElement.val(), + colorOnShow = false, + currentPreferredFormat = opts.preferredFormat, + clickoutFiresChange = !opts.showButtons || opts.clickoutFiresChange, + isEmpty = !initialColor, + allowEmpty = opts.allowEmpty && !isInputTypeColor; + + function applyOptions() { + if (opts.showPaletteOnly) { + opts.showPalette = true; + } + + toggleButton.text(opts.showPaletteOnly ? opts.togglePaletteMoreText : opts.togglePaletteLessText); + + if (opts.palette) { + palette = opts.palette.slice(0); + paletteArray = $.isArray(palette[0]) ? palette : [palette]; + paletteLookup = {}; + + for (var i = 0; i < paletteArray.length; i++) { + for (var j = 0; j < paletteArray[i].length; j++) { + var rgb = tinycolor(paletteArray[i][j]).toRgbString(); + paletteLookup[rgb] = true; + } + } + } - canvas = new Canvas(config); - CanvasView = new CanvasView({ - model: canvas, - config: c - }); + container.toggleClass('sp-flat', flat); + container.toggleClass('sp-input-disabled', !opts.showInput); + container.toggleClass('sp-alpha-enabled', opts.showAlpha); + container.toggleClass('sp-clear-enabled', allowEmpty); + container.toggleClass('sp-buttons-disabled', !opts.showButtons); + container.toggleClass('sp-palette-buttons-disabled', !opts.togglePaletteOnly); + container.toggleClass('sp-palette-disabled', !opts.showPalette); + container.toggleClass('sp-palette-only', opts.showPaletteOnly); + container.toggleClass('sp-initial-disabled', !opts.showInitial); + container.addClass(opts.className).addClass(opts.containerClassName); + reflow(); + } - var cm = c.em.get('DomComponents'); - if (cm) this.setWrapper(cm); + function initialize() { + if (IE) { + container.find('*:not(input)').attr('unselectable', 'on'); + } - this.startAutoscroll = this.startAutoscroll.bind(this); - this.stopAutoscroll = this.stopAutoscroll.bind(this); - this.autoscroll = this.autoscroll.bind(this); - return this; - }, + applyOptions(); + if (shouldReplace) { + boundElement.after(replacer).hide(); + } - /** - * Return config object - * @return {Object} - */ - getConfig: function getConfig() { - return c; - }, + if (!allowEmpty) { + clearButton.hide(); + } + if (flat) { + boundElement.after(container).hide(); + } else { + var appendTo = opts.appendTo === 'parent' ? boundElement.parent() : $(opts.appendTo); - /** - * Add wrapper - * @param {Object} wrp Wrapper - * - * */ - setWrapper: function setWrapper(wrp) { - canvas.set('wrapper', wrp); - }, + if (appendTo.length !== 1) { + appendTo = $('body'); + } + appendTo.append(container); + } - /** - * Returns canvas element - * @return {HTMLElement} - */ - getElement: function getElement() { - return CanvasView.el; - }, + updateSelectionPaletteFromStorage(); + offsetElement.bind('click.spectrum touchstart.spectrum', function (e) { + if (!disabled) { + toggle(); + } + e.stopPropagation(); - /** - * Returns frame element of the canvas - * @return {HTMLElement} - */ - getFrameEl: function getFrameEl() { - return CanvasView.frame.el; - }, + if (!$(e.target).is('input')) { + e.preventDefault(); + } + }); + if (boundElement.is(':disabled') || opts.disabled === true) { + disable(); + } // Prevent clicks from bubbling up to document. This would cause it to be hidden. - /** - * Returns body element of the frame - * @return {HTMLElement} - */ - getBody: function getBody() { - return CanvasView.frame.el.contentDocument.body; - }, + container.click(stopPropagation); // Handle user typed input - /** - * Returns body wrapper element of the frame - * @return {HTMLElement} - */ - getWrapperEl: function getWrapperEl() { - return this.getBody().querySelector('#wrapper'); - }, + textInput.change(setFromTextInput); + textInput.bind('paste', function () { + setTimeout(setFromTextInput, 1); + }); + textInput.keydown(function (e) { + if (e.keyCode == 13) { + setFromTextInput(); + } + }); + cancelButton.text(opts.cancelText); + cancelButton.bind('click.spectrum', function (e) { + e.stopPropagation(); + e.preventDefault(); + revert(); + hide(); + }); + clearButton.attr('title', opts.clearText); + clearButton.bind('click.spectrum', function (e) { + e.stopPropagation(); + e.preventDefault(); + isEmpty = true; + move(); + if (flat) { + //for the flat style, this is a change event + updateOriginalInput(true); + } + }); + chooseButton.text(opts.chooseText); + chooseButton.bind('click.spectrum', function (e) { + e.stopPropagation(); + e.preventDefault(); - /** - * Returns element containing all canvas tools - * @return {HTMLElement} - */ - getToolsEl: function getToolsEl() { - return CanvasView.toolsEl; - }, + if (IE && textInput.is(':focus')) { + textInput.trigger('change'); + } + if (isValid()) { + updateOriginalInput(true); + hide(); + } + }); + toggleButton.text(opts.showPaletteOnly ? opts.togglePaletteMoreText : opts.togglePaletteLessText); + toggleButton.bind('click.spectrum', function (e) { + e.stopPropagation(); + e.preventDefault(); + opts.showPaletteOnly = !opts.showPaletteOnly; // To make sure the Picker area is drawn on the right, next to the + // Palette area (and not below the palette), first move the Palette + // to the left to make space for the picker, plus 5px extra. + // The 'applyOptions' function puts the whole container back into place + // and takes care of the button-text and the sp-palette-only CSS class. - /** - * Returns highlighter element - * @return {HTMLElement} - */ - getHighlighter: function getHighlighter() { - return CanvasView.hlEl; - }, + if (!opts.showPaletteOnly && !flat) { + container.css('left', '-=' + (pickerContainer.outerWidth(true) + 5)); + } + applyOptions(); + }); + draggable(alphaSlider, function (dragX, dragY, e) { + currentAlpha = dragX / alphaWidth; + isEmpty = false; - /** - * Returns badge element - * @return {HTMLElement} - */ - getBadgeEl: function getBadgeEl() { - return CanvasView.badgeEl; - }, + if (e.shiftKey) { + currentAlpha = Math.round(currentAlpha * 10) / 10; + } + move(); + }, dragStart, dragStop); + draggable(slider, function (dragX, dragY) { + currentHue = parseFloat(dragY / slideHeight); + isEmpty = false; - /** - * Returns placer element - * @return {HTMLElement} - */ - getPlacerEl: function getPlacerEl() { - return CanvasView.placerEl; - }, + if (!opts.showAlpha) { + currentAlpha = 1; + } + move(); + }, dragStart, dragStop); + draggable(dragger, function (dragX, dragY, e) { + // shift+drag should snap the movement to either the x or y axis. + if (!e.shiftKey) { + shiftMovementDirection = null; + } else if (!shiftMovementDirection) { + var oldDragX = currentSaturation * dragWidth; + var oldDragY = dragHeight - currentValue * dragHeight; + var furtherFromX = Math.abs(dragX - oldDragX) > Math.abs(dragY - oldDragY); + shiftMovementDirection = furtherFromX ? 'x' : 'y'; + } - /** - * Returns ghost element - * @return {HTMLElement} - * @private - */ - getGhostEl: function getGhostEl() { - return CanvasView.ghostEl; - }, + var setSaturation = !shiftMovementDirection || shiftMovementDirection === 'x'; + var setValue = !shiftMovementDirection || shiftMovementDirection === 'y'; + if (setSaturation) { + currentSaturation = parseFloat(dragX / dragWidth); + } - /** - * Returns toolbar element - * @return {HTMLElement} - */ - getToolbarEl: function getToolbarEl() { - return CanvasView.toolbarEl; - }, + if (setValue) { + currentValue = parseFloat((dragHeight - dragY) / dragHeight); + } + isEmpty = false; - /** - * Returns resizer element - * @return {HTMLElement} - */ - getResizerEl: function getResizerEl() { - return CanvasView.resizerEl; - }, + if (!opts.showAlpha) { + currentAlpha = 1; + } + move(); + }, dragStart, dragStop); - /** - * Returns offset viewer element - * @return {HTMLElement} - */ - getOffsetViewerEl: function getOffsetViewerEl() { - return CanvasView.offsetEl; - }, + if (!!initialColor) { + _set(initialColor); // In case color was black - update the preview UI and set the format + // since the set function will not run (default color is black). - /** - * Returns fixed offset viewer element - * @return {HTMLElement} - */ - getFixedOffsetViewerEl: function getFixedOffsetViewerEl() { - return CanvasView.fixedOffsetEl; - }, + updateUI(); + currentPreferredFormat = opts.preferredFormat || tinycolor(initialColor).format; + addColorToSelectionPalette(initialColor); + } else { + updateUI(); + } + if (flat) { + show(); + } - /** - * Render canvas - * */ - render: function render() { - return CanvasView.render().el; - }, + function paletteElementClick(e) { + if (e.data && e.data.ignore) { + _set($(e.target).closest('.sp-thumb-el').data('color')); + move(); + } else { + _set($(e.target).closest('.sp-thumb-el').data('color')); - /** - * Get frame position - * @return {Object} - * @private - */ - getOffset: function getOffset() { - var frameOff = this.offset(this.getFrameEl()); - var canvasOff = this.offset(this.getElement()); - return { - top: frameOff.top - canvasOff.top, - left: frameOff.left - canvasOff.left - }; - }, + move(); + updateOriginalInput(true); + if (opts.hideAfterPaletteSelect) { + hide(); + } + } - /** - * Get the offset of the element - * @param {HTMLElement} el - * @return {Object} - * @private - */ - offset: function offset(el) { - return CanvasView.offset(el); - }, + return false; + } + var paletteEvent = IE ? 'mousedown.spectrum' : 'click.spectrum touchstart.spectrum'; + paletteContainer.delegate('.sp-thumb-el', paletteEvent, paletteElementClick); + initialColorContainer.delegate('.sp-thumb-el:nth-child(1)', paletteEvent, { + ignore: true + }, paletteElementClick); + } - /** - * Set custom badge naming strategy - * @param {Function} f - * @example - * canvas.setCustomBadgeLabel(function(model){ - * return ComponentModel.getName(); - * }); - */ - setCustomBadgeLabel: function setCustomBadgeLabel(f) { - c.customBadgeLabel = f; - }, + function updateSelectionPaletteFromStorage() { + if (localStorageKey && window.localStorage) { + // Migrate old palettes over to new format. May want to remove this eventually. + try { + var oldPalette = window.localStorage[localStorageKey].split(',#'); + if (oldPalette.length > 1) { + delete window.localStorage[localStorageKey]; + $.each(oldPalette, function (i, c) { + addColorToSelectionPalette(c); + }); + } + } catch (e) {} - /** - * Get element position relative to the canvas - * @param {HTMLElement} el - * @return {Object} - */ - getElementPos: function getElementPos(el, opts) { - return CanvasView.getElementPos(el, opts); - }, + try { + selectionPalette = window.localStorage[localStorageKey].split(';'); + } catch (e) {} + } + } + function addColorToSelectionPalette(color) { + if (showSelectionPalette) { + var rgb = tinycolor(color).toRgbString(); - /** - * This method comes handy when you need to attach something like toolbars - * to elements inside the canvas, dealing with all relative position, - * offsets, etc. and returning as result the object with positions which are - * viewable by the user (when the canvas is scrolled the top edge of the element - * is not viewable by the user anymore so the new top edge is the one of the canvas) - * - * The target should be visible before being passed here as invisible elements - * return empty string as width - * @param {HTMLElement} target The target in this case could be the toolbar - * @param {HTMLElement} element The element on which I'd attach the toolbar - * @param {Object} options Custom options - * @param {Boolean} options.toRight Set to true if you want the toolbar attached to the right - * @return {Object} - */ - getTargetToElementDim: function getTargetToElementDim(target, element, options) { - var opts = options || {}; - var canvasPos = CanvasView.getPosition(); - var pos = opts.elPos || CanvasView.getElementPos(element); - var toRight = options.toRight || 0; - var targetHeight = opts.targetHeight || target.offsetHeight; - var targetWidth = opts.targetWidth || target.offsetWidth; - var eventToTrigger = opts.event || null; + if (!paletteLookup[rgb] && $.inArray(rgb, selectionPalette) === -1) { + selectionPalette.push(rgb); - var elTop = pos.top - targetHeight; - var elLeft = pos.left; - elLeft += toRight ? pos.width : 0; - elLeft = toRight ? elLeft - targetWidth : elLeft; + while (selectionPalette.length > maxSelectionSize) { + selectionPalette.shift(); + } + } - var leftPos = elLeft < canvasPos.left ? canvasPos.left : elLeft; - var topPos = elTop < canvasPos.top ? canvasPos.top : elTop; - topPos = topPos > pos.top + pos.height ? pos.top + pos.height : topPos; + if (localStorageKey && window.localStorage) { + try { + window.localStorage[localStorageKey] = selectionPalette.join(';'); + } catch (e) {} + } + } + } - var result = { - top: topPos, - left: leftPos, - elementTop: pos.top, - elementLeft: pos.left, - elementWidth: pos.width, - elementHeight: pos.height, - targetWidth: target.offsetWidth, - targetHeight: target.offsetHeight, - canvasTop: canvasPos.top, - canvasLeft: canvasPos.left - }; + function getUniqueSelectionPalette() { + var unique = []; - // In this way I can catch data and also change the position strategy - if (eventToTrigger && c.em) { - c.em.trigger(eventToTrigger, result); + if (opts.showPalette) { + for (var i = 0; i < selectionPalette.length; i++) { + var rgb = tinycolor(selectionPalette[i]).toRgbString(); + + if (!paletteLookup[rgb]) { + unique.push(selectionPalette[i]); + } + } } - return result; - }, + return unique.reverse().slice(0, opts.maxSelectionSize); + } + function drawPalette() { + var currentColor = get(); + var html = $.map(paletteArray, function (palette, i) { + return paletteTemplate(palette, currentColor, 'sp-palette-row sp-palette-row-' + i, opts); + }); + updateSelectionPaletteFromStorage(); - /** - * Instead of simply returning e.clientX and e.clientY this function - * calculates also the offset based on the canvas. This is helpful when you - * need to get X and Y position while moving between the editor area and - * canvas area, which is in the iframe - * @param {Event} e - * @return {Object} - */ - getMouseRelativePos: function getMouseRelativePos(e, options) { - var opts = options || {}; - var addTop = 0; - var addLeft = 0; - var subWinOffset = opts.subWinOffset; - var doc = e.target.ownerDocument; - var win = doc.defaultView || doc.parentWindow; - var frame = win.frameElement; - var yOffset = subWinOffset ? win.pageYOffset : 0; - var xOffset = subWinOffset ? win.pageXOffset : 0; + if (selectionPalette) { + html.push(paletteTemplate(getUniqueSelectionPalette(), currentColor, 'sp-palette-row sp-palette-row-selection', opts)); + } - if (frame) { - var frameRect = frame.getBoundingClientRect(); - addTop = frameRect.top || 0; - addLeft = frameRect.left || 0; + paletteContainer.html(html.join('')); + } + + function drawInitial() { + if (opts.showInitial) { + var initial = colorOnShow; + var current = get(); + initialColorContainer.html(paletteTemplate([initial, current], current, 'sp-palette-row-initial', opts)); + } + } + + function dragStart() { + if (dragHeight <= 0 || dragWidth <= 0 || slideHeight <= 0) { + reflow(); } - return { - y: e.clientY + addTop - yOffset, - x: e.clientX + addLeft - xOffset - }; - }, + isDragging = true; + container.addClass(draggingClass); + shiftMovementDirection = null; + boundElement.trigger('dragstart.spectrum', [get()]); + } + function dragStop() { + isDragging = false; + container.removeClass(draggingClass); + boundElement.trigger('dragstop.spectrum', [get()]); + } - /** - * X and Y mouse position relative to the canvas - * @param {Event} e - * @return {Object} - */ - getMouseRelativeCanvas: function getMouseRelativeCanvas(e, options) { - var opts = options || {}; - var frame = this.getFrameEl(); - var body = this.getBody(); - var addTop = frame.offsetTop || 0; - var addLeft = frame.offsetLeft || 0; - var yOffset = body.scrollTop || 0; - var xOffset = body.scrollLeft || 0; + function setFromTextInput() { + var value = textInput.val(); - return { - y: e.clientY + addTop + yOffset, - x: e.clientX + addLeft + xOffset - }; - }, + if ((value === null || value === '') && allowEmpty) { + _set(null); + updateOriginalInput(true); + } else { + var tiny = tinycolor(value); - /** - * Detects if some input is focused (input elements, text components, etc.) - * Used internally, for example, to avoid undo/redo in text editing mode - * @return {Boolean} - */ - isInputFocused: function isInputFocused() { - return this.getFrameEl().contentDocument.activeElement.tagName !== 'BODY'; - }, + if (tiny.isValid()) { + _set(tiny); + updateOriginalInput(true); + } else { + textInput.addClass('sp-validation-error'); + } + } + } - /** - * Start autoscroll - */ - startAutoscroll: function startAutoscroll() { - var _this = this; + function toggle() { + if (visible) { + hide(); + } else { + show(); + } + } - this.dragging = 1; - var toListen = this.getScrollListeners(); - frameRect = CanvasView.getFrameOffset(1); + function show() { + var event = $.Event('beforeShow.spectrum'); - // By detaching those from the stack avoid browsers lags - // Noticeable with "fast" drag of blocks - setTimeout(function () { - (0, _mixins.on)(toListen, 'mousemove', _this.autoscroll); - (0, _mixins.on)(toListen, 'mouseup', _this.stopAutoscroll); - }, 0); - }, - autoscroll: function autoscroll(e) { - e.preventDefault(); - if (this.dragging) { - var frameWindow = this.getFrameEl().contentWindow; - var actualTop = frameWindow.document.body.scrollTop; - var nextTop = actualTop; - var clientY = e.clientY; - var limitTop = 50; - var limitBottom = frameRect.height - limitTop; + if (visible) { + reflow(); + return; + } - if (clientY < limitTop) { - nextTop -= limitTop - clientY; - } + boundElement.trigger(event, [get()]); - if (clientY > limitBottom) { - nextTop += clientY - limitBottom; - } + if (callbacks.beforeShow(get()) === false || event.isDefaultPrevented()) { + return; + } - //console.log(`actualTop: ${actualTop} clientY: ${clientY} nextTop: ${nextTop} frameHeigh: ${frameRect.height}`); - frameWindow.scrollTo(0, nextTop); + hideAll(); + visible = true; + var $doc = $(doc); + $doc.bind('keydown.spectrum', onkeydown); + $doc.bind('click.spectrum', clickout); + $(window).bind('resize.spectrum', resize); + replacer.addClass('sp-active'); + container.removeClass('sp-hidden'); + reflow(); + updateUI(); + colorOnShow = get(); + drawInitial(); + callbacks.show(colorOnShow); + boundElement.trigger('show.spectrum', [colorOnShow]); + } + + function onkeydown(e) { + // Close on ESC + if (e.keyCode === 27) { + hide(); } - }, + } + function clickout(e) { + // Return on right click. + if (e.button == 2) { + return; + } // If a drag event was happening during the mouseup, don't hide + // on click. - /** - * Stop autoscroll - */ - stopAutoscroll: function stopAutoscroll() { - this.dragging = 0; - var toListen = this.getScrollListeners(); - (0, _mixins.off)(toListen, 'mousemove', this.autoscroll); - (0, _mixins.off)(toListen, 'mouseup', this.stopAutoscroll); - }, - getScrollListeners: function getScrollListeners() { - return [this.getFrameEl().contentWindow, this.getElement()]; - }, + if (isDragging) { + return; + } - /** - * Returns wrapper element - * @return {HTMLElement} - * ???? - */ - getFrameWrapperEl: function getFrameWrapperEl() { - return CanvasView.frame.getWrapper(); + if (clickoutFiresChange) { + updateOriginalInput(true); + } else { + revert(); + } + + hide(); } - }; -}; -/***/ }), -/* 179 */ -/***/ (function(module, exports, __webpack_require__) { + function hide() { + // Return if hiding is unnecessary + if (!visible || flat) { + return; + } -"use strict"; + visible = false; + $(doc).unbind('keydown.spectrum', onkeydown); + $(doc).unbind('click.spectrum', clickout); + $(window).unbind('resize.spectrum', resize); + replacer.removeClass('sp-active'); + container.addClass('sp-hidden'); + callbacks.hide(get()); + boundElement.trigger('hide.spectrum', [get()]); + } + function revert() { + _set(colorOnShow, true); + } -module.exports = { + function _set(color, ignoreFormatChange) { + if (tinycolor.equals(color, get())) { + // Update UI just in case a validation error needs + // to be cleared. + updateUI(); + return; + } - stylePrefix: 'cv-', + var newColor, newHsv; - // Coming soon - rulers: false, + if (!color && allowEmpty) { + isEmpty = true; + } else { + isEmpty = false; + newColor = tinycolor(color); + newHsv = newColor.toHsv(); + currentHue = newHsv.h % 360 / 360; + currentSaturation = newHsv.s; + currentValue = newHsv.v; + currentAlpha = newHsv.a; + } - /* - * Append external scripts in head of the iframe before renderBody content - * In this case, you have to add them manually later in the final HTML page - * @example - * scripts: [ - * 'https://...', - * ] - */ - scripts: [], + updateUI(); - /* - * Append external styles. This styles won't be added to the final HTML/CSS - * @example - * styles: [ - * 'https://...', - * ] - */ - styles: [], + if (newColor && newColor.isValid() && !ignoreFormatChange) { + currentPreferredFormat = opts.preferredFormat || newColor.getFormat(); + } + } - /** - * Add custom badge naming strategy - * @example - * customBadgeLabel: function(ComponentModel) { - * return ComponentModel.getName(); - * } - */ - customBadgeLabel: '' + function get(opts) { + opts = opts || {}; -}; + if (allowEmpty && isEmpty) { + return null; + } -/***/ }), -/* 180 */ -/***/ (function(module, exports, __webpack_require__) { + return tinycolor.fromRatio({ + h: currentHue, + s: currentSaturation, + v: currentValue, + a: Math.round(currentAlpha * 100) / 100 + }, { + format: opts.format || currentPreferredFormat + }); + } -"use strict"; + function isValid() { + return !textInput.hasClass('sp-validation-error'); + } + function move() { + updateUI(); + callbacks.move(get()); + boundElement.trigger('move.spectrum', [get()]); + } -var Backbone = __webpack_require__(0); -var Frame = __webpack_require__(181); + function updateUI() { + textInput.removeClass('sp-validation-error'); + updateHelperLocations(); // Update dragger background color (gradients take care of saturation and value). -module.exports = Backbone.Model.extend({ + var flatColor = tinycolor.fromRatio({ + h: currentHue, + s: 1, + v: 1 + }); + dragger.css('background-color', flatColor.toHexString()); // Get a format that alpha will be included in (hex and names ignore alpha) - defaults: { - frame: '', - wrapper: '', - rulers: false - }, + var format = currentPreferredFormat; - initialize: function initialize(config) { - var conf = this.conf || {}; - this.set('frame', new Frame(conf.frame)); - } -}); + if (currentAlpha < 1 && !(currentAlpha === 0 && format === 'name')) { + if (format === 'hex' || format === 'hex3' || format === 'hex6' || format === 'name') { + format = 'rgb'; + } + } -/***/ }), -/* 181 */ -/***/ (function(module, exports, __webpack_require__) { + var realColor = get({ + format: format + }), + displayColor = ''; //reset background info for preview element -"use strict"; + previewElement.removeClass('sp-clear-display'); + previewElement.css('background-color', 'transparent'); + if (!realColor && allowEmpty) { + // Update the replaced elements background with icon indicating no color selection + previewElement.addClass('sp-clear-display'); + } else { + var realHex = realColor.toHexString(), + realRgb = realColor.toRgbString(); // Update the replaced elements background color (with actual selected color) -var Backbone = __webpack_require__(0); + if (rgbaSupport || realColor.alpha === 1) { + previewElement.css('background-color', realRgb); + } else { + previewElement.css('background-color', 'transparent'); + previewElement.css('filter', realColor.toFilter()); + } -module.exports = Backbone.Model.extend({ + if (opts.showAlpha) { + var rgb = realColor.toRgb(); + rgb.a = 0; + var realAlpha = tinycolor(rgb).toRgbString(); + var gradient = 'linear-gradient(left, ' + realAlpha + ', ' + realHex + ')'; - defaults: { - wrapper: '', - width: '', - height: '', - attributes: {} - } + if (IE) { + alphaSliderInner.css('filter', tinycolor(realAlpha).toFilter({ + gradientType: 1 + }, realHex)); + } else { + alphaSliderInner.css('background', '-webkit-' + gradient); + alphaSliderInner.css('background', '-moz-' + gradient); + alphaSliderInner.css('background', '-ms-' + gradient); // Use current syntax gradient on unprefixed property. -}); + alphaSliderInner.css('background', 'linear-gradient(to right, ' + realAlpha + ', ' + realHex + ')'); + } + } -/***/ }), -/* 182 */ -/***/ (function(module, exports, __webpack_require__) { + displayColor = realColor.toString(format); + } // Update the text entry input as it changes happen -"use strict"; -/* WEBPACK VAR INJECTION */(function(Backbone, _) { -var FrameView = __webpack_require__(183); -var $ = Backbone.$; + if (opts.showInput) { + textInput.val(displayColor); + } -module.exports = Backbone.View.extend({ - initialize: function initialize(o) { - _.bindAll(this, 'renderBody', 'onFrameScroll', 'clearOff'); - window.onscroll = this.clearOff; - this.config = o.config || {}; - this.em = this.config.em || {}; - this.ppfx = this.config.pStylePrefix || ''; - this.className = this.config.stylePrefix + 'canvas'; - this.listenTo(this.em, 'change:canvasOffset', this.clearOff); - this.frame = new FrameView({ - model: this.model.get('frame'), - config: this.config - }); - }, + if (opts.showPalette) { + drawPalette(); + } + drawInitial(); + } - /** - * Checks if the element is visible in the canvas's viewport - * @param {HTMLElement} el - * @return {Boolean} - */ - isElInViewport: function isElInViewport(el) { - var rect = el.getBoundingClientRect(); - var frameRect = this.getFrameOffset(1); - var rTop = rect.top; - var rLeft = rect.left; - return rTop >= 0 && rLeft >= 0 && rTop <= frameRect.height && rLeft <= frameRect.width; - }, + function updateHelperLocations() { + var s = currentSaturation; + var v = currentValue; + if (allowEmpty && isEmpty) { + //if selected color is empty, hide the helpers + alphaSlideHelper.hide(); + slideHelper.hide(); + dragHelper.hide(); + } else { + //make sure helpers are visible + alphaSlideHelper.show(); + slideHelper.show(); + dragHelper.show(); // Where to show the little circle in that displays your current selected color + + var dragX = s * dragWidth; + var dragY = dragHeight - v * dragHeight; + dragX = Math.max(-dragHelperHeight, Math.min(dragWidth - dragHelperHeight, dragX - dragHelperHeight)); + dragY = Math.max(-dragHelperHeight, Math.min(dragHeight - dragHelperHeight, dragY - dragHelperHeight)); + dragHelper.css({ + top: dragY + 'px', + left: dragX + 'px' + }); + var alphaX = currentAlpha * alphaWidth; + alphaSlideHelper.css({ + left: alphaX - alphaSlideHelperWidth / 2 + 'px' + }); // Where to show the bar that displays your current selected hue + + var slideY = currentHue * slideHeight; + slideHelper.css({ + top: slideY - slideHelperHeight + 'px' + }); + } + } - /** - * Update tools position - * @private - */ - onFrameScroll: function onFrameScroll() { - var u = 'px'; - var body = this.frame.el.contentDocument.body; - this.toolsEl.style.top = '-' + body.scrollTop + u; - this.toolsEl.style.left = '-' + body.scrollLeft + u; - this.em.trigger('canvasScroll'); - }, + function updateOriginalInput(fireCallback) { + var color = get(), + displayColor = '', + hasChanged = !tinycolor.equals(color, colorOnShow); + if (color) { + displayColor = color.toString(currentPreferredFormat); // Update the selection palette with the current color - /** - * Insert scripts into head, it will call renderBody after all scripts loaded or failed - * @private - */ - renderScripts: function renderScripts() { - var frame = this.frame; - var that = this; + addColorToSelectionPalette(color); + } - frame.el.onload = function () { - var scripts = that.config.scripts.slice(0), - // clone - counter = 0; + if (isInput) { + boundElement.val(displayColor); + } - function appendScript(scripts) { - if (scripts.length > 0) { - var script = document.createElement('script'); - script.type = 'text/javascript'; - script.src = scripts.shift(); - script.onerror = script.onload = appendScript.bind(null, scripts); - frame.el.contentDocument.head.appendChild(script); + if (fireCallback && hasChanged) { + callbacks.change(color); + boundElement.trigger('change', [color]); + } + } + + function reflow() { + if (!visible) { + return; // Calculations would be useless and wouldn't be reliable anyways + } + + dragWidth = dragger.width(); + dragHeight = dragger.height(); + dragHelperHeight = dragHelper.height(); + slideWidth = slider.width(); + slideHeight = slider.height(); + slideHelperHeight = slideHelper.height(); + alphaWidth = alphaSlider.width(); + alphaSlideHelperWidth = alphaSlideHelper.width(); + + if (!flat) { + container.css('position', 'absolute'); + + if (opts.offset) { + container.offset(opts.offset); } else { - that.renderBody(); + container.offset(getOffset(container, offsetElement)); } } - appendScript(scripts); - }; - }, + updateHelperLocations(); - /** - * Render inside frame's body - * @private - */ - renderBody: function renderBody() { - var wrap = this.model.get('frame').get('wrapper'); - var em = this.config.em; - if (wrap) { - var ppfx = this.ppfx; - //var body = this.frame.$el.contents().find('body'); - var body = $(this.frame.el.contentWindow.document.body); - var cssc = em.get('CssComposer'); - var conf = em.get('Config'); - var confCanvas = this.config; - var protCss = conf.protectedCss; - var externalStyles = ''; + if (opts.showPalette) { + drawPalette(); + } - confCanvas.styles.forEach(function (style) { - externalStyles += ''; - }); + boundElement.trigger('reflow.spectrum'); + } - var colorWarn = '#ffca6f'; + function destroy() { + boundElement.show(); + offsetElement.unbind('click.spectrum touchstart.spectrum'); + container.remove(); + replacer.remove(); + spectrums[spect.id] = null; + } - var baseCss = '\n * {\n box-sizing: border-box;\n }\n html, body, #wrapper {\n min-height: 100%;\n }\n body {\n margin: 0;\n height: 100%;\n background-color: #fff\n }\n #wrapper {\n overflow: auto\n }\n '; - // Remove `html { height: 100%;}` from the baseCss as it gives jumpings - // effects (on ENTER) with RTE like CKEditor (maybe some bug there?!?) - // With `body {height: auto;}` jumps in CKEditor are removed but in - // Firefox is impossible to drag stuff in empty canvas, so bring back - // `body {height: 100%;}`. - // For the moment I give the priority to Firefox as it might be - // CKEditor's issue + function option(optionName, optionValue) { + if (optionName === undefined) { + return $.extend({}, opts); + } + + if (optionValue === undefined) { + return opts[optionName]; + } - // I need all this styles to make the editor work properly - var frameCss = '\n ' + baseCss + '\n\n .' + ppfx + 'dashed *[data-highlightable] {\n outline: 1px dashed rgba(170,170,170,0.7);\n outline-offset: -3px\n }\n\n .' + ppfx + 'comp-selected {\n outline: 3px solid #3b97e3 !important;\n }\n\n .' + ppfx + 'comp-selected-parent {\n outline: 2px solid ' + colorWarn + ' !important\n }\n\n .' + ppfx + 'no-select {\n user-select: none;\n -webkit-user-select:none;\n -moz-user-select: none;\n }\n\n .' + ppfx + 'freezed {\n opacity: 0.5;\n pointer-events: none;\n }\n\n .' + ppfx + 'no-pointer {\n pointer-events: none;\n }\n\n .' + ppfx + 'plh-image {\n background: #f5f5f5;\n border: none;\n height: 50px;\n width: 50px;\n display: block;\n outline: 3px solid #ffca6f;\n cursor: pointer;\n outline-offset: -2px\n }\n\n .' + ppfx + 'grabbing {\n cursor: grabbing;\n cursor: -webkit-grabbing;\n }\n\n * ::-webkit-scrollbar-track {\n background: rgba(0, 0, 0, 0.1)\n }\n\n * ::-webkit-scrollbar-thumb {\n background: rgba(255, 255, 255, 0.2)\n }\n\n * ::-webkit-scrollbar {\n width: 10px\n }\n\n ' + (conf.canvasCss || '') + '\n ' + (protCss || '') + '\n '; + opts[optionName] = optionValue; - if (externalStyles) { - body.append(externalStyles); + if (optionName === 'preferredFormat') { + currentPreferredFormat = opts.preferredFormat; } - body.append(''); - body.append(wrap.render()).append(cssc.render()); - body.append(this.getJsContainer()); - em.trigger('loaded'); - this.frame.el.contentWindow.onscroll = this.onFrameScroll; - this.frame.udpateOffset(); + applyOptions(); + } - // When the iframe is focused the event dispatcher is not the same so - // I need to delegate all events to the parent document - var doc = document; - var fdoc = this.frame.el.contentDocument; + function enable() { + disabled = false; + boundElement.attr('disabled', false); + offsetElement.removeClass('sp-disabled'); + } + + function disable() { + hide(); + disabled = true; + boundElement.attr('disabled', true); + offsetElement.addClass('sp-disabled'); + } - // Unfortunately just creating `KeyboardEvent(e.type, e)` is not enough, - // the keyCode/which will be always `0`. Even if it's an old/deprecated - // property keymaster (and many others) still use it... using `defineProperty` - // hack seems the only way - var createCustomEvent = function createCustomEvent(e) { - var oEvent = new KeyboardEvent(e.type, e); - oEvent.keyCodeVal = e.keyCode; - ['keyCode', 'which'].forEach(function (prop) { - Object.defineProperty(oEvent, prop, { - get: function get() { - return this.keyCodeVal; - } - }); - }); - return oEvent; - }; - fdoc.addEventListener('keydown', function (e) { - doc.dispatchEvent(createCustomEvent(e)); - }); - fdoc.addEventListener('keyup', function (e) { - doc.dispatchEvent(createCustomEvent(e)); - }); + function setOffset(coord) { + opts.offset = coord; + reflow(); } - }, + initialize(); + var spect = { + show: show, + hide: hide, + toggle: toggle, + reflow: reflow, + option: option, + enable: enable, + disable: disable, + offset: setOffset, + set: function set(c) { + _set(c); + updateOriginalInput(); + }, + get: get, + destroy: destroy, + container: container + }; + spect.id = spectrums.push(spect) - 1; + return spect; + } /** - * Get the offset of the element - * @param {HTMLElement} el - * @return {Object} + * checkOffset - get the offset below/above and left/right element depending on screen position + * Thanks https://github.com/jquery/jquery-ui/blob/master/ui/jquery.ui.datepicker.js */ - offset: function offset(el) { - var rect = el.getBoundingClientRect(); - var docBody = el.ownerDocument.body; - return { - top: rect.top + docBody.scrollTop, - left: rect.left + docBody.scrollLeft, - width: rect.width, - height: rect.height - }; - }, + function getOffset(picker, input) { + var extraY = 0; + var dpWidth = picker.outerWidth(); + var dpHeight = picker.outerHeight(); + var inputHeight = input.outerHeight(); + var doc = picker[0].ownerDocument; + var docElem = doc.documentElement; + var cW = docElem.clientWidth; + var cH = docElem.clientHeight; + var scL = $(doc).scrollLeft(); + var scT = $(doc).scrollTop(); + var viewWidth = cW + scL; + var viewHeight = cH + scT; + var offset = input.offset(); + offset.top += inputHeight; + offset.left -= Math.min(offset.left, offset.left + dpWidth > viewWidth && viewWidth > dpWidth ? Math.abs(offset.left + dpWidth - viewWidth) : 0); + offset.top -= Math.min(offset.top, offset.top + dpHeight > viewHeight && viewHeight > dpHeight ? Math.abs(dpHeight + inputHeight - extraY) : extraY); + return offset; + } /** - * Cleare cached offsets - * @private + * noop - do nothing */ - clearOff: function clearOff() { - this.frmOff = null; - this.cvsOff = null; - }, + function noop() {} /** - * Return frame offset - * @return {Object} - * @private + * stopPropagation - makes the code only doing this a little easier to read in line */ - getFrameOffset: function getFrameOffset() { - var force = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 0; - - if (!this.frmOff || force) this.frmOff = this.offset(this.frame.el); - return this.frmOff; - }, + function stopPropagation(e) { + e.stopPropagation(); + } /** - * Return canvas offset - * @return {Object} - * @private + * Create a function bound to a given object + * Thanks to underscore.js */ - getCanvasOffset: function getCanvasOffset() { - if (!this.cvsOff) this.cvsOff = this.offset(this.el); - return this.cvsOff; - }, + function bind(func, obj) { + var slice = Array.prototype.slice; + var args = slice.call(arguments, 2); + return function () { + return func.apply(obj, args.concat(slice.call(arguments))); + }; + } /** - * Returns element's data info - * @param {HTMLElement} el - * @return {Object} - * @private + * Lightweight drag helper. Handles containment within the element, so that + * when dragging, the x is within [0,element.width] and y is within [0,element.height] */ - getElementPos: function getElementPos(el, opts) { - var opt = opts || {}; - var frmOff = this.getFrameOffset(); - var cvsOff = this.getCanvasOffset(); - var eo = this.offset(el); - var frmTop = opt.avoidFrameOffset ? 0 : frmOff.top; - var frmLeft = opt.avoidFrameOffset ? 0 : frmOff.left; - var top = eo.top + frmTop - cvsOff.top; - var left = eo.left + frmLeft - cvsOff.left; - // clientHeight/clientWidth are for SVGs - var height = el.offsetHeight || el.clientHeight; - var width = el.offsetWidth || el.clientWidth; + function draggable(element, onmove, onstart, onstop) { + onmove = onmove || function () {}; - return { top: top, left: left, height: height, width: width }; - }, + onstart = onstart || function () {}; + onstop = onstop || function () {}; - /** - * Returns position data of the canvas element - * @return {Object} obj Position object - * @private - */ - getPosition: function getPosition() { - var bEl = this.frame.el.contentDocument.body; - var fo = this.getFrameOffset(); - var co = this.getCanvasOffset(); - return { - top: fo.top + bEl.scrollTop - co.top, - left: fo.left + bEl.scrollLeft - co.left - }; - }, + var doc = document; + var dragging = false; + var offset = {}; + var maxHeight = 0; + var maxWidth = 0; + var hasTouch = 'ontouchstart' in window; + var duringDragEvents = {}; + duringDragEvents['selectstart'] = prevent; + duringDragEvents['dragstart'] = prevent; + duringDragEvents['touchmove mousemove'] = move; + duringDragEvents['touchend mouseup'] = stop; + function prevent(e) { + if (e.stopPropagation) { + e.stopPropagation(); + } - /** - * Update javascript of a specific component passed by its View - * @param {View} view Component's View - * @private - */ - updateScript: function updateScript(view) { - if (!view.scriptContainer) { - view.scriptContainer = $('
'); - this.getJsContainer().append(view.scriptContainer.get(0)); + if (e.preventDefault) { + e.preventDefault(); + } + + e.returnValue = false; } - var model = view.model; - var id = model.getId(); - view.el.id = id; - view.scriptContainer.html(''); - // In editor, I make use of setTimeout as during the append process of elements - // those will not be available immediatly, therefore 'item' variable - var script = document.createElement('script'); - script.innerText = '\n setTimeout(function() {\n var item = document.getElementById(\'' + id + '\');\n if (!item) return;\n (function(){\n ' + model.getScriptString() + ';\n }.bind(item))()\n }, 1);'; - view.scriptContainer.get(0).appendChild(script); - }, + function move(e) { + if (dragging) { + // Mouseup happened outside of window + if (IE && doc.documentMode < 9 && !e.button) { + return stop(); + } + var t0 = e && e.touches && e.touches[0]; + var pageX = t0 && t0.pageX || e.pageX; + var pageY = t0 && t0.pageY || e.pageY; + var dragX = Math.max(0, Math.min(pageX - offset.left, maxWidth)); + var dragY = Math.max(0, Math.min(pageY - offset.top, maxHeight)); - /** - * Get javascript container - * @private - */ - getJsContainer: function getJsContainer() { - if (!this.jsContainer) { - this.jsContainer = $('
').get(0); - } - return this.jsContainer; - }, - render: function render() { - this.wrapper = this.model.get('wrapper'); + if (hasTouch) { + // Stop scrolling in iOS + prevent(e); + } - if (this.wrapper && typeof this.wrapper.render == 'function') { - this.model.get('frame').set('wrapper', this.wrapper); - this.$el.append(this.frame.render().el); - var frame = this.frame; - if (this.config.scripts.length === 0) { - frame.el.onload = this.renderBody; - } else { - this.renderScripts(); // will call renderBody later + onmove.apply(element, [dragX, dragY, e]); } } - var ppfx = this.ppfx; - this.$el.append('\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n '); - var el = this.el; - var toolsEl = el.querySelector('#' + ppfx + 'tools'); - this.hlEl = el.querySelector('.' + ppfx + 'highlighter'); - this.badgeEl = el.querySelector('.' + ppfx + 'badge'); - this.placerEl = el.querySelector('.' + ppfx + 'placeholder'); - this.ghostEl = el.querySelector('.' + ppfx + 'ghost'); - this.toolbarEl = el.querySelector('.' + ppfx + 'toolbar'); - this.resizerEl = el.querySelector('.' + ppfx + 'resizer'); - this.offsetEl = el.querySelector('.' + ppfx + 'offset-v'); - this.fixedOffsetEl = el.querySelector('.' + ppfx + 'offset-fixed-v'); - this.toolsEl = toolsEl; - this.el.className = this.className; - return this; - } -}); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(0), __webpack_require__(1))) -/***/ }), -/* 183 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; + function start(e) { + var rightclick = e.which ? e.which == 3 : e.button == 2; + if (!rightclick && !dragging) { + if (onstart.apply(element, arguments) !== false) { + dragging = true; + maxHeight = $(element).height(); + maxWidth = $(element).width(); + offset = $(element).offset(); + $(doc).bind(duringDragEvents); + $(doc.body).addClass('sp-dragging'); + move(e); + prevent(e); + } + } + } -var _underscore = __webpack_require__(1); + function stop() { + if (dragging) { + $(doc).unbind(duringDragEvents); + $(doc.body).removeClass('sp-dragging'); // Wait a tick before notifying observers to allow the click event + // to fire in Chrome. -var motionsEv = 'transitionend oTransitionEnd transitionend webkitTransitionEnd'; + setTimeout(function () { + onstop.apply(element, arguments); + }, 0); + } -module.exports = __webpack_require__(0).View.extend({ + dragging = false; + } - tagName: 'iframe', + $(element).bind('touchstart mousedown', start); + } - attributes: { - src: 'about:blank', - allowfullscreen: 'allowfullscreen' - }, + function throttle(func, wait, debounce) { + var timeout; + return function () { + var context = this, + args = arguments; - initialize: function initialize(o) { - (0, _underscore.bindAll)(this, 'udpateOffset'); - this.config = o.config || {}; - this.ppfx = this.config.pStylePrefix || ''; - this.em = this.config.em; - this.listenTo(this.em, 'change:device', this.updateDim); - }, + var throttler = function throttler() { + timeout = null; + func.apply(context, args); + }; + if (debounce) clearTimeout(timeout); + if (debounce || !timeout) timeout = setTimeout(throttler, wait); + }; + } + function inputTypeColorSupport() { + return $.fn.spectrum.inputTypeColorSupport(); + } /** - * Update dimensions of the frame - * @private + * Define a jQuery plugin */ - updateDim: function updateDim(model) { - var em = this.em; - var device = em.getDeviceModel(); - var style = this.el.style; - style.width = device ? device.get('width') : ''; - style.height = device ? device.get('height') : ''; - this.udpateOffset(); - em.stopDefault({ preserveSelected: 1 }); - this.$el.on(motionsEv, this.udpateOffset); - }, - udpateOffset: function udpateOffset() { - var em = this.em; - var offset = em.get('Canvas').getOffset(); - em.set('canvasOffset', offset); - em.runDefault({ preserveSelected: 1 }); - this.$el.off(motionsEv, this.udpateOffset); - }, - getBody: function getBody() { - this.$el.contents().find('body'); - }, - getWrapper: function getWrapper() { - return this.$el.contents().find('body > div'); - }, - render: function render() { - this.$el.attr({ class: this.ppfx + 'frame' }); - return this; - } -}); -/***/ }), -/* 184 */ -/***/ (function(module, exports, __webpack_require__) { -"use strict"; + var dataID = 'spectrum.id'; + + $.fn.spectrum = function (opts, extra) { + if (typeof opts == 'string') { + var returnValue = this; + var args = Array.prototype.slice.call(arguments, 1); + this.each(function () { + var spect = spectrums[$(this).data(dataID)]; + if (spect) { + var method = spect[opts]; -var _underscore = __webpack_require__(1); + if (!method) { + throw new Error("Spectrum: no such method: '" + opts + "'"); + } + + if (opts == 'get') { + returnValue = spect.get(); + } else if (opts == 'container') { + returnValue = spect.container; + } else if (opts == 'option') { + returnValue = spect.option.apply(spect, args); + } else if (opts == 'destroy') { + spect.destroy(); + $(this).removeData(dataID); + } else { + method.apply(spect, args); + } + } + }); + return returnValue; + } // Initializing a new instance of spectrum -module.exports = function () { - var em = void 0; - var c = {}, - commands = {}, - defaultCommands = {}, - defaults = __webpack_require__(185), - AbsCommands = __webpack_require__(186); - // Need it here as it would be used below - var add = function add(id, obj) { - if ((0, _underscore.isFunction)(obj)) { - obj = { run: obj }; + return this.spectrum('destroy').each(function () { + var options = $.extend({}, opts, $(this).data()); + var spect = spectrum(this, options); + $(this).data(dataID, spect.id); + }); + }; + + $.fn.spectrum.load = true; + $.fn.spectrum.loadOpts = {}; + $.fn.spectrum.draggable = draggable; + $.fn.spectrum.defaults = defaultOpts; + + $.fn.spectrum.inputTypeColorSupport = function inputTypeColorSupport() { + if (typeof inputTypeColorSupport._cachedResult === 'undefined') { + var colorInput = $("")[0]; // if color element is supported, value will default to not null + + inputTypeColorSupport._cachedResult = colorInput.type === 'color' && colorInput.value !== ''; } - delete obj.initialize; - commands[id] = AbsCommands.extend(obj); - return this; + return inputTypeColorSupport._cachedResult; }; - return { + $.spectrum = {}; + $.spectrum.localization = {}; + $.spectrum.palettes = {}; - /** - * Name of the module - * @type {String} - * @private - */ - name: 'Commands', + $.fn.spectrum.processNativeColorInputs = function () { + var colorInputs = $('input[type=color]'); - /** - * Initialize module. Automatically called with a new instance of the editor - * @param {Object} config Configurations - * @private - */ - init: function init(config) { - c = config || {}; - for (var name in defaults) { - if (!(name in c)) c[name] = defaults[name]; - } - em = c.em; - var ppfx = c.pStylePrefix; - if (ppfx) c.stylePrefix = ppfx + c.stylePrefix; + if (colorInputs.length && !inputTypeColorSupport()) { + colorInputs.spectrum({ + preferredFormat: 'hex6' + }); + } + }; // TinyColor v1.1.2 + // https://github.com/bgrins/TinyColor + // Brian Grinstead, MIT License + //(function() { + + + var trimLeft = /^[\s,#]+/, + trimRight = /\s+$/, + tinyCounter = 0, + math = Math, + mathRound = math.round, + mathMin = math.min, + mathMax = math.max, + mathRandom = math.random; + + var tinycolor = function tinycolor(color, opts) { + color = color ? color : ''; + opts = opts || {}; // If input is already a tinycolor, return itself + + if (color instanceof tinycolor) { + return color; + } // If we are called as a function, call using new instead + + + if (!(this instanceof tinycolor)) { + return new tinycolor(color, opts); + } + + var rgb = inputToRGB(color); + this._originalInput = color, this._r = rgb.r, this._g = rgb.g, this._b = rgb.b, this._a = rgb.a, this._roundA = mathRound(100 * this._a) / 100, this._format = opts.format || rgb.format; + this._gradientType = opts.gradientType; // Don't let the range of [0,255] come back in [0,1]. + // Potentially lose a little bit of precision here, but will fix issues where + // .5 gets interpreted as half of the total, instead of half of 1 + // If it was supposed to be 128, this was already taken care of by `inputToRgb` + + if (this._r < 1) { + this._r = mathRound(this._r); + } + + if (this._g < 1) { + this._g = mathRound(this._g); + } + + if (this._b < 1) { + this._b = mathRound(this._b); + } + + this._ok = rgb.ok; + this._tc_id = tinyCounter++; + }; + + tinycolor.prototype = { + isDark: function isDark() { + return this.getBrightness() < 128; + }, + isLight: function isLight() { + return !this.isDark(); + }, + isValid: function isValid() { + return this._ok; + }, + getOriginalInput: function getOriginalInput() { + return this._originalInput; + }, + getFormat: function getFormat() { + return this._format; + }, + getAlpha: function getAlpha() { + return this._a; + }, + getBrightness: function getBrightness() { + var rgb = this.toRgb(); + return (rgb.r * 299 + rgb.g * 587 + rgb.b * 114) / 1000; + }, + setAlpha: function setAlpha(value) { + this._a = boundAlpha(value); + this._roundA = mathRound(100 * this._a) / 100; + return this; + }, + toHsv: function toHsv() { + var hsv = rgbToHsv(this._r, this._g, this._b); + return { + h: hsv.h * 360, + s: hsv.s, + v: hsv.v, + a: this._a + }; + }, + toHsvString: function toHsvString() { + var hsv = rgbToHsv(this._r, this._g, this._b); + var h = mathRound(hsv.h * 360), + s = mathRound(hsv.s * 100), + v = mathRound(hsv.v * 100); + return this._a == 1 ? 'hsv(' + h + ', ' + s + '%, ' + v + '%)' : 'hsva(' + h + ', ' + s + '%, ' + v + '%, ' + this._roundA + ')'; + }, + toHsl: function toHsl() { + var hsl = rgbToHsl(this._r, this._g, this._b); + return { + h: hsl.h * 360, + s: hsl.s, + l: hsl.l, + a: this._a + }; + }, + toHslString: function toHslString() { + var hsl = rgbToHsl(this._r, this._g, this._b); + var h = mathRound(hsl.h * 360), + s = mathRound(hsl.s * 100), + l = mathRound(hsl.l * 100); + return this._a == 1 ? 'hsl(' + h + ', ' + s + '%, ' + l + '%)' : 'hsla(' + h + ', ' + s + '%, ' + l + '%, ' + this._roundA + ')'; + }, + toHex: function toHex(allow3Char) { + return rgbToHex(this._r, this._g, this._b, allow3Char); + }, + toHexString: function toHexString(allow3Char) { + return '#' + this.toHex(allow3Char); + }, + toHex8: function toHex8() { + return rgbaToHex(this._r, this._g, this._b, this._a); + }, + toHex8String: function toHex8String() { + return '#' + this.toHex8(); + }, + toRgb: function toRgb() { + return { + r: mathRound(this._r), + g: mathRound(this._g), + b: mathRound(this._b), + a: this._a + }; + }, + toRgbString: function toRgbString() { + return this._a == 1 ? 'rgb(' + mathRound(this._r) + ', ' + mathRound(this._g) + ', ' + mathRound(this._b) + ')' : 'rgba(' + mathRound(this._r) + ', ' + mathRound(this._g) + ', ' + mathRound(this._b) + ', ' + this._roundA + ')'; + }, + toPercentageRgb: function toPercentageRgb() { + return { + r: mathRound(bound01(this._r, 255) * 100) + '%', + g: mathRound(bound01(this._g, 255) * 100) + '%', + b: mathRound(bound01(this._b, 255) * 100) + '%', + a: this._a + }; + }, + toPercentageRgbString: function toPercentageRgbString() { + return this._a == 1 ? 'rgb(' + mathRound(bound01(this._r, 255) * 100) + '%, ' + mathRound(bound01(this._g, 255) * 100) + '%, ' + mathRound(bound01(this._b, 255) * 100) + '%)' : 'rgba(' + mathRound(bound01(this._r, 255) * 100) + '%, ' + mathRound(bound01(this._g, 255) * 100) + '%, ' + mathRound(bound01(this._b, 255) * 100) + '%, ' + this._roundA + ')'; + }, + toName: function toName() { + if (this._a === 0) { + return 'transparent'; + } - // Load commands passed via configuration - for (var k in c.defaults) { - var obj = c.defaults[k]; - if (obj.id) this.add(obj.id, obj); + if (this._a < 1) { + return false; } - var ViewCode = __webpack_require__(187); - defaultCommands['select-comp'] = __webpack_require__(21); - defaultCommands['create-comp'] = __webpack_require__(22); - defaultCommands['delete-comp'] = __webpack_require__(192); - defaultCommands['image-comp'] = __webpack_require__(193); - defaultCommands['move-comp'] = __webpack_require__(194); - defaultCommands['text-comp'] = __webpack_require__(195); - defaultCommands['insert-custom'] = __webpack_require__(54); - defaultCommands['export-template'] = ViewCode; - defaultCommands['sw-visibility'] = __webpack_require__(196); - defaultCommands['open-layers'] = __webpack_require__(197); - defaultCommands['open-sm'] = __webpack_require__(200); - defaultCommands['open-tm'] = __webpack_require__(201); - defaultCommands['open-blocks'] = __webpack_require__(202); - defaultCommands['open-assets'] = __webpack_require__(203); - defaultCommands['show-offset'] = __webpack_require__(204); - defaultCommands['select-parent'] = __webpack_require__(205); - defaultCommands.fullscreen = __webpack_require__(206); - defaultCommands.preview = __webpack_require__(207); - defaultCommands.resize = __webpack_require__(208); - defaultCommands.drag = __webpack_require__(209); + return hexNames[rgbToHex(this._r, this._g, this._b, true)] || false; + }, + toFilter: function toFilter(secondColor) { + var hex8String = '#' + rgbaToHex(this._r, this._g, this._b, this._a); + var secondHex8String = hex8String; + var gradientType = this._gradientType ? 'GradientType = 1, ' : ''; - defaultCommands['tlb-delete'] = { - run: function run(ed) { - var sel = ed.getSelected(); + if (secondColor) { + var s = tinycolor(secondColor); + secondHex8String = s.toHex8String(); + } - if (!sel || !sel.get('removable')) { - console.warn('The element is not removable'); - return; - } + return 'progid:DXImageTransform.Microsoft.gradient(' + gradientType + 'startColorstr=' + hex8String + ',endColorstr=' + secondHex8String + ')'; + }, + toString: function toString(format) { + var formatSet = !!format; + format = format || this._format; + var formattedString = false; + var hasAlpha = this._a < 1 && this._a >= 0; + var needsAlphaFormat = !formatSet && hasAlpha && (format === 'hex' || format === 'hex6' || format === 'hex3' || format === 'name'); - ed.select(null); - sel.destroy(); + if (needsAlphaFormat) { + // Special case for "transparent", all other non-alpha formats + // will return rgba when there is transparency. + if (format === 'name' && this._a === 0) { + return this.toName(); } - }; - - defaultCommands['tlb-clone'] = { - run: function run(ed) { - var sel = ed.getSelected(); - if (!sel || !sel.get('copyable')) { - console.warn('The element is not clonable'); - return; - } - - var collection = sel.collection; - var index = collection.indexOf(sel); - collection.add(sel.clone(), { at: index + 1 }); - sel.emitUpdate(); - } - }; + return this.toRgbString(); + } - defaultCommands['tlb-move'] = { - run: function run(ed, sender, opts) { - var sel = ed.getSelected(); - var dragger; + if (format === 'rgb') { + formattedString = this.toRgbString(); + } - if (!sel || !sel.get('draggable')) { - console.warn('The element is not draggable'); - return; - } + if (format === 'prgb') { + formattedString = this.toPercentageRgbString(); + } - var onStart = function onStart(e, opts) { - console.log('start mouse pos ', opts.start); - console.log('el rect ', opts.elRect); - var el = opts.el; - el.style.position = 'absolute'; - el.style.margin = 0; - }; + if (format === 'hex' || format === 'hex6') { + formattedString = this.toHexString(); + } - var onEnd = function onEnd(e, opts) { - em.runDefault(); - em.set('selectedComponent', sel); - sel.emitUpdate(); - dragger && dragger.blur(); - }; + if (format === 'hex3') { + formattedString = this.toHexString(true); + } - var onDrag = function onDrag(e, opts) { - console.log('Delta ', opts.delta); - console.log('Current ', opts.current); - }; + if (format === 'hex8') { + formattedString = this.toHex8String(); + } - var toolbarEl = ed.Canvas.getToolbarEl(); - toolbarEl.style.display = 'none'; - var em = ed.getModel(); - em.stopDefault(); + if (format === 'name') { + formattedString = this.toName(); + } - if (em.get('designerMode')) { - // TODO move grabbing func in editor/canvas from the Sorter - dragger = editor.runCommand('drag', { - el: sel.view.el, - options: { - event: opts && opts.event, - onStart: onStart, - onDrag: onDrag, - onEnd: onEnd - } - }); - } else { - var cmdMove = ed.Commands.get('move-comp'); - cmdMove.onEndMoveFromModel = onEnd; - cmdMove.initSorterFromModel(sel); - } + if (format === 'hsl') { + formattedString = this.toHslString(); + } - sel.set('status', 'selected'); - } - }; + if (format === 'hsv') { + formattedString = this.toHsvString(); + } - // Core commands - defaultCommands['core:undo'] = function (e) { - return e.UndoManager.undo(); - }; - defaultCommands['core:redo'] = function (e) { - return e.UndoManager.redo(); - }; - defaultCommands['core:canvas-clear'] = function (e) { - e.DomComponents.clear(); - e.CssComposer.clear(); - }; - defaultCommands['core:copy'] = function (ed) { - var em = ed.getModel(); - var model = ed.getSelected(); + return formattedString || this.toHexString(); + }, + _applyModification: function _applyModification(fn, args) { + var color = fn.apply(null, [this].concat([].slice.call(args))); + this._r = color._r; + this._g = color._g; + this._b = color._b; + this.setAlpha(color._a); + return this; + }, + lighten: function lighten() { + return this._applyModification(_lighten, arguments); + }, + brighten: function brighten() { + return this._applyModification(_brighten, arguments); + }, + darken: function darken() { + return this._applyModification(_darken, arguments); + }, + desaturate: function desaturate() { + return this._applyModification(_desaturate, arguments); + }, + saturate: function saturate() { + return this._applyModification(_saturate, arguments); + }, + greyscale: function greyscale() { + return this._applyModification(_greyscale, arguments); + }, + spin: function spin() { + return this._applyModification(_spin, arguments); + }, + _applyCombination: function _applyCombination(fn, args) { + return fn.apply(null, [this].concat([].slice.call(args))); + }, + analogous: function analogous() { + return this._applyCombination(_analogous, arguments); + }, + complement: function complement() { + return this._applyCombination(_complement, arguments); + }, + monochromatic: function monochromatic() { + return this._applyCombination(_monochromatic, arguments); + }, + splitcomplement: function splitcomplement() { + return this._applyCombination(_splitcomplement, arguments); + }, + triad: function triad() { + return this._applyCombination(_triad, arguments); + }, + tetrad: function tetrad() { + return this._applyCombination(_tetrad, arguments); + } + }; // If input is an object, force 1 into "1.0" to handle ratios properly + // String input requires "1.0" as input, so 1 will be treated as 1 - if (model && model.get('copyable') && !ed.Canvas.isInputFocused()) { - em.set('clipboard', model); - } - }; - defaultCommands['core:paste'] = function (ed) { - var em = ed.getModel(); - var clp = em.get('clipboard'); - var model = ed.getSelected(); - var coll = model && model.collection; + tinycolor.fromRatio = function (color, opts) { + if (_babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0___default()(color) == 'object') { + var newColor = {}; - if (coll && clp && !ed.Canvas.isInputFocused()) { - var at = coll.indexOf(model) + 1; - coll.add(clp.clone(), { at: at }); + for (var i in color) { + if (color.hasOwnProperty(i)) { + if (i === 'a') { + newColor[i] = color[i]; + } else { + newColor[i] = convertToPercentage(color[i]); + } } - }; + } - if (c.em) c.model = c.em.get('Canvas'); + color = newColor; + } - this.loadDefaultCommands(); + return tinycolor(color, opts); + }; // Given a string or object, convert that input to RGB + // Possible string inputs: + // + // "red" + // "#f00" or "f00" + // "#ff0000" or "ff0000" + // "#ff000000" or "ff000000" + // "rgb 255 0 0" or "rgb (255, 0, 0)" + // "rgb 1.0 0 0" or "rgb (1, 0, 0)" + // "rgba (255, 0, 0, 1)" or "rgba 255, 0, 0, 1" + // "rgba (1.0, 0, 0, 1)" or "rgba 1.0, 0, 0, 1" + // "hsl(0, 100%, 50%)" or "hsl 0 100% 50%" + // "hsla(0, 100%, 50%, 1)" or "hsla 0 100% 50%, 1" + // "hsv(0, 100%, 100%)" or "hsv 0 100% 100%" + // - return this; - }, + function inputToRGB(color) { + var rgb = { + r: 0, + g: 0, + b: 0 + }; + var a = 1; + var ok = false; + var format = false; - /** - * Add new command to the collection - * @param {string} id Command's ID - * @param {Object|Function} command Object representing your command, - * By passing just a function it's intended as a stateless command - * (just like passing an object with only `run` method). - * @return {this} - * @example - * commands.add('myCommand', { - * run(editor, sender) { - * alert('Hello world!'); - * }, - * stop(editor, sender) { - * }, - * }); - * // As a function - * commands.add('myCommand2', editor => { ... }); - * */ - add: add, + if (typeof color == 'string') { + color = stringInputToObject(color); + } - /** - * Get command by ID - * @param {string} id Command's ID - * @return {Object} Object representing the command - * @example - * var myCommand = commands.get('myCommand'); - * myCommand.run(); - * */ - get: function get(id) { - var el = commands[id]; + if (_babel_runtime_helpers_typeof__WEBPACK_IMPORTED_MODULE_0___default()(color) == 'object') { + if (color.hasOwnProperty('r') && color.hasOwnProperty('g') && color.hasOwnProperty('b')) { + rgb = rgbToRgb(color.r, color.g, color.b); + ok = true; + format = String(color.r).substr(-1) === '%' ? 'prgb' : 'rgb'; + } else if (color.hasOwnProperty('h') && color.hasOwnProperty('s') && color.hasOwnProperty('v')) { + color.s = convertToPercentage(color.s); + color.v = convertToPercentage(color.v); + rgb = hsvToRgb(color.h, color.s, color.v); + ok = true; + format = 'hsv'; + } else if (color.hasOwnProperty('h') && color.hasOwnProperty('s') && color.hasOwnProperty('l')) { + color.s = convertToPercentage(color.s); + color.l = convertToPercentage(color.l); + rgb = hslToRgb(color.h, color.s, color.l); + ok = true; + format = 'hsl'; + } - if (typeof el == 'function') { - el = new el(c); - commands[id] = el; + if (color.hasOwnProperty('a')) { + a = color.a; } + } - return el; - }, + a = boundAlpha(a); + return { + ok: ok, + format: color.format || format, + r: mathMin(255, mathMax(rgb.r, 0)), + g: mathMin(255, mathMax(rgb.g, 0)), + b: mathMin(255, mathMax(rgb.b, 0)), + a: a + }; + } // Conversion Functions + // -------------------- + // `rgbToHsl`, `rgbToHsv`, `hslToRgb`, `hsvToRgb` modified from: + // + // `rgbToRgb` + // Handle bounds / percentage checking to conform to CSS color spec + // + // *Assumes:* r, g, b in [0, 255] or [0, 1] + // *Returns:* { r, g, b } in [0, 255] - /** - * Check if command exists - * @param {string} id Command's ID - * @return {Boolean} - * */ - has: function has(id) { - return !!commands[id]; - }, + function rgbToRgb(r, g, b) { + return { + r: bound01(r, 255) * 255, + g: bound01(g, 255) * 255, + b: bound01(b, 255) * 255 + }; + } // `rgbToHsl` + // Converts an RGB color value to HSL. + // *Assumes:* r, g, and b are contained in [0, 255] or [0, 1] + // *Returns:* { h, s, l } in [0,1] + + + function rgbToHsl(r, g, b) { + r = bound01(r, 255); + g = bound01(g, 255); + b = bound01(b, 255); + var max = mathMax(r, g, b), + min = mathMin(r, g, b); + var h, + s, + l = (max + min) / 2; + + if (max == min) { + h = s = 0; // achromatic + } else { + var d = max - min; + s = l > 0.5 ? d / (2 - max - min) : d / (max + min); + switch (max) { + case r: + h = (g - b) / d + (g < b ? 6 : 0); + break; - /** - * Load default commands - * @return {this} - * @private - * */ - loadDefaultCommands: function loadDefaultCommands() { - for (var id in defaultCommands) { - this.add(id, defaultCommands[id]); + case g: + h = (b - r) / d + 2; + break; + + case b: + h = (r - g) / d + 4; + break; } - return this; + h /= 6; } - }; -}; /** - * - * * [add](#add) - * * [get](#get) - * * [has](#has) - * - * You can init the editor with all necessary commands via configuration - * - * ```js - * var editor = grapesjs.init({ - * ... - * commands: {...} // Check below for the properties - * ... - * }); - * ``` - * - * Before using methods you should get first the module from the editor instance, in this way: - * - * ```js - * var commands = editor.Commands; - * ``` - * - * @module Commands - * @param {Object} config Configurations - * @param {Array} [config.defaults=[]] Array of possible commands - * @example - * ... - * commands: { - * defaults: [{ - * id: 'helloWorld', - * run: function(editor, sender){ - * alert('Hello world!'); - * }, - * stop: function(editor, sender){ - * alert('Stop!'); - * }, - * }], - * }, - * ... - */ -/***/ }), -/* 185 */ -/***/ (function(module, exports, __webpack_require__) { + return { + h: h, + s: s, + l: l + }; + } // `hslToRgb` + // Converts an HSL color value to RGB. + // *Assumes:* h is contained in [0, 1] or [0, 360] and s and l are contained [0, 1] or [0, 100] + // *Returns:* { r, g, b } in the set [0, 255] -"use strict"; + function hslToRgb(h, s, l) { + var r, g, b; + h = bound01(h, 360); + s = bound01(s, 100); + l = bound01(l, 100); -module.exports = { + function hue2rgb(p, q, t) { + if (t < 0) t += 1; + if (t > 1) t -= 1; + if (t < 1 / 6) return p + (q - p) * 6 * t; + if (t < 1 / 2) return q; + if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6; + return p; + } - ESCAPE_KEY: 27, + if (s === 0) { + r = g = b = l; // achromatic + } else { + var q = l < 0.5 ? l * (1 + s) : l + s - l * s; + var p = 2 * l - q; + r = hue2rgb(p, q, h + 1 / 3); + g = hue2rgb(p, q, h); + b = hue2rgb(p, q, h - 1 / 3); + } - stylePrefix: 'com-', + return { + r: r * 255, + g: g * 255, + b: b * 255 + }; + } // `rgbToHsv` + // Converts an RGB color value to HSV + // *Assumes:* r, g, and b are contained in the set [0, 255] or [0, 1] + // *Returns:* { h, s, v } in [0,1] + + + function rgbToHsv(r, g, b) { + r = bound01(r, 255); + g = bound01(g, 255); + b = bound01(b, 255); + var max = mathMax(r, g, b), + min = mathMin(r, g, b); + var h, + s, + v = max; + var d = max - min; + s = max === 0 ? 0 : d / max; + + if (max == min) { + h = 0; // achromatic + } else { + switch (max) { + case r: + h = (g - b) / d + (g < b ? 6 : 0); + break; - defaults: [], + case g: + h = (b - r) / d + 2; + break; - // Editor model - em: null, + case b: + h = (r - g) / d + 4; + break; + } - // If true center new first-level components - firstCentered: true, + h /= 6; + } - // If true the new component will created with 'height', else 'min-height' - newFixedH: false, + return { + h: h, + s: s, + v: v + }; + } // `hsvToRgb` + // Converts an HSV color value to RGB. + // *Assumes:* h is contained in [0, 1] or [0, 360] and s and v are contained in [0, 1] or [0, 100] + // *Returns:* { r, g, b } in the set [0, 255] + + + function hsvToRgb(h, s, v) { + h = bound01(h, 360) * 6; + s = bound01(s, 100); + v = bound01(v, 100); + var i = math.floor(h), + f = h - i, + p = v * (1 - s), + q = v * (1 - f * s), + t = v * (1 - (1 - f) * s), + mod = i % 6, + r = [v, q, p, p, t, v][mod], + g = [t, v, v, q, p, p][mod], + b = [p, p, t, v, v, q][mod]; + return { + r: r * 255, + g: g * 255, + b: b * 255 + }; + } // `rgbToHex` + // Converts an RGB color to hex + // Assumes r, g, and b are contained in the set [0, 255] + // Returns a 3 or 6 character hex - // Minimum height (in px) of new component - minComponentH: 50, - // Minimum width (in px) of component on creation - minComponentW: 50 -}; + function rgbToHex(r, g, b, allow3Char) { + var hex = [pad2(mathRound(r).toString(16)), pad2(mathRound(g).toString(16)), pad2(mathRound(b).toString(16))]; // Return a 3 character hex if possible -/***/ }), -/* 186 */ -/***/ (function(module, exports, __webpack_require__) { + if (allow3Char && hex[0].charAt(0) == hex[0].charAt(1) && hex[1].charAt(0) == hex[1].charAt(1) && hex[2].charAt(0) == hex[2].charAt(1)) { + return hex[0].charAt(0) + hex[1].charAt(0) + hex[2].charAt(0); + } -"use strict"; -/* WEBPACK VAR INJECTION */(function(Backbone) { + return hex.join(''); + } // `rgbaToHex` + // Converts an RGBA color plus alpha transparency to hex + // Assumes r, g, b and a are contained in the set [0, 255] + // Returns an 8 character hex -var $ = Backbone.$; -module.exports = Backbone.View.extend({ + function rgbaToHex(r, g, b, a) { + var hex = [pad2(convertDecimalToHex(a)), pad2(mathRound(r).toString(16)), pad2(mathRound(g).toString(16)), pad2(mathRound(b).toString(16))]; + return hex.join(''); + } // `equals` + // Can be called with any tinycolor input - /** - * Initialize method that can't be removed - * @param {Object} o Options - * @private - * */ - initialize: function initialize(o) { - this.config = o || {}; - this.editorModel = this.em = this.config.em || {}; - this.pfx = this.config.stylePrefix; - this.ppfx = this.config.pStylePrefix; - this.hoverClass = this.pfx + 'hover'; - this.badgeClass = this.pfx + 'badge'; - this.plhClass = this.pfx + 'placeholder'; - this.freezClass = this.ppfx + 'freezed'; - this.canvas = this.em.get && this.em.get('Canvas'); + tinycolor.equals = function (color1, color2) { + if (!color1 || !color2) { + return false; + } - if (this.em.get) this.setElement(this.getCanvas()); + return tinycolor(color1).toRgbString() == tinycolor(color2).toRgbString(); + }; - if (this.canvas) { - this.$canvas = this.$el; - this.$wrapper = $(this.getCanvasWrapper()); - this.frameEl = this.canvas.getFrameEl(); - this.canvasTool = this.getCanvasTools(); - this.bodyEl = this.getCanvasBody(); + tinycolor.random = function () { + return tinycolor.fromRatio({ + r: mathRandom(), + g: mathRandom(), + b: mathRandom() + }); + }; // Modification Functions + // ---------------------- + // Thanks to less.js for some of the basics here + // + + + function _desaturate(color, amount) { + amount = amount === 0 ? 0 : amount || 10; + var hsl = tinycolor(color).toHsl(); + hsl.s -= amount / 100; + hsl.s = clamp01(hsl.s); + return tinycolor(hsl); + } + + function _saturate(color, amount) { + amount = amount === 0 ? 0 : amount || 10; + var hsl = tinycolor(color).toHsl(); + hsl.s += amount / 100; + hsl.s = clamp01(hsl.s); + return tinycolor(hsl); + } + + function _greyscale(color) { + return tinycolor(color).desaturate(100); + } + + function _lighten(color, amount) { + amount = amount === 0 ? 0 : amount || 10; + var hsl = tinycolor(color).toHsl(); + hsl.l += amount / 100; + hsl.l = clamp01(hsl.l); + return tinycolor(hsl); + } + + function _brighten(color, amount) { + amount = amount === 0 ? 0 : amount || 10; + var rgb = tinycolor(color).toRgb(); + rgb.r = mathMax(0, mathMin(255, rgb.r - mathRound(255 * -(amount / 100)))); + rgb.g = mathMax(0, mathMin(255, rgb.g - mathRound(255 * -(amount / 100)))); + rgb.b = mathMax(0, mathMin(255, rgb.b - mathRound(255 * -(amount / 100)))); + return tinycolor(rgb); + } + + function _darken(color, amount) { + amount = amount === 0 ? 0 : amount || 10; + var hsl = tinycolor(color).toHsl(); + hsl.l -= amount / 100; + hsl.l = clamp01(hsl.l); + return tinycolor(hsl); + } // Spin takes a positive or negative amount within [-360, 360] indicating the change of hue. + // Values outside of this range will be wrapped into this range. + + + function _spin(color, amount) { + var hsl = tinycolor(color).toHsl(); + var hue = (mathRound(hsl.h) + amount) % 360; + hsl.h = hue < 0 ? 360 + hue : hue; + return tinycolor(hsl); + } // Combination Functions + // --------------------- + // Thanks to jQuery xColor for some of the ideas behind these + // + + + function _complement(color) { + var hsl = tinycolor(color).toHsl(); + hsl.h = (hsl.h + 180) % 360; + return tinycolor(hsl); + } + + function _triad(color) { + var hsl = tinycolor(color).toHsl(); + var h = hsl.h; + return [tinycolor(color), tinycolor({ + h: (h + 120) % 360, + s: hsl.s, + l: hsl.l + }), tinycolor({ + h: (h + 240) % 360, + s: hsl.s, + l: hsl.l + })]; + } + + function _tetrad(color) { + var hsl = tinycolor(color).toHsl(); + var h = hsl.h; + return [tinycolor(color), tinycolor({ + h: (h + 90) % 360, + s: hsl.s, + l: hsl.l + }), tinycolor({ + h: (h + 180) % 360, + s: hsl.s, + l: hsl.l + }), tinycolor({ + h: (h + 270) % 360, + s: hsl.s, + l: hsl.l + })]; + } + + function _splitcomplement(color) { + var hsl = tinycolor(color).toHsl(); + var h = hsl.h; + return [tinycolor(color), tinycolor({ + h: (h + 72) % 360, + s: hsl.s, + l: hsl.l + }), tinycolor({ + h: (h + 216) % 360, + s: hsl.s, + l: hsl.l + })]; + } + + function _analogous(color, results, slices) { + results = results || 6; + slices = slices || 30; + var hsl = tinycolor(color).toHsl(); + var part = 360 / slices; + var ret = [tinycolor(color)]; + + for (hsl.h = (hsl.h - (part * results >> 1) + 720) % 360; --results;) { + hsl.h = (hsl.h + part) % 360; + ret.push(tinycolor(hsl)); + } + + return ret; + } + + function _monochromatic(color, results) { + results = results || 6; + var hsv = tinycolor(color).toHsv(); + var h = hsv.h, + s = hsv.s, + v = hsv.v; + var ret = []; + var modification = 1 / results; + + while (results--) { + ret.push(tinycolor({ + h: h, + s: s, + v: v + })); + v = (v + modification) % 1; } - this.init(this.config); - }, + return ret; + } // Utility Functions + // --------------------- - /** - * On frame scroll callback - * @param {[type]} e [description] - * @return {[type]} [description] - */ - onFrameScroll: function onFrameScroll(e) {}, + tinycolor.mix = function (color1, color2, amount) { + amount = amount === 0 ? 0 : amount || 50; + var rgb1 = tinycolor(color1).toRgb(); + var rgb2 = tinycolor(color2).toRgb(); + var p = amount / 100; + var w = p * 2 - 1; + var a = rgb2.a - rgb1.a; + var w1; + if (w * a == -1) { + w1 = w; + } else { + w1 = (w + a) / (1 + w * a); + } - /** - * Returns canval element - * @return {HTMLElement} - */ - getCanvas: function getCanvas() { - return this.canvas.getElement(); - }, + w1 = (w1 + 1) / 2; + var w2 = 1 - w1; + var rgba = { + r: rgb2.r * w1 + rgb1.r * w2, + g: rgb2.g * w1 + rgb1.g * w2, + b: rgb2.b * w1 + rgb1.b * w2, + a: rgb2.a * p + rgb1.a * (1 - p) + }; + return tinycolor(rgba); + }; // Readability Functions + // --------------------- + // + // `readability` + // Analyze the 2 colors and returns an object with the following properties: + // `brightness`: difference in brightness between the two colors + // `color`: difference in color/hue between the two colors + + + tinycolor.readability = function (color1, color2) { + var c1 = tinycolor(color1); + var c2 = tinycolor(color2); + var rgb1 = c1.toRgb(); + var rgb2 = c2.toRgb(); + var brightnessA = c1.getBrightness(); + var brightnessB = c2.getBrightness(); + var colorDiff = Math.max(rgb1.r, rgb2.r) - Math.min(rgb1.r, rgb2.r) + Math.max(rgb1.g, rgb2.g) - Math.min(rgb1.g, rgb2.g) + Math.max(rgb1.b, rgb2.b) - Math.min(rgb1.b, rgb2.b); + return { + brightness: Math.abs(brightnessA - brightnessB), + color: colorDiff + }; + }; // `readable` + // http://www.w3.org/TR/AERT#color-contrast + // Ensure that foreground and background color combinations provide sufficient contrast. + // *Example* + // tinycolor.isReadable("#000", "#111") => false - /** - * Get canvas body element - * @return {HTMLElement} - */ - getCanvasBody: function getCanvasBody() { - return this.canvas.getBody(); - }, + tinycolor.isReadable = function (color1, color2) { + var readability = tinycolor.readability(color1, color2); + return readability.brightness > 125 && readability.color > 500; + }; // `mostReadable` + // Given a base color and a list of possible foreground or background + // colors for that base, returns the most readable color. + // *Example* + // tinycolor.mostReadable("#123", ["#fff", "#000"]) => "#000" - /** - * Get canvas wrapper element - * @return {HTMLElement} - */ - getCanvasWrapper: function getCanvasWrapper() { - return this.canvas.getWrapperEl(); - }, + tinycolor.mostReadable = function (baseColor, colorList) { + var bestColor = null; + var bestScore = 0; + var bestIsReadable = false; + for (var i = 0; i < colorList.length; i++) { + // We normalize both around the "acceptable" breaking point, + // but rank brightness constrast higher than hue. + var readability = tinycolor.readability(baseColor, colorList[i]); + var readable = readability.brightness > 125 && readability.color > 500; + var score = 3 * (readability.brightness / 125) + readability.color / 500; - /** - * Get canvas wrapper element - * @return {HTMLElement} - */ - getCanvasTools: function getCanvasTools() { - return this.canvas.getToolsEl(); - }, + if (readable && !bestIsReadable || readable && bestIsReadable && score > bestScore || !readable && !bestIsReadable && score > bestScore) { + bestIsReadable = readable; + bestScore = score; + bestColor = tinycolor(colorList[i]); + } + } + + return bestColor; + }; // Big List of Colors + // ------------------ + // + + + var names = tinycolor.names = { + aliceblue: 'f0f8ff', + antiquewhite: 'faebd7', + aqua: '0ff', + aquamarine: '7fffd4', + azure: 'f0ffff', + beige: 'f5f5dc', + bisque: 'ffe4c4', + black: '000', + blanchedalmond: 'ffebcd', + blue: '00f', + blueviolet: '8a2be2', + brown: 'a52a2a', + burlywood: 'deb887', + burntsienna: 'ea7e5d', + cadetblue: '5f9ea0', + chartreuse: '7fff00', + chocolate: 'd2691e', + coral: 'ff7f50', + cornflowerblue: '6495ed', + cornsilk: 'fff8dc', + crimson: 'dc143c', + cyan: '0ff', + darkblue: '00008b', + darkcyan: '008b8b', + darkgoldenrod: 'b8860b', + darkgray: 'a9a9a9', + darkgreen: '006400', + darkgrey: 'a9a9a9', + darkkhaki: 'bdb76b', + darkmagenta: '8b008b', + darkolivegreen: '556b2f', + darkorange: 'ff8c00', + darkorchid: '9932cc', + darkred: '8b0000', + darksalmon: 'e9967a', + darkseagreen: '8fbc8f', + darkslateblue: '483d8b', + darkslategray: '2f4f4f', + darkslategrey: '2f4f4f', + darkturquoise: '00ced1', + darkviolet: '9400d3', + deeppink: 'ff1493', + deepskyblue: '00bfff', + dimgray: '696969', + dimgrey: '696969', + dodgerblue: '1e90ff', + firebrick: 'b22222', + floralwhite: 'fffaf0', + forestgreen: '228b22', + fuchsia: 'f0f', + gainsboro: 'dcdcdc', + ghostwhite: 'f8f8ff', + gold: 'ffd700', + goldenrod: 'daa520', + gray: '808080', + green: '008000', + greenyellow: 'adff2f', + grey: '808080', + honeydew: 'f0fff0', + hotpink: 'ff69b4', + indianred: 'cd5c5c', + indigo: '4b0082', + ivory: 'fffff0', + khaki: 'f0e68c', + lavender: 'e6e6fa', + lavenderblush: 'fff0f5', + lawngreen: '7cfc00', + lemonchiffon: 'fffacd', + lightblue: 'add8e6', + lightcoral: 'f08080', + lightcyan: 'e0ffff', + lightgoldenrodyellow: 'fafad2', + lightgray: 'd3d3d3', + lightgreen: '90ee90', + lightgrey: 'd3d3d3', + lightpink: 'ffb6c1', + lightsalmon: 'ffa07a', + lightseagreen: '20b2aa', + lightskyblue: '87cefa', + lightslategray: '789', + lightslategrey: '789', + lightsteelblue: 'b0c4de', + lightyellow: 'ffffe0', + lime: '0f0', + limegreen: '32cd32', + linen: 'faf0e6', + magenta: 'f0f', + maroon: '800000', + mediumaquamarine: '66cdaa', + mediumblue: '0000cd', + mediumorchid: 'ba55d3', + mediumpurple: '9370db', + mediumseagreen: '3cb371', + mediumslateblue: '7b68ee', + mediumspringgreen: '00fa9a', + mediumturquoise: '48d1cc', + mediumvioletred: 'c71585', + midnightblue: '191970', + mintcream: 'f5fffa', + mistyrose: 'ffe4e1', + moccasin: 'ffe4b5', + navajowhite: 'ffdead', + navy: '000080', + oldlace: 'fdf5e6', + olive: '808000', + olivedrab: '6b8e23', + orange: 'ffa500', + orangered: 'ff4500', + orchid: 'da70d6', + palegoldenrod: 'eee8aa', + palegreen: '98fb98', + paleturquoise: 'afeeee', + palevioletred: 'db7093', + papayawhip: 'ffefd5', + peachpuff: 'ffdab9', + peru: 'cd853f', + pink: 'ffc0cb', + plum: 'dda0dd', + powderblue: 'b0e0e6', + purple: '800080', + rebeccapurple: '663399', + red: 'f00', + rosybrown: 'bc8f8f', + royalblue: '4169e1', + saddlebrown: '8b4513', + salmon: 'fa8072', + sandybrown: 'f4a460', + seagreen: '2e8b57', + seashell: 'fff5ee', + sienna: 'a0522d', + silver: 'c0c0c0', + skyblue: '87ceeb', + slateblue: '6a5acd', + slategray: '708090', + slategrey: '708090', + snow: 'fffafa', + springgreen: '00ff7f', + steelblue: '4682b4', + tan: 'd2b48c', + teal: '008080', + thistle: 'd8bfd8', + tomato: 'ff6347', + turquoise: '40e0d0', + violet: 'ee82ee', + wheat: 'f5deb3', + white: 'fff', + whitesmoke: 'f5f5f5', + yellow: 'ff0', + yellowgreen: '9acd32' + }; // Make it easy to access colors via `hexNames[hex]` + + var hexNames = tinycolor.hexNames = flip(names); // Utilities + // --------- + // `{ 'name1': 'val1' }` becomes `{ 'val1': 'name1' }` + + function flip(o) { + var flipped = {}; + + for (var i in o) { + if (o.hasOwnProperty(i)) { + flipped[o[i]] = i; + } + } + + return flipped; + } // Return a valid alpha value [0,1] with all invalid values being set to 1 + + + function boundAlpha(a) { + a = parseFloat(a); + + if (isNaN(a) || a < 0 || a > 1) { + a = 1; + } + + return a; + } // Take input from [0, n] and return it as [0, 1] + + + function bound01(n, max) { + if (isOnePointZero(n)) { + n = '100%'; + } + var processPercent = isPercentage(n); + n = mathMin(max, mathMax(0, parseFloat(n))); // Automatically convert percentage into number - /** - * Get the offset of the element - * @param {HTMLElement} el - * @return {Object} - */ - offset: function offset(el) { - var rect = el.getBoundingClientRect(); - return { - top: rect.top + el.ownerDocument.body.scrollTop, - left: rect.left + el.ownerDocument.body.scrollLeft - }; - }, + if (processPercent) { + n = parseInt(n * max, 10) / 100; + } // Handle floating point rounding errors - /** - * Callback triggered after initialize - * @param {Object} o Options - * @private - * */ - init: function init(o) {}, + if (math.abs(n - max) < 0.000001) { + return 1; + } // Convert into [0, 1] range if it isn't already - /** - * Method that run command - * @param {Object} em Editor model - * @param {Object} sender Button sender - * @private - * */ - run: function run(em, sender) {}, + return n % max / parseFloat(max); + } // Force a number between 0 and 1 - /** - * Method that stop command - * @param {Object} em Editor model - * @param {Object} sender Button sender - * @private - * */ - stop: function stop(em, sender) {} -}); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(0))) + function clamp01(val) { + return mathMin(1, mathMax(0, val)); + } // Parse a base-16 hex value into a base-10 integer -/***/ }), -/* 187 */ -/***/ (function(module, exports, __webpack_require__) { -"use strict"; -/* WEBPACK VAR INJECTION */(function(Backbone) { + function parseIntFromHex(val) { + return parseInt(val, 16); + } // Need to handle 1.0 as 100%, since once it is a number, there is no difference between it and 1 + // -var $ = Backbone.$; -module.exports = { - run: function run(editor, sender) { - var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + function isOnePointZero(n) { + return typeof n == 'string' && n.indexOf('.') != -1 && parseFloat(n) === 1; + } // Check to see if string passed in is a percentage - sender && sender.set && sender.set('active', 0); - var config = editor.getConfig(); - var modal = editor.Modal; - var pfx = config.stylePrefix; - this.cm = editor.CodeManager || null; - if (!this.$editors) { - var oHtmlEd = this.buildEditor('htmlmixed', 'hopscotch', 'HTML'); - var oCsslEd = this.buildEditor('css', 'hopscotch', 'CSS'); - this.htmlEditor = oHtmlEd.el; - this.cssEditor = oCsslEd.el; - var $editors = $('
'); - $editors.append(oHtmlEd.$el).append(oCsslEd.$el); - this.$editors = $editors; + function isPercentage(n) { + return typeof n === 'string' && n.indexOf('%') != -1; + } // Force a hex value to have 2 characters + + + function pad2(c) { + return c.length == 1 ? '0' + c : '' + c; + } // Replace a decimal with it's percentage value + + + function convertToPercentage(n) { + if (n <= 1) { + n = n * 100 + '%'; } - modal.setTitle(config.textViewCode); - modal.setContent(this.$editors); - modal.open(); - this.htmlEditor.setContent(editor.getHtml()); - this.cssEditor.setContent(editor.getCss()); - }, - stop: function stop(editor) { - var modal = editor.Modal; - modal && modal.close(); - }, - buildEditor: function buildEditor(codeName, theme, label) { - var input = document.createElement('textarea'); - !this.codeMirror && (this.codeMirror = this.cm.getViewer('CodeMirror')); + return n; + } // Converts a decimal to a hex value - var el = this.codeMirror.clone().set({ - label: label, - codeName: codeName, - theme: theme, - input: input - }); - var $el = new this.cm.EditorView({ - model: el, - config: this.cm.getConfig() - }).render().$el; + function convertDecimalToHex(d) { + return Math.round(parseFloat(d) * 255).toString(16); + } // Converts a hex value to a decimal - el.init(input); - return { el: el, $el: $el }; + function convertHexToDecimal(h) { + return parseIntFromHex(h) / 255; } -}; -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(0))) -/***/ }), -/* 188 */ -/***/ (function(module, exports, __webpack_require__) { + var matchers = function () { + // + var CSS_INTEGER = '[-\\+]?\\d+%?'; // -"use strict"; + var CSS_NUMBER = '[-\\+]?\\d*\\.\\d+%?'; // Allow positive/negative integer/number. Don't capture the either/or, just the entire outcome. + var CSS_UNIT = '(?:' + CSS_NUMBER + ')|(?:' + CSS_INTEGER + ')'; // Actual matching. + // Parentheses and commas are optional, but not required. + // Whitespace can take the place of commas or opening paren -var Backbone = __webpack_require__(0); -var DomainViews = __webpack_require__(48); -var ToolbarButtonView = __webpack_require__(189); + var PERMISSIVE_MATCH3 = '[\\s|\\(]+(' + CSS_UNIT + ')[,|\\s]+(' + CSS_UNIT + ')[,|\\s]+(' + CSS_UNIT + ')\\s*\\)?'; + var PERMISSIVE_MATCH4 = '[\\s|\\(]+(' + CSS_UNIT + ')[,|\\s]+(' + CSS_UNIT + ')[,|\\s]+(' + CSS_UNIT + ')[,|\\s]+(' + CSS_UNIT + ')\\s*\\)?'; + return { + rgb: new RegExp('rgb' + PERMISSIVE_MATCH3), + rgba: new RegExp('rgba' + PERMISSIVE_MATCH4), + hsl: new RegExp('hsl' + PERMISSIVE_MATCH3), + hsla: new RegExp('hsla' + PERMISSIVE_MATCH4), + hsv: new RegExp('hsv' + PERMISSIVE_MATCH3), + hsva: new RegExp('hsva' + PERMISSIVE_MATCH4), + hex3: /^([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/, + hex6: /^([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/, + hex8: /^([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/ + }; + }(); // `stringInputToObject` + // Permissive string parsing. Take in a number of formats, and output an object + // based on detected format. Returns `{ r, g, b }` or `{ h, s, l }` or `{ h, s, v}` -module.exports = DomainViews.extend({ - itemView: ToolbarButtonView, + function stringInputToObject(color) { + color = color.replace(trimLeft, '').replace(trimRight, '').toLowerCase(); + var named = false; - initialize: function initialize(opts) { - this.config = { editor: opts.editor || '' }; - this.listenTo(this.collection, 'reset', this.render); - } -}); + if (names[color]) { + color = names[color]; + named = true; + } else if (color == 'transparent') { + return { + r: 0, + g: 0, + b: 0, + a: 0, + format: 'name' + }; + } // Try to match string input using regular expressions. + // Keep most of the number bounding out of this function - don't worry about [0,1] or [0,100] or [0,360] + // Just return an object and let the conversion functions handle that. + // This way the result will be the same whether the tinycolor is initialized with string or object. -/***/ }), -/* 189 */ -/***/ (function(module, exports, __webpack_require__) { -"use strict"; + var match; + if (match = matchers.rgb.exec(color)) { + return { + r: match[1], + g: match[2], + b: match[3] + }; + } -var Backbone = __webpack_require__(0); + if (match = matchers.rgba.exec(color)) { + return { + r: match[1], + g: match[2], + b: match[3], + a: match[4] + }; + } -module.exports = Backbone.View.extend({ - events: { - 'mousedown': 'handleClick' - }, + if (match = matchers.hsl.exec(color)) { + return { + h: match[1], + s: match[2], + l: match[3] + }; + } - attributes: function attributes() { - return this.model.get('attributes'); - }, - initialize: function initialize(opts) { - this.editor = opts.config.editor; - }, - handleClick: function handleClick(event) { - event.preventDefault(); - event.stopPropagation(); - var opts = { event: event }; - var command = this.model.get('command'); - var editor = this.editor; + if (match = matchers.hsla.exec(color)) { + return { + h: match[1], + s: match[2], + l: match[3], + a: match[4] + }; + } - if (typeof command === 'function') { - command(editor, null, opts); + if (match = matchers.hsv.exec(color)) { + return { + h: match[1], + s: match[2], + v: match[3] + }; } - if (typeof command === 'string') { - editor.runCommand(command, opts); + if (match = matchers.hsva.exec(color)) { + return { + h: match[1], + s: match[2], + v: match[3], + a: match[4] + }; } - }, - render: function render() { - var config = this.editor.getConfig(); - this.el.className += ' ' + config.stylePrefix + 'toolbar-item'; - return this; - } -}); -/***/ }), -/* 190 */ -/***/ (function(module, exports, __webpack_require__) { + if (match = matchers.hex8.exec(color)) { + return { + a: convertHexToDecimal(match[1]), + r: parseIntFromHex(match[2]), + g: parseIntFromHex(match[3]), + b: parseIntFromHex(match[4]), + format: named ? 'name' : 'hex8' + }; + } -"use strict"; + if (match = matchers.hex6.exec(color)) { + return { + r: parseIntFromHex(match[1]), + g: parseIntFromHex(match[2]), + b: parseIntFromHex(match[3]), + format: named ? 'name' : 'hex' + }; + } + + if (match = matchers.hex3.exec(color)) { + return { + r: parseIntFromHex(match[1] + '' + match[1]), + g: parseIntFromHex(match[2] + '' + match[2]), + b: parseIntFromHex(match[3] + '' + match[3]), + format: named ? 'name' : 'hex' + }; + } + return false; + } -var Backbone = __webpack_require__(0); -var ToolbarButton = __webpack_require__(191); + window.tinycolor = tinycolor; //})(); -module.exports = Backbone.Collection.extend({ model: ToolbarButton }); + $(function () { + if ($.fn.spectrum.load) { + $.fn.spectrum.processNativeColorInputs(); + } + }); +}); /***/ }), -/* 191 */ -/***/ (function(module, exports, __webpack_require__) { + +/***/ "./src/utils/Dragger.js": +/*!******************************!*\ + !*** ./src/utils/Dragger.js ***! + \******************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "default", function() { return Dragger; }); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "./node_modules/@babel/runtime/helpers/classCallCheck.js"); +/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "./node_modules/@babel/runtime/helpers/createClass.js"); +/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_2__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_3__); +/* harmony import */ var utils_mixins__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! utils/mixins */ "./src/utils/mixins.js"); -var Backbone = __webpack_require__(0); -module.exports = Backbone.Model.extend({ - defaults: { - command: '', - attributes: {} - } +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } -}); +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } -/***/ }), -/* 192 */ -/***/ (function(module, exports, __webpack_require__) { -"use strict"; -/* WEBPACK VAR INJECTION */(function(Backbone, _) { -var SelectComponent = __webpack_require__(21); -var $ = Backbone.$; -module.exports = _.extend({}, SelectComponent, { - init: function init(o) { - _.bindAll(this, 'startDelete', 'stopDelete', 'onDelete'); - this.hoverClass = this.pfx + 'hover-delete'; - this.badgeClass = this.pfx + 'badge-red'; - }, - enable: function enable() { - var that = this; - this.$el.find('*').mouseover(this.startDelete).mouseout(this.stopDelete).click(this.onDelete); - }, +var resetPos = function resetPos() { + return { + x: 0, + y: 0 + }; +}; +var Dragger = +/*#__PURE__*/ +function () { + /** + * Init the dragger + * @param {Object} opts + */ + function Dragger() { + var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_1___default()(this, Dragger); + + this.opts = { + /** + * Element on which the drag will be executed. By default, the document will be used + */ + container: null, + + /** + * Callback on start + * onStart(ev, dragger) { + * console.log('pointer start', dragger.startPointer, 'position start', dragger.startPosition); + * }, + */ + onStart: null, + + /** + * Callback on drag + * onDrag(ev, dragger) { + * console.log('pointer', dragger.currentPointer, 'position', dragger.position, 'delta', dragger.delta); + * }, + */ + onDrag: null, + + /** + * Callback on drag + * onEnd(ev, dragger) { + * console.log('pointer', dragger.currentPointer, 'position', dragger.position, 'delta', dragger.delta); + * }, + */ + onEnd: null, + + /** + * Indicate a callback where to pass an object with new coordinates + */ + setPosition: null, + + /** + * Indicate a callback where to get initial coordinates. + * getPosition: () => { + * ... + * return { x: 10, y: 100 } + * } + */ + getPosition: null, + // Static guides to be snapped + guidesStatic: null, + // Target guides that will snap to static one + guidesTarget: null, + // Offset before snap to guides + snapOffset: 5, + // Document on which listen to pointer events + doc: 0, + // Scale result points, can also be a function + scale: 1 + }; + Object(underscore__WEBPACK_IMPORTED_MODULE_3__["bindAll"])(this, 'drag', 'stop', 'keyHandle', 'handleScroll'); + this.setOptions(opts); + this.delta = resetPos(); + return this; + } /** - * Start command - * @param {Object} e - * @private + * Update options + * @param {Object} options */ - startDelete: function startDelete(e) { - e.stopPropagation(); - var $this = $(e.target); - // Show badge if possible - if ($this.data('model').get('removable')) { - $this.addClass(this.hoverClass); - this.attachBadge($this.get(0)); + + _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_2___default()(Dragger, [{ + key: "setOptions", + value: function setOptions() { + var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + this.opts = _objectSpread({}, this.opts, {}, opts); } - }, + }, { + key: "toggleDrag", + value: function toggleDrag(enable) { + var docs = this.getDocumentEl(); + var container = this.getContainerEl(); + var win = this.getWindowEl(); + var method = enable ? 'on' : 'off'; + var methods = { + on: utils_mixins__WEBPACK_IMPORTED_MODULE_4__["on"], + off: utils_mixins__WEBPACK_IMPORTED_MODULE_4__["off"] + }; + methods[method](container, 'mousemove dragover', this.drag); + methods[method](docs, 'mouseup dragend touchend', this.stop); + methods[method](docs, 'keydown', this.keyHandle); + methods[method](win, 'scroll', this.handleScroll); + } + }, { + key: "handleScroll", + value: function handleScroll() { + var lastScroll = this.lastScroll, + delta = this.delta; + var actualScroll = this.getScrollInfo(); + var scrollDiff = { + x: actualScroll.x - lastScroll.x, + y: actualScroll.y - lastScroll.y + }; + this.move(delta.x + scrollDiff.x, delta.y + scrollDiff.y); + this.lastScrollDiff = scrollDiff; + } + /** + * Start dragging + * @param {Event} e + */ + }, { + key: "start", + value: function start(ev) { + var opts = this.opts; + var onStart = opts.onStart; + this.toggleDrag(1); + this.startPointer = this.getPointerPos(ev); + this.guidesStatic = Object(underscore__WEBPACK_IMPORTED_MODULE_3__["result"])(opts, 'guidesStatic') || []; + this.guidesTarget = Object(underscore__WEBPACK_IMPORTED_MODULE_3__["result"])(opts, 'guidesTarget') || []; + Object(underscore__WEBPACK_IMPORTED_MODULE_3__["isFunction"])(onStart) && onStart(ev, this); + this.startPosition = this.getStartPosition(); + this.lastScrollDiff = resetPos(); + this.globScrollDiff = resetPos(); + this.drag(ev); + } + /** + * Drag event + * @param {Event} event + */ - /** - * Stop command - * @param {Object} e - * @private - */ - stopDelete: function stopDelete(e) { - e.stopPropagation(); - var $this = $(e.target); - $this.removeClass(this.hoverClass); + }, { + key: "drag", + value: function drag(ev) { + var _this = this; - // Hide badge if possible - if (this.badge) this.badge.css({ left: -1000, top: -1000 }); - }, + var opts = this.opts, + lastScrollDiff = this.lastScrollDiff, + globScrollDiff = this.globScrollDiff; + var onDrag = opts.onDrag; + var startPointer = this.startPointer; + var currentPos = this.getPointerPos(ev); + var glDiff = { + x: globScrollDiff.x + lastScrollDiff.x, + y: globScrollDiff.y + lastScrollDiff.y + }; + this.globScrollDiff = glDiff; + var delta = { + x: currentPos.x - startPointer.x + glDiff.x, + y: currentPos.y - startPointer.y + glDiff.y + }; + this.lastScrollDiff = resetPos(); + var lockedAxis = this.lockedAxis; // Lock one axis + if (ev.shiftKey) { + lockedAxis = !lockedAxis && this.detectAxisLock(delta.x, delta.y); + } else { + lockedAxis = null; + } - /** - * Delete command - * @param {Object} e - * @private - */ - onDelete: function onDelete(e) { - e.stopPropagation(); - var $this = $(e.target); + if (lockedAxis === 'x') { + delta.x = startPointer.x; + } else if (lockedAxis === 'y') { + delta.y = startPointer.y; + } - // Do nothing in case can't remove - if (!$this.data('model').get('removable')) return; + var moveDelta = function moveDelta(delta) { + ['x', 'y'].forEach(function (co) { + return delta[co] = delta[co] * Object(underscore__WEBPACK_IMPORTED_MODULE_3__["result"])(opts, 'scale'); + }); + _this.delta = delta; - $this.data('model').destroy(); - this.removeBadge(); - this.clean(); - }, + _this.move(delta.x, delta.y); + Object(underscore__WEBPACK_IMPORTED_MODULE_3__["isFunction"])(onDrag) && onDrag(ev, _this); + }; - /** - * Updates badge label - * @param {Object} model - * @private - * */ - updateBadgeLabel: function updateBadgeLabel(model) { - this.badge.html('Remove ' + model.getName()); - } -}); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(0), __webpack_require__(1))) + var deltaPre = _objectSpread({}, delta); + + this.currentPointer = currentPos; + this.lockedAxis = lockedAxis; + this.lastScroll = this.getScrollInfo(); + moveDelta(delta); + + if (this.guidesTarget.length) { + var _this$snapGuides = this.snapGuides(deltaPre), + newDelta = _this$snapGuides.newDelta, + trgX = _this$snapGuides.trgX, + trgY = _this$snapGuides.trgY; + + (trgX || trgY) && moveDelta(newDelta); + } // In case the mouse button was released outside of the window + + + ev.which === 0 && this.stop(ev); + } + /** + * Check if the delta hits some guide + */ + + }, { + key: "snapGuides", + value: function snapGuides(delta) { + var _this2 = this; + + var newDelta = delta; + var trgX = this.trgX, + trgY = this.trgY; + this.guidesTarget.forEach(function (trg) { + // Skip the guide if its locked axis already exists + if (trg.x && _this2.trgX || trg.y && _this2.trgY) return; + trg.active = 0; + + _this2.guidesStatic.forEach(function (stat) { + if (trg.y && stat.x || trg.x && stat.y) return; + var isY = trg.y && stat.y; + var axs = isY ? 'y' : 'x'; + var trgPoint = trg[axs]; + var statPoint = stat[axs]; + var deltaPoint = delta[axs]; + var trgGuide = isY ? trgY : trgX; + + if (_this2.isPointIn(trgPoint, statPoint)) { + if (Object(underscore__WEBPACK_IMPORTED_MODULE_3__["isUndefined"])(trgGuide)) { + var trgValue = deltaPoint - (trgPoint - statPoint); + + _this2.setGuideLock(trg, trgValue); + } + } + }); + }); + trgX = this.trgX; + trgY = this.trgY; + ['x', 'y'].forEach(function (co) { + var axis = co.toUpperCase(); -/***/ }), -/* 193 */ -/***/ (function(module, exports, __webpack_require__) { + var trg = _this2["trg".concat(axis)]; -"use strict"; -/* WEBPACK VAR INJECTION */(function(_) { + if (trg && !_this2.isPointIn(delta[co], trg.lock)) { + _this2.setGuideLock(trg, null); -var Backbone = __webpack_require__(0); -var InsertCustom = __webpack_require__(54); + trg = null; + } -module.exports = _.extend({}, InsertCustom, { + if (trg && !Object(underscore__WEBPACK_IMPORTED_MODULE_3__["isUndefined"])(trg.lock)) { + newDelta[co] = trg.lock; + } + }); + return { + newDelta: newDelta, + trgX: this.trgX, + trgY: this.trgY + }; + } + }, { + key: "isPointIn", + value: function isPointIn(src, trg) { + var _ref = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}, + offset = _ref.offset; - /** - * Trigger before insert - * @param {Object} object - * @private - * - * */ - beforeInsert: function beforeInsert(object) { - object.type = 'image'; - object.style = {}; - object.attributes = {}; - object.attributes.onmousedown = 'return false'; - if (this.config.firstCentered && this.getCanvasWrapper() == this.sorter.target) { - object.style.margin = '0 auto'; + var ofst = offset || this.opts.snapOffset; + return src >= trg && src <= trg + ofst || src <= trg && src >= trg - ofst; } - }, + }, { + key: "setGuideLock", + value: function setGuideLock(guide, value) { + var axis = !Object(underscore__WEBPACK_IMPORTED_MODULE_3__["isUndefined"])(guide.x) ? 'X' : 'Y'; + var trgName = "trg".concat(axis); + + if (value !== null) { + guide.active = 1; + guide.lock = value; + this[trgName] = guide; + } else { + delete guide.active; + delete guide.lock; + delete this[trgName]; + } + return guide; + } + /** + * Stop dragging + */ - /** - * Trigger after insert - * @param {Object} model Model created after insert - * @private - * */ - afterInsert: function afterInsert(model) { - model.trigger('dblclick'); - if (this.sender) this.sender.set('active', false); - } -}); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(1))) + }, { + key: "stop", + value: function stop(ev) { + var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + var delta = this.delta; + var cancelled = opts.cancel; + var x = cancelled ? 0 : delta.x; + var y = cancelled ? 0 : delta.y; + this.toggleDrag(); + this.lockedAxis = null; + this.move(x, y, 1); + var onEnd = this.opts.onEnd; + Object(underscore__WEBPACK_IMPORTED_MODULE_3__["isFunction"])(onEnd) && onEnd(ev, this, { + cancelled: cancelled + }); + } + }, { + key: "keyHandle", + value: function keyHandle(ev) { + if (Object(utils_mixins__WEBPACK_IMPORTED_MODULE_4__["isEscKey"])(ev)) { + this.stop(ev, { + cancel: 1 + }); + } + } + /** + * Move the element + * @param {integer} x + * @param {integer} y + */ -/***/ }), -/* 194 */ -/***/ (function(module, exports, __webpack_require__) { + }, { + key: "move", + value: function move(x, y, end) { + var el = this.el, + opts = this.opts; + var pos = this.startPosition; + if (!pos) return; + var setPosition = opts.setPosition; + var xPos = pos.x + x; + var yPos = pos.y + y; + this.position = { + x: xPos, + y: yPos, + end: end + }; + Object(underscore__WEBPACK_IMPORTED_MODULE_3__["isFunction"])(setPosition) && setPosition(this.position); -"use strict"; -/* WEBPACK VAR INJECTION */(function(Backbone, _) { + if (el) { + el.style.left = "".concat(xPos, "px"); + el.style.top = "".concat(yPos, "px"); + } + } + }, { + key: "getContainerEl", + value: function getContainerEl() { + var container = this.opts.container; + return container ? [container] : this.getDocumentEl(); + } + }, { + key: "getWindowEl", + value: function getWindowEl() { + var cont = this.getContainerEl(); + return cont.map(function (item) { + var doc = item.ownerDocument || item; + return doc.defaultView || doc.parentWindow; + }); + } + /** + * Returns documents + */ -var _mixins = __webpack_require__(2); + }, { + key: "getDocumentEl", + value: function getDocumentEl(el) { + var doc = this.opts.doc; + el = el || this.el; -var SelectComponent = __webpack_require__(21); -var SelectPosition = __webpack_require__(53); -var $ = Backbone.$; + if (!this.docs) { + var docs = [document]; + el && docs.push(el.ownerDocument); + doc && docs.push(doc); + this.docs = docs; + } -module.exports = _.extend({}, SelectPosition, SelectComponent, { - init: function init(o) { - SelectComponent.init.apply(this, arguments); - _.bindAll(this, 'initSorter', 'rollback', 'onEndMove'); - this.opt = o; - this.hoverClass = this.ppfx + 'highlighter-warning'; - this.badgeClass = this.ppfx + 'badge-warning'; - this.noSelClass = this.ppfx + 'no-select'; - }, - enable: function enable() { - for (var _len = arguments.length, args = Array(_len), _key = 0; _key < _len; _key++) { - args[_key] = arguments[_key]; + return this.docs; } + /** + * Get mouse coordinates + * @param {Event} event + * @return {Object} + */ - SelectComponent.enable.apply(this, args); - this.getBadgeEl().addClass(this.badgeClass); - this.getHighlighterEl().addClass(this.hoverClass); - var wp = this.$wrapper; - wp.css('cursor', 'move'); - wp.on('mousedown', this.initSorter); + }, { + key: "getPointerPos", + value: function getPointerPos(ev) { + var getPos = this.opts.getPointerPosition; + var pEv = Object(utils_mixins__WEBPACK_IMPORTED_MODULE_4__["getPointerEvent"])(ev); + return getPos ? getPos(ev) : { + x: pEv.clientX, + y: pEv.clientY + }; + } + }, { + key: "getStartPosition", + value: function getStartPosition() { + var el = this.el, + opts = this.opts; + var getPos = opts.getPosition; + var result = resetPos(); + + if (Object(underscore__WEBPACK_IMPORTED_MODULE_3__["isFunction"])(getPos)) { + result = getPos(); + } else if (el) { + result = { + x: parseFloat(el.style.left), + y: parseFloat(el.style.top) + }; + } - // Avoid strange moving behavior - wp.addClass(this.noSelClass); - }, + return result; + } + }, { + key: "getScrollInfo", + value: function getScrollInfo() { + var doc = this.opts.doc; + var body = doc && doc.body; + return { + y: body ? body.scrollTop : 0, + x: body ? body.scrollLeft : 0 + }; + } + }, { + key: "detectAxisLock", + value: function detectAxisLock(x, y) { + var relX = x; + var relY = y; + var absX = Math.abs(relX); + var absY = Math.abs(relY); // Vertical or Horizontal lock + if (relY >= absX || relY <= -absX) { + return 'x'; + } else if (relX > absY || relX < -absY) { + return 'y'; + } + } + }]); - /** - * Overwrite for doing nothing - * @private - */ - toggleClipboard: function toggleClipboard() {}, + return Dragger; +}(); - /** - * Delegate sorting - * @param {Event} e - * @private - * */ - initSorter: function initSorter(e) { - var el = $(e.target).data('model'); - var drag = el.get('draggable'); - if (!drag) return; - // Avoid badge showing on move - this.cacheEl = null; - this.startSelectPosition(e.target, this.frameEl.contentDocument); - this.sorter.draggable = drag; - this.sorter.onEndMove = this.onEndMove.bind(this); - this.stopSelectComponent(); - this.$wrapper.off('mousedown', this.initSorter); - (0, _mixins.on)(this.getContentWindow(), 'keydown', this.rollback); - }, +/***/ }), +/***/ "./src/utils/Droppable.js": +/*!********************************!*\ + !*** ./src/utils/Droppable.js ***! + \********************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - /** - * Init sorter from model - * @param {Object} model - * @private - */ - initSorterFromModel: function initSorterFromModel(model) { - var drag = model.get('draggable'); - if (!drag) return; - // Avoid badge showing on move - this.cacheEl = null; - var el = model.view.el; - this.startSelectPosition(el, this.frameEl.contentDocument); - this.sorter.draggable = drag; - this.sorter.onEndMove = this.onEndMoveFromModel.bind(this); +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "default", function() { return Droppable; }); +/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "./node_modules/@babel/runtime/helpers/classCallCheck.js"); +/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "./node_modules/@babel/runtime/helpers/createClass.js"); +/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var utils_mixins__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! utils/mixins */ "./src/utils/mixins.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_3___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_3__); - /* - this.sorter.setDragHelper(el); - var dragHelper = this.sorter.dragHelper; - dragHelper.className = this.ppfx + 'drag-helper'; - dragHelper.innerHTML = ''; - dragHelper.backgroundColor = 'white'; - */ - this.stopSelectComponent(); - (0, _mixins.on)(this.getContentWindow(), 'keydown', this.rollback); - }, - onEndMoveFromModel: function onEndMoveFromModel() { - (0, _mixins.off)(this.getContentWindow(), 'keydown', this.rollback); - }, +/* + This class makes the canvas droppable + */ - /** - * Callback after sorting - * @private - */ - onEndMove: function onEndMove() { - this.enable(); - (0, _mixins.off)(this.getContentWindow(), 'keydown', this.rollback); - }, - /** - * Say what to do after the component was selected (selectComponent) - * @param {Event} e - * @param {Object} Selected element - * @private - * */ - onSelect: function onSelect(e, el) {}, +var Droppable = +/*#__PURE__*/ +function () { + function Droppable(em) { + _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default()(this, Droppable); + this.em = em; + var el = em.get('DomComponents').getWrapper().getEl(); + this.el = el; + this.counter = 0; + Object(underscore__WEBPACK_IMPORTED_MODULE_3__["bindAll"])(this, 'handleDragEnter', 'handleDragOver', 'handleDrop', 'handleDragLeave'); + Object(utils_mixins__WEBPACK_IMPORTED_MODULE_2__["on"])(el, 'dragenter', this.handleDragEnter); + Object(utils_mixins__WEBPACK_IMPORTED_MODULE_2__["on"])(el, 'dragover', this.handleDragOver); + Object(utils_mixins__WEBPACK_IMPORTED_MODULE_2__["on"])(el, 'drop', this.handleDrop); + Object(utils_mixins__WEBPACK_IMPORTED_MODULE_2__["on"])(el, 'dragleave', this.handleDragLeave); + return this; + } - /** - * Used to bring the previous situation before start moving the component - * @param {Event} e - * @param {Boolean} Indicates if rollback in anycase - * @private - * */ - rollback: function rollback(e, force) { - var key = e.which || e.keyCode; - if (key == this.opt.ESCAPE_KEY || force) { - this.sorter.moved = false; - this.sorter.endMove(); + _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default()(Droppable, [{ + key: "endDrop", + value: function endDrop(cancel, ev) { + var em = this.em, + dragStop = this.dragStop; + this.counter = 0; + this.over = 0; + dragStop && dragStop(cancel); + em.runDefault(); + em.trigger('canvas:dragend', ev); } - return; - }, + }, { + key: "handleDragLeave", + value: function handleDragLeave(ev) { + this.updateCounter(-1, ev); + } + }, { + key: "updateCounter", + value: function updateCounter(value, ev) { + this.counter += value; + this.counter === 0 && this.endDrop(1, ev); + } + }, { + key: "handleDragEnter", + value: function handleDragEnter(ev) { + var _this = this; + var em = this.em; + var dt = ev.dataTransfer; + this.updateCounter(1, ev); + if (this.over) return; + this.over = 1; + var utils = em.get('Utils'); + var canvas = em.get('Canvas'); + var container = canvas.getBody(); // For security reason I can't read the drag data on dragenter, but + // as I need it for the Sorter context I will use `dragContent` or just + // any not empty element + + var content = em.get('dragContent') || '
'; + var dragStop, dragContent; + em.stopDefault(); + + if (em.inAbsoluteMode()) { + var wrapper = em.get('DomComponents').getWrapper(); + var target = wrapper.append({})[0]; + var dragger = em.get('Commands').run('core:component-drag', { + event: ev, + guidesInfo: 1, + center: 1, + target: target, + onEnd: function onEnd(ev, dragger, _ref) { + var cancelled = _ref.cancelled; - /** - * Returns badge element - * @return {HTMLElement} - * @private - */ - getBadgeEl: function getBadgeEl() { - if (!this.$badge) this.$badge = $(this.getBadge()); - return this.$badge; - }, + if (!cancelled) { + var comp = wrapper.append(content)[0]; + var _target$getStyle = target.getStyle(), + left = _target$getStyle.left, + top = _target$getStyle.top, + position = _target$getStyle.position; - /** - * Returns highlighter element - * @return {HTMLElement} - * @private - */ - getHighlighterEl: function getHighlighterEl() { - if (!this.$hl) this.$hl = $(this.canvas.getHighlighter()); - return this.$hl; - }, - stop: function stop() { - for (var _len2 = arguments.length, args = Array(_len2), _key2 = 0; _key2 < _len2; _key2++) { - args[_key2] = arguments[_key2]; + comp.setStyle({ + left: left, + top: top, + position: position + }); + + _this.handleDragEnd(comp, dt); + } + + target.remove(); + } + }); + + dragStop = function dragStop(cancel) { + return dragger.stop(ev, { + cancel: cancel + }); + }; + + dragContent = function dragContent(cnt) { + return content = cnt; + }; + } else { + var sorter = new utils.Sorter({ + em: em, + wmargin: 1, + nested: 1, + canvasRelative: 1, + direction: 'a', + container: container, + placer: canvas.getPlacerEl(), + containerSel: '*', + itemSel: '*', + pfx: 'gjs-', + onEndMove: function onEndMove(model) { + return _this.handleDragEnd(model, dt); + }, + document: canvas.getFrameEl().contentDocument + }); + sorter.setDropContent(content); + sorter.startSort(); + this.sorter = sorter; + + dragStop = function dragStop(cancel) { + cancel && (sorter.moved = 0); + sorter.endMove(); + }; + + dragContent = function dragContent(content) { + return sorter.setDropContent(content); + }; + } + + this.dragStop = dragStop; + this.dragContent = dragContent; + em.trigger('canvas:dragenter', dt, content); + } + }, { + key: "handleDragEnd", + value: function handleDragEnd(model, dt) { + if (!model) return; + var em = this.em; + em.set('dragResult', model); + em.trigger('canvas:drop', dt, model); } + /** + * Always need to have this handler active for enabling the drop + * @param {Event} ev + */ - SelectComponent.stop.apply(this, args); - this.getBadgeEl().removeClass(this.badgeClass); - this.getHighlighterEl().removeClass(this.hoverClass); - var wp = this.$wrapper; - wp.css('cursor', '').unbind().removeClass(this.noSelClass); - } -}); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(0), __webpack_require__(1))) + }, { + key: "handleDragOver", + value: function handleDragOver(ev) { + ev.preventDefault(); + this.em.trigger('canvas:dragover', ev); + } + }, { + key: "handleDrop", + value: function handleDrop(ev) { + ev.preventDefault(); + var dragContent = this.dragContent; + var dt = ev.dataTransfer; + var content = this.getContentByData(dt).content; + ev.target.style.border = ''; + content && dragContent && dragContent(content); + this.endDrop(!content, ev); + } + }, { + key: "getContentByData", + value: function getContentByData(dataTransfer) { + var em = this.em; + var types = dataTransfer.types; + var files = dataTransfer.files || []; + var dragContent = em.get('dragContent'); + var content = dataTransfer.getData('text'); -/***/ }), -/* 195 */ -/***/ (function(module, exports, __webpack_require__) { + if (files.length) { + content = []; -"use strict"; -/* WEBPACK VAR INJECTION */(function(_) { + for (var i = 0; i < files.length; i++) { + var file = files[i]; + var type = file.type.split('/')[0]; -var Backbone = __webpack_require__(0); -var CreateComponent = __webpack_require__(22); + if (type == 'image') { + content.push({ + type: type, + file: file, + attributes: { + alt: file.name + } + }); + } + } + } else if (dragContent) { + content = dragContent; + } else if (Object(underscore__WEBPACK_IMPORTED_MODULE_3__["indexOf"])(types, 'text/html') >= 0) { + content = dataTransfer.getData('text/html').replace(/<\/?meta[^>]*>/g, ''); + } else if (Object(underscore__WEBPACK_IMPORTED_MODULE_3__["indexOf"])(types, 'text/uri-list') >= 0) { + content = { + type: 'link', + attributes: { + href: content + }, + content: content + }; + } else if (Object(underscore__WEBPACK_IMPORTED_MODULE_3__["indexOf"])(types, 'text/json') >= 0) { + var json = dataTransfer.getData('text/json'); + json && (content = JSON.parse(json)); + } -module.exports = _.extend({}, CreateComponent, { + var result = { + content: content + }; + em.trigger('canvas:dragdata', dataTransfer, result); + return result; + } + }]); - /** - * This event is triggered at the beginning of a draw operation - * @param {Object} component Object component before creation - * @private - * */ - beforeDraw: function beforeDraw(component) { - component.type = 'text'; - if (!component.style) component.style = {}; - component.style.padding = '10px'; - }, + return Droppable; +}(); - /** - * This event is triggered at the end of a draw operation - * @param {Object} model Component model created - * @private - * */ - afterDraw: function afterDraw(model) { - if (!model || !model.set) return; - model.trigger('focus'); - if (this.sender) this.sender.set('active', false); - } -}); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(1))) /***/ }), -/* 196 */ -/***/ (function(module, exports, __webpack_require__) { + +/***/ "./src/utils/Resizer.js": +/*!******************************!*\ + !*** ./src/utils/Resizer.js ***! + \******************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/classCallCheck */ "./node_modules/@babel/runtime/helpers/classCallCheck.js"); +/* harmony import */ var _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @babel/runtime/helpers/createClass */ "./node_modules/@babel/runtime/helpers/createClass.js"); +/* harmony import */ var _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_2__); +/* harmony import */ var utils_mixins__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! utils/mixins */ "./src/utils/mixins.js"); -module.exports = { - run: function run(ed) { - ed.Canvas.getBody().className = this.ppfx + 'dashed'; - }, - stop: function stop(ed) { - ed.Canvas.getBody().className = ""; - } -}; -/***/ }), -/* 197 */ -/***/ (function(module, exports, __webpack_require__) { -"use strict"; -/* WEBPACK VAR INJECTION */(function(Backbone) { +var defaultOpts = { + // Function which returns custom X and Y coordinates of the mouse + mousePosFetcher: null, + // Indicates custom target updating strategy + updateTarget: null, + // Function which gets HTMLElement as an arg and returns it relative position + ratioDefault: 0, + posFetcher: null, + onStart: null, + onMove: null, + onEnd: null, + // Resize unit step + step: 1, + // Minimum dimension + minDim: 32, + // Maximum dimension + maxDim: '', + // Unit used for height resizing + unitHeight: 'px', + // Unit used for width resizing + unitWidth: 'px', + // The key used for height resizing + keyHeight: 'height', + // The key used for width resizing + keyWidth: 'width', + // If true, will override unitHeight and unitWidth, on start, with units + // from the current focused element (currently used only in SelectComponent) + currentUnit: 1, + // With this option active the mousemove event won't be altered when + // the pointer comes over iframes + silentFrames: 0, + // If true the container of handlers won't be updated + avoidContainerUpdate: 0, + // If height is 'auto', this setting will preserve it and only update width + keepAutoHeight: false, + // If width is 'auto', this setting will preserve it and only update height + keepAutoWidth: false, + // When keepAutoHeight is true and the height has the value 'auto', this is set to true and height isn't updated + autoHeight: false, + // When keepAutoWidth is true and the width has the value 'auto', this is set to true and width isn't updated + autoWidth: false, + // Handlers + tl: 1, + // Top left + tc: 1, + // Top center + tr: 1, + // Top right + cl: 1, + // Center left + cr: 1, + // Center right + bl: 1, + // Bottom left + bc: 1, + // Bottom center + br: 1 // Bottom right -var Layers = __webpack_require__(198); -var $ = Backbone.$; +}; -module.exports = { - run: function run(em, sender) { - if (!this.toAppend) { - var collection = em.DomComponents.getComponent().get('components'); - var config = em.getConfig(); - var pfx = config.stylePrefix; - var panels = em.Panels; - var lyStylePfx = config.layers.stylePrefix || 'nv-'; - - config.layers.stylePrefix = config.stylePrefix + lyStylePfx; - config.layers.pStylePrefix = config.stylePrefix; - config.layers.em = em.editor; - config.layers.opened = em.editor.get('opened'); - - // Check if panel exists otherwise crate it - if (!panels.getPanel('views-container')) this.panel = panels.addPanel({ id: 'views-container' });else this.panel = panels.getPanel('views-container'); - - var toAppend = $('
'); - this.panel.set('appendContent', toAppend).trigger('change:appendContent'); - config.layers.sortContainer = toAppend.get(0); - var layers = new Layers().init(collection, config.layers); - this.$layers = layers.render(); - toAppend.append(this.$layers); - this.toAppend = toAppend; - } - this.toAppend.show(); - }, - stop: function stop() { - this.toAppend && this.toAppend.hide(); - } +var createHandler = function createHandler(name, opts) { + var pfx = opts.prefix || ''; + var el = document.createElement('i'); + el.className = pfx + 'resizer-h ' + pfx + 'resizer-h-' + name; + el.setAttribute('data-' + pfx + 'handler', name); + return el; }; -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(0))) -/***/ }), -/* 198 */ -/***/ (function(module, exports, __webpack_require__) { +var getBoundingRect = function getBoundingRect(el, win) { + var w = win || window; + var rect = el.getBoundingClientRect(); + return { + left: rect.left + w.pageXOffset, + top: rect.top + w.pageYOffset, + width: rect.width, + height: rect.height + }; +}; -"use strict"; +var Resizer = +/*#__PURE__*/ +function () { + /** + * Init the Resizer with options + * @param {Object} options + */ + function Resizer() { + var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + _babel_runtime_helpers_classCallCheck__WEBPACK_IMPORTED_MODULE_0___default()(this, Resizer); -module.exports = function () { - var itemsView = void 0; - var config = {}; - var defaults = __webpack_require__(199); - var ItemView = __webpack_require__(55); - var ItemsView = __webpack_require__(56); + this.setOptions(opts); + Object(underscore__WEBPACK_IMPORTED_MODULE_2__["bindAll"])(this, 'handleKeyDown', 'handleMouseDown', 'move', 'stop'); + return this; + } + /** + * Get current connfiguration options + * @return {Object} + */ - return { - init: function init(collection, opts) { - config = opts || config; - var em = config.em; - // Set default options - for (var name in defaults) { - if (!(name in config)) config[name] = defaults[name]; - } + _babel_runtime_helpers_createClass__WEBPACK_IMPORTED_MODULE_1___default()(Resizer, [{ + key: "getConfig", + value: function getConfig() { + return this.opts; + } + /** + * Setup options + * @param {Object} options + */ - var View = ItemsView; - var level = 0; - var opened = opts.opened || {}; - var options = { - level: level, - config: config, - opened: opened + }, { + key: "setOptions", + value: function setOptions() { + var options = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + this.opts = Object(underscore__WEBPACK_IMPORTED_MODULE_2__["defaults"])(options, defaultOpts); + this.setup(); + } + /** + * Setup resizer + */ - // Show wrapper if requested - };if (config.showWrapper && collection.parent) { - View = ItemView; - options.model = collection.parent; - } else { - options.collection = collection; + }, { + key: "setup", + value: function setup() { + var opts = this.opts; + var pfx = opts.prefix || ''; + var appendTo = opts.appendTo || document.body; + var container = this.container; // Create container if not yet exist + + if (!container) { + container = document.createElement('div'); + container.className = "".concat(pfx, "resizer-c"); + appendTo.appendChild(container); + this.container = container; } - itemsView = new View(options); - em && em.on('change:selectedComponent', this.componentChanged); - this.componentChanged(); + while (container.firstChild) { + container.removeChild(container.firstChild); + } // Create handlers - return this; - }, + var handlers = {}; + ['tl', 'tc', 'tr', 'cl', 'cr', 'bl', 'bc', 'br'].forEach(function (hdl) { + return handlers[hdl] = opts[hdl] ? createHandler(hdl, opts) : ''; + }); + + for (var n in handlers) { + var handler = handlers[n]; + handler && container.appendChild(handler); + } + this.handlers = handlers; + this.mousePosFetcher = opts.mousePosFetcher; + this.updateTarget = opts.updateTarget; + this.posFetcher = opts.posFetcher; + this.onStart = opts.onStart; + this.onMove = opts.onMove; + this.onEnd = opts.onEnd; + } /** - * Triggered when the selected component is changed - * @private + * Toggle iframes pointer event + * @param {Boolean} silent If true, iframes will be silented */ - componentChanged: function componentChanged(e, md) { - var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; - if (opts.fromLayers) { - return; + }, { + key: "toggleFrames", + value: function toggleFrames(silent) { + if (this.opts.silentFrames) { + var frames = document.querySelectorAll('iframe'); + Object(underscore__WEBPACK_IMPORTED_MODULE_2__["each"])(frames, function (frame) { + return frame.style.pointerEvents = silent ? 'none' : ''; + }); } + } + /** + * Detects if the passed element is a resize handler + * @param {HTMLElement} el + * @return {Boolean} + */ - var em = config.em; - var opened = em.get('opened'); - var model = em.get('selectedComponent'); - var parent = model && model.collection ? model.collection.parent : null; + }, { + key: "isHandler", + value: function isHandler(el) { + var handlers = this.handlers; - for (var cid in opened) { - opened[cid].set('open', 0); + for (var n in handlers) { + if (handlers[n] === el) return true; } - while (parent) { - parent.set('open', 1); - opened[parent.cid] = parent; - parent = parent.collection ? parent.collection.parent : null; - } - }, - render: function render() { - return itemsView.render().$el; + return false; } - }; -}; - -/***/ }), -/* 199 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; + /** + * Returns the focused element + * @return {HTMLElement} + */ + }, { + key: "getFocusedEl", + value: function getFocusedEl() { + return this.el; + } + /** + * Returns documents + */ -module.exports = { - stylePrefix: 'nv-', + }, { + key: "getDocumentEl", + value: function getDocumentEl() { + return [this.el.ownerDocument, document]; + } + /** + * Return element position + * @param {HTMLElement} el + * @param {Object} opts Custom options + * @return {Object} + */ - // Enable/Disable globally the possibility to sort layers - sortable: 1, + }, { + key: "getElementPos", + value: function getElementPos(el) { + var opts = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; + var posFetcher = this.posFetcher || ''; + return posFetcher ? posFetcher(el, opts) : getBoundingRect(el); + } + /** + * Focus resizer on the element, attaches handlers to it + * @param {HTMLElement} el + */ - // Enable/Disable globally the possibility to hide layers - hidable: 1, + }, { + key: "focus", + value: function focus(el) { + // Avoid focusing on already focused element + if (el && el === this.el) { + return; + } - // Hide textnodes - hideTextnode: 1, + this.el = el; + this.updateContainer({ + forceShow: 1 + }); + Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["on"])(this.getDocumentEl(), 'mousedown', this.handleMouseDown); + } + /** + * Blur from element + */ - // Indicates if the wrapper is visible in layers - showWrapper: 1 -}; + }, { + key: "blur", + value: function blur() { + this.container.style.display = 'none'; -/***/ }), -/* 200 */ -/***/ (function(module, exports, __webpack_require__) { + if (this.el) { + Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["off"])(this.getDocumentEl(), 'mousedown', this.handleMouseDown); + this.el = null; + } + } + /** + * Start resizing + * @param {Event} e + */ -"use strict"; + }, { + key: "start", + value: function start(e) { + //Right or middel click + if (e.button !== 0) return; + e.preventDefault(); + e.stopPropagation(); + var el = this.el; + var resizer = this; + var config = this.opts || {}; + var attrName = 'data-' + config.prefix + 'handler'; + var rect = this.getElementPos(el, { + target: 'el' + }); + this.handlerAttr = e.target.getAttribute(attrName); + this.clickedHandler = e.target; + this.startDim = { + t: rect.top, + l: rect.left, + w: rect.width, + h: rect.height + }; + this.rectDim = { + t: rect.top, + l: rect.left, + w: rect.width, + h: rect.height + }; + this.startPos = { + x: e.clientX, + y: e.clientY + }; // Listen events + var doc = this.getDocumentEl(); + Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["on"])(doc, 'mousemove', this.move); + Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["on"])(doc, 'keydown', this.handleKeyDown); + Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["on"])(doc, 'mouseup', this.stop); + Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isFunction"])(this.onStart) && this.onStart(e, { + docs: doc, + config: config, + el: el, + resizer: resizer + }); + this.toggleFrames(1); + this.move(e); + } + /** + * While resizing + * @param {Event} e + */ -var StyleManager = __webpack_require__(31); -var Backbone = __webpack_require__(0); -var $ = Backbone.$; + }, { + key: "move", + value: function move(e) { + var onMove = this.onMove; + var mouseFetch = this.mousePosFetcher; + var currentPos = mouseFetch ? mouseFetch(e) : { + x: e.clientX, + y: e.clientY + }; + this.currentPos = currentPos; + this.delta = { + x: currentPos.x - this.startPos.x, + y: currentPos.y - this.startPos.y + }; + this.keys = { + shift: e.shiftKey, + ctrl: e.ctrlKey, + alt: e.altKey + }; + this.rectDim = this.calc(this); + this.updateRect(0); // Move callback -module.exports = { - run: function run(em, sender) { - this.sender = sender; - if (!this.$cn) { - var config = em.getConfig(), - panels = em.Panels; - // Main container - this.$cn = $('
'); - // Secondary container - this.$cn2 = $('
'); - this.$cn.append(this.$cn2); + onMove && onMove(e); // In case the mouse button was released outside of the window - // Device Manager - var dvm = em.DeviceManager; - if (dvm && config.showDevices) { - var devicePanel = panels.addPanel({ id: 'devices-c' }); - devicePanel.set('appendContent', dvm.render()).trigger('change:appendContent'); + if (e.which === 0) { + this.stop(e); } + } + /** + * Stop resizing + * @param {Event} e + */ - // Class Manager container - var clm = em.SelectorManager; - if (clm) this.$cn2.append(clm.render([])); - - this.$cn2.append(em.StyleManager.render()); - var smConfig = em.StyleManager.getConfig(); - var pfx = smConfig.stylePrefix; - // Create header - this.$header = $('
' + smConfig.textNoElement + '
'); - this.$cn.append(this.$header); - - // Create panel if not exists - if (!panels.getPanel('views-container')) this.panel = panels.addPanel({ id: 'views-container' });else this.panel = panels.getPanel('views-container'); - - // Add all containers to the panel - this.panel.set('appendContent', this.$cn).trigger('change:appendContent'); - - this.target = em.editor; - this.listenTo(this.target, 'change:selectedComponent', this.toggleSm); + }, { + key: "stop", + value: function stop(e) { + var config = this.opts; + var doc = this.getDocumentEl(); + Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["off"])(doc, 'mousemove', this.move); + Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["off"])(doc, 'keydown', this.handleKeyDown); + Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["off"])(doc, 'mouseup', this.stop); + this.updateRect(1); + this.toggleFrames(); + Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isFunction"])(this.onEnd) && this.onEnd(e, { + docs: doc, + config: config + }); } - this.toggleSm(); - }, + /** + * Update rect + */ + }, { + key: "updateRect", + value: function updateRect(store) { + var el = this.el; + var resizer = this; + var config = this.opts; + var rect = this.rectDim; + var updateTarget = this.updateTarget; + var selectedHandler = this.getSelectedHandler(); + var unitHeight = config.unitHeight, + unitWidth = config.unitWidth, + keyWidth = config.keyWidth, + keyHeight = config.keyHeight; // Use custom updating strategy if requested - /** - * Toggle Style Manager visibility - * @private - */ - toggleSm: function toggleSm() { - var sender = this.sender; - if (sender && sender.get && !sender.get('active')) return; + if (Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isFunction"])(updateTarget)) { + updateTarget(el, rect, { + store: store, + selectedHandler: selectedHandler, + resizer: resizer, + config: config + }); + } else { + var elStyle = el.style; + elStyle[keyWidth] = rect.w + unitWidth; + elStyle[keyHeight] = rect.h + unitHeight; + } - if (this.target.get('selectedComponent')) { - this.$cn2.show(); - this.$header.hide(); - } else { - this.$cn2.hide(); - this.$header.show(); + this.updateContainer(); } - }, - stop: function stop() { - // Hide secondary container if exists - if (this.$cn2) this.$cn2.hide(); - - // Hide header container if exists - if (this.$header) this.$header.hide(); - } -}; + }, { + key: "updateContainer", + value: function updateContainer() { + var opt = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; + var opts = this.opts, + container = this.container, + el = this.el; + var style = container.style; + + if (!opts.avoidContainerUpdate && el) { + var toUpdate = ['left', 'top', 'width', 'height']; + var rectEl = this.getElementPos(el, { + target: 'container' + }); + toUpdate.forEach(function (pos) { + return style[pos] = "".concat(rectEl[pos], "px"); + }); + if (opt.forceShow) style.display = 'block'; + } + } + /** + * Get selected handler name + * @return {string} + */ -/***/ }), -/* 201 */ -/***/ (function(module, exports, __webpack_require__) { + }, { + key: "getSelectedHandler", + value: function getSelectedHandler() { + var handlers = this.handlers; -"use strict"; -/* WEBPACK VAR INJECTION */(function(Backbone) { + if (!this.selectedHandler) { + return; + } -var $ = Backbone.$; + for (var n in handlers) { + if (handlers[n] === this.selectedHandler) return n; + } + } + /** + * Handle ESC key + * @param {Event} e + */ -module.exports = { - run: function run(editor, sender) { - var config = editor.Config; - var pfx = config.stylePrefix; - var tm = editor.TraitManager; - var panelC; - if (!this.obj) { - var tmView = tm.getTraitsViewer(); - var confTm = tm.getConfig(); - this.obj = $('
').append('
' + confTm.labelContainer + '
').get(0); - this.obj.appendChild(tmView.render().el); - var panels = editor.Panels; - if (!panels.getPanel('views-container')) panelC = panels.addPanel({ id: 'views-container' });else panelC = panels.getPanel('views-container'); - panelC.set('appendContent', this.obj).trigger('change:appendContent'); + }, { + key: "handleKeyDown", + value: function handleKeyDown(e) { + if (e.keyCode === 27) { + // Rollback to initial dimensions + this.rectDim = this.startDim; + this.stop(e); + } } + /** + * Handle mousedown to check if it's possible to start resizing + * @param {Event} e + */ - this.obj.style.display = 'block'; - }, - stop: function stop() { - if (this.obj) this.obj.style.display = 'none'; - } -}; -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(0))) + }, { + key: "handleMouseDown", + value: function handleMouseDown(e) { + var el = e.target; -/***/ }), -/* 202 */ -/***/ (function(module, exports, __webpack_require__) { + if (this.isHandler(el)) { + this.selectedHandler = el; + this.start(e); + } else if (el !== this.el) { + this.selectedHandler = ''; + this.blur(); + } + } + /** + * All positioning logic + * @return {Object} + */ -"use strict"; + }, { + key: "calc", + value: function calc(data) { + var value; + var opts = this.opts || {}; + var step = opts.step; + var startDim = this.startDim; + var minDim = opts.minDim; + var maxDim = opts.maxDim; + var deltaX = data.delta.x; + var deltaY = data.delta.y; + var startW = startDim.w; + var startH = startDim.h; + var box = { + t: 0, + l: 0, + w: startW, + h: startH + }; + if (!data) return; + var attr = data.handlerAttr; + if (~attr.indexOf('r')) { + value = Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["normalizeFloat"])(startW + deltaX * step, step); + value = Math.max(minDim, value); + maxDim && (value = Math.min(maxDim, value)); + box.w = value; + } -module.exports = { - run: function run(editor, sender) { - var bm = editor.BlockManager; - var pn = editor.Panels; + if (~attr.indexOf('b')) { + value = Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["normalizeFloat"])(startH + deltaY * step, step); + value = Math.max(minDim, value); + maxDim && (value = Math.min(maxDim, value)); + box.h = value; + } - if (!this.blocks) { - bm.render(); - var id = 'views-container'; - var blocks = document.createElement('div'); - var panels = pn.getPanel(id) || pn.addPanel({ id: id }); - blocks.appendChild(bm.getContainer()); - panels.set('appendContent', blocks).trigger('change:appendContent'); - this.blocks = blocks; - } + if (~attr.indexOf('l')) { + value = Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["normalizeFloat"])(startW - deltaX * step, step); + value = Math.max(minDim, value); + maxDim && (value = Math.min(maxDim, value)); + box.w = value; + } - this.blocks.style.display = 'block'; - }, - stop: function stop() { - var blocks = this.blocks; - blocks && (blocks.style.display = 'none'); - } -}; + if (~attr.indexOf('t')) { + value = Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["normalizeFloat"])(startH - deltaY * step, step); + value = Math.max(minDim, value); + maxDim && (value = Math.min(maxDim, value)); + box.h = value; + } // Enforce aspect ratio (unless shift key is being held) -/***/ }), -/* 203 */ -/***/ (function(module, exports, __webpack_require__) { -"use strict"; + var ratioActive = opts.ratioDefault ? !data.keys.shift : data.keys.shift; + if (attr.indexOf('c') < 0 && ratioActive) { + var ratio = startDim.w / startDim.h; -module.exports = { - run: function run(editor, sender) { - var opts = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {}; + if (box.w / box.h > ratio) { + box.h = Math.round(box.w / ratio); + } else { + box.w = Math.round(box.h * ratio); + } + } - var modal = editor.Modal; - var am = editor.AssetManager; - var config = am.getConfig(); - var title = opts.modalTitle || config.modalTitle || ''; + if (~attr.indexOf('l')) { + box.l = startDim.w - box.w; + } - am.setTarget(opts.target); - am.onClick(opts.onClick); - am.onDblClick(opts.onDblClick); - am.onSelect(opts.onSelect); + if (~attr.indexOf('t')) { + box.t = startDim.h - box.h; + } - if (!this.rendered) { - am.render(am.getAll().filter(function (asset) { - return asset.get('type') == 'image'; - })); - this.rendered = 1; + return box; } + }]); + + return Resizer; +}(); - modal.setTitle(title); - modal.setContent(am.getContainer()); - modal.open(); +/* harmony default export */ __webpack_exports__["default"] = ({ + init: function init(opts) { + return new Resizer(opts); } -}; +}); /***/ }), -/* 204 */ -/***/ (function(module, exports, __webpack_require__) { + +/***/ "./src/utils/Sorter.js": +/*!*****************************!*\ + !*** ./src/utils/Sorter.js ***! + \*****************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; -/* WEBPACK VAR INJECTION */(function(Backbone) { +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @babel/runtime/helpers/defineProperty */ "./node_modules/@babel/runtime/helpers/defineProperty.js"); +/* harmony import */ var _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(_babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0__); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! backbone */ "./node_modules/backbone/backbone.js"); +/* harmony import */ var backbone__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(backbone__WEBPACK_IMPORTED_MODULE_1__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_2___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_2__); +/* harmony import */ var utils_mixins__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! utils/mixins */ "./src/utils/mixins.js"); -var $ = Backbone.$; -module.exports = { - getOffsetMethod: function getOffsetMethod(state) { - var method = state || ''; - return 'get' + method + 'OffsetViewerEl'; - }, - run: function run(editor, sender, opts) { - var opt = opts || {}; - var state = opt.state || ''; - var config = editor.getConfig(); +function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } - if (!config.showOffsets || !config.showOffsetsSelected && state == 'Fixed') { - return; - } +function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _babel_runtime_helpers_defineProperty__WEBPACK_IMPORTED_MODULE_0___default()(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } - var canvas = editor.Canvas; - var el = opt.el || ''; - var pos = opt.elPos || canvas.getElementPos(el); - var style = window.getComputedStyle(el); - var ppfx = this.ppfx; - var stateVar = state + 'State'; - var method = this.getOffsetMethod(state); - var offsetViewer = canvas[method](); - offsetViewer.style.display = 'block'; - var marginT = this['marginT' + state]; - var marginB = this['marginB' + state]; - var marginL = this['marginL' + state]; - var marginR = this['marginR' + state]; - var padT = this['padT' + state]; - var padB = this['padB' + state]; - var padL = this['padL' + state]; - var padR = this['padR' + state]; - if (!this[stateVar]) { - var stateLow = state.toLowerCase(); - var marginName = stateLow + 'margin-v'; - var paddingName = stateLow + 'padding-v'; - var marginV = $('
').get(0); - var paddingV = $('
').get(0); - var marginEls = ppfx + marginName + '-el'; - var paddingEls = ppfx + paddingName + '-el'; - var fullMargName = marginEls + ' ' + (ppfx + marginName); - var fullPadName = paddingEls + ' ' + (ppfx + paddingName); - marginT = $('
').get(0); - marginB = $('
').get(0); - marginL = $('
').get(0); - marginR = $('
').get(0); - padT = $('
').get(0); - padB = $('
').get(0); - padL = $('
').get(0); - padR = $('
').get(0); - this['marginT' + state] = marginT; - this['marginB' + state] = marginB; - this['marginL' + state] = marginL; - this['marginR' + state] = marginR; - this['padT' + state] = padT; - this['padB' + state] = padB; - this['padL' + state] = padL; - this['padR' + state] = padR; - marginV.appendChild(marginT); - marginV.appendChild(marginB); - marginV.appendChild(marginL); - marginV.appendChild(marginR); - paddingV.appendChild(padT); - paddingV.appendChild(padB); - paddingV.appendChild(padL); - paddingV.appendChild(padR); - offsetViewer.appendChild(marginV); - offsetViewer.appendChild(paddingV); - this[stateVar] = '1'; - } - var unit = 'px'; - var marginLeftSt = style.marginLeft.replace(unit, ''); - var marginTopSt = parseInt(style.marginTop.replace(unit, '')); - var marginBottomSt = parseInt(style.marginBottom.replace(unit, '')); - var mtStyle = marginT.style; - var mbStyle = marginB.style; - var mlStyle = marginL.style; - var mrStyle = marginR.style; - var ptStyle = padT.style; - var pbStyle = padB.style; - var plStyle = padL.style; - var prStyle = padR.style; - var posLeft = parseInt(pos.left); +var $ = backbone__WEBPACK_IMPORTED_MODULE_1___default.a.$; +/* harmony default export */ __webpack_exports__["default"] = (backbone__WEBPACK_IMPORTED_MODULE_1___default.a.View.extend({ + initialize: function initialize(opt) { + this.opt = opt || {}; + Object(underscore__WEBPACK_IMPORTED_MODULE_2__["bindAll"])(this, 'startSort', 'onMove', 'endMove', 'rollback', 'updateOffset', 'moveDragHelper'); + var o = opt || {}; + this.elT = 0; + this.elL = 0; + this.borderOffset = o.borderOffset || 10; + var el = o.container; + this.el = typeof el === 'string' ? document.querySelector(el) : el; + this.$el = $(this.el); + this.containerSel = o.containerSel || 'div'; + this.itemSel = o.itemSel || 'div'; + this.draggable = o.draggable || true; + this.nested = o.nested || 0; + this.pfx = o.pfx || ''; + this.ppfx = o.ppfx || ''; + this.freezeClass = o.freezeClass || this.pfx + 'freezed'; + this.onStart = o.onStart || ''; + this.onEndMove = o.onEndMove || ''; + this.direction = o.direction || 'v'; // v (vertical), h (horizontal), a (auto) - // Margin style - mtStyle.height = style.marginTop; - mtStyle.width = style.width; - mtStyle.top = pos.top - style.marginTop.replace(unit, '') + unit; - mtStyle.left = posLeft + unit; + this.onMoveClb = o.onMove || ''; + this.relative = o.relative || 0; + this.ignoreViewChildren = o.ignoreViewChildren || 0; + this.ignoreModels = o.ignoreModels || 0; + this.plh = o.placer || ''; // Frame offset - mbStyle.height = style.marginBottom; - mbStyle.width = style.width; - mbStyle.top = pos.top + pos.height + unit; - mbStyle.left = posLeft + unit; + this.wmargin = o.wmargin || 0; + this.offTop = o.offsetTop || 0; + this.offLeft = o.offsetLeft || 0; + this.document = o.document || document; + this.$document = $(this.document); + this.dropContent = null; + this.em = o.em || ''; + this.dragHelper = null; + this.canvasRelative = o.canvasRelative || 0; + this.selectOnEnd = !o.avoidSelectOnEnd; + this.scale = o.scale; + this.activeTextModel = null; - var marginSideH = pos.height + marginTopSt + marginBottomSt + unit; - var marginSideT = pos.top - marginTopSt + unit; - mlStyle.height = marginSideH; - mlStyle.width = style.marginLeft; - mlStyle.top = marginSideT; - mlStyle.left = posLeft - marginLeftSt + unit; + if (this.em && this.em.on) { + this.em.on('change:canvasOffset', this.updateOffset); + this.updateOffset(); + } + }, + getScale: function getScale() { + return Object(underscore__WEBPACK_IMPORTED_MODULE_2__["result"])(this, scale) || 1; + }, + getContainerEl: function getContainerEl() { + if (!this.el) { + var el = this.opt.container; + this.el = typeof el === 'string' ? document.querySelector(el) : el; + this.$el = $(this.el); + } - mrStyle.height = marginSideH; - mrStyle.width = style.marginRight; - mrStyle.top = marginSideT; - mrStyle.left = posLeft + pos.width + unit; + return this.el; + }, + getDocuments: function getDocuments() { + var em = this.em; + var canvasDoc = em && em.get('Canvas').getBody().ownerDocument; + var docs = [document]; + canvasDoc && docs.push(canvasDoc); + return docs; + }, - // Padding style - var padTop = parseInt(style.paddingTop.replace(unit, '')); - ptStyle.height = style.paddingTop; - ptStyle.width = style.width; - ptStyle.top = pos.top + unit; - ptStyle.left = posLeft + unit; + /** + * Triggered when the offset of the editro is changed + */ + updateOffset: function updateOffset() { + var offset = this.em.get('canvasOffset') || {}; + this.offTop = offset.top; + this.offLeft = offset.left; + }, - var padBot = parseInt(style.paddingBottom.replace(unit, '')); - pbStyle.height = style.paddingBottom; - pbStyle.width = style.width; - pbStyle.top = pos.top + pos.height - padBot + unit; - pbStyle.left = posLeft + unit; + /** + * Set content to drop + * @param {String|Object} content + */ + setDropContent: function setDropContent(content) { + this.dropModel = null; + this.dropContent = content; + }, + updateTextViewCursorPosition: function updateTextViewCursorPosition(e) { + var Canvas = this.em.get('Canvas'); + var targetDoc = Canvas.getDocument(); + var range = null; - var padSideH = pos.height - padBot - padTop + unit; - var padSideT = pos.top + padTop + unit; - plStyle.height = padSideH; - plStyle.width = style.paddingLeft; - plStyle.top = padSideT; - plStyle.left = pos.left + unit; + if (targetDoc.caretRangeFromPoint) { + // Chrome + var poiner = Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["getPointerEvent"])(e); + range = targetDoc.caretRangeFromPoint(poiner.clientX, poiner.clientY); + } else if (e.rangeParent) { + // Firefox + range = targetDoc.createRange(); + range.setStart(e.rangeParent, e.rangeOffset); + } - var padRight = parseInt(style.paddingRight.replace(unit, '')); - prStyle.height = padSideH; - prStyle.width = style.paddingRight; - prStyle.top = padSideT; - prStyle.left = pos.left + pos.width - padRight + unit; + var sel = Canvas.getWindow().getSelection(); + Canvas.getFrameEl().focus(); + sel.removeAllRanges(); + range && sel.addRange(range); + }, + setContentEditable: function setContentEditable(model, mode) { + if (model) { + var el = model.getEl(); + if (el.contentEditable != mode) el.contentEditable = mode; + } }, - stop: function stop(editor, sender, opts) { - var opt = opts || {}; - var state = opt.state || ''; - var method = this.getOffsetMethod(state); - var canvas = editor.Canvas; - var offsetViewer = canvas[method](); - offsetViewer.style.display = 'none'; - } -}; -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(0))) -/***/ }), -/* 205 */ -/***/ (function(module, exports, __webpack_require__) { + /** + * Toggle cursor while sorting + * @param {Boolean} active + */ + toggleSortCursor: function toggleSortCursor(active) { + var em = this.em; + var body = document.body; + var pfx = this.ppfx || this.pfx; + var sortCls = pfx + 'grabbing'; + var emBody = em ? em.get('Canvas').getBody() : ''; // Avoid updating body className as it causes a huge repaint + // Noticeable with "fast" drag of blocks -"use strict"; + if (active) { + em && em.get('Canvas').startAutoscroll(); //body.className += ' ' + sortCls; + //if (em) emBody.className += ' ' + sortCls; + } else { + em && em.get('Canvas').stopAutoscroll(); //body.className = body.className.replace(sortCls, '').trim(); + //if(em) emBody.className = emBody.className.replace(sortCls, '').trim(); + } + }, + + /** + * Set drag helper + * @param {HTMLElement} el + * @param {Event} event + */ + setDragHelper: function setDragHelper(el, event) { + var ev = event || ''; + var clonedEl = el.cloneNode(1); + var rect = el.getBoundingClientRect(); + var computed = getComputedStyle(el); + var style = ''; + for (var i = 0; i < computed.length; i++) { + var prop = computed[i]; + style += "".concat(prop, ":").concat(computed.getPropertyValue(prop), ";"); + } -module.exports = { - run: function run(editor) { - var sel = editor.getSelected(); - var comp = sel && sel.parent(); + document.body.appendChild(clonedEl); + clonedEl.className += " ".concat(this.pfx, "bdrag"); + clonedEl.setAttribute('style', style); + this.dragHelper = clonedEl; + clonedEl.style.width = "".concat(rect.width, "px"); + clonedEl.style.height = "".concat(rect.height, "px"); + ev && this.moveDragHelper(ev); // Listen mouse move events - // Recurse through the parent() chain until a selectable parent is found - while (comp && !comp.get("selectable")) { - comp = comp.parent(); + if (this.em) { + $(this.em.get('Canvas').getBody().ownerDocument).off('mousemove', this.moveDragHelper).on('mousemove', this.moveDragHelper); } - comp && editor.select(comp); - } -}; + $(document).off('mousemove', this.moveDragHelper).on('mousemove', this.moveDragHelper); + }, -/***/ }), -/* 206 */ -/***/ (function(module, exports, __webpack_require__) { + /** + * Update the position of the helper + * @param {Event} e + */ + moveDragHelper: function moveDragHelper(e) { + var doc = e.target.ownerDocument; -"use strict"; + if (!this.dragHelper || !doc) { + return; + } + + var posY = e.pageY; + var posX = e.pageX; + var addTop = 0; + var addLeft = 0; + var window = doc.defaultView || doc.parentWindow; + var frame = window.frameElement; + var dragHelperStyle = this.dragHelper.style; // If frame is present that means mouse has moved over the editor's canvas, + // which is rendered inside the iframe and the mouse move event comes from + // the iframe, not the parent window. Mouse position relative to the frame's + // parent window needs to account for the frame's position relative to the + // parent window. + + if (frame) { + var frameRect = frame.getBoundingClientRect(); + addTop = frameRect.top + document.documentElement.scrollTop; + addLeft = frameRect.left + document.documentElement.scrollLeft; + posY = e.clientY; + posX = e.clientX; + } + dragHelperStyle.top = posY + addTop + 'px'; + dragHelperStyle.left = posX + addLeft + 'px'; + }, -module.exports = { /** - * Check if fullscreen mode is enabled + * Returns true if the element matches with selector + * @param {Element} el + * @param {String} selector * @return {Boolean} */ - isEnabled: function isEnabled() { - var d = document; - if (d.fullscreenElement || d.webkitFullscreenElement || d.mozFullScreenElement) return 1;else return 0; + matches: function matches(el, selector, useBody) { + return utils_mixins__WEBPACK_IMPORTED_MODULE_3__["matches"].call(el, selector); }, + /** + * Closest parent + * @param {Element} el + * @param {String} selector + * @return {Element|null} + */ + closest: function closest(el, selector) { + if (!el) return; + var elem = el.parentNode; + + while (elem && elem.nodeType === 1) { + if (this.matches(elem, selector)) return elem; + elem = elem.parentNode; + } + + return null; + }, /** - * Enable fullscreen mode and return browser prefix + * Get the offset of the element * @param {HTMLElement} el - * @return {string} + * @return {Object} */ - enable: function enable(el) { - var pfx = ''; - if (el.requestFullscreen) el.requestFullscreen();else if (el.webkitRequestFullscreen) { - pfx = 'webkit'; - el.webkitRequestFullscreen(); - } else if (el.mozRequestFullScreen) { - pfx = 'moz'; - el.mozRequestFullScreen(); - } else if (el.msRequestFullscreen) el.msRequestFullscreen();else console.warn('Fullscreen not supported'); - return pfx; + offset: function offset(el) { + var rect = el.getBoundingClientRect(); + return { + top: rect.top + document.body.scrollTop, + left: rect.left + document.body.scrollLeft + }; }, - /** - * Disable fullscreen mode + * Create placeholder + * @return {HTMLElement} */ - disable: function disable() { - var d = document; - if (d.exitFullscreen) d.exitFullscreen();else if (d.webkitExitFullscreen) d.webkitExitFullscreen();else if (d.mozCancelFullScreen) d.mozCancelFullScreen();else if (d.msExitFullscreen) d.msExitFullscreen(); + createPlaceholder: function createPlaceholder() { + var pfx = this.pfx; + var el = document.createElement('div'); + var ins = document.createElement('div'); + el.className = pfx + 'placeholder'; + el.style.display = 'none'; + el.style['pointer-events'] = 'none'; + ins.className = pfx + 'placeholder-int'; + el.appendChild(ins); + return el; }, - /** - * Triggered when the state of the fullscreen is changed. Inside detects if - * it's enabled - * @param {strinf} pfx Browser prefix - * @param {Event} e - */ - fsChanged: function fsChanged(pfx, e) { - var d = document; - var ev = (pfx || '') + 'fullscreenchange'; - if (!this.isEnabled()) { - this.stop(null, this.sender); - document.removeEventListener(ev, this.fsChanged); + * Picking component to move + * @param {HTMLElement} src + * */ + startSort: function startSort(src) { + var em = this.em; + var itemSel = this.itemSel; + var contSel = this.containerSel; + var container = this.getContainerEl(); + var docs = this.getDocuments(); + var onStart = this.onStart; + var srcModel; + var plh = this.plh; + this.dropModel = null; + this.moved = 0; // Check if the start element is a valid one, if not get the + // closest valid one + + if (src && !this.matches(src, "".concat(itemSel, ", ").concat(contSel))) { + src = this.closest(src, itemSel); } - }, - run: function run(editor, sender) { - this.sender = sender; - var pfx = this.enable(editor.getContainer()); - this.fsChanged = this.fsChanged.bind(this, pfx); - document.addEventListener(pfx + 'fullscreenchange', this.fsChanged); - if (editor) editor.trigger('change:canvasOffset'); - }, - stop: function stop(editor, sender) { - if (sender && sender.set) sender.set('active', false); - this.disable(); - if (editor) editor.trigger('change:canvasOffset'); - } -}; -/***/ }), -/* 207 */ -/***/ (function(module, exports, __webpack_require__) { + this.eV = src; // Create placeholder if not yet exists -"use strict"; -/* WEBPACK VAR INJECTION */(function(_) { + if (!plh) { + plh = this.createPlaceholder(); + container.appendChild(plh); + this.plh = plh; + } -module.exports = { - getPanels: function getPanels(editor) { - if (!this.panels) this.panels = editor.Panels.getPanelsEl(); - return this.panels; - }, - tglPointers: function tglPointers(editor, v) { - var elP = editor.Canvas.getBody().querySelectorAll('.' + this.ppfx + 'no-pointer'); - _.each(elP, function (item) { - item.style.pointerEvents = v ? '' : 'all'; - }); - }, - run: function run(editor, sender) { - if (sender && sender.set) sender.set('active', false); - editor.stopCommand('sw-visibility'); - editor.getModel().stopDefault(); - var that = this; - var panels = this.getPanels(editor); - var canvas = editor.Canvas.getElement(); - var editorEl = editor.getEl(); - var pfx = editor.Config.stylePrefix; - if (!this.helper) { - this.helper = document.createElement('span'); - this.helper.className = pfx + 'off-prv fa fa-eye-slash'; - editorEl.appendChild(this.helper); - this.helper.onclick = function () { - editor.stopCommand('preview'); - }; + if (src) { + srcModel = this.getSourceModel(src); + srcModel && srcModel.set && srcModel.set('status', 'freezed'); } - this.helper.style.display = 'inline-block'; - this.tglPointers(editor); - /* - editor.Canvas.getBody().querySelectorAll('.' + pfx + 'no-pointer').forEach(function(){ - this.style.pointerEvents = 'all'; - });*/ + Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["on"])(container, 'mousemove dragover', this.onMove); + Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["on"])(docs, 'mouseup dragend touchend', this.endMove); + Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["on"])(docs, 'keydown', this.rollback); + onStart && onStart(); // Avoid strange effects on dragging - panels.style.display = 'none'; - var canvasS = canvas.style; - canvasS.width = '100%'; - canvasS.height = '100%'; - canvasS.top = '0'; - canvasS.left = '0'; - canvasS.padding = '0'; - canvasS.margin = '0'; - editor.trigger('change:canvasOffset'); + em && em.clearSelection(); + this.toggleSortCursor(1); + em && em.trigger('sorter:drag:start', src, srcModel); }, - stop: function stop(editor, sender) { - var panels = this.getPanels(editor); - editor.runCommand('sw-visibility'); - editor.getModel().runDefault(); - panels.style.display = 'block'; - var canvas = editor.Canvas.getElement(); - canvas.setAttribute('style', ''); - if (this.helper) { - this.helper.style.display = 'none'; - } - editor.trigger('change:canvasOffset'); - this.tglPointers(editor, 1); - } -}; -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(1))) - -/***/ }), -/* 208 */ -/***/ (function(module, exports, __webpack_require__) { -"use strict"; + /** + * Get the model from HTMLElement target + * @return {Model|null} + */ + getTargetModel: function getTargetModel(el) { + var elem = el || this.target; + return $(elem).data('model'); + }, + /** + * Get the model of the current source element (element to drag) + * @return {Model} + */ + getSourceModel: function getSourceModel(source) { + var _this = this; -module.exports = { - run: function run(editor, sender, opts) { - var opt = opts || {}; - var el = opt.el || ''; - var canvas = editor.Canvas; - var canvasResizer = this.canvasResizer; - var options = opt.options || {}; - var canvasView = canvas.getCanvasView(); - options.ratioDefault = 1; - options.appendTo = canvas.getResizerEl(); - options.prefix = editor.getConfig().stylePrefix; - options.posFetcher = canvasView.getElementPos.bind(canvasView); - options.mousePosFetcher = canvas.getMouseRelativePos; + var _ref = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}, + target = _ref.target, + _ref$avoidChildren = _ref.avoidChildren, + avoidChildren = _ref$avoidChildren === void 0 ? 1 : _ref$avoidChildren; - // Create the resizer for the canvas if not yet created - if (!canvasResizer || opt.forceNew) { - this.canvasResizer = editor.Utils.Resizer.init(options); - canvasResizer = this.canvasResizer; - } + var em = this.em, + eV = this.eV; + var src = source || eV; + var dropModel = this.dropModel, + dropContent = this.dropContent; - canvasResizer.setOptions(options); - canvasResizer.focus(el); - return canvasResizer; - }, - stop: function stop() { - var resizer = this.canvasResizer; - resizer && resizer.blur(); - } -}; + var isTextable = function isTextable(src) { + return src && target && src.opt && src.opt.avoidChildren && _this.isTextableActive(src, target); + }; -/***/ }), -/* 209 */ -/***/ (function(module, exports, __webpack_require__) { + if (dropContent && em) { + if (isTextable(dropModel)) { + dropModel = null; + } -"use strict"; + if (!dropModel) { + var comps = em.get('DomComponents').getComponents(); + var opts = { + avoidChildren: avoidChildren, + avoidStore: 1, + avoidUpdateStyle: 1 + }; + var tempModel = comps.add(dropContent, _objectSpread({}, opts, { + temporary: 1 + })); + dropModel = comps.remove(tempModel, opts); + dropModel = dropModel instanceof Array ? dropModel[0] : dropModel; + this.dropModel = dropModel; + + if (isTextable(dropModel)) { + return this.getSourceModel(src, { + target: target, + avoidChildren: 0 + }); + } + } + return dropModel; + } -module.exports = { - run: function run(editor, sender, opts) { - var el = opts && opts.el || ''; - var canvas = editor.Canvas; - var dragger = this.dragger; - var options = opts.options || {}; - var canvasView = canvas.getCanvasView(); - options.prefix = editor.getConfig().stylePrefix; - options.mousePosFetcher = canvas.getMouseRelativePos; - options.posFetcher = canvasView.getElementPos.bind(canvasView); + return src && $(src).data('model'); + }, - // Create the resizer for the canvas if not yet created - if (!dragger) { - dragger = editor.Utils.Dragger.init(options); - this.dragger = dragger; + /** + * Highlight target + * @param {Model|null} model + */ + selectTargetModel: function selectTargetModel(model) { + if (model instanceof backbone__WEBPACK_IMPORTED_MODULE_1___default.a.Collection) { + return; } - dragger.setOptions(options); - dragger.focus(el); + var prevModel = this.targetModel; - if (options.event) { - dragger.start(options.event); + if (prevModel) { + prevModel.set('status', ''); } - return dragger; + if (model && model.set) { + model.set('status', 'selected-parent'); + this.targetModel = model; + } }, - stop: function stop() { - if (this.canvasResizer) this.canvasResizer.blur(); - } -}; -/***/ }), -/* 210 */ -/***/ (function(module, exports, __webpack_require__) { + /** + * During move + * @param {Event} e + * */ + onMove: function onMove(e) { + var ev = e; + var em = this.em, + onMoveClb = this.onMoveClb, + plh = this.plh; + this.moved = 1; // Turn placeholder visibile -"use strict"; + var dsp = plh.style.display; + if (!dsp || dsp === 'none') plh.style.display = 'block'; // Cache all necessary positions + + var eO = this.offset(this.el); + this.elT = this.wmargin ? Math.abs(eO.top) : eO.top; + this.elL = this.wmargin ? Math.abs(eO.left) : eO.left; + var rY = e.pageY - this.elT + this.el.scrollTop; + var rX = e.pageX - this.elL + this.el.scrollLeft; + if (this.canvasRelative && em) { + var mousePos = em.get('Canvas').getMouseRelativeCanvas(e); + rX = mousePos.x; + rY = mousePos.y; + } -/** - * * [add](#add) - * * [get](#get) - * * [getAll](#getall) - * * [getAllVisible](#getallvisible) - * * [getCategories](#getcategories) - * * [getContainer](#getcontainer) - * * [render](#render) - * - * Block manager helps managing various, draggable, piece of contents that could be easily reused inside templates. - * - * Before using methods you should get first the module from the editor instance, in this way: - * - * ```js - * var blockManager = editor.BlockManager; - * ``` - * - * @module BlockManager - * @param {Object} config Configurations - * @param {Array} [config.blocks=[]] Default blocks - * @example - * ... - * { - * blocks: [ - * {id:'h1-block' label: 'Heading', content:'

...

'}, - * ... - * ], - * } - * ... - */ -module.exports = function () { - var c = {}, - defaults = __webpack_require__(211), - Blocks = __webpack_require__(212), - BlockCategories = __webpack_require__(214), - BlocksView = __webpack_require__(215); - var blocks, blocksVisible, blocksView; - var categories = []; + this.rX = rX; + this.rY = rY; + this.eventMove = e; //var targetNew = this.getTargetFromEl(e.target); - return { + var sourceModel = this.getSourceModel(); + var dims = this.dimsFromTarget(e.target, rX, rY); + var target = this.target; + var targetModel = this.getTargetModel(target); + this.selectTargetModel(targetModel); + if (!targetModel) plh.style.display = 'none'; + this.lastDims = dims; + var pos = this.findPosition(dims, rX, rY); - /** - * Name of the module - * @type {String} - * @private - */ - name: 'BlockManager', + if (this.isTextableActive(sourceModel, targetModel)) { + this.activeTextModel = targetModel; + this.setContentEditable(targetModel, true); + plh.style.display = 'none'; + this.lastPos = pos; + this.updateTextViewCursorPosition(ev); + } else { + this.disableTextable(); + this.activeTextModel = null; // If there is a significant changes with the pointer - /** - * Initialize module. Automatically called with a new instance of the editor - * @param {Object} config Configurations - * @return {this} - * @private - */ - init: function init(config) { - c = config || {}; - var em = c.em; + if (!this.lastPos || this.lastPos.index != pos.index || this.lastPos.method != pos.method) { + this.movePlaceholder(this.plh, dims, pos, this.prevTargetDim); + if (!this.$plh) this.$plh = $(this.plh); // With canvasRelative the offset is calculated automatically for + // each element - for (var name in defaults) { - if (!(name in c)) { - c[name] = defaults[name]; + if (!this.canvasRelative) { + if (this.offTop) this.$plh.css('top', '+=' + this.offTop + 'px'); + if (this.offLeft) this.$plh.css('left', '+=' + this.offLeft + 'px'); } + + this.lastPos = pos; } + } - // Global blocks collection - blocks = new Blocks([]); - blocksVisible = new Blocks([]); - categories = new BlockCategories(), blocksView = new BlocksView({ - // Visible collection - collection: blocksVisible, - categories: categories - }, c); + Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isFunction"])(onMoveClb) && onMoveClb(e); + em && em.trigger('sorter:drag', { + target: target, + targetModel: targetModel, + sourceModel: sourceModel, + dims: dims, + pos: pos, + x: rX, + y: rY + }); + }, + isTextableActive: function isTextableActive(src, trg) { + return src && src.get && src.get('textable') && trg && trg.is('text'); + }, + disableTextable: function disableTextable() { + var activeTextModel = this.activeTextModel; + activeTextModel && activeTextModel.getView().disableEditing(); + }, - // Setup the sync between the global and public collections - blocks.listenTo(blocks, 'add', function (model) { - blocksVisible.add(model); - em && em.trigger('block:add', model); - }); + /** + * Returns true if the elements is in flow, so is not in flow where + * for example the component is with float:left + * @param {HTMLElement} el + * @param {HTMLElement} parent + * @return {Boolean} + * @private + * */ + isInFlow: function isInFlow(el, parent) { + if (!el) return false; + parent = parent || document.body; + var ch = -1, + h; + var elem = el; + h = elem.offsetHeight; + if ( + /*h < ch || */ + !this.styleInFlow(elem, parent)) return false;else return true; + }, - blocks.listenTo(blocks, 'remove', function (model) { - blocksVisible.remove(model); - em && em.trigger('block:remove', model); - }); + /** + * Check if el has style to be in flow + * @param {HTMLElement} el + * @param {HTMLElement} parent + * @return {Boolean} + * @private + */ + styleInFlow: function styleInFlow(el, parent) { + if (Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["isTextNode"])(el)) return; + var style = el.style || {}; + var $el = $(el); + var $parent = parent && $(parent); + if (style.overflow && style.overflow !== 'visible') return; + if ($el.css('float') !== 'none') return; + if ($parent && $parent.css('display') == 'flex' && $parent.css('flex-direction') !== 'column') return; - blocks.listenTo(blocks, 'reset', function (coll) { - blocksVisible.reset(coll.models); - }); + switch (style.position) { + case 'static': + case 'relative': + case '': + break; - return this; - }, + default: + return; + } + + switch (el.tagName) { + case 'TR': + case 'TBODY': + case 'THEAD': + case 'TFOOT': + return true; + } + switch ($el.css('display')) { + case 'block': + case 'list-item': + case 'table': + case 'flex': + return true; + } - /** - * Get configuration object - * @return {Object} - */ - getConfig: function getConfig() { - return c; - }, + return; + }, + /** + * Check if the target is valid with the actual source + * @param {HTMLElement} trg + * @return {Boolean} + */ + validTarget: function validTarget(trg, src) { + var trgModel = this.getTargetModel(trg); + var srcModel = this.getSourceModel(src, { + target: trgModel + }); + src = srcModel && srcModel.view && srcModel.view.el; + trg = trgModel && trgModel.view && trgModel.view.el; + var result = { + valid: true, + src: src, + srcModel: srcModel, + trg: trg, + trgModel: trgModel + }; - /** - * Load default blocks if the collection is empty - */ - onLoad: function onLoad() { - var blocks = this.getAll(); - !blocks.length && blocks.reset(c.blocks); - }, + if (!src || !trg) { + result.valid = false; + return result; + } // check if the source is draggable in target - /** - * Add new block to the collection. - * @param {string} id Block id - * @param {Object} opts Options - * @param {string} opts.label Name of the block - * @param {string} opts.content HTML content - * @param {string|Object} opts.category Group the block inside a catgegory. - * You should pass objects with id property, eg: - * {id: 'some-uid', label: 'My category'} - * The string will be converted in: - * 'someid' => {id: 'someid', label: 'someid'} - * @param {Object} [opts.attributes={}] Block attributes - * @return {Block} Added block - * @example - * blockManager.add('h1-block', { - * label: 'Heading', - * content: '

Put your title here

', - * category: 'Basic', - * attributes: { - * title: 'Insert h1 block' - * } - * }); - */ - add: function add(id, opts) { - var obj = opts || {}; - obj.id = id; - return blocks.add(obj); - }, + var draggable = srcModel.get('draggable'); + draggable = draggable instanceof Array ? draggable.join(', ') : draggable; + result.dragInfo = draggable; + draggable = Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isString"])(draggable) ? this.matches(trg, draggable) : draggable; + result.draggable = draggable; // Check if the target could accept the source + var droppable = trgModel.get('droppable'); + droppable = droppable instanceof backbone__WEBPACK_IMPORTED_MODULE_1___default.a.Collection ? 1 : droppable; + droppable = droppable instanceof Array ? droppable.join(', ') : droppable; + result.dropInfo = droppable; + droppable = Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isString"])(droppable) ? this.matches(src, droppable) : droppable; + droppable = draggable && this.isTextableActive(srcModel, trgModel) ? 1 : droppable; + result.droppable = droppable; - /** - * Return the block by id - * @param {string} id Block id - * @example - * const block = blockManager.get('h1-block'); - * console.log(JSON.stringify(block)); - * // {label: 'Heading', content: '

Put your ...', ...} - */ - get: function get(id) { - return blocks.get(id); - }, + if (!droppable || !draggable) { + result.valid = false; + } + return result; + }, - /** - * Return all blocks - * @return {Collection} - * @example - * const blocks = blockManager.getAll(); - * console.log(JSON.stringify(blocks)); - * // [{label: 'Heading', content: '

Put your ...'}, ...] - */ - getAll: function getAll() { - return blocks; - }, + /** + * Get dimensions of nodes relative to the coordinates + * @param {HTMLElement} target + * @param {number} rX Relative X position + * @param {number} rY Relative Y position + * @return {Array} + */ + dimsFromTarget: function dimsFromTarget(target, rX, rY) { + var em = this.em; + var dims = []; + if (!target) { + return dims; + } // Select the first valuable target - /** - * Return the visible collection, which containes blocks actually rendered - * @return {Collection} - */ - getAllVisible: function getAllVisible() { - return blocksVisible; - }, + if (!this.matches(target, "".concat(this.itemSel, ", ").concat(this.containerSel))) { + target = this.closest(target, this.itemSel); + } // If draggable is an array the target will be one of those - /** - * Remove a block by id - * @param {string} id Block id - * @return {Block} Removed block - */ - remove: function remove(id) { - return blocks.remove(id); - }, + if (this.draggable instanceof Array) { + target = this.closest(target, this.draggable.join(',')); + } - /** - * Get all available categories. - * It's possible to add categories only within blocks via 'add()' method - * @return {Array|Collection} - */ - getCategories: function getCategories() { - return categories; - }, + if (!target) { + return dims; + } // Check if the target is different from the previous one - /** - * Return the Blocks container element - * @return {HTMLElement} - */ - getContainer: function getContainer() { - return blocksView.el; - }, + if (this.prevTarget && this.prevTarget != target) { + this.prevTarget = null; + } // New target found - /** - * Render blocks - * @param {Array} blocks Blocks to render, without the argument will render - * all global blocks - * @example - * // Render all blocks (inside the global collection) - * blockManager.render(); - * - * // Render new set of blocks - * const blocks = blockManager.getAll(); - * blockManager.render(blocks.filter( - * block => block.get('category') == 'sections' - * )); - * // Or a new set from an array - * blockManager.render([ - * {label: 'Label text', content: '
Content
'} - * ]); - * - * // Back to blocks from the global collection - * blockManager.render(); - */ - render: function render(blocks) { - var toRender = blocks || this.getAll().models; + if (!this.prevTarget) { + this.targetP = this.closest(target, this.containerSel); // Check if the source is valid with the target - if (!blocksView.rendered) { - blocksView.render(); - blocksView.rendered = 1; - } + var validResult = this.validTarget(target); + em && em.trigger('sorter:drag:validation', validResult); - blocksView.collection.reset(toRender); - } - }; -}; + if (!validResult.valid && this.targetP) { + return this.dimsFromTarget(this.targetP, rX, rY); + } -/***/ }), -/* 211 */ -/***/ (function(module, exports, __webpack_require__) { + this.prevTarget = target; + this.prevTargetDim = this.getDim(target); + this.cacheDimsP = this.getChildrenDim(this.targetP); + this.cacheDims = this.getChildrenDim(target); + } // If the target is the previous one will return the cached dims -"use strict"; + if (this.prevTarget == target) dims = this.cacheDims; // Target when I will drop element to sort -module.exports = { + this.target = this.prevTarget; // Generally, on any new target the poiner enters inside its area and + // triggers nearBorders(), so have to take care of this - blocks: [], + if (this.nearBorders(this.prevTargetDim, rX, rY) || !this.nested && !this.cacheDims.length) { + var targetParent = this.targetP; - appendTo: '' + if (targetParent && this.validTarget(targetParent).valid) { + dims = this.cacheDimsP; + this.target = targetParent; + } + } -}; + this.lastPos = null; + return dims; + }, -/***/ }), -/* 212 */ -/***/ (function(module, exports, __webpack_require__) { + /** + * Get valid target from element + * This method should replace dimsFromTarget() + * @param {HTMLElement} el + * @return {HTMLElement} + */ + getTargetFromEl: function getTargetFromEl(el) { + var target = el; + var targetParent; + var targetPrev = this.targetPrev; + var em = this.em; + var containerSel = this.containerSel; + var itemSel = this.itemSel; // Select the first valuable target -"use strict"; + if (!this.matches(target, "".concat(itemSel, ", ").concat(containerSel))) { + target = this.closest(target, itemSel); + } // If draggable is an array the target will be one of those + // TODO check if this options is used somewhere -var Backbone = __webpack_require__(0); -var Block = __webpack_require__(213); + if (this.draggable instanceof Array) { + target = this.closest(target, this.draggable.join(',')); + } // Check if the target is different from the previous one -module.exports = Backbone.Collection.extend({ - model: Block -}); -/***/ }), -/* 213 */ -/***/ (function(module, exports, __webpack_require__) { + if (targetPrev && targetPrev != target) { + this.targetPrev = ''; + } // New target found -"use strict"; + if (!this.targetPrev) { + targetParent = this.closest(target, containerSel); // If the current target is not valid (src/trg reasons) try with + // the parent one (if exists) -var Backbone = __webpack_require__(0); -var Category = __webpack_require__(57); + var validResult = this.validTarget(target); + em && em.trigger('sorter:drag:validation', validResult); -module.exports = Backbone.Model.extend({ + if (!validResult.valid && targetParent) { + return this.getTargetFromEl(targetParent); + } - defaults: { - label: '', - content: '', - category: '', - attributes: {} - }, + this.targetPrev = target; + } // Generally, on any new target the poiner enters inside its area and + // triggers nearBorders(), so have to take care of this - initialize: function initialize() { - var opts = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; - var category = this.get('category'); + if (this.nearElBorders(target)) { + targetParent = this.closest(target, containerSel); - if (category) { - if (typeof category == 'string') { - var catObj = new Category({ - id: category, - label: category - }); + if (targetParent && this.validTarget(targetParent).valid) { + target = targetParent; } } - } -}); -/***/ }), -/* 214 */ -/***/ (function(module, exports, __webpack_require__) { + return target; + }, -"use strict"; + /** + * Check if the current pointer is neare to element borders + * @return {Boolen} + */ + nearElBorders: function nearElBorders(el) { + var off = 10; + var rect = el.getBoundingClientRect(); + var body = el.ownerDocument.body; + var _this$getCurrentPos = this.getCurrentPos(), + x = _this$getCurrentPos.x, + y = _this$getCurrentPos.y; -var Backbone = __webpack_require__(0); + var top = rect.top + body.scrollTop; + var left = rect.left + body.scrollLeft; + var width = rect.width; + var height = rect.height; -module.exports = Backbone.Collection.extend({ - model: __webpack_require__(57) -}); + if (y < top + off || // near top edge + y > top + height - off || // near bottom edge + x < left + off || // near left edge + x > left + width - off // near right edge + ) { + return 1; + } + }, + getCurrentPos: function getCurrentPos() { + var ev = this.eventMove; + var x = ev.pageX || 0; + var y = ev.pageY || 0; + return { + x: x, + y: y + }; + }, -/***/ }), -/* 215 */ -/***/ (function(module, exports, __webpack_require__) { + /** + * Returns dimensions and positions about the element + * @param {HTMLElement} el + * @return {Array} + */ + getDim: function getDim(el) { + var em = this.em, + canvasRelative = this.canvasRelative; + var top, left, height, width; -"use strict"; -/* WEBPACK VAR INJECTION */(function(_) { + if (canvasRelative && em) { + var canvas = em.get('Canvas'); + var pos = canvas.getElementPos(el); + var elOffsets = canvas.getElementOffsets(el); + top = pos.top - elOffsets.marginTop; + left = pos.left - elOffsets.marginLeft; + height = pos.height + elOffsets.marginTop + elOffsets.marginBottom; + width = pos.width + elOffsets.marginLeft + elOffsets.marginRight; + } else { + var o = this.offset(el); + top = this.relative ? el.offsetTop : o.top - (this.wmargin ? -1 : 1) * this.elT; + left = this.relative ? el.offsetLeft : o.left - (this.wmargin ? -1 : 1) * this.elL; + height = el.offsetHeight; + width = el.offsetWidth; + } -var Backbone = __webpack_require__(0); -var BlockView = __webpack_require__(216); -var CategoryView = __webpack_require__(217); + return [top, left, height, width]; + }, -module.exports = Backbone.View.extend({ - initialize: function initialize(opts, config) { - _.bindAll(this, 'getSorter', 'onDrag', 'onDrop'); - this.config = config || {}; - this.categories = opts.categories || ''; - this.renderedCategories = []; - var ppfx = this.config.pStylePrefix || ''; - this.ppfx = ppfx; - this.noCatClass = ppfx + 'blocks-no-cat'; - this.blockContClass = ppfx + 'blocks-c'; - this.catsClass = ppfx + 'block-categories'; - var coll = this.collection; - this.listenTo(coll, 'add', this.addTo); - this.listenTo(coll, 'reset', this.render); - this.em = this.config.em; - this.tac = 'test-tac'; - this.grabbingCls = this.ppfx + 'grabbing'; + /** + * Get children dimensions + * @param {HTMLELement} el Element root + * @retun {Array} + * */ + getChildrenDim: function getChildrenDim(trg) { + var _this2 = this; - if (this.em) { - this.config.getSorter = this.getSorter; - this.canvas = this.em.get('Canvas'); + var dims = []; + if (!trg) return dims; // Get children based on getChildrenContainer + + var trgModel = this.getTargetModel(trg); + + if (trgModel && trgModel.view && !this.ignoreViewChildren) { + trg = trgModel.view.getChildrenContainer(); } - }, + Object(underscore__WEBPACK_IMPORTED_MODULE_2__["each"])(trg.children, function (el, i) { + var model = Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["getModel"])(el, $); + var elIndex = model && model.index ? model.index() : i; + + if (!Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["isTextNode"])(el) && !_this2.matches(el, _this2.itemSel)) { + return; + } + + var dim = _this2.getDim(el); + + var dir = _this2.direction; + if (dir == 'v') dir = true;else if (dir == 'h') dir = false;else dir = _this2.isInFlow(el, trg); + dim.push(dir, el, elIndex); + dims.push(dim); + }); + return dims; + }, /** - * Get sorter - * @private - */ - getSorter: function getSorter() { - if (!this.em) return; - if (!this.sorter) { - var utils = this.em.get('Utils'); - var canvas = this.canvas; - this.sorter = new utils.Sorter({ - container: canvas.getBody(), - placer: canvas.getPlacerEl(), - containerSel: '*', - itemSel: '*', - pfx: this.ppfx, - onStart: this.onDrag, - onEndMove: this.onDrop, - onMove: this.onMove, - document: canvas.getFrameEl().contentDocument, - direction: 'a', - wmargin: 1, - nested: 1, - em: this.em, - canvasRelative: 1 - }); - } - return this.sorter; + * Check if the coordinates are near to the borders + * @param {Array} dim + * @param {number} rX Relative X position + * @param {number} rY Relative Y position + * @return {Boolean} + * */ + nearBorders: function nearBorders(dim, rX, rY) { + var result = 0; + var off = this.borderOffset; + var x = rX || 0; + var y = rY || 0; + var t = dim[0]; + var l = dim[1]; + var h = dim[2]; + var w = dim[3]; + if (t + off > y || y > t + h - off || l + off > x || x > l + w - off) result = 1; + return !!result; }, + /** + * Find the position based on passed dimensions and coordinates + * @param {Array} dims Dimensions of nodes to parse + * @param {number} posX X coordindate + * @param {number} posY Y coordindate + * @retun {Object} + * */ + findPosition: function findPosition(dims, posX, posY) { + var result = { + index: 0, + indexEl: 0, + method: 'before' + }; + var leftLimit = 0, + xLimit = 0, + dimRight = 0, + yLimit = 0, + xCenter = 0, + yCenter = 0, + dimDown = 0, + dim = 0; // Each dim is: Top, Left, Height, Width + + for (var i = 0, len = dims.length; i < len; i++) { + dim = dims[i]; // Right position of the element. Left + Width - /** - * Callback when block is on drag - * @private - */ - onDrag: function onDrag(e) { - this.em.stopDefault(); - this.em.trigger('block:drag:start', e); - }, - onMove: function onMove(e) { - this.em.trigger('block:drag:move', e); - }, + dimRight = dim[1] + dim[3]; // Bottom position of the element. Top + Height + dimDown = dim[0] + dim[2]; // X center position of the element. Left + (Width / 2) - /** - * Callback when block is dropped - * @private - */ - onDrop: function onDrop(model) { - var em = this.em; - em.runDefault(); + xCenter = dim[1] + dim[3] / 2; // Y center position of the element. Top + (Height / 2) - if (model && model.get) { - if (model.get('activeOnRender')) { - model.trigger('active'); - model.set('activeOnRender', 0); - } + yCenter = dim[0] + dim[2] / 2; // Skip if over the limits - em.trigger('block:drag:stop', model); + if (xLimit && dim[1] > xLimit || yLimit && yCenter >= yLimit || // >= avoid issue with clearfixes + leftLimit && dimRight < leftLimit) continue; + result.index = i; + result.indexEl = dim[6]; // If it's not in flow (like 'float' element) + + if (!dim[4]) { + if (posY < dimDown) yLimit = dimDown; //If x lefter than center + + if (posX < xCenter) { + xLimit = xCenter; + result.method = 'before'; + } else { + leftLimit = xCenter; + result.method = 'after'; + } + } else { + // If y upper than center + if (posY < yCenter) { + result.method = 'before'; + break; + } else result.method = 'after'; // After last element + + } } - }, + return result; + }, /** - * Add new model to the collection - * @param {Model} model - * @private + * Updates the position of the placeholder + * @param {HTMLElement} phl + * @param {Array} dims + * @param {Object} pos Position object + * @param {Array} trgDim target dimensions * */ - addTo: function addTo(model) { - this.add(model); - }, + movePlaceholder: function movePlaceholder(plh, dims, pos, trgDim) { + var marg = 0, + t = 0, + l = 0, + w = 0, + h = 0, + un = 'px', + margI = 5, + brdCol = '#62c462', + brd = 3, + method = pos.method; + var elDim = dims[pos.index]; + plh.style.borderColor = 'transparent ' + brdCol; + plh.style.borderWidth = brd + un + ' ' + (brd + 2) + un; + plh.style.margin = '-' + brd + 'px 0 0'; + + if (elDim) { + // If it's not in flow (like 'float' element) + if (!elDim[4]) { + w = 'auto'; + h = elDim[2] - marg * 2 + un; + t = elDim[0] + marg; + l = method == 'before' ? elDim[1] - marg : elDim[1] + elDim[3] - marg; + plh.style.borderColor = brdCol + ' transparent'; + plh.style.borderWidth = brd + 2 + un + ' ' + brd + un; + plh.style.margin = '0 0 0 -' + brd + 'px'; + } else { + w = elDim[3] + un; + h = 'auto'; + t = method == 'before' ? elDim[0] - marg : elDim[0] + elDim[2] - marg; + l = elDim[1]; + } + } else { + if (!this.nested) { + plh.style.display = 'none'; + return; + } + + if (trgDim) { + t = trgDim[0] + margI; + l = trgDim[1] + margI; + w = parseInt(trgDim[3]) - margI * 2 + un; + h = 'auto'; + } + } + plh.style.top = t + un; + plh.style.left = l + un; + if (w) plh.style.width = w; + if (h) plh.style.height = h; + }, /** - * Render new model inside the view - * @param {Model} model - * @param {Object} fragment Fragment collection - * @private + * Leave item + * @param event + * + * @return void * */ - add: function add(model, fragment) { - var frag = fragment || null; - var view = new BlockView({ - model: model, - attributes: model.get('attributes') - }, this.config); - var rendered = view.render().el; - var category = model.get('category'); + endMove: function endMove(e) { + var _this3 = this; - // Check for categories - if (category && this.categories) { - if (typeof category == 'string') { - category = { - id: category, - label: category - }; - } + var moved = [null]; + var docs = this.getDocuments(); + var container = this.getContainerEl(); + var onEndMove = this.onEndMove; + var target = this.target, + lastPos = this.lastPos; + Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["off"])(container, 'mousemove dragover', this.onMove); + Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["off"])(docs, 'mouseup dragend touchend', this.endMove); + Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["off"])(docs, 'keydown', this.rollback); + this.plh.style.display = 'none'; + var src = this.eV; - var catModel = this.categories.add(category); - var catId = catModel.get('id'); - var catView = this.renderedCategories[catId]; - var categories = this.getCategoriesEl(); - model.set('category', catModel); + if (src && this.selectOnEnd) { + var srcModel = this.getSourceModel(); - if (!catView && categories) { - catView = new CategoryView({ - model: catModel - }, this.config).render(); - this.renderedCategories[catId] = catView; - categories.appendChild(catView.el); + if (srcModel && srcModel.set) { + srcModel.set('status', ''); + srcModel.set('status', 'selected'); } - - catView && catView.append(rendered); - return; } - if (frag) frag.appendChild(rendered);else this.append(rendered); - }, - getCategoriesEl: function getCategoriesEl() { - if (!this.catsEl) { - this.catsEl = this.el.querySelector('.' + this.catsClass); + if (this.moved) { + var toMove = this.toMove; + var toMoveArr = Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isArray"])(toMove) ? toMove : toMove ? [toMove] : [src]; + toMoveArr.forEach(function (model) { + moved.push(_this3.move(target, model, lastPos)); + }); } - return this.catsEl; - }, - getBlocksEl: function getBlocksEl() { - if (!this.blocksEl) { - this.blocksEl = this.el.querySelector('.' + this.noCatClass + ' .' + this.blockContClass); + if (this.plh) this.plh.style.display = 'none'; + var dragHelper = this.dragHelper; + + if (dragHelper) { + dragHelper.parentNode.removeChild(dragHelper); + this.dragHelper = null; } - return this.blocksEl; - }, - append: function append(el) { - var blocks = this.getBlocksEl(); - blocks && blocks.appendChild(el); + this.disableTextable(); + this.selectTargetModel(); + this.toggleSortCursor(); + this.toMove = null; + Object(underscore__WEBPACK_IMPORTED_MODULE_2__["isFunction"])(onEndMove) && moved.forEach(function (m) { + return onEndMove(m, _this3); + }); }, - render: function render() { - var _this = this; - var frag = document.createDocumentFragment(); - this.catsEl = null; - this.blocksEl = null; - this.renderedCategories = []; - this.el.innerHTML = '\n
\n
\n
\n
\n '; + /** + * Move component to new position + * @param {HTMLElement} dst Destination target + * @param {HTMLElement} src Element to move + * @param {Object} pos Object with position coordinates + * */ + move: function move(dst, src, pos) { + var em = this.em, + activeTextModel = this.activeTextModel, + dropContent = this.dropContent; + var srcEl = Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["getElement"])(src); + em && em.trigger('component:dragEnd:before', dst, srcEl, pos); // @depricated - this.collection.each(function (model) { - return _this.add(model, frag); - }); - this.append(frag); - this.$el.addClass(this.blockContClass + 's'); - return this; - } -}); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(1))) + var warns = []; + var index = pos.indexEl; + var modelToDrop, modelTemp, created; + var validResult = this.validTarget(dst, srcEl); + var targetCollection = $(dst).data('collection'); + var model = validResult.srcModel; + var droppable = validResult.droppable; + var draggable = validResult.draggable; + var dropInfo = validResult.dropInfo; + var dragInfo = validResult.dragInfo; + var trgModel = validResult.trgModel; + droppable = trgModel instanceof backbone__WEBPACK_IMPORTED_MODULE_1___default.a.Collection ? 1 : droppable; + var isTextableActive = this.isTextableActive(model, trgModel); -/***/ }), -/* 216 */ -/***/ (function(module, exports, __webpack_require__) { + if (targetCollection && droppable && draggable) { + index = pos.method === 'after' ? index + 1 : index; + var opts = { + at: index, + noIncrement: 1 + }; -"use strict"; -/* WEBPACK VAR INJECTION */(function(Backbone) { + if (!dropContent) { + // Putting `avoidStore` here will make the UndoManager behave wrong + opts.temporary = 1; + modelTemp = targetCollection.add({}, _objectSpread({}, opts)); -var _mixins = __webpack_require__(2); + if (model.collection) { + modelToDrop = model.collection.remove(model, { + temporary: 1 + }); + } + } else { + modelToDrop = dropContent; + opts.silent = false; + opts.avoidUpdateStyle = 1; + } -module.exports = Backbone.View.extend({ + if (isTextableActive) { + var viewActive = activeTextModel.getView(); + activeTextModel.trigger('active'); + var activeRte = viewActive.activeRte; + var modelEl = model.getEl(); + delete model.opt.temporary; + model.getView().render(); + modelEl.setAttribute('data-gjs-textable', 'true'); + var outerHTML = modelEl.outerHTML; + activeRte.insertHTML && activeRte.insertHTML(outerHTML); + } else { + created = targetCollection.add(modelToDrop, opts); + } - events: { - mousedown: 'startDrag' - }, + if (!dropContent) { + targetCollection.remove(modelTemp); + } else { + this.dropContent = null; + } // This will cause to recalculate children dimensions - initialize: function initialize(o) { - var config = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; - this.config = config; - this.endDrag = this.endDrag.bind(this); - this.ppfx = config.pStylePrefix || ''; - this.listenTo(this.model, 'destroy remove', this.remove); - }, + this.prevTarget = null; + } else { + if (!targetCollection) { + warns.push('Target collection not found'); + } + if (!droppable) { + warns.push("Target is not droppable, accepts [".concat(dropInfo, "]")); + } - /** - * Start block dragging - * @private - */ - startDrag: function startDrag(e) { - //Right or middel click - if (e.button !== 0) { - return; - } + if (!draggable) { + warns.push("Component not draggable, acceptable by [".concat(dragInfo, "]")); + } - if (!this.config.getSorter) { - return; + console.warn('Invalid target position: ' + warns.join(', ')); } - this.config.em.refreshCanvas(); - var sorter = this.config.getSorter(); - sorter.setDragHelper(this.el, e); - sorter.setDropContent(this.model.get('content')); - sorter.startSort(this.el); - (0, _mixins.on)(document, 'mouseup', this.endDrag); - }, + em && em.trigger('component:dragEnd', targetCollection, modelToDrop, warns); // @depricated + em && em.trigger('sorter:drag:end', { + targetCollection: targetCollection, + modelToDrop: modelToDrop, + warns: warns, + validResult: validResult, + dst: dst, + srcEl: srcEl + }); + return created; + }, /** - * Drop block - * @private - */ - endDrag: function endDrag(e) { - (0, _mixins.off)(document, 'mouseup', this.endDrag); - var sorter = this.config.getSorter(); + * Rollback to previous situation + * @param {Event} + * @param {Bool} Indicates if rollback in anycase + * */ + rollback: function rollback(e) { + Object(utils_mixins__WEBPACK_IMPORTED_MODULE_3__["off"])(this.getDocuments(), 'keydown', this.rollback); + var key = e.which || e.keyCode; - // After dropping the block in the canvas the mouseup event is not yet - // triggerd on 'this.doc' and so clicking outside, the sorter, tries to move - // things (throws false positives). As this method just need to drop away - // the block helper I use the trick of 'moved = 0' to void those errors. - sorter.moved = 0; - sorter.endMove(); - }, - render: function render() { - var el = this.el; - var pfx = this.ppfx; - var className = pfx + 'block'; - el.className += ' ' + className + ' ' + pfx + 'one-bg ' + pfx + 'four-color-h'; - el.innerHTML = '
' + this.model.get('label') + '
'; - return this; + if (key == 27) { + this.moved = 0; + this.endMove(); + } } -}); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(0))) +})); /***/ }), -/* 217 */ -/***/ (function(module, exports, __webpack_require__) { - -"use strict"; -/* WEBPACK VAR INJECTION */(function(_) { - -var Backbone = __webpack_require__(0); -module.exports = Backbone.View.extend({ +/***/ "./src/utils/dom.js": +/*!**************************!*\ + !*** ./src/utils/dom.js ***! + \**************************/ +/*! exports provided: empty, replaceWith, appendAtIndex, appendVNodes */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - template: _.template('\n
\n \n <%= label %>\n
\n
\n '), - - events: {}, - - initialize: function initialize() { - var o = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {}; - var config = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; - - this.config = config; - var pfx = this.config.pStylePrefix || ''; - this.pfx = pfx; - this.caretR = 'fa fa-caret-right'; - this.caretD = 'fa fa-caret-down'; - this.iconClass = pfx + 'caret-icon'; - this.activeClass = pfx + 'open'; - this.className = pfx + 'block-category'; - this.events['click .' + pfx + 'title'] = 'toggle'; - this.listenTo(this.model, 'change:open', this.updateVisibility); - this.delegateEvents(); - }, - updateVisibility: function updateVisibility() { - if (this.model.get('open')) this.open();else this.close(); - }, - open: function open() { - this.el.className = this.className + ' ' + this.activeClass; - this.getIconEl().className = this.iconClass + ' ' + this.caretD; - this.getBlocksEl().style.display = ''; - }, - close: function close() { - this.el.className = this.className; - this.getIconEl().className = this.iconClass + ' ' + this.caretR; - this.getBlocksEl().style.display = 'none'; - }, - toggle: function toggle() { - var model = this.model; - model.set('open', !model.get('open')); - }, - getIconEl: function getIconEl() { - if (!this.iconEl) { - this.iconEl = this.el.querySelector('.' + this.iconClass); - } +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "empty", function() { return empty; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "replaceWith", function() { return replaceWith; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "appendAtIndex", function() { return appendAtIndex; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "appendVNodes", function() { return appendVNodes; }); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_0__); +// DOM helpers + +var KEY_TAG = 'tag'; +var KEY_ATTR = 'attributes'; +var KEY_CHILD = 'children'; +var empty = function empty(node) { + while (node.firstChild) { + node.removeChild(node.firstChild); + } +}; +var replaceWith = function replaceWith(oldEl, newEl) { + oldEl.parentNode.replaceChild(newEl, oldEl); +}; +var appendAtIndex = function appendAtIndex(parent, child, index) { + var childNodes = parent.childNodes; + var total = childNodes.length; + var at = Object(underscore__WEBPACK_IMPORTED_MODULE_0__["isUndefined"])(index) ? total : index; - return this.iconEl; - }, - getBlocksEl: function getBlocksEl() { - if (!this.blocksEl) { - this.blocksEl = this.el.querySelector('.' + this.pfx + 'blocks-c'); - } + if (at >= total) { + parent.appendChild(child); + } else { + parent.insertBefore(child, childNodes[at]); + } +}; +/** + * Append an array of vNodes to an element + * @param {HTMLElement} node HTML element + * @param {Array} vNodes Array of node objects + */ - return this.blocksEl; - }, - append: function append(el) { - this.getBlocksEl().appendChild(el); - }, - render: function render() { - this.el.innerHTML = this.template({ - pfx: this.pfx, - label: this.model.get('label') +var appendVNodes = function appendVNodes(node) { + var vNodes = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : []; + var vNodesArr = Array.isArray(vNodes) ? vNodes : [vNodes]; + vNodesArr.forEach(function (vnode) { + var tag = vnode[KEY_TAG] || 'div'; + var attr = vnode[KEY_ATTR] || {}; + var el = document.createElement(tag); + Object(underscore__WEBPACK_IMPORTED_MODULE_0__["each"])(attr, function (value, key) { + el.setAttribute(key, value); }); - this.el.className = this.className; - this.updateVisibility(); - return this; - } -}); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(1))) + node.appendChild(el); + }); +}; /***/ }), -/* 218 */ -/***/ (function(module, exports, __webpack_require__) { -"use strict"; +/***/ "./src/utils/extender.js": +/*!*******************************!*\ + !*** ./src/utils/extender.js ***! + \*******************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_0__); -module.exports = function (_ref) { +/* harmony default export */ __webpack_exports__["default"] = (function (_ref) { var $ = _ref.$, Backbone = _ref.Backbone; @@ -46780,8 +52567,8 @@ module.exports = function (_ref) { ViewProt.delegate = function (eventName, selector, listener) { var vid = '.delegateEvents' + this.cid; - this.$el.on(eventName, selector, listener); - //return this; + this.$el.on(eventName, selector, listener); //return this; + var eventMap = eventNsMap[vid]; if (!eventMap) { @@ -46789,7 +52576,11 @@ module.exports = function (_ref) { eventNsMap[vid] = eventMap; } - eventMap.push({ eventName: eventName, selector: selector, listener: listener }); + eventMap.push({ + eventName: eventName, + selector: selector, + listener: listener + }); return this; }; @@ -46797,6 +52588,7 @@ module.exports = function (_ref) { var _this = this; var vid = '.delegateEvents' + this.cid; + if (this.$el) { //this.$el.off(); return this; var eventMap = eventNsMap[vid]; @@ -46811,14 +52603,15 @@ module.exports = function (_ref) { }); } } + return this; }; ViewProt.undelegate = function (ev, sel, list) { var _this2 = this; - var vid = '.delegateEvents' + this.cid; - //this.$el.off(ev, sel, list); return this; + var vid = '.delegateEvents' + this.cid; //this.$el.off(ev, sel, list); return this; + var eventMap = eventNsMap[vid]; if (eventMap) { @@ -46844,46 +52637,16 @@ module.exports = function (_ref) { var namespaceArray = name.split('.'); return name.indexOf('.') !== 0 ? [namespaceArray[0], namespaceArray.slice(1)] : [null, namespaceArray]; }; - /* - const CashEvent = function(node, eventName, namespaces, delegate, originalCallback, runOnce) { - const eventCache = getData(node,'_cashEvents') || setData(node, '_cashEvents', {}); - const remove = function(c, namespace){ - if ( c && originalCallback !== c ) { return; } - if ( namespace && this.namespaces.indexOf(namespace) < 0 ) { return; } - node.removeEventListener(eventName, callback); - }; - const callback = function(e) { - var t = this; - if (delegate) { - t = e.target; - while (t && !matches(t, delegate)) { - if (t === this) { - return (t = false); - } - t = t.parentNode; - } - } - if (t) { - originalCallback.call(t, e, e.data); - if ( runOnce ) { remove(); } - } - }; - this.remove = remove; - this.namespaces = namespaces; - node.addEventListener(eventName, callback); - eventCache[eventName] = eventCache[eventName] || []; - eventCache[eventName].push(this); - return this; - } - */ var on = $.prototype.on; var off = $.prototype.off; var trigger = $.prototype.trigger; var offset = $.prototype.offset; + var getEvents = function getEvents(eventName) { return eventName.split(/[,\s]+/g); }; + var getNamespaces = function getNamespaces(eventName) { return eventName.split('.'); }; @@ -46906,8 +52669,8 @@ module.exports = function (_ref) { if (namespaces.length) { //console.log('Found event with namespaces', namespaces, eventName, delegate, this); - var cashNs = this.data('_cashNs') || []; - // cashNs[namespace] + var cashNs = this.data('_cashNs') || []; // cashNs[namespace] + this.data('_cashNs', namespaces); // for each ns need to store '.store' => eventName, delegate, callback } @@ -46939,8 +52702,7 @@ module.exports = function (_ref) { namespaces = namespaces.slice(1); - if (namespaces.length) { - // Have to off only with the same namespace + if (namespaces.length) {// Have to off only with the same namespace } return off.call(this, eventName, callback); @@ -46975,8 +52737,7 @@ module.exports = function (_ref) { namespaces = namespaces.slice(1); - if (namespaces.length) { - // have to trigger with same namespaces and eventName + if (namespaces.length) {// have to trigger with same namespaces and eventName } return trigger.call(this, eventName, data); @@ -47003,21 +52764,50 @@ module.exports = function (_ref) { var el = this.get(0); el && el.focus(); return this; - }; + }; // For SVGs in IE + + + fn.removeClass = function (c) { + if (!arguments.length) { + return this.attr('class', ''); + } + + var classes = Object(underscore__WEBPACK_IMPORTED_MODULE_0__["isString"])(c) && c.match(/\S+/g); + return classes ? this.each(function (el) { + Object(underscore__WEBPACK_IMPORTED_MODULE_0__["each"])(classes, function (c) { + if (el.classList) { + el.classList.remove(c); + } else { + var val = el.className; + var bval = el.className.baseVal; - fn.remove = function () { + if (!Object(underscore__WEBPACK_IMPORTED_MODULE_0__["isUndefined"])(bval)) { + val.baseVal = bval.replace(c, ''); + } else { + el.className = val.replace(c, ''); + } + } + }); + }) : this; + }, fn.remove = function () { return this.each(function (node) { return node.parentNode && node.parentNode.removeChild(node); }); - }, - - // For spectrum compatibility + }, // For spectrum compatibility fn.bind = function (ev, h) { return this.on(ev, h); }; fn.unbind = function (ev, h) { - return this.off(ev, h); + if (Object(underscore__WEBPACK_IMPORTED_MODULE_0__["isObject"])(ev)) { + for (var name in ev) { + ev.hasOwnProperty(name) && this.off(name, ev[name]); + } + + return this; + } else { + return this.off(ev, h); + } }; fn.click = function (h) { @@ -47050,188 +52840,438 @@ module.exports = function (_ref) { return win ? win.pageXOffset : el.scrollLeft || 0; }; - fn.scrollTop = function () { - var el = this.get(0); - el = el.nodeType == 9 ? el.defaultView : el; - var win = el instanceof Window ? el : null; - return win ? win.pageYOffset : el.scrollTop || 0; - }; + fn.scrollTop = function () { + var el = this.get(0); + el = el.nodeType == 9 ? el.defaultView : el; + var win = el instanceof Window ? el : null; + return win ? win.pageYOffset : el.scrollTop || 0; + }; + + fn.offset = function (coords) { + var top, left; + + if (coords) { + top = coords.top; + left = coords.left; + } + + if (typeof top != 'undefined') { + this.css('top', "".concat(top, "px")); + } + + if (typeof left != 'undefined') { + this.css('left', "".concat(left, "px")); + } + + return offset.call(this); + }; + + $.map = function (items, clb) { + var ar = []; + + for (var i = 0; i < items.length; i++) { + ar.push(clb(items[i], i)); + } + + return ar; + }; + + var indexOf = Array.prototype.indexOf; + + $.inArray = function (val, arr, i) { + return arr == null ? -1 : indexOf.call(arr, val, i); + }; + + $.Event = function (src, props) { + if (!(this instanceof $.Event)) { + return new $.Event(src, props); + } + + this.type = src; + + this.isDefaultPrevented = function () { + return false; + }; + }; + } +}); + +/***/ }), + +/***/ "./src/utils/fetch.js": +/*!****************************!*\ + !*** ./src/utils/fetch.js ***! + \****************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var promise_polyfill__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! promise-polyfill */ "./node_modules/promise-polyfill/src/index.js"); + +window.Promise = window.Promise || promise_polyfill__WEBPACK_IMPORTED_MODULE_0__["default"]; +/* harmony default export */ __webpack_exports__["default"] = (typeof fetch == 'function' ? fetch.bind() : function (url, options) { + return new promise_polyfill__WEBPACK_IMPORTED_MODULE_0__["default"](function (res, rej) { + var req = new XMLHttpRequest(); + req.open(options.method || 'get', url); + req.withCredentials = options.credentials == 'include'; + + for (var k in options.headers || {}) { + req.setRequestHeader(k, options.headers[k]); + } + + req.onload = function (e) { + return res({ + status: req.status, + statusText: req.statusText, + text: function text() { + return promise_polyfill__WEBPACK_IMPORTED_MODULE_0__["default"].resolve(req.responseText); + } + }); + }; + + req.onerror = rej; // Actually, fetch doesn't support onProgress feature + + if (req.upload && options.onProgress) { + req.upload.onprogress = options.onProgress; + } // Include body only if present + + + options.body ? req.send(options.body) : req.send(); + }); +}); + +/***/ }), + +/***/ "./src/utils/index.js": +/*!****************************!*\ + !*** ./src/utils/index.js ***! + \****************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { + +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony import */ var _Dragger__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ./Dragger */ "./src/utils/Dragger.js"); +/* harmony import */ var _Sorter__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./Sorter */ "./src/utils/Sorter.js"); +/* harmony import */ var _Resizer__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./Resizer */ "./src/utils/Resizer.js"); + + + +/* harmony default export */ __webpack_exports__["default"] = (function () { + return { + /** + * Name of the module + * @type {String} + * @private + */ + name: 'Utils', + + /** + * Initialize module + */ + init: function init() { + return this; + }, + Sorter: _Sorter__WEBPACK_IMPORTED_MODULE_1__["default"], + Resizer: _Resizer__WEBPACK_IMPORTED_MODULE_2__["default"], + Dragger: _Dragger__WEBPACK_IMPORTED_MODULE_0__["default"] + }; +}); + +/***/ }), + +/***/ "./src/utils/mixins.js": +/*!*****************************!*\ + !*** ./src/utils/mixins.js ***! + \*****************************/ +/*! exports provided: isCommentNode, isTaggableNode, on, off, hasDnd, upFirst, matches, getModel, getElRect, camelCase, isTextNode, getKeyCode, getKeyChar, isEscKey, getElement, shallowDiff, normalizeFloat, getPointerEvent, getUnitFromValue, capitalize */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { - fn.offset = function (coords) { - var top = void 0, - left = void 0; +"use strict"; +__webpack_require__.r(__webpack_exports__); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isCommentNode", function() { return isCommentNode; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isTaggableNode", function() { return isTaggableNode; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "on", function() { return on; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "off", function() { return off; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "hasDnd", function() { return hasDnd; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "upFirst", function() { return upFirst; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "matches", function() { return matches; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getModel", function() { return getModel; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getElRect", function() { return getElRect; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "camelCase", function() { return camelCase; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isTextNode", function() { return isTextNode; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getKeyCode", function() { return getKeyCode; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getKeyChar", function() { return getKeyChar; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "isEscKey", function() { return isEscKey; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getElement", function() { return getElement; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "shallowDiff", function() { return shallowDiff; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "normalizeFloat", function() { return normalizeFloat; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getPointerEvent", function() { return getPointerEvent; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "getUnitFromValue", function() { return getUnitFromValue; }); +/* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "capitalize", function() { return capitalize; }); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! underscore */ "./node_modules/underscore/underscore.js"); +/* harmony import */ var underscore__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(underscore__WEBPACK_IMPORTED_MODULE_0__); - if (coords) { - top = coords.top; - left = coords.left; - } +var elProt = window.Element.prototype; +var matches = elProt.matches || elProt.webkitMatchesSelector || elProt.mozMatchesSelector || elProt.msMatchesSelector; +/** + * Returns shallow diff between 2 objects + * @param {Object} objOrig + * @param {Objec} objNew + * @return {Object} + * @example + * var a = {foo: 'bar', baz: 1, faz: 'sop'}; + * var b = {foo: 'bar', baz: 2, bar: ''}; + * shallowDiff(a, b); + * // -> {baz: 2, faz: null, bar: ''}; + */ - if (typeof top != 'undefined') { - this.css('top', top + 'px'); - } - if (typeof left != 'undefined') { - this.css('left', left + 'px'); - } +var shallowDiff = function shallowDiff(objOrig, objNew) { + var result = {}; + var keysNew = Object(underscore__WEBPACK_IMPORTED_MODULE_0__["keys"])(objNew); - return offset.call(this); - }; + for (var prop in objOrig) { + if (objOrig.hasOwnProperty(prop)) { + var origValue = objOrig[prop]; + var newValue = objNew[prop]; - $.map = function (items, clb) { - var ar = []; + if (keysNew.indexOf(prop) >= 0) { + if (origValue !== newValue) { + result[prop] = newValue; + } + } else { + result[prop] = null; + } + } + } - for (var i = 0; i < items.length; i++) { - ar.push(clb(items[i], i)); + for (var _prop in objNew) { + if (objNew.hasOwnProperty(_prop)) { + if (Object(underscore__WEBPACK_IMPORTED_MODULE_0__["isUndefined"])(objOrig[_prop])) { + result[_prop] = objNew[_prop]; } + } + } - return ar; - }; + return result; +}; - var indexOf = Array.prototype.indexOf; +var on = function on(el, ev, fn) { + ev = ev.split(/\s+/); + el = el instanceof Array ? el : [el]; - $.inArray = function (val, arr, i) { - return arr == null ? -1 : indexOf.call(arr, val, i); - }; + var _loop = function _loop(i) { + el.forEach(function (elem) { + return elem.addEventListener(ev[i], fn); + }); + }; - $.Event = function (src, props) { - if (!(this instanceof $.Event)) { - return new $.Event(src, props); - } + for (var i = 0; i < ev.length; ++i) { + _loop(i); + } +}; - this.type = src; - this.isDefaultPrevented = function () { - return false; - }; - }; +var off = function off(el, ev, fn) { + ev = ev.split(/\s+/); + el = el instanceof Array ? el : [el]; + + var _loop2 = function _loop2(i) { + el.forEach(function (elem) { + return elem.removeEventListener(ev[i], fn); + }); + }; + + for (var i = 0; i < ev.length; ++i) { + _loop2(i); } }; -/***/ }), -/* 219 */ -/***/ (function(module, exports, __webpack_require__) { +var getUnitFromValue = function getUnitFromValue(value) { + return value.replace(parseFloat(value), ''); +}; -"use strict"; -/* WEBPACK VAR INJECTION */(function(Backbone) { +var upFirst = function upFirst(value) { + return value[0].toUpperCase() + value.toLowerCase().slice(1); +}; -var $ = Backbone.$; +var camelCase = function camelCase(value) { + var values = value.split('-').filter(String); + return values[0].toLowerCase() + values.slice(1).map(upFirst); +}; -module.exports = Backbone.View.extend({ - initialize: function initialize() { - var _this = this; +var normalizeFloat = function normalizeFloat(value) { + var step = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1; + var valueDef = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 0; + var stepDecimals = 0; + if (isNaN(value)) return valueDef; + value = parseFloat(value); - var model = this.model; - model.view = this; - this.conf = model.config; - this.pn = model.get('Panels'); - model.on('loaded', function () { - _this.pn.active(); - _this.pn.disableButtons(); - model.runDefault(); - setTimeout(function () { - return model.trigger('load'); - }, 0); - }); - }, - render: function render() { - var model = this.model; - var el = this.$el; - var conf = this.conf; - var contEl = $(conf.el || 'body ' + conf.container); - var pfx = conf.stylePrefix; - el.empty(); + if (Math.floor(value) !== value) { + var side = step.toString().split('.')[1]; + stepDecimals = side ? side.length : 0; + } - if (conf.width) contEl.css('width', conf.width); + return stepDecimals ? parseFloat(value.toFixed(stepDecimals)) : value; +}; - if (conf.height) contEl.css('height', conf.height); +var hasDnd = function hasDnd(em) { + return 'draggable' in document.createElement('i') && (em ? em.get('Config').nativeDnD : 1); +}; +/** + * Ensure to fetch the element from the input argument + * @param {HTMLElement|Component} el Component or HTML element + * @return {HTMLElement} + */ - el.append(model.get('Canvas').render()); - el.append(this.pn.render()); - el.attr('class', pfx + 'editor ' + pfx + 'one-bg ' + pfx + 'two-color'); - contEl.addClass(pfx + 'editor-cont').empty().append(el); - return this; +var getElement = function getElement(el) { + if (Object(underscore__WEBPACK_IMPORTED_MODULE_0__["isElement"])(el) || isTextNode(el)) { + return el; + } else if (el && el.getEl) { + return el.getEl(); } -}); -/* WEBPACK VAR INJECTION */}.call(exports, __webpack_require__(0))) +}; +/** + * Check if element is a text node + * @param {HTMLElement} el + * @return {Boolean} + */ -/***/ }), -/* 220 */ -/***/ (function(module, exports, __webpack_require__) { -"use strict"; +var isTextNode = function isTextNode(el) { + return el && el.nodeType === 3; +}; +/** + * Check if element is a comment node + * @param {HTMLElement} el + * @return {Boolean} + */ -module.exports = function (config) { +var isCommentNode = function isCommentNode(el) { + return el && el.nodeType === 8; +}; +/** + * Check if element is a comment node + * @param {HTMLElement} el + * @return {Boolean} + */ + +var isTaggableNode = function isTaggableNode(el) { + return el && !isTextNode(el) && !isCommentNode(el); +}; +/** + * Ensure to fetch the model from the input argument + * @param {HTMLElement|Component} el Component or HTML element + * @return {Component} + */ + +var getModel = function getModel(el, $) { + var model = el; + Object(underscore__WEBPACK_IMPORTED_MODULE_0__["isElement"])(el) && (model = $(el).data('model')); + return model; +}; - var c = config || {}, - defaults = __webpack_require__(221); +var getElRect = function getElRect(el) { + var def = { + top: 0, + left: 0, + width: 0, + height: 0 + }; + if (!el) return def; + var rectText; - // Set default options - for (var name in defaults) { - if (!(name in c)) c[name] = defaults[name]; + if (isTextNode(el)) { + var range = document.createRange(); + range.selectNode(el); + rectText = range.getBoundingClientRect(); + range.detach(); } - var plugins = {}; + return rectText || (el.getBoundingClientRect ? el.getBoundingClientRect() : def); +}; +/** + * Get cross-device pointer event + * @param {Event} ev + * @return {Event} + */ - return { - /** - * Add new plugin. Plugins could not be overwritten - * @param {string} id Plugin ID - * @param {Function} plugin Function which contains all plugin logic - * @return {Function} The plugin function - * @example - * PluginManager.add('some-plugin', function(editor){ - * editor.Commands.add('new-command', { - * run: function(editor, senderBtn){ - * console.log('Executed new-command'); - * } - * }) - * }); - */ - add: function add(id, plugin) { - if (plugins[id]) { - return plugins[id]; - } +var getPointerEvent = function getPointerEvent(ev) { + return ev.touches && ev.touches[0] ? ev.touches[0] : ev; +}; +/** + * Get cross-browser keycode + * @param {Event} ev + * @return {Number} + */ - plugins[id] = plugin; - return plugin; - }, +var getKeyCode = function getKeyCode(ev) { + return ev.which || ev.keyCode; +}; - /** - * Returns plugin by ID - * @param {string} id Plugin ID - * @return {Function|undefined} Plugin - * @example - * var plugin = PluginManager.get('some-plugin'); - * plugin(editor); - */ - get: function get(id) { - return plugins[id]; - }, +var getKeyChar = function getKeyChar(ev) { + return String.fromCharCode(getKeyCode(ev)); +}; +var isEscKey = function isEscKey(ev) { + return getKeyCode(ev) === 27; +}; - /** - * Returns object with all plugins - * @return {Object} - */ - getAll: function getAll() { - return plugins; - } - }; +var capitalize = function capitalize(str) { + return str.charAt(0).toUpperCase() + str.substring(1); }; + + /***/ }), -/* 221 */ -/***/ (function(module, exports, __webpack_require__) { + +/***/ "./src/utils/polyfills.js": +/*!********************************!*\ + !*** ./src/utils/polyfills.js ***! + \********************************/ +/*! exports provided: default */ +/***/ (function(module, __webpack_exports__, __webpack_require__) { "use strict"; +__webpack_require__.r(__webpack_exports__); +/** + * File made for IE/Edge support + * https://github.com/artf/grapesjs/issues/214 + */ +/* harmony default export */ __webpack_exports__["default"] = (function () { + /** + * Check if IE/Edge + * @return {Boolean} + */ + var isIE = function isIE() { + var match; + var agent = window.navigator.userAgent; + var rules = [['edge', /Edge\/([0-9\._]+)/], ['ie', /MSIE\s(7\.0)/], ['ie', /MSIE\s([0-9\.]+);.*Trident\/[4-7].0/], ['ie', /Trident\/7\.0.*rv\:([0-9\.]+).*\).*Gecko$/]]; + + for (var i = 0; i < rules.length; i++) { + var rule = rules[i]; + match = rule[1].exec(agent); + if (match) break; + } + return !!match; + }; -module.exports = { - plugins: [] -}; + if (isIE()) { + var originalCreateHTMLDocument = DOMImplementation.prototype.createHTMLDocument; + + DOMImplementation.prototype.createHTMLDocument = function (title) { + if (!title) title = ''; + return originalCreateHTMLDocument.apply(document.implementation, [title]); + }; + } +}); /***/ }) -/******/ ]); + +/******/ })["default"]; }); \ No newline at end of file diff --git a/dist/grapes.min.js b/dist/grapes.min.js index 6a0f19841..f88d209fb 100644 --- a/dist/grapes.min.js +++ b/dist/grapes.min.js @@ -1,5 +1,7 @@ -/*! grapesjs - 0.12.60 */ -!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e():"function"==typeof define&&define.amd?define([],e):"object"==typeof exports?exports.grapesjs=e():t.grapesjs=e()}(this,function(){return function(t){function e(i){if(n[i])return n[i].exports;var r=n[i]={i:i,l:!1,exports:{}};return t[i].call(r.exports,r,r.exports,e),r.l=!0,r.exports}var n={};return e.m=t,e.c=n,e.d=function(t,n,i){e.o(t,n)||Object.defineProperty(t,n,{configurable:!1,enumerable:!0,get:i})},e.n=function(t){var n=t&&t.__esModule?function(){return t.default}:function(){return t};return e.d(n,"a",n),n},e.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},e.p="",e(e.s=58)}([function(t,e,n){(function(i){var r,o;!function(s){var a="object"==typeof self&&self.self===self&&self||"object"==typeof i&&i.global===i&&i;r=[n(1),n(9),e],void 0!==(o=function(t,e,n){a.Backbone=s(a,n,t,e)}.apply(e,r))&&(t.exports=o)}(function(t,e,n,i){var r=t.Backbone,o=Array.prototype.slice;e.VERSION="1.3.3",e.$=i,e.noConflict=function(){return t.Backbone=r,this},e.emulateHTTP=!1,e.emulateJSON=!1;var s=function(t,e,i){switch(t){case 1:return function(){return n[e](this[i])};case 2:return function(t){return n[e](this[i],t)};case 3:return function(t,r){return n[e](this[i],l(t,this),r)};case 4:return function(t,r,o){return n[e](this[i],l(t,this),r,o)};default:return function(){var t=o.call(arguments);return t.unshift(this[i]),n[e].apply(n,t)}}},a=function(t,e,i){n.each(e,function(e,r){n[r]&&(t.prototype[r]=s(e,r,i))})},l=function(t,e){return n.isFunction(t)?t:n.isObject(t)&&!e._isModel(t)?c(t):n.isString(t)?function(e){return e.get(t)}:t},c=function(t){var e=n.matches(t);return function(t){return e(t.attributes)}},u=e.Events={},h=/\s+/,d=function(t,e,i,r,o){var s,a=0;if(i&&"object"==typeof i){void 0!==r&&"context"in o&&void 0===o.context&&(o.context=r);for(s=n.keys(i);athis.length&&(r=this.length),r<0&&(r+=this.length+1);var o,s,a=[],l=[],c=[],u=[],h={},d=e.add,f=e.merge,p=e.remove,g=!1,v=this.comparator&&null==r&&!1!==e.sort,m=n.isString(this.comparator)?this.comparator:null;for(s=0;s7),this._useHashChange=this._wantsHashChange&&this._hasHashChange,this._wantsPushState=!!this.options.pushState,this._hasPushState=!(!this.history||!this.history.pushState),this._usePushState=this._wantsPushState&&this._hasPushState,this.fragment=this.getFragment(),this.root=("/"+this.root+"/").replace(_,"/"),this._wantsHashChange&&this._wantsPushState){if(!this._hasPushState&&!this.atRoot()){var e=this.root.slice(0,-1)||"/";return this.location.replace(e+"#"+this.getPath()),!0}this._hasPushState&&this.atRoot()&&this.navigate(this.getHash(),{replace:!0})}if(!this._hasHashChange&&this._wantsHashChange&&!this._usePushState){this.iframe=document.createElement("iframe"),this.iframe.src="javascript:0",this.iframe.style.display="none",this.iframe.tabIndex=-1;var i=document.body,r=i.insertBefore(this.iframe,i.firstChild).contentWindow;r.document.open(),r.document.close(),r.location.hash="#"+this.fragment}var o=window.addEventListener||function(t,e){return attachEvent("on"+t,e)};if(this._usePushState?o("popstate",this.checkUrl,!1):this._useHashChange&&!this.iframe?o("hashchange",this.checkUrl,!1):this._wantsHashChange&&(this._checkUrlInterval=setInterval(this.checkUrl,this.interval)),!this.options.silent)return this.loadUrl()},stop:function(){var t=window.removeEventListener||function(t,e){return detachEvent("on"+t,e)};this._usePushState?t("popstate",this.checkUrl,!1):this._useHashChange&&!this.iframe&&t("hashchange",this.checkUrl,!1),this.iframe&&(document.body.removeChild(this.iframe),this.iframe=null),this._checkUrlInterval&&clearInterval(this._checkUrlInterval),I.started=!1},route:function(t,e){this.handlers.unshift({route:t,callback:e})},checkUrl:function(t){var e=this.getFragment();if(e===this.fragment&&this.iframe&&(e=this.getHash(this.iframe.contentWindow)),e===this.fragment)return!1;this.iframe&&this.navigate(e),this.loadUrl()},loadUrl:function(t){return!!this.matchRoot()&&(t=this.fragment=this.getFragment(t),n.some(this.handlers,function(e){if(e.route.test(t))return e.callback(t),!0}))},navigate:function(t,e){if(!I.started)return!1;e&&!0!==e||(e={trigger:!!e}),t=this.getFragment(t||"");var n=this.root;""!==t&&"?"!==t.charAt(0)||(n=n.slice(0,-1)||"/");var i=n+t;if(t=this.decodeFragment(t.replace(F,"")),this.fragment!==t){if(this.fragment=t,this._usePushState)this.history[e.replace?"replaceState":"pushState"]({},document.title,i);else{if(!this._wantsHashChange)return this.location.assign(i);if(this._updateHash(this.location,t,e.replace),this.iframe&&t!==this.getHash(this.iframe.contentWindow)){var r=this.iframe.contentWindow;e.replace||(r.document.open(),r.document.close()),this._updateHash(r.location,t,e.replace)}}return e.trigger?this.loadUrl(t):void 0}},_updateHash:function(t,e,n){if(n){var i=t.href.replace(/(javascript:|#).*$/,"");t.replace(i+"#"+e)}else t.hash="#"+e}}),e.history=new I;var z=function(t,e){var i,r=this;return i=t&&n.has(t,"constructor")?t.constructor:function(){return r.apply(this,arguments)},n.extend(i,r,e),i.prototype=n.create(r.prototype,t),i.prototype.constructor=i,i.__super__=r.prototype,i};b.extend=x.extend=P.extend=S.extend=I.extend=z;var $=function(){throw new Error('A "url" property or function must be specified')},R=function(t,e){var n=e.error;e.error=function(i){n&&n.call(e.context,t,i,e),t.trigger("error",t,i,e)}};return e})}).call(e,n(16))},function(t,e,n){var i,r;(function(){function n(t){function e(e,n,i,r,o,s){for(;o>=0&&o0?0:a-1;return arguments.length<3&&(r=n[s?s[l]:l],l+=t),e(n,i,r,s,l,a)}}function o(t){return function(e,n,i){n=S(n,i);for(var r=A(e),o=t>0?0:r-1;o>=0&&o0?s=o>=0?o:Math.max(o+a,s):a=o>=0?Math.min(o+1,a):o+a+1;else if(n&&o&&a)return o=n(i,r),i[o]===r?o:-1;if(r!==r)return o=e(p.call(i,s,a),C.isNaN),o>=0?o+s:-1;for(o=t>0?s:a-1;o>=0&&o=0&&e<=P};C.each=C.forEach=function(t,e,n){e=k(e,n);var i,r;if(O(t))for(i=0,r=t.length;i=0},C.invoke=function(t,e){var n=p.call(arguments,2),i=C.isFunction(e);return C.map(t,function(t){var r=i?e:t[e];return null==r?r:r.apply(t,n)})},C.pluck=function(t,e){return C.map(t,C.property(e))},C.where=function(t,e){return C.filter(t,C.matcher(e))},C.findWhere=function(t,e){return C.find(t,C.matcher(e))},C.max=function(t,e,n){var i,r,o=-1/0,s=-1/0;if(null==e&&null!=t){t=O(t)?t:C.values(t);for(var a=0,l=t.length;ao&&(o=i)}else e=S(e,n),C.each(t,function(t,n,i){((r=e(t,n,i))>s||r===-1/0&&o===-1/0)&&(o=t,s=r)});return o},C.min=function(t,e,n){var i,r,o=1/0,s=1/0;if(null==e&&null!=t){t=O(t)?t:C.values(t);for(var a=0,l=t.length;ai||void 0===n)return 1;if(ne?(s&&(clearTimeout(s),s=null),a=c,o=t.apply(i,r),s||(i=r=null)):s||!1===n.trailing||(s=setTimeout(l,u)),o}},C.debounce=function(t,e,n){var i,r,o,s,a,l=function(){var c=C.now()-s;c=0?i=setTimeout(l,e-c):(i=null,n||(a=t.apply(o,r),i||(o=r=null)))};return function(){o=this,r=arguments,s=C.now();var c=n&&!i;return i||(i=setTimeout(l,e)),c&&(a=t.apply(o,r),o=r=null),a}},C.wrap=function(t,e){return C.partial(e,t)},C.negate=function(t){return function(){return!t.apply(this,arguments)}},C.compose=function(){var t=arguments,e=t.length-1;return function(){for(var n=e,i=t[e].apply(this,arguments);n--;)i=t[n].call(this,i);return i}},C.after=function(t,e){return function(){if(--t<1)return e.apply(this,arguments)}},C.before=function(t,e){var n;return function(){return--t>0&&(n=e.apply(this,arguments)),t<=1&&(e=null),n}},C.once=C.partial(C.before,2);var D=!{toString:null}.propertyIsEnumerable("toString"),_=["valueOf","isPrototypeOf","toString","propertyIsEnumerable","hasOwnProperty","toLocaleString"];C.keys=function(t){if(!C.isObject(t))return[];if(y)return y(t);var e=[];for(var n in t)C.has(t,n)&&e.push(n);return D&&a(t,e),e},C.allKeys=function(t){if(!C.isObject(t))return[];var e=[];for(var n in t)e.push(n);return D&&a(t,e),e},C.values=function(t){for(var e=C.keys(t),n=e.length,i=Array(n),r=0;r":">",'"':""","'":"'","`":"`"},$=C.invert(z),R=function(t){var e=function(e){return t[e]},n="(?:"+C.keys(t).join("|")+")",i=RegExp(n),r=RegExp(n,"g");return function(t){return t=null==t?"":""+t,i.test(t)?t.replace(r,e):t}};C.escape=R(z),C.unescape=R($),C.result=function(t,e,n){var i=null==t?void 0:t[e];return void 0===i&&(i=n),C.isFunction(i)?i.call(t):i};var V=0;C.uniqueId=function(t){var e=++V+"";return t?t+e:e},C.templateSettings={evaluate:/<%([\s\S]+?)%>/g,interpolate:/<%=([\s\S]+?)%>/g,escape:/<%-([\s\S]+?)%>/g};var H=/(.)^/,j={"'":"'","\\":"\\","\r":"r","\n":"n","\u2028":"u2028","\u2029":"u2029"},B=/\\|'|\r|\n|\u2028|\u2029/g,W=function(t){return"\\"+j[t]};C.template=function(t,e,n){!e&&n&&(e=n),e=C.defaults({},e,C.templateSettings);var i=RegExp([(e.escape||H).source,(e.interpolate||H).source,(e.evaluate||H).source].join("|")+"|$","g"),r=0,o="__p+='";t.replace(i,function(e,n,i,s,a){return o+=t.slice(r,a).replace(B,W),r=a+e.length,n?o+="'+\n((__t=("+n+"))==null?'':_.escape(__t))+\n'":i?o+="'+\n((__t=("+i+"))==null?'':__t)+\n'":s&&(o+="';\n"+s+"\n__p+='"),e}),o+="';\n",e.variable||(o="with(obj||{}){\n"+o+"}\n"),o="var __t,__p='',__j=Array.prototype.join,print=function(){__p+=__j.call(arguments,'');};\n"+o+"return __p;\n";try{var s=new Function(e.variable||"obj","_",o)}catch(t){throw t.source=o,t}var a=function(t){return s.call(this,t,C)};return a.source="function("+(e.variable||"obj")+"){\n"+o+"}",a},C.chain=function(t){var e=C(t);return e._chain=!0,e};var U=function(t,e){return t._chain?C(e).chain():e};C.mixin=function(t){C.each(C.functions(t),function(e){var n=C[e]=t[e];C.prototype[e]=function(){var t=[this._wrapped];return f.apply(t,arguments),U(this,n.apply(C,t))}})},C.mixin(C),C.each(["pop","push","reverse","shift","sort","splice","unshift"],function(t){var e=u[t];C.prototype[t]=function(){var n=this._wrapped;return e.apply(n,arguments),"shift"!==t&&"splice"!==t||0!==n.length||delete n[0],U(this,n)}}),C.each(["concat","join","slice"],function(t){var e=u[t];C.prototype[t]=function(){return U(this,e.apply(this._wrapped,arguments))}}),C.prototype.value=function(){return this._wrapped},C.prototype.valueOf=C.prototype.toJSON=C.prototype.value,C.prototype.toString=function(){return""+this._wrapped},i=[],void 0!==(r=function(){return C}.apply(e,i))&&(t.exports=r)}).call(this)},function(t,e,n){"use strict";Object.defineProperty(e,"__esModule",{value:!0}),e.getUnitFromValue=e.normalizeFloat=e.shallowDiff=e.camelCase=e.matches=e.upFirst=e.off=e.on=void 0;var i=n(1),r=window.Element.prototype,o=r.matches||r.webkitMatchesSelector||r.mozMatchesSelector||r.msMatchesSelector,s=function(t,e){var n={},r=(0,i.keys)(e);for(var o in t)if(t.hasOwnProperty(o)){var s=t[o],a=e[o];r.indexOf(o)>=0?s!==a&&(n[o]=a):n[o]=null}for(var l in e)e.hasOwnProperty(l)&&(0,i.isUndefined)(t[l])&&(n[l]=e[l]);return n},a=function(t,e,n){e=e.split(/\s+/),t=t instanceof Array?t:[t];for(var i=0;i1&&void 0!==arguments[1]?arguments[1]:1,n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:0,i=0;if(isNaN(t))return n;if(t=parseFloat(t),Math.floor(t)!==t){var r=e.toString().split(".")[1];i=r?r.length:0}return i?parseFloat(t.toFixed(i)):t};e.on=a,e.off=l,e.upFirst=u,e.matches=o,e.camelCase=h,e.shallowDiff=s,e.normalizeFloat=d,e.getUnitFromValue=c},function(t,e,n){"use strict";(function(e){var i=n(1),r=n(50);t.exports=e.View.extend({className:function(){return this.getClasses()},tagName:function(){return this.model.get("tagName")},initialize:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=this.model,n=t.config||{};this.opts=t,this.config=n,this.em=n.em||"",this.pfx=n.stylePrefix||"",this.ppfx=n.pStylePrefix||"",this.attr=e.get("attributes"),this.classe=this.attr.class||[];var i=this.$el,r=e.get("classes");this.listenTo(e,"destroy remove",this.remove),this.listenTo(e,"change:style",this.updateStyle),this.listenTo(e,"change:attributes",this.updateAttributes),this.listenTo(e,"change:highlightable",this.updateHighlight),this.listenTo(e,"change:status",this.updateStatus),this.listenTo(e,"change:state",this.updateState),this.listenTo(e,"change:script",this.render),this.listenTo(e,"change",this.handleChange),this.listenTo(r,"add remove change",this.updateClasses),i.data("model",e),i.data("collection",e.get("components")),e.view=this,r.length&&this.importClasses(),this.init()},remove:function(){e.View.prototype.remove.apply(this);var t=this.childrenView;t&&t.stopListening()},init:function(){},handleChange:function(){var t=this.model;t.emitUpdate();for(var e in t.changed)t.emitUpdate(e)},importClasses:function(){var t=this.config.em.get("SelectorManager");t&&this.model.get("classes").each(function(e){t.add(e.get("name"))})},updateState:function(t){var e="hc-state";this.model.get("state")?this.$el.addClass(e):this.$el.removeClass(e)},updateStatus:function(t){var e=this.el,n=this.model.get("status"),i=this.pfx,r=this.ppfx,o=i+"selected",s=o+"-parent",a=r+"freezed",l=e.getAttribute("class")||"",c="";switch(n){case"selected":c=l+" "+o;break;case"selected-parent":c=l+" "+s;break;case"freezed":c=l+" "+a;break;default:this.$el.removeClass(o+" "+s+" "+a)}(c=c.trim())&&e.setAttribute("class",c)},updateHighlight:function(){var t=this.model.get("highlightable");this.setAttribute("data-highlightable",t?1:"")},updateStyle:function(){var t=this.em,e=this.model;t&&t.get("avoidInlineStyle")?(this.el.id=e.getId(),e.setStyle(e.getStyle())):this.setAttribute("style",e.styleToString())},updateClasses:function(){var t=this.model.get("classes").pluck("name").join(" ");this.setAttribute("class",t),this.updateStatus()},setAttribute:function(t,e){var n=this.$el;e?n.attr(t,e):n.removeAttr(t)},getClasses:function(){var t=this.model.get("attributes"),e=t.class||[];return e=(0,i.isArray)(e)?e:[e],e.length?e.join(" "):null},updateAttributes:function(){var t=this.model,e={},n=t.get("attributes"),i=t.get("src");for(var r in n)e[r]=n[r];i&&(e.src=i),this.$el.attr(e),this.updateHighlight(),this.updateStyle()},updateContent:function(){this.getChildrenContainer().innerHTML=this.model.get("content")},prevDef:function(t){t.preventDefault()},updateScript:function(){if(this.model.get("script")){var t=this.em;if(t){t.get("Canvas").getCanvasView().updateScript(this)}}},getChildrenContainer:function(){var t=this.el;return"function"==typeof this.getChildrenSelector?t=this.el.querySelector(this.getChildrenSelector()):this.getTemplate,t},renderChildren:function(){var t=this.getChildrenContainer(),e=new r({collection:this.model.get("components"),config:this.config,componentTypes:this.opts.componentTypes});e.render(t),this.childrenView=e;for(var n=Array.prototype.slice.call(e.el.childNodes),i=0,o=n.length;i0&&void 0!==arguments[0]?arguments[0]:{},n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},o=n.sm||n.em||"",s=this.parent(),a=s&&s.attributes;if(a&&a.propagate){var l={},c=a.propagate;c.forEach(function(t){return l[t]=s.get(t)}),l.propagate=c,l=i({},l,e),this.set(l)}var u=this.get("propagate");u&&this.set("propagate",(0,r.isArray)(u)?u:[u]),n&&n.config&&n.config.voidElements.indexOf(this.get("tagName"))>=0&&this.set("void",!0),n.em=o,this.opt=n,this.sm=o,this.em=o,this.config=n.config||{},this.set("attributes",this.get("attributes")||{}),this.listenTo(this,"change:script",this.scriptUpdated),this.listenTo(this,"change:traits",this.traitsUpdated),this.listenTo(this,"change:tagName",this.tagUpdated),this.listenTo(this,"change:attributes",this.attrUpdated),this.initClasses(),this.loadTraits(),this.initComponents(),this.initToolbar(),this.set("status",""),this.listenTo(this.get("classes"),"add remove change",function(){return t.emitUpdate("classes")}),this.init()},is:function(t){return!(this.get("type")!=t)},find:function(t){var e=[];return this.view.$el.find(t).each(function(t,n,i){var r=i.eq(n),o=r.data("model");o&&e.push(o)}),e},tagUpdated:function(){var t=this.collection,e=t.indexOf(this);t.remove(this),t.add(this,{at:e})},attrUpdated:function(){var t=this,e=i({},this.previous("attributes")),n=i({},this.get("attributes")),s=(0,o.shallowDiff)(e,n);(0,r.keys)(s).forEach(function(e){return t.trigger("change:attributes:"+e)})},setAttributes:function(t){t=i({},t);var e=t.class;e&&this.setClass(e),delete t.class;var n=t.style;n&&this.setStyle(n),delete t.style,this.set("attributes",t)},getStyle:function(){var t=this.em;if(t&&t.getConfig("avoidInlineStyle")){var e=this.get("state"),n=t.get("CssComposer"),i=n.getIdRule(this.getId(),{state:e});if(this.rule=i,i)return i.getStyle()}return a.default.getStyle.call(this)},setStyle:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},s=this.em;if(s&&s.getConfig("avoidInlineStyle")){e=(0,r.isString)(e)?this.parseStyle(e):e;var l=this.get("state"),c=s.get("CssComposer"),u=this.getStyle();this.rule=c.setIdRule(this.getId(),e,i({},n,{state:l}));var h=(0,o.shallowDiff)(u,e);(0,r.keys)(h).forEach(function(e){return t.trigger("change:style:"+e)})}else e=a.default.setStyle.apply(this,arguments);return e},getAttributes:function(){var t=[],e=i({},this.get("attributes"));return this.get("classes").each(function(e){return t.push(e.get("name"))}),t.length&&(e.class=t.join(" ")),(0,r.isEmpty)(this.getStyle())||(0,r.has)(e,"id")||(e.id=this.getId()),e},addClass:function(t){var e=this.em.get("SelectorManager").addClass(t);return this.get("classes").add(e)},setClass:function(t){return this.get("classes").reset(),this.addClass(t)},removeClass:function(t){var e=[];t=(0,r.isArray)(t)?t:[t];var n=this.get("classes"),i=u.TYPE_CLASS;return t.forEach(function(t){t.split(" ").forEach(function(t){var r=n.where({name:t,type:i})[0];r&&e.push(n.remove(r))})}),e},initClasses:function(){var t=this.normalizeClasses(this.get("classes")||[]);return this.set("classes",new h(t)),this},initComponents:function(){var t=new c(null,this.opt);return t.parent=this,t.reset(this.get("components")),this.set("components",t),this},init:function(){},append:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=this.components().add(t,e);return(0,r.isArray)(n)?n:[n]},components:function(t){var e=this.get("components");if((0,r.isUndefined)(t))return e;e.reset(),t&&this.append(t)},parent:function(){var t=this.collection;return t&&t.parent},scriptUpdated:function(){this.set("scriptUpdated",1)},traitsUpdated:function(){var t=0,e=i({},this.get("attributes")),n=this.get("traits");if(!(n instanceof d))return void this.loadTraits();n.each(function(n){if(t=1,!n.get("changeProp")){var i=n.getInitValue();i&&(e[n.get("name")]=i)}}),t&&this.set("attributes",e)},initToolbar:function(){var t=this;if(!t.get("toolbar")){var e=[];t.collection&&e.push({attributes:{class:"fa fa-arrow-up"},command:"select-parent"}),t.get("draggable")&&e.push({attributes:{class:"fa fa-arrows"},command:"tlb-move"}),t.get("copyable")&&e.push({attributes:{class:"fa fa-clone"},command:"tlb-clone"}),t.get("removable")&&e.push({attributes:{class:"fa fa-trash-o"},command:"tlb-delete"}),t.set("toolbar",e)}},loadTraits:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=new d([],this.opt);return n.setTarget(this),t=t||this.get("traits"),t.length&&n.add(t),this.set("traits",n,e),this},normalizeClasses:function(t){var e=[];if(this.sm.get){var n=this.sm.get("SelectorManager");if(n)return t.forEach(function(t){var i="";i="string"==typeof t?t:t.name;var r=n.add(i);e.push(r)}),e}},clone:function(t){var e=this.em,n=this.getStyle(),o=i({},this.attributes);return o.attributes=i({},o.attributes),delete o.attributes.id,o.components=[],o.classes=[],o.traits=[],this.get("components").each(function(t,e){o.components[e]=t.clone(1)}),this.get("traits").each(function(t,e){o.traits[e]=t.clone()}),this.get("classes").each(function(t,e){o.classes[e]=t.get("name")}),o.status="",o.view="",t&&(this.opt.collection=null),e&&e.getConfig("avoidInlineStyle")&&!(0,r.isEmpty)(n)&&(o.style=n),new this.constructor(o,this.opt)},getName:function(){var t=this.get("name")||this.get("custom-name"),e=this.get("tagName");e="div"==e?"box":e;var n=this.get("type")||e;return n=n.charAt(0).toUpperCase()+n.slice(1),t||n},getIcon:function(){var t=this.get("icon");return t?t+" ":""},toHTML:function(t){var e=this,n=[],i=e.get("tagName"),o=e.get("void"),s=this.getAttrToHTML();for(var a in s){var l=s[a];(0,r.isUndefined)(l)||n.push(a+'="'+l+'"')}var c=n.length?" "+n.join(" "):"",u="<"+i+c+(o?"/":"")+">"+e.get("content");return e.get("components").each(function(t){return u+=t.toHTML()}),!o&&(u+=""),u},getAttrToHTML:function(){var t=this.getAttributes();return delete t.style,t},toJSON:function(){for(var t=arguments.length,e=Array(t),n=0;n\n '+this.templateLabel(t)+'\n \n
\n '+this.templateInput(t)+"\n
\n "},templateLabel:function(t){var e=this.pfx;return'\n \n '+t.get("name")+'\n \n \n '},templateInput:function(t){return'\n
\n \n
\n '},events:function(t,e,n){return e in t?Object.defineProperty(t,e,{value:n,enumerable:!0,configurable:!0,writable:!0}):t[e]=n,t}({change:"inputValueChanged"},"click [data-clear-style]","clear"),initialize:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};(0,i.bindAll)(this,"targetUpdated"),this.config=t.config||{};var e=this.config.em;this.em=e,this.pfx=this.config.stylePrefix||"",this.ppfx=this.config.pStylePrefix||"",this.target=t.target||{},this.propTarget=t.propTarget||{},this.onChange=t.onChange,this.onInputRender=t.onInputRender||{},this.customValue=t.customValue||{};var n=this.model;this.property=n.get("property"),this.input=null;var r=this.pfx;this.inputHolderId="#"+r+"input-holder",this.sector=n.collection&&n.collection.sector,n.view=this,n.get("value")||n.set("value",n.getDefaultValue()),e&&e.on("update:component:style:"+this.property,this.targetUpdated),this.listenTo(this.propTarget,"update",this.targetUpdated),this.listenTo(n,"destroy remove",this.remove),this.listenTo(n,"change:value",this.modelValueChanged),this.listenTo(n,"targetUpdated",this.targetUpdated),this.listenTo(n,"change:visible",this.updateVisibility),this.listenTo(n,"change:status",this.updateStatus);var o=this.init&&this.init.bind(this);o&&o()},updateStatus:function(){var t=this.model.get("status"),e=this.pfx,n=this.ppfx,i=this.config,r=n+"four-color",o=n+"color-warn",s=this.$el.children("."+e+"label"),a=this.getClearEl().style;switch(s.removeClass(r+" "+o),a.display="none",t){case"updated":s.addClass(r),i.clearProperties&&(a.display="inline");break;case"computed":s.addClass(o)}},clear:function(){this.getTargetModel().removeStyle(this.model.get("property")),this.targetUpdated()},getClearEl:function(){return this.el.querySelector("[data-clear-style]")},getTarget:function(){return this.getTargetModel()},getTargetModel:function(){return this.propTarget&&this.propTarget.model},getHelperModel:function(){return this.propTarget&&this.propTarget.helper},inputValueChanged:function(t){t&&t.stopPropagation(),this.model.setValue(this.getInputValue(),1,{fromInput:1}),this.elementUpdated()},elementUpdated:function(){this.setStatus("updated")},setStatus:function(t){this.model.set("status",t);var e=this.model.parent;e&&e.set("status",t)},targetUpdated:function(){if(this.checkVisibility()){var t=this.config,e=t.em,n=this.model,i="",r="",o=this.getTargetValue({ignoreDefault:1}),s=n.getDefaultValue(),a=this.getComputedValue();o?(i=o,t.highlightChanged&&(r="updated")):a&&t.showComputed&&a!=s?(i=a,t.highlightComputed&&(r="computed")):(i=s,r=""),n.setValue(i,0,{fromTarget:1}),this.setStatus(r),e&&(e.trigger("styleManager:change",this),e.trigger("styleManager:change:"+n.get("property"),this))}},checkVisibility:function(){var t=1;return this.config.hideNotStylable&&(this.isTargetStylable()&&this.isComponentStylable()?this.show():(this.hide(),t=0),this.sector&&this.sector.trigger("updateVisibility")),t},getTargetValue:function(){var t,e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},n=this.model,i=this.getTargetModel(),r=this.customValue;if(!i)return t;if(t=i.getStyle()[n.get("property")],t||e.ignoreDefault||(t=n.getDefaultValue()),"function"==typeof r&&!e.ignoreCustomValue){var o=n.collection.indexOf(n),s=r(this,o);s&&(t=s)}return t},getComputedValue:function(){var t=this.propTarget,e=t.computed||{},n=t.computedDefault||{},i=this.config.avoidComputed||[],o=this.model.get("property"),s=i.indexOf(o)<0,a=e[o],l=n[(0,r.camelCase)(o)];return e&&s&&l!==a&&a},getInputValue:function(){var t=this.getInputEl();return t?t.value:""},modelValueChanged:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},i=this.config.em,r=this.model,o=r.getFullValue(),s=this.getTarget(),a=this.onChange;n.fromInput||this.setValue(o),s&&this.isTargetStylable()&&this.isComponentStylable()&&(n.fromTarget||(a&&!n.fromParent?a(s,this,n):this.updateTargetStyle(o,null,n)),i&&(i.trigger("component:update",s),i.trigger("component:styleUpdate",s),i.trigger("component:styleUpdate:"+r.get("property"),s)))},updateTargetStyle:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"",n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},i=e||this.model.get("property"),r=this.getTarget(),o=r.getStyle();t?o[i]=t:delete o[i],r.setStyle(o,n);var s=this.getHelperModel();s&&s.setStyle(o,n)},isTargetStylable:function(t){this.model.get("id");var e=t||this.getTarget(),n=this.model,r=n.get("property"),o=n.get("toRequire"),s=e.get("unstylable"),a=e.get("stylable-require"),l=e.get("stylable");return(0,i.isArray)(l)&&(l=l.indexOf(r)>=0),(0,i.isArray)(s)&&(l=s.indexOf(r)<0),o&&(l=a&&a.indexOf(r)>=0||!t),l},isComponentStylable:function(){var t=this.em,e=t&&t.get("selectedComponent");return!e||this.isTargetStylable(e)},setRawValue:function(t){this.setValue(this.model.parseValue(t))},setValue:function(t){var e=this.model,n=t||e.getDefaultValue(),i=this.getInputEl();i&&(i.value=n)},getInputEl:function(){return this.input||(this.input=this.el.querySelector("input")),this.input},updateVisibility:function(){this.el.style.display=this.model.get("visible")?"block":"none"},show:function(){this.model.set("visible",1)},hide:function(){this.model.set("visible",0)},cleanValue:function(){this.setValue("")},render:function(){var t=this.pfx,e=this.model,n=this.el;n.innerHTML=this.template(e),n.className=t+"property "+t+e.get("type"),this.updateStatus();var i=this.onRender&&this.onRender.bind(this);i&&i(),this.setValue(e.get("value"),{targetUpdate:1})}})}).call(e,n(0))},function(t,e,n){!function(e,n){t.exports=n()}(0,function(){"use strict";function t(t){return new RegExp("(^|\\s)"+t+"(?:$|\\s)\\s*")}function e(t){for(var e=t.childNodes.length;e>0;--e)t.removeChild(t.firstChild);return t}function n(t,n){return e(t).appendChild(n)}function i(t,e,n,i){var r=document.createElement(t);if(n&&(r.className=n),i&&(r.style.cssText=i),"string"==typeof e)r.appendChild(document.createTextNode(e));else if(e)for(var o=0;o=e)return s+(e-o);s+=a-o,s+=n-s%n,o=a+1}}function d(t,e){for(var n=0;n=e)return i+Math.min(s,e-r);if(r+=o-i,r+=n-r%n,i=o+1,r>=e)return i}}function p(t){for(;qs.length<=t;)qs.push(g(qs)+" ");return qs[t]}function g(t){return t[t.length-1]}function v(t,e){for(var n=[],i=0;i"€"&&(t.toUpperCase()!=t.toLowerCase()||Ks.test(t))}function w(t,e){return e?!!(e.source.indexOf("\\w")>-1&&x(t))||e.test(t):x(t)}function C(t){for(var e in t)if(t.hasOwnProperty(e)&&t[e])return!1;return!0}function k(t){return t.charCodeAt(0)>=768&&Gs.test(t)}function S(t,e,n){for(;(n<0?e>0:en?-1:1;;){if(e==n)return e;var r=(e+n)/2,o=i<0?Math.ceil(r):Math.floor(r);if(o==e)return t(o)?e:n;t(o)?n=o:e=o+i}}function E(t,e,n){var o=this;this.input=n,o.scrollbarFiller=i("div",null,"CodeMirror-scrollbar-filler"),o.scrollbarFiller.setAttribute("cm-not-content","true"),o.gutterFiller=i("div",null,"CodeMirror-gutter-filler"),o.gutterFiller.setAttribute("cm-not-content","true"),o.lineDiv=r("div",null,"CodeMirror-code"),o.selectionDiv=i("div",null,null,"position: relative; z-index: 1"),o.cursorDiv=i("div",null,"CodeMirror-cursors"),o.measure=i("div",null,"CodeMirror-measure"),o.lineMeasure=i("div",null,"CodeMirror-measure"),o.lineSpace=r("div",[o.measure,o.lineMeasure,o.selectionDiv,o.cursorDiv,o.lineDiv],null,"position: relative; outline: none");var s=r("div",[o.lineSpace],"CodeMirror-lines");o.mover=i("div",[s],null,"position: relative"),o.sizer=i("div",[o.mover],"CodeMirror-sizer"),o.sizerWidth=null,o.heightForcer=i("div",null,null,"position: absolute; height: "+Hs+"px; width: 1px;"),o.gutters=i("div",null,"CodeMirror-gutters"),o.lineGutter=null,o.scroller=i("div",[o.sizer,o.heightForcer,o.gutters],"CodeMirror-scroll"),o.scroller.setAttribute("tabIndex","-1"),o.wrapper=i("div",[o.scrollbarFiller,o.gutterFiller,o.scroller],"CodeMirror"),ms&&ys<8&&(o.gutters.style.zIndex=-1,o.scroller.style.paddingRight=0),bs||fs&&Ps||(o.scroller.draggable=!0),t&&(t.appendChild?t.appendChild(o.wrapper):t(o.wrapper)),o.viewFrom=o.viewTo=e.first,o.reportedViewFrom=o.reportedViewTo=e.first,o.view=[],o.renderedView=null,o.externalMeasured=null,o.viewOffset=0,o.lastWrapHeight=o.lastWrapWidth=0,o.updateLineNumbers=null,o.nativeBarWidth=o.barHeight=o.barWidth=0,o.scrollbarsClipped=!1,o.lineNumWidth=o.lineNumInnerWidth=o.lineNumChars=null,o.alignWidgets=!1,o.cachedCharWidth=o.cachedTextHeight=o.cachedPaddingH=null,o.maxLine=null,o.maxLineLength=0,o.maxLineChanged=!1,o.wheelDX=o.wheelDY=o.wheelStartX=o.wheelStartY=null,o.shift=!1,o.selForContextMenu=null,o.activeTouch=null,n.init(o)}function M(t,e){if((e-=t.first)<0||e>=t.size)throw new Error("There is no line "+(e+t.first)+" in the document.");for(var n=t;!n.lines;)for(var i=0;;++i){var r=n.children[i],o=r.chunkSize();if(e=t.first&&en?_(n,M(t,n).text.length):B(e,M(t,e.line).text.length)}function B(t,e){var n=t.ch;return null==n||n>e?_(t.line,e):n<0?_(t.line,0):t}function W(t,e){for(var n=[],i=0;i=e:o.to>e);(i||(i=[])).push(new K(s,o.from,l?null:o.to))}}return i}function Z(t,e,n){var i;if(t)for(var r=0;r=e:o.to>e);if(a||o.from==e&&"bookmark"==s.type&&(!n||o.marker.insertLeft)){var l=null==o.from||(s.inclusiveLeft?o.from<=e:o.from0&&a)for(var w=0;w0)){var u=[l,1],h=F(c.from,a.from),f=F(c.to,a.to);(h<0||!s.inclusiveLeft&&!h)&&u.push({from:c.from,to:a.from}),(f>0||!s.inclusiveRight&&!f)&&u.push({from:a.to,to:c.to}),r.splice.apply(r,u),l+=u.length-3}}return r}function nt(t){var e=t.markedSpans;if(e){for(var n=0;n=0&&h<=0||u<=0&&h>=0)&&(u<=0&&(l.marker.inclusiveRight&&r.inclusiveLeft?F(c.to,n)>=0:F(c.to,n)>0)||u>=0&&(l.marker.inclusiveRight&&r.inclusiveLeft?F(c.from,i)<=0:F(c.from,i)<0)))return!0}}}function ht(t){for(var e;e=lt(t);)t=e.find(-1,!0).line;return t}function dt(t){for(var e;e=ct(t);)t=e.find(1,!0).line;return t}function ft(t){for(var e,n;e=ct(t);)t=e.find(1,!0).line,(n||(n=[])).push(t);return n}function pt(t,e){var n=M(t,e),i=ht(n);return n==i?e:L(i)}function gt(t,e){if(e>t.lastLine())return e;var n,i=M(t,e);if(!vt(t,i))return e;for(;n=ct(i);)i=n.find(1,!0).line;return L(i)+1}function vt(t,e){var n=Xs&&e.markedSpans;if(n)for(var i=void 0,r=0;re.maxLineLength&&(e.maxLineLength=n,e.maxLine=t)})}function wt(t,e,n,i){if(!t)return i(e,n,"ltr",0);for(var r=!1,o=0;oe||e==n&&s.to==e)&&(i(Math.max(s.from,e),Math.min(s.to,n),1==s.level?"rtl":"ltr",o),r=!0)}r||i(e,n,"ltr")}function Ct(t,e,n){var i;Js=null;for(var r=0;re)return r;o.to==e&&(o.from!=o.to&&"before"==n?i=r:Js=r),o.from==e&&(o.from!=o.to&&"before"!=n?i=r:Js=r)}return null!=i?i:Js}function kt(t,e){var n=t.order;return null==n&&(n=t.order=Zs(t.text,e)),n}function St(t,e){return t._handlers&&t._handlers[e]||Qs}function Tt(t,e,n){if(t.removeEventListener)t.removeEventListener(e,n,!1);else if(t.detachEvent)t.detachEvent("on"+e,n);else{var i=t._handlers,r=i&&i[e];if(r){var o=d(r,n);o>-1&&(i[e]=r.slice(0,o).concat(r.slice(o+1)))}}}function Et(t,e){var n=St(t,e);if(n.length)for(var i=Array.prototype.slice.call(arguments,2),r=0;r0}function Ot(t){t.prototype.on=function(t,e){ta(this,t,e)},t.prototype.off=function(t,e){Tt(this,t,e)}}function Lt(t){t.preventDefault?t.preventDefault():t.returnValue=!1}function Nt(t){t.stopPropagation?t.stopPropagation():t.cancelBubble=!0}function It(t){return null!=t.defaultPrevented?t.defaultPrevented:0==t.returnValue}function Dt(t){Lt(t),Nt(t)}function _t(t){return t.target||t.srcElement}function Ft(t){var e=t.which;return null==e&&(1&t.button?e=1:2&t.button?e=3:4&t.button&&(e=2)),As&&t.ctrlKey&&1==e&&(e=3),e}function zt(t){if(null==Rs){var e=i("span","​");n(t,i("span",[e,document.createTextNode("x")])),0!=t.firstChild.offsetHeight&&(Rs=e.offsetWidth<=1&&e.offsetHeight>2&&!(ms&&ys<8))}var r=Rs?i("span","​"):i("span"," ",null,"display: inline-block; width: 1px; margin-right: -1px");return r.setAttribute("cm-text",""),r}function $t(t){if(null!=Vs)return Vs;var i=n(t,document.createTextNode("AخA")),r=Is(i,0,1).getBoundingClientRect(),o=Is(i,1,2).getBoundingClientRect();return e(t),!(!r||r.left==r.right)&&(Vs=o.right-r.right<3)}function Rt(t){if(null!=oa)return oa;var e=n(t,i("span","x")),r=e.getBoundingClientRect(),o=Is(e,0,1).getBoundingClientRect();return oa=Math.abs(r.left-o.left)>1}function Vt(t,e){arguments.length>2&&(e.dependencies=Array.prototype.slice.call(arguments,2)),sa[t]=e}function Ht(t,e){aa[t]=e}function jt(t){if("string"==typeof t&&aa.hasOwnProperty(t))t=aa[t];else if(t&&"string"==typeof t.name&&aa.hasOwnProperty(t.name)){var e=aa[t.name];"string"==typeof e&&(e={name:e}),t=b(e,t),t.name=e.name}else{if("string"==typeof t&&/^[\w\-]+\/[\w\-]+\+xml$/.test(t))return jt("application/xml");if("string"==typeof t&&/^[\w\-]+\/[\w\-]+\+json$/.test(t))return jt("application/json")}return"string"==typeof t?{name:t}:t||{name:"null"}}function Bt(t,e){e=jt(e);var n=sa[e.name];if(!n)return Bt(t,"text/plain");var i=n(t,e);if(la.hasOwnProperty(e.name)){var r=la[e.name];for(var o in r)r.hasOwnProperty(o)&&(i.hasOwnProperty(o)&&(i["_"+o]=i[o]),i[o]=r[o])}if(i.name=e.name,e.helperType&&(i.helperType=e.helperType),e.modeProps)for(var s in e.modeProps)i[s]=e.modeProps[s];return i}function Wt(t,e){u(e,la.hasOwnProperty(t)?la[t]:la[t]={})}function Ut(t,e){if(!0===e)return e;if(t.copyState)return t.copyState(e);var n={};for(var i in e){var r=e[i];r instanceof Array&&(r=r.concat([])),n[i]=r}return n}function qt(t,e){for(var n;t.innerMode&&(n=t.innerMode(e))&&n.mode!=t;)e=n.state,t=n.mode;return n||{mode:t,state:e}}function Kt(t,e,n){return!t.startState||t.startState(e,n)}function Gt(t,e,n,i){var r=[t.state.modeGen],o={};ne(t,e.text,t.doc.mode,n,function(t,e){return r.push(t,e)},o,i);for(var s=n.state,a=0;at&&r.splice(l,1,t,r[l+1],i),l+=2,c=Math.min(t,i)}if(e)if(a.opaque)r.splice(n,l-n,t,"overlay "+e),l=n+2;else for(;nt.options.maxHighlightLength&&Ut(t.doc.mode,i.state),o=Gt(t,e,i);r&&(i.state=r),e.stateAfter=i.save(!r),e.styles=o.styles,o.classes?e.styleClasses=o.classes:e.styleClasses&&(e.styleClasses=null),n===t.doc.highlightFrontier&&(t.doc.modeFrontier=Math.max(t.doc.modeFrontier,++t.doc.highlightFrontier))}return e.styles}function Xt(t,e,n){var i=t.doc,r=t.display;if(!i.mode.startState)return new ha(i,!0,e);var o=ie(t,e,n),s=o>i.first&&M(i,o-1).stateAfter,a=s?ha.fromSaved(i,s,o):new ha(i,Kt(i.mode),o);return i.iter(o,e,function(n){Jt(t,n.text,a);var i=a.line;n.stateAfter=i==e-1||i%5==0||i>=r.viewFrom&&ie.start)return o}throw new Error("Mode "+t.name+" failed to advance stream.")}function te(t,e,n,i){var r,o=t.doc,s=o.mode;e=j(o,e);var a,l=M(o,e.line),c=Xt(t,e.line,n),u=new ca(l.text,t.options.tabSize,c);for(i&&(a=[]);(i||u.post.options.maxHighlightLength?(a=!1,s&&Jt(t,e,i,h.pos),h.pos=e.length,l=null):l=ee(Qt(n,h,i.state,d),o),d){var f=d[0].name;f&&(l="m-"+(l?f+" "+l:f))}if(!a||u!=l){for(;cs;--a){if(a<=o.first)return o.first;var l=M(o,a-1),c=l.stateAfter;if(c&&(!n||a+(c instanceof ua?c.lookAhead:0)<=o.modeFrontier))return a;var u=h(l.text,null,t.options.tabSize);(null==r||i>u)&&(r=a-1,i=u)}return r}function re(t,e){if(t.modeFrontier=Math.min(t.modeFrontier,e),!(t.highlightFrontiern;i--){var r=M(t,i).stateAfter;if(r&&(!(r instanceof ua)||i+r.lookAhead1&&!/ /.test(t))return t;for(var n=e,i="",r=0;rc&&h.from<=c));d++);if(h.to>=u)return t(n,i,r,o,s,a,l);t(n,i.slice(0,h.to-c),r,o,null,a,l),o=null,i=i.slice(h.to-c),c=h.to}}}function fe(t,e,n,i){var r=!i&&n.widgetNode;r&&t.map.push(t.pos,t.pos+e,r),!i&&t.cm.display.input.needsContentAttribute&&(r||(r=t.content.appendChild(document.createElement("span"))),r.setAttribute("cm-marker",n.id)),r&&(t.cm.display.input.setUneditable(r),t.content.appendChild(r)),t.pos+=e,t.trailingSpace=!1}function pe(t,e,n){var i=t.markedSpans,r=t.text,o=0;if(i)for(var s,a,l,c,u,h,d,f=r.length,p=0,g=1,v="",m=0;;){if(m==p){l=c=u=h=a="",d=null,m=1/0;for(var y=[],b=void 0,x=0;xp||C.collapsed&&w.to==p&&w.from==p)?(null!=w.to&&w.to!=p&&m>w.to&&(m=w.to,c=""),C.className&&(l+=" "+C.className),C.css&&(a=(a?a+";":"")+C.css),C.startStyle&&w.from==p&&(u+=" "+C.startStyle),C.endStyle&&w.to==m&&(b||(b=[])).push(C.endStyle,w.to),C.title&&!h&&(h=C.title),C.collapsed&&(!d||st(d.marker,C)<0)&&(d=w)):w.from>p&&m>w.from&&(m=w.from)}if(b)for(var k=0;k=f)break;for(var T=Math.min(f,m);;){if(v){var E=p+v.length;if(!d){var M=E>T?v.slice(0,T-p):v;e.addToken(e,M,s?s+l:l,u,p+M.length==m?c:"",h,a)}if(E>=T){v=v.slice(T-p),p=T;break}p=E,u=""}v=r.slice(o,o=n[g++]),s=ae(n[g++],e.cm.options)}}else for(var P=1;P2&&o.push((l.bottom+c.top)/2-n.top)}}o.push(n.bottom-n.top)}}function Be(t,e,n){if(t.line==e)return{map:t.measure.map,cache:t.measure.cache};for(var i=0;in)return{map:t.measure.maps[r],cache:t.measure.caches[r],before:!0}}function We(t,e){e=ht(e);var i=L(e),r=t.display.externalMeasured=new ge(t.doc,e,i);r.lineN=i;var o=r.built=le(t,r);return r.text=o.pre,n(t.display.lineMeasure,o.pre),r}function Ue(t,e,n,i){return Ge(t,Ke(t,e),n,i)}function qe(t,e){if(e>=t.display.viewFrom&&e=n.lineN&&ee)&&(o=l-a,r=o-1,e>=l&&(s="right")),null!=r){if(i=t[c+2],a==l&&n==(i.insertLeft?"left":"right")&&(s=n),"left"==n&&0==r)for(;c&&t[c-2]==t[c-3]&&t[c-1].insertLeft;)i=t[2+(c-=3)],s="left";if("right"==n&&r==l-a)for(;c=0&&(n=t[r]).left==n.right;r--);return n}function Je(t,e,n,i){var r,o=Ye(e.map,n,i),s=o.node,a=o.start,l=o.end,c=o.collapse;if(3==s.nodeType){for(var u=0;u<4;u++){for(;a&&k(e.line.text.charAt(o.coverStart+a));)--a;for(;o.coverStart+l0&&(c=i="right");var h;r=t.options.lineWrapping&&(h=s.getClientRects()).length>1?h["right"==i?h.length-1:0]:s.getBoundingClientRect()}if(ms&&ys<9&&!a&&(!r||!r.left&&!r.right)){var d=s.parentNode.getClientRects()[0];r=d?{left:d.left,right:d.left+xn(t.display),top:d.top,bottom:d.bottom}:ba}for(var f=r.top-e.rect.top,p=r.bottom-e.rect.top,g=(f+p)/2,v=e.view.measure.heights,m=0;m=i.text.length?(c=i.text.length,u="before"):c<=0&&(c=0,u="after"),!l)return s("before"==u?c-1:c,"before"==u);var h=Ct(l,c,u),d=Js,f=a(c,h,"before"==u);return null!=d&&(f.other=a(c,d,"before"!=u)),f}function un(t,e){var n=0;e=j(t.doc,e),t.options.lineWrapping||(n=xn(t.display)*e.ch);var i=M(t.doc,e.line),r=yt(i)+Fe(t.display);return{left:n,right:n,top:r,bottom:r+i.height}}function hn(t,e,n,i,r){var o=_(t,e,n);return o.xRel=r,i&&(o.outside=!0),o}function dn(t,e,n){var i=t.doc;if((n+=t.display.viewOffset)<0)return hn(i.first,0,null,!0,-1);var r=N(i,n),o=i.first+i.size-1;if(r>o)return hn(i.first+i.size-1,M(i,o).text.length,null,!0,1);e<0&&(e=0);for(var s=M(i,r);;){var a=vn(t,s,r,e,n),l=ct(s),c=l&&l.find(0,!0);if(!l||!(a.ch>c.from.ch||a.ch==c.from.ch&&a.xRel>0))return a;r=L(s=c.to.line)}}function fn(t,e,n,i){i-=on(e);var r=e.text.length,o=T(function(e){return Ge(t,n,e-1).bottom<=i},r,0);return r=T(function(e){return Ge(t,n,e).top>i},o,r),{begin:o,end:r}}function pn(t,e,n,i){return n||(n=Ke(t,e)),fn(t,e,n,sn(t,e,Ge(t,n,i),"line").top)}function gn(t,e,n,i){return!(t.bottom<=n)&&(t.top>n||(i?t.left:t.right)>e)}function vn(t,e,n,i,r){r-=yt(e);var o=Ke(t,e),s=on(e),a=0,l=e.text.length,c=!0,u=kt(e,t.doc.direction);if(u){var h=(t.options.lineWrapping?yn:mn)(t,e,n,o,u,i,r);c=1!=h.level,a=c?h.from:h.to-1,l=c?h.to:h.from-1}var d,f,p=null,g=null,v=T(function(e){var n=Ge(t,o,e);return n.top+=s,n.bottom+=s,!!gn(n,i,r,!1)&&(n.top<=r&&n.left<=i&&(p=e,g=n),!0)},a,l),m=!1;if(g){var y=i-g.left=x.bottom}return v=S(e.text,v,1),hn(n,v,f,m,i-d)}function mn(t,e,n,i,r,o,s){var a=T(function(a){var l=r[a],c=1!=l.level;return gn(cn(t,_(n,c?l.to:l.from,c?"before":"after"),"line",e,i),o,s,!0)},0,r.length-1),l=r[a];if(a>0){var c=1!=l.level,u=cn(t,_(n,c?l.from:l.to,c?"after":"before"),"line",e,i);gn(u,o,s,!0)&&u.top>s&&(l=r[a-1])}return l}function yn(t,e,n,i,r,o,s){var a=fn(t,e,i,s),l=a.begin,c=a.end;/\s/.test(e.text.charAt(c-1))&&c--;for(var u=null,h=null,d=0;d=c||f.to<=l)){var p=1!=f.level,g=Ge(t,i,p?Math.min(c,f.to)-1:Math.max(l,f.from)).right,v=gv)&&(u=f,h=v)}}return u||(u=r[r.length-1]),u.fromc&&(u={from:u.from,to:c,level:u.level}),u}function bn(t){if(null!=t.cachedTextHeight)return t.cachedTextHeight;if(null==pa){pa=i("pre");for(var r=0;r<49;++r)pa.appendChild(document.createTextNode("x")),pa.appendChild(i("br"));pa.appendChild(document.createTextNode("x"))}n(t.measure,pa);var o=pa.offsetHeight/50;return o>3&&(t.cachedTextHeight=o),e(t.measure),o||1}function xn(t){if(null!=t.cachedCharWidth)return t.cachedCharWidth;var e=i("span","xxxxxxxxxx"),r=i("pre",[e]);n(t.measure,r);var o=e.getBoundingClientRect(),s=(o.right-o.left)/10;return s>2&&(t.cachedCharWidth=s),s||10}function wn(t){for(var e=t.display,n={},i={},r=e.gutters.clientLeft,o=e.gutters.firstChild,s=0;o;o=o.nextSibling,++s)n[t.options.gutters[s]]=o.offsetLeft+o.clientLeft+r,i[t.options.gutters[s]]=o.clientWidth;return{fixedPos:Cn(e),gutterTotalWidth:e.gutters.offsetWidth,gutterLeft:n,gutterWidth:i,wrapperWidth:e.wrapper.clientWidth}}function Cn(t){return t.scroller.getBoundingClientRect().left-t.sizer.getBoundingClientRect().left}function kn(t){var e=bn(t.display),n=t.options.lineWrapping,i=n&&Math.max(5,t.display.scroller.clientWidth/xn(t.display)-3);return function(r){if(vt(t.doc,r))return 0;var o=0;if(r.widgets)for(var s=0;s=t.display.viewTo)return null;if((e-=t.display.viewFrom)<0)return null;for(var n=t.display.view,i=0;i=t.display.viewTo||a.to().line0?e.blinker=setInterval(function(){return e.cursorDiv.style.visibility=(n=!n)?"":"hidden"},t.options.cursorBlinkRate):t.options.cursorBlinkRate<0&&(e.cursorDiv.style.visibility="hidden")}}function In(t){t.state.focused||(t.display.input.focus(),_n(t))}function Dn(t){t.state.delayingBlurEvent=!0,setTimeout(function(){t.state.delayingBlurEvent&&(t.state.delayingBlurEvent=!1,Fn(t))},100)}function _n(t,e){t.state.delayingBlurEvent&&(t.state.delayingBlurEvent=!1),"nocursor"!=t.options.readOnly&&(t.state.focused||(Et(t,"focus",t,e),t.state.focused=!0,a(t.display.wrapper,"CodeMirror-focused"),t.curOp||t.display.selForContextMenu==t.doc.sel||(t.display.input.reset(),bs&&setTimeout(function(){return t.display.input.reset(!0)},20)),t.display.input.receivedFocus()),Nn(t))}function Fn(t,e){t.state.delayingBlurEvent||(t.state.focused&&(Et(t,"blur",t,e),t.state.focused=!1,Fs(t.display.wrapper,"CodeMirror-focused")),clearInterval(t.display.blinker),setTimeout(function(){t.state.focused||(t.display.shift=!1)},150))}function zn(t){for(var e=t.display,n=e.lineDiv.offsetTop,i=0;i.005||l<-.005)&&(O(r.line,o),$n(r.line),r.rest))for(var c=0;c=s&&(o=N(e,yt(M(e,l))-t.wrapper.clientHeight),s=l)}return{from:o,to:Math.max(s,o+1)}}function Vn(t){var e=t.display,n=e.view;if(e.alignWidgets||e.gutters.firstChild&&t.options.fixedGutter){for(var i=Cn(e)-e.scroller.scrollLeft+t.doc.scrollLeft,r=e.gutters.offsetWidth,o=i+"px",s=0;s(window.innerHeight||document.documentElement.clientHeight)&&(o=!1),null!=o&&!Ts){var s=i("div","​",null,"position: absolute;\n top: "+(e.top-n.viewOffset-Fe(t.display))+"px;\n height: "+(e.bottom-e.top+Re(t)+n.barHeight)+"px;\n left: "+e.left+"px; width: "+Math.max(2,e.right-e.left)+"px;");t.display.lineSpace.appendChild(s),s.scrollIntoView(o),t.display.lineSpace.removeChild(s)}}}function Bn(t,e,n,i){null==i&&(i=0);var r;t.options.lineWrapping||e!=n||(e=e.ch?_(e.line,"before"==e.sticky?e.ch-1:e.ch,"after"):e,n="before"==e.sticky?_(e.line,e.ch+1,"before"):e);for(var o=0;o<5;o++){var s=!1,a=cn(t,e),l=n&&n!=e?cn(t,n):a;r={left:Math.min(a.left,l.left),top:Math.min(a.top,l.top)-i,right:Math.max(a.left,l.left),bottom:Math.max(a.bottom,l.bottom)+i};var c=Un(t,r),u=t.doc.scrollTop,h=t.doc.scrollLeft;if(null!=c.scrollTop&&(Zn(t,c.scrollTop),Math.abs(t.doc.scrollTop-u)>1&&(s=!0)),null!=c.scrollLeft&&(ti(t,c.scrollLeft),Math.abs(t.doc.scrollLeft-h)>1&&(s=!0)),!s)break}return r}function Wn(t,e){var n=Un(t,e);null!=n.scrollTop&&Zn(t,n.scrollTop),null!=n.scrollLeft&&ti(t,n.scrollLeft)}function Un(t,e){var n=t.display,i=bn(t.display);e.top<0&&(e.top=0);var r=t.curOp&&null!=t.curOp.scrollTop?t.curOp.scrollTop:n.scroller.scrollTop,o=He(t),s={};e.bottom-e.top>o&&(e.bottom=e.top+o);var a=t.doc.height+ze(n),l=e.topa-i;if(e.topr+o){var u=Math.min(e.top,(c?a:e.bottom)-o);u!=r&&(s.scrollTop=u)}var h=t.curOp&&null!=t.curOp.scrollLeft?t.curOp.scrollLeft:n.scroller.scrollLeft,d=Ve(t)-(t.options.fixedGutter?n.gutters.offsetWidth:0),f=e.right-e.left>d;return f&&(e.right=e.left+d),e.left<10?s.scrollLeft=0:e.leftd+h-3&&(s.scrollLeft=e.right+(f?0:10)-d),s}function qn(t,e){null!=e&&(Xn(t),t.curOp.scrollTop=(null==t.curOp.scrollTop?t.doc.scrollTop:t.curOp.scrollTop)+e)}function Kn(t){Xn(t);var e=t.getCursor();t.curOp.scrollToPos={from:e,to:e,margin:t.options.cursorScrollMargin}}function Gn(t,e,n){null==e&&null==n||Xn(t),null!=e&&(t.curOp.scrollLeft=e),null!=n&&(t.curOp.scrollTop=n)}function Yn(t,e){Xn(t),t.curOp.scrollToPos=e}function Xn(t){var e=t.curOp.scrollToPos;if(e){t.curOp.scrollToPos=null;Jn(t,un(t,e.from),un(t,e.to),e.margin)}}function Jn(t,e,n,i){var r=Un(t,{left:Math.min(e.left,n.left),top:Math.min(e.top,n.top)-i,right:Math.max(e.right,n.right),bottom:Math.max(e.bottom,n.bottom)+i});Gn(t,r.scrollLeft,r.scrollTop)}function Zn(t,e){Math.abs(t.doc.scrollTop-e)<2||(fs||Oi(t,{top:e}),Qn(t,e,!0),fs&&Oi(t),ki(t,100))}function Qn(t,e,n){e=Math.min(t.display.scroller.scrollHeight-t.display.scroller.clientHeight,e),(t.display.scroller.scrollTop!=e||n)&&(t.doc.scrollTop=e,t.display.scrollbars.setScrollTop(e),t.display.scroller.scrollTop!=e&&(t.display.scroller.scrollTop=e))}function ti(t,e,n,i){e=Math.min(e,t.display.scroller.scrollWidth-t.display.scroller.clientWidth),(n?e==t.doc.scrollLeft:Math.abs(t.doc.scrollLeft-e)<2)&&!i||(t.doc.scrollLeft=e,Vn(t),t.display.scroller.scrollLeft!=e&&(t.display.scroller.scrollLeft=e),t.display.scrollbars.setScrollLeft(e))}function ei(t){var e=t.display,n=e.gutters.offsetWidth,i=Math.round(t.doc.height+ze(t.display));return{clientHeight:e.scroller.clientHeight,viewHeight:e.wrapper.clientHeight,scrollWidth:e.scroller.scrollWidth,clientWidth:e.scroller.clientWidth,viewWidth:e.wrapper.clientWidth,barLeft:t.options.fixedGutter?n:0,docHeight:i,scrollHeight:i+Re(t)+e.barHeight,nativeBarWidth:e.nativeBarWidth,gutterWidth:n}}function ni(t,e){e||(e=ei(t));var n=t.display.barWidth,i=t.display.barHeight;ii(t,e);for(var r=0;r<4&&n!=t.display.barWidth||i!=t.display.barHeight;r++)n!=t.display.barWidth&&t.options.lineWrapping&&zn(t),ii(t,ei(t)),n=t.display.barWidth,i=t.display.barHeight}function ii(t,e){var n=t.display,i=n.scrollbars.update(e);n.sizer.style.paddingRight=(n.barWidth=i.right)+"px",n.sizer.style.paddingBottom=(n.barHeight=i.bottom)+"px",n.heightForcer.style.borderBottom=i.bottom+"px solid transparent",i.right&&i.bottom?(n.scrollbarFiller.style.display="block",n.scrollbarFiller.style.height=i.bottom+"px",n.scrollbarFiller.style.width=i.right+"px"):n.scrollbarFiller.style.display="",i.bottom&&t.options.coverGutterNextToScrollbar&&t.options.fixedGutter?(n.gutterFiller.style.display="block",n.gutterFiller.style.height=i.bottom+"px",n.gutterFiller.style.width=e.gutterWidth+"px"):n.gutterFiller.style.display=""}function ri(t){t.display.scrollbars&&(t.display.scrollbars.clear(),t.display.scrollbars.addClass&&Fs(t.display.wrapper,t.display.scrollbars.addClass)),t.display.scrollbars=new Ca[t.options.scrollbarStyle](function(e){t.display.wrapper.insertBefore(e,t.display.scrollbarFiller),ta(e,"mousedown",function(){t.state.focused&&setTimeout(function(){return t.display.input.focus()},0)}),e.setAttribute("cm-not-content","true")},function(e,n){"horizontal"==n?ti(t,e):Zn(t,e)},t),t.display.scrollbars.addClass&&a(t.display.wrapper,t.display.scrollbars.addClass)}function oi(t){t.curOp={cm:t,viewChanged:!1,startHeight:t.doc.height,forceUpdate:!1,updateInput:null,typing:!1,changeObjs:null,cursorActivityHandlers:null,cursorActivityCalled:0,selectionChanged:!1,updateMaxLine:!1,scrollLeft:null,scrollTop:null,scrollToPos:null,focus:!1,id:++ka},me(t.curOp)}function si(t){be(t.curOp,function(t){for(var e=0;e=n.viewTo)||n.maxLineChanged&&e.options.lineWrapping,t.update=t.mustUpdate&&new Sa(e,t.mustUpdate&&{top:t.scrollTop,ensure:t.scrollToPos},t.forceUpdate)}function ci(t){t.updatedDisplay=t.mustUpdate&&Pi(t.cm,t.update)}function ui(t){var e=t.cm,n=e.display;t.updatedDisplay&&zn(e),t.barMeasure=ei(e),n.maxLineChanged&&!e.options.lineWrapping&&(t.adjustWidthTo=Ue(e,n.maxLine,n.maxLine.text.length).left+3,e.display.sizerWidth=t.adjustWidthTo,t.barMeasure.scrollWidth=Math.max(n.scroller.clientWidth,n.sizer.offsetLeft+t.adjustWidthTo+Re(e)+e.display.barWidth),t.maxScrollLeft=Math.max(0,n.sizer.offsetLeft+t.adjustWidthTo-Ve(e))),(t.updatedDisplay||t.selectionChanged)&&(t.preparedSelection=n.input.prepareSelection())}function hi(t){var e=t.cm;null!=t.adjustWidthTo&&(e.display.sizer.style.minWidth=t.adjustWidthTo+"px",t.maxScrollLefte)&&(r.updateLineNumbers=e),t.curOp.viewChanged=!0,e>=r.viewTo)Xs&&pt(t.doc,e)r.viewFrom?bi(t):(r.viewFrom+=i,r.viewTo+=i);else if(e<=r.viewFrom&&n>=r.viewTo)bi(t);else if(e<=r.viewFrom){var o=xi(t,n,n+i,1);o?(r.view=r.view.slice(o.index),r.viewFrom=o.lineN,r.viewTo+=i):bi(t)}else if(n>=r.viewTo){var s=xi(t,e,e,-1);s?(r.view=r.view.slice(0,s.index),r.viewTo=s.lineN):bi(t)}else{var a=xi(t,e,e,-1),l=xi(t,n,n+i,1);a&&l?(r.view=r.view.slice(0,a.index).concat(ve(t,a.lineN,l.lineN)).concat(r.view.slice(l.index)),r.viewTo+=i):bi(t)}var c=r.externalMeasured;c&&(n=r.lineN&&e=i.viewTo)){var o=i.view[En(t,e)];if(null!=o.node){var s=o.changes||(o.changes=[]);-1==d(s,n)&&s.push(n)}}}function bi(t){t.display.viewFrom=t.display.viewTo=t.doc.first,t.display.view=[],t.display.viewOffset=0}function xi(t,e,n,i){var r,o=En(t,e),s=t.display.view;if(!Xs||n==t.doc.first+t.doc.size)return{index:o,lineN:n};for(var a=t.display.viewFrom,l=0;l0){if(o==s.length-1)return null;r=a+s[o].size-e,o++}else r=a-e;e+=r,n+=r}for(;pt(t.doc,n)!=n;){if(o==(i<0?0:s.length-1))return null;n+=i*s[o-(i<0?1:0)].size,o+=i}return{index:o,lineN:n}}function wi(t,e,n){var i=t.display;0==i.view.length||e>=i.viewTo||n<=i.viewFrom?(i.view=ve(t,e,n),i.viewFrom=e):(i.viewFrom>e?i.view=ve(t,e,i.viewFrom).concat(i.view):i.viewFromn&&(i.view=i.view.slice(0,En(t,n)))),i.viewTo=n}function Ci(t){for(var e=t.display.view,n=0,i=0;i=t.display.viewTo)){var n=+new Date+t.options.workTime,i=Xt(t,e.highlightFrontier),r=[];e.iter(i.line,Math.min(e.first+e.size,t.display.viewTo+500),function(o){if(i.line>=t.display.viewFrom){var s=o.styles,a=o.text.length>t.options.maxHighlightLength?Ut(e.mode,i.state):null,l=Gt(t,o,i,!0);a&&(i.state=a),o.styles=l.styles;var c=o.styleClasses,u=l.classes;u?o.styleClasses=u:c&&(o.styleClasses=null);for(var h=!s||s.length!=o.styles.length||c!=u&&(!c||!u||c.bgClass!=u.bgClass||c.textClass!=u.textClass),d=0;!h&&dn)return ki(t,t.options.workDelay),!0}),e.highlightFrontier=i.line,e.modeFrontier=Math.max(e.modeFrontier,i.line),r.length&&fi(t,function(){for(var e=0;e=i.viewFrom&&n.visible.to<=i.viewTo&&(null==i.updateLineNumbers||i.updateLineNumbers>=i.viewTo)&&i.renderedView==i.view&&0==Ci(t))return!1;Hn(t)&&(bi(t),n.dims=wn(t));var o=r.first+r.size,s=Math.max(n.visible.from-t.options.viewportMargin,r.first),a=Math.min(o,n.visible.to+t.options.viewportMargin);i.viewFroma&&i.viewTo-a<20&&(a=Math.min(o,i.viewTo)),Xs&&(s=pt(t.doc,s),a=gt(t.doc,a));var l=s!=i.viewFrom||a!=i.viewTo||i.lastWrapHeight!=n.wrapperHeight||i.lastWrapWidth!=n.wrapperWidth;wi(t,s,a),i.viewOffset=yt(M(t.doc,i.viewFrom)),t.display.mover.style.top=i.viewOffset+"px";var c=Ci(t);if(!l&&0==c&&!n.force&&i.renderedView==i.view&&(null==i.updateLineNumbers||i.updateLineNumbers>=i.viewTo))return!1;var u=Ei(t);return c>4&&(i.lineDiv.style.display="none"),Li(t,i.updateLineNumbers,n.dims),c>4&&(i.lineDiv.style.display=""),i.renderedView=i.view,Mi(u),e(i.cursorDiv),e(i.selectionDiv),i.gutters.style.height=i.sizer.style.minHeight=0,l&&(i.lastWrapHeight=n.wrapperHeight,i.lastWrapWidth=n.wrapperWidth,ki(t,400)),i.updateLineNumbers=null,!0}function Ai(t,e){for(var n=e.viewport,i=!0;(i&&t.options.lineWrapping&&e.oldDisplayWidth!=Ve(t)||(n&&null!=n.top&&(n={top:Math.min(t.doc.height+ze(t.display)-He(t),n.top)}),e.visible=Rn(t.display,t.doc,n),!(e.visible.from>=t.display.viewFrom&&e.visible.to<=t.display.viewTo)))&&Pi(t,e);i=!1){zn(t);var r=ei(t);Mn(t),ni(t,r),Ii(t,r),e.force=!1}e.signal(t,"update",t),t.display.viewFrom==t.display.reportedViewFrom&&t.display.viewTo==t.display.reportedViewTo||(e.signal(t,"viewportChange",t,t.display.viewFrom,t.display.viewTo),t.display.reportedViewFrom=t.display.viewFrom,t.display.reportedViewTo=t.display.viewTo)}function Oi(t,e){var n=new Sa(t,e);if(Pi(t,n)){zn(t),Ai(t,n);var i=ei(t);Mn(t),ni(t,i),Ii(t,i),n.finish()}}function Li(t,n,i){function r(e){var n=e.nextSibling;return bs&&As&&t.display.currentWheelTarget==e?e.style.display="none":e.parentNode.removeChild(e),n}for(var o=t.display,s=t.options.lineNumbers,a=o.lineDiv,l=a.firstChild,c=o.view,u=o.viewFrom,h=0;h-1&&(p=!1),Ce(t,f,u,i)),p&&(e(f.lineNumber),f.lineNumber.appendChild(document.createTextNode(D(t.options,u)))),l=f.node.nextSibling}else{var g=Oe(t,f,u,i);a.insertBefore(g,l)}u+=f.size}for(;l;)l=r(l)}function Ni(t){var e=t.display.gutters.offsetWidth;t.display.sizer.style.marginLeft=e+"px"}function Ii(t,e){t.display.sizer.style.minHeight=e.docHeight+"px",t.display.heightForcer.style.top=e.docHeight+"px",t.display.gutters.style.height=e.docHeight+t.display.barHeight+Re(t)+"px"}function Di(t){var n=t.display.gutters,r=t.options.gutters;e(n);for(var o=0;o-1&&!t.lineNumbers&&(t.gutters=t.gutters.slice(0),t.gutters.splice(e,1))}function Fi(t){var e=t.wheelDeltaX,n=t.wheelDeltaY;return null==e&&t.detail&&t.axis==t.HORIZONTAL_AXIS&&(e=t.detail),null==n&&t.detail&&t.axis==t.VERTICAL_AXIS?n=t.detail:null==n&&(n=t.wheelDelta),{x:e,y:n}}function zi(t){var e=Fi(t);return e.x*=Ea,e.y*=Ea,e}function $i(t,e){var n=Fi(e),i=n.x,r=n.y,o=t.display,s=o.scroller,a=s.scrollWidth>s.clientWidth,l=s.scrollHeight>s.clientHeight;if(i&&a||r&&l){if(r&&As&&bs)t:for(var c=e.target,u=o.view;c!=s;c=c.parentNode)for(var h=0;h=0){var s=V(o.from(),r.from()),a=R(o.to(),r.to()),l=o.empty()?r.from()==r.head:o.from()==o.head;i<=e&&--e,t.splice(--i,2,new Pa(l?a:s,l?s:a))}}return new Ma(t,e)}function Vi(t,e){return new Ma([new Pa(t,e||t)],0)}function Hi(t){return t.text?_(t.from.line+t.text.length-1,g(t.text).length+(1==t.text.length?t.from.ch:0)):t.to}function ji(t,e){if(F(t,e.from)<0)return t;if(F(t,e.to)<=0)return Hi(e);var n=t.line+e.text.length-(e.to.line-e.from.line)-1,i=t.ch;return t.line==e.to.line&&(i+=Hi(e).ch-e.to.ch),_(n,i)}function Bi(t,e){for(var n=[],i=0;i1&&t.remove(a.line+1,p-1),t.insert(a.line+1,y)}xe(t,"change",t,e)}function Xi(t,e,n){function i(t,r,o){if(t.linked)for(var s=0;s1&&!t.done[t.done.length-2].ranges?(t.done.pop(),g(t.done)):void 0}function rr(t,e,n,i){var r=t.history;r.undone.length=0;var o,s,a=+new Date;if((r.lastOp==i||r.lastOrigin==e.origin&&e.origin&&("+"==e.origin.charAt(0)&&t.cm&&r.lastModTime>a-t.cm.options.historyEventDelay||"*"==e.origin.charAt(0)))&&(o=ir(r,r.lastOp==i)))s=g(o.changes),0==F(e.from,e.to)&&0==F(e.from,s.to)?s.to=Hi(e):o.changes.push(er(t,e));else{var l=g(r.done);for(l&&l.ranges||ar(t.sel,r.done),o={changes:[er(t,e)],generation:r.generation},r.done.push(o);r.done.length>r.undoDepth;)r.done.shift(),r.done[0].ranges||r.done.shift()}r.done.push(n),r.generation=++r.maxGeneration,r.lastModTime=r.lastSelTime=a,r.lastOp=r.lastSelOp=i,r.lastOrigin=r.lastSelOrigin=e.origin,s||Et(t,"historyAdded")}function or(t,e,n,i){var r=e.charAt(0);return"*"==r||"+"==r&&n.ranges.length==i.ranges.length&&n.somethingSelected()==i.somethingSelected()&&new Date-t.history.lastSelTime<=(t.cm?t.cm.options.historyEventDelay:500)}function sr(t,e,n,i){var r=t.history,o=i&&i.origin;n==r.lastSelOp||o&&r.lastSelOrigin==o&&(r.lastModTime==r.lastSelTime&&r.lastOrigin==o||or(t,o,g(r.done),e))?r.done[r.done.length-1]=e:ar(e,r.done),r.lastSelTime=+new Date,r.lastSelOrigin=o,r.lastSelOp=n,i&&!1!==i.clearRedo&&nr(r.undone)}function ar(t,e){var n=g(e);n&&n.ranges&&n.equals(t)||e.push(t)}function lr(t,e,n,i){var r=e["spans_"+t.id],o=0;t.iter(Math.max(t.first,n),Math.min(t.first+t.size,i),function(n){n.markedSpans&&((r||(r=e["spans_"+t.id]={}))[o]=n.markedSpans),++o})}function cr(t){if(!t)return null;for(var e,n=0;n-1&&(g(a)[h]=c[h],delete c[h])}}}return i}function fr(t,e,n,i){if(i){var r=t.anchor;if(n){var o=F(e,r)<0;o!=F(n,r)<0?(r=e,e=n):o!=F(e,n)<0&&(e=n)}return new Pa(r,e)}return new Pa(n||e,e)}function pr(t,e,n,i,r){null==r&&(r=t.cm&&(t.cm.display.shift||t.extend)),xr(t,new Ma([fr(t.sel.primary(),e,n,r)],0),i)}function gr(t,e,n){for(var i=[],r=t.cm&&(t.cm.display.shift||t.extend),o=0;o=e.ch:a.to>e.ch))){if(r&&(Et(l,"beforeCursorEnter"),l.explicitlyCleared)){if(o.markedSpans){--s;continue}break}if(!l.atomic)continue;if(n){var c=l.find(i<0?1:-1),u=void 0;if((i<0?l.inclusiveRight:l.inclusiveLeft)&&(c=Mr(t,c,-i,c&&c.line==e.line?o:null)),c&&c.line==e.line&&(u=F(c,n))&&(i<0?u<0:u>0))return Tr(t,c,e,i,r)}var h=l.find(i<0?-1:1);return(i<0?l.inclusiveLeft:l.inclusiveRight)&&(h=Mr(t,h,i,h.line==e.line?o:null)),h?Tr(t,h,e,i,r):null}}return e}function Er(t,e,n,i,r){var o=i||1,s=Tr(t,e,n,o,r)||!r&&Tr(t,e,n,o,!0)||Tr(t,e,n,-o,r)||!r&&Tr(t,e,n,-o,!0);return s||(t.cantEdit=!0,_(t.first,0))}function Mr(t,e,n,i){return n<0&&0==e.ch?e.line>t.first?j(t,_(e.line-1)):null:n>0&&e.ch==(i||M(t,e.line)).text.length?e.line=0;--r)Lr(t,{from:i[r].from,to:i[r].to,text:r?[""]:e.text,origin:e.origin});else Lr(t,e)}}function Lr(t,e){if(1!=e.text.length||""!=e.text[0]||0!=F(e.from,e.to)){var n=Bi(t,e);rr(t,e,n,t.cm?t.cm.curOp.id:NaN),Dr(t,e,n,Q(t,e));var i=[];Xi(t,function(t,n){n||-1!=d(i,t.history)||(Rr(t.history,e),i.push(t.history)),Dr(t,e,null,Q(t,e))})}}function Nr(t,e,n){if(!t.cm||!t.cm.state.suppressEdits||n){for(var i,r=t.history,o=t.sel,s="undo"==e?r.done:r.undone,a="undo"==e?r.undone:r.done,l=0;l=0;--h){var f=function(n){var r=i.changes[n];if(r.origin=e,u&&!Ar(t,r,!1))return s.length=0,{};c.push(er(t,r));var o=n?Bi(t,r):g(s);Dr(t,r,o,hr(t,r)),!n&&t.cm&&t.cm.scrollIntoView({from:r.from,to:Hi(r)});var a=[];Xi(t,function(t,e){e||-1!=d(a,t.history)||(Rr(t.history,r),a.push(t.history)),Dr(t,r,null,hr(t,r))})}(h);if(f)return f.v}}}}function Ir(t,e){if(0!=e&&(t.first+=e,t.sel=new Ma(v(t.sel.ranges,function(t){return new Pa(_(t.anchor.line+e,t.anchor.ch),_(t.head.line+e,t.head.ch))}),t.sel.primIndex),t.cm)){mi(t.cm,t.first,t.first-e,e);for(var n=t.cm.display,i=n.viewFrom;it.lastLine())){if(e.from.lineo&&(e={from:e.from,to:_(o,M(t,o).text.length),text:[e.text[0]],origin:e.origin}),e.removed=P(t,e.from,e.to),n||(n=Bi(t,e)),t.cm?_r(t.cm,e,i):Yi(t,e,i),wr(t,n,Bs)}}function _r(t,e,n){var i=t.doc,r=t.display,o=e.from,s=e.to,a=!1,l=o.line;t.options.lineWrapping||(l=L(ht(M(i,o.line))),i.iter(l,s.line+1,function(t){if(t==r.maxLine)return a=!0,!0})),i.sel.contains(e.from,e.to)>-1&&Pt(t),Yi(i,e,n,kn(t)),t.options.lineWrapping||(i.iter(l,o.line+e.text.length,function(t){var e=bt(t);e>r.maxLineLength&&(r.maxLine=t,r.maxLineLength=e,r.maxLineChanged=!0,a=!1)}),a&&(t.curOp.updateMaxLine=!0)),re(i,o.line),ki(t,400);var c=e.text.length-(s.line-o.line)-1;e.full?mi(t):o.line!=s.line||1!=e.text.length||Gi(t.doc,e)?mi(t,o.line,s.line+1,c):yi(t,o.line,"text");var u=At(t,"changes"),h=At(t,"change");if(h||u){var d={from:o,to:s,text:e.text,removed:e.removed,origin:e.origin};h&&xe(t,"change",t,d),u&&(t.curOp.changeObjs||(t.curOp.changeObjs=[])).push(d)}t.display.selForContextMenu=null}function Fr(t,e,n,i,r){if(i||(i=n),F(i,n)<0){var o;o=[i,n],n=o[0],i=o[1]}"string"==typeof e&&(e=t.splitLines(e)),Or(t,{from:n,to:i,text:e,origin:r})}function zr(t,e,n,i){n0||0==a&&!1!==s.clearWhenEmpty)return s;if(s.replacedWith&&(s.collapsed=!0,s.widgetNode=r("span",[s.replacedWith],"CodeMirror-widget"),i.handleMouseEvents||s.widgetNode.setAttribute("cm-ignore-events","true"),i.insertLeft&&(s.widgetNode.insertLeft=!0)),s.collapsed){if(ut(t,e.line,e,n,s)||e.line!=n.line&&ut(t,n.line,e,n,s))throw new Error("Inserting collapsed marker partially overlapping an existing one");q()}s.addToHistory&&rr(t,{from:e,to:n,origin:"markText"},t.sel,NaN);var l,c=e.line,h=t.cm;if(t.iter(c,n.line+1,function(t){h&&s.collapsed&&!h.options.lineWrapping&&ht(t)==h.display.maxLine&&(l=!0),s.collapsed&&c!=e.line&&O(t,0),X(t,new K(s,c==e.line?e.ch:null,c==n.line?n.ch:null)),++c}),s.collapsed&&t.iter(e.line,n.line+1,function(e){vt(t,e)&&O(e,0)}),s.clearOnEnter&&ta(s,"beforeCursorEnter",function(){return s.clear()}),s.readOnly&&(U(),(t.history.done.length||t.history.undone.length)&&t.clearHistory()),s.collapsed&&(s.id=++Oa,s.atomic=!0),h){if(l&&(h.curOp.updateMaxLine=!0),s.collapsed)mi(h,e.line,n.line+1);else if(s.className||s.title||s.startStyle||s.endStyle||s.css)for(var d=e.line;d<=n.line;d++)yi(h,d,"text");s.atomic&&kr(h.doc),xe(h,"markerAdded",h,s)}return s}function qr(t,e,n,i,r){i=u(i),i.shared=!1;var o=[Ur(t,e,n,i,r)],s=o[0],a=i.widgetNode;return Xi(t,function(t){a&&(i.widgetNode=a.cloneNode(!0)),o.push(Ur(t,j(t,e),j(t,n),i,r));for(var l=0;l-1)return e.state.draggingText(t),void setTimeout(function(){return e.display.input.focus()},20);try{var l=t.dataTransfer.getData("Text");if(l){var c;if(e.state.draggingText&&!e.state.draggingText.copy&&(c=e.listSelections()),wr(e.doc,Vi(n,n)),c)for(var u=0;u=0;e--)Fr(t.doc,"",i[e].from,i[e].to,"+delete");Kn(t)})}function fo(t,e,n){var i=S(t.text,e+n,n);return i<0||i>t.text.length?null:i}function po(t,e,n){var i=fo(t,e.ch,n);return null==i?null:new _(e.line,i,n<0?"after":"before")}function go(t,e,n,i,r){if(t){var o=kt(n,e.doc.direction);if(o){var s,a=r<0?g(o):o[0],l=r<0==(1==a.level),c=l?"after":"before";if(a.level>0||"rtl"==e.doc.direction){var u=Ke(e,n);s=r<0?n.text.length-1:0;var h=Ge(e,u,s).top;s=T(function(t){return Ge(e,u,t).top==h},r<0==(1==a.level)?a.from:a.to-1,s),"before"==c&&(s=fo(n,s,1))}else s=r<0?a.to:a.from;return new _(i,s,c)}}return new _(i,r<0?n.text.length:0,r<0?"before":"after")}function vo(t,e,n,i){var r=kt(e,t.doc.direction);if(!r)return po(e,n,i);n.ch>=e.text.length?(n.ch=e.text.length,n.sticky="before"):n.ch<=0&&(n.ch=0,n.sticky="after");var o=Ct(r,n.ch,n.sticky),s=r[o];if("ltr"==t.doc.direction&&s.level%2==0&&(i>0?s.to>n.ch:s.from=s.from&&d>=u.begin)){var f=h?"before":"after";return new _(n.line,d,f)}}var p=function(t,e,i){for(var o=function(t,e){return e?new _(n.line,l(t,1),"before"):new _(n.line,t,"after")};t>=0&&t0==(1!=s.level),c=a?i.begin:l(i.end,-1);if(s.from<=c&&c0?u.end:l(u.begin,-1);return null==v||i>0&&v==e.text.length||!(g=p(i>0?0:r.length-1,i,c(v)))?null:g}function mo(t,e){var n=M(t.doc,e),i=ht(n);return i!=n&&(e=L(i)),go(!0,t,i,e,1)}function yo(t,e){var n=M(t.doc,e),i=dt(n);return i!=n&&(e=L(i)),go(!0,t,n,e,-1)}function bo(t,e){var n=mo(t,e.line),i=M(t.doc,n.line),r=kt(i,t.doc.direction);if(!r||0==r[0].level){var o=Math.max(0,i.text.search(/\S/)),s=e.line==n.line&&e.ch<=o&&e.ch;return _(n.line,s?0:o,n.sticky)}return n}function xo(t,e,n){if("string"==typeof e&&!(e=ja[e]))return!1;t.display.input.ensurePolled();var i=t.display.shift,r=!1;try{t.isReadOnly()&&(t.state.suppressEdits=!0),n&&(t.display.shift=!1),r=e(t)!=js}finally{t.display.shift=i,t.state.suppressEdits=!1}return r}function wo(t,e,n){for(var i=0;i-1&&(F((r=a.ranges[r]).from(),e)<0||e.xRel>0)&&(F(r.to(),e)>0||e.xRel<0)?Do(t,i,e,o):Fo(t,i,e,o)}function Do(t,e,n,i){var r=t.display,o=!1,s=pi(t,function(e){bs&&(r.scroller.draggable=!1),t.state.draggingText=!1,Tt(document,"mouseup",s),Tt(document,"mousemove",a),Tt(r.scroller,"dragstart",l),Tt(r.scroller,"drop",s),o||(Lt(e),i.addNew||pr(t.doc,n,null,null,i.extend),bs||ms&&9==ys?setTimeout(function(){document.body.focus(),r.input.focus()},20):r.input.focus())}),a=function(t){o=o||Math.abs(e.clientX-t.clientX)+Math.abs(e.clientY-t.clientY)>=10},l=function(){return o=!0};bs&&(r.scroller.draggable=!0),t.state.draggingText=s,s.copy=!i.moveOnDrag,r.scroller.dragDrop&&r.scroller.dragDrop(),ta(document,"mouseup",s),ta(document,"mousemove",a),ta(r.scroller,"dragstart",l),ta(r.scroller,"drop",s),Dn(t),setTimeout(function(){return r.input.focus()},20)}function _o(t,e,n){if("char"==n)return new Pa(e,e);if("word"==n)return t.findWordAt(e);if("line"==n)return new Pa(_(e.line,0),j(t.doc,_(e.line+1,0)));var i=n(t,e);return new Pa(i.from,i.to)}function Fo(t,e,n,i){function r(e){if(0!=F(m,e))if(m=e,"rectangle"==i.unit){for(var r=[],o=t.options.tabSize,s=h(M(c,n.line).text,n.ch,o),a=h(M(c,e.line).text,e.ch,o),l=Math.min(s,a),g=Math.max(s,a),v=Math.min(n.line,e.line),y=Math.min(t.lastLine(),Math.max(n.line,e.line));v<=y;v++){var b=M(c,v).text,x=f(b,l,o);l==g?r.push(new Pa(_(v,x),_(v,x))):b.length>x&&r.push(new Pa(_(v,x),_(v,f(b,g,o))))}r.length||r.push(new Pa(n,n)),xr(c,Ri(p.ranges.slice(0,d).concat(r),d),{origin:"*mouse",scroll:!1}),t.scrollIntoView(e)}else{var w,C=u,k=_o(t,e,i.unit),S=C.anchor;F(k.anchor,S)>0?(w=k.head,S=V(C.from(),k.anchor)):(w=k.anchor,S=R(C.to(),k.head));var T=p.ranges.slice(0);T[d]=zo(t,new Pa(j(c,S),w)),xr(c,Ri(T,d),Ws)}}function o(e){var n=++b,a=Tn(t,e,!0,"rectangle"==i.unit);if(a)if(0!=F(a,m)){t.curOp.focus=s(),r(a);var u=Rn(l,c);(a.line>=u.to||a.liney.bottom?20:0;h&&setTimeout(pi(t,function(){b==n&&(l.scroller.scrollTop+=h,o(e))}),50)}}function a(e){t.state.selectingText=!1,b=1/0,Lt(e),l.input.focus(),Tt(document,"mousemove",x),Tt(document,"mouseup",w),c.history.lastSelOrigin=null}var l=t.display,c=t.doc;Lt(e);var u,d,p=c.sel,g=p.ranges;if(i.addNew&&!i.extend?(d=c.sel.contains(n),u=d>-1?g[d]:new Pa(n,n)):(u=c.sel.primary(),d=c.sel.primIndex),"rectangle"==i.unit)i.addNew||(u=new Pa(n,n)),n=Tn(t,e,!0,!0),d=-1;else{var v=_o(t,n,i.unit);u=i.extend?fr(u,v.anchor,v.head,i.extend):v}i.addNew?-1==d?(d=g.length,xr(c,Ri(g.concat([u]),d),{scroll:!1,origin:"*mouse"})):g.length>1&&g[d].empty()&&"char"==i.unit&&!i.extend?(xr(c,Ri(g.slice(0,d).concat(g.slice(d+1)),0),{scroll:!1,origin:"*mouse"}),p=c.sel):vr(c,d,u,Ws):(d=0,xr(c,new Ma([u],0),Ws),p=c.sel);var m=n,y=l.wrapper.getBoundingClientRect(),b=0,x=pi(t,function(t){Ft(t)?o(t):a(t)}),w=pi(t,a);t.state.selectingText=w,ta(document,"mousemove",x),ta(document,"mouseup",w)}function zo(t,e){var n=e.anchor,i=e.head,r=M(t.doc,n.line);if(0==F(n,i)&&n.sticky==i.sticky)return e;var o=kt(r);if(!o)return e;var s=Ct(o,n.ch,n.sticky),a=o[s];if(a.from!=n.ch&&a.to!=n.ch)return e;var l=s+(a.from==n.ch==(1!=a.level)?0:1);if(0==l||l==o.length)return e;var c;if(i.line!=n.line)c=(i.line-n.line)*("ltr"==t.doc.direction?1:-1)>0;else{var u=Ct(o,i.ch,i.sticky),h=u-s||(i.ch-n.ch)*(1==a.level?-1:1);c=u==l-1||u==l?h<0:h>0}var d=o[l+(c?-1:0)],f=c==(1==d.level),p=f?d.from:d.to,g=f?"after":"before";return n.ch==p&&n.sticky==g?e:new Pa(new _(n.line,p,g),i)}function $o(t,e,n,i){var r,o;if(e.touches)r=e.touches[0].clientX,o=e.touches[0].clientY;else try{r=e.clientX,o=e.clientY}catch(e){return!1}if(r>=Math.floor(t.display.gutters.getBoundingClientRect().right))return!1;i&&Lt(e);var s=t.display,a=s.lineDiv.getBoundingClientRect();if(o>a.bottom||!At(t,n))return It(e);o-=a.top-s.viewOffset;for(var l=0;l=r){return Et(t,n,t,N(t.doc,o),t.options.gutters[l],e),It(e)}}}function Ro(t,e){return $o(t,e,"gutterClick",!0)}function Vo(t,e){_e(t.display,e)||Ho(t,e)||Mt(t,e,"contextmenu")||t.display.input.onContextMenu(e)}function Ho(t,e){return!!At(t,"gutterContextMenu")&&$o(t,e,"gutterContextMenu",!1)}function jo(t){t.display.wrapper.className=t.display.wrapper.className.replace(/\s*cm-s-\S+/g,"")+t.options.theme.replace(/(^|\s)\s*/g," cm-s-"),en(t)}function Bo(t){Di(t),mi(t),Vn(t)}function Wo(t,e,n){if(!e!=!(n&&n!=Ga)){var i=t.display.dragFunctions,r=e?ta:Tt;r(t.display.scroller,"dragstart",i.start),r(t.display.scroller,"dragenter",i.enter),r(t.display.scroller,"dragover",i.over),r(t.display.scroller,"dragleave",i.leave),r(t.display.scroller,"drop",i.drop)}}function Uo(t){t.options.lineWrapping?(a(t.display.wrapper,"CodeMirror-wrap"),t.display.sizer.style.minWidth="",t.display.sizerWidth=null):(Fs(t.display.wrapper,"CodeMirror-wrap"),xt(t)),Sn(t),mi(t),en(t),setTimeout(function(){return ni(t)},100)}function qo(t,e){var n=this;if(!(this instanceof qo))return new qo(t,e);this.options=e=e?u(e):{},u(Ya,e,!1),_i(e);var i=e.value;"string"==typeof i&&(i=new Da(i,e.mode,null,e.lineSeparator,e.direction)),this.doc=i;var r=new qo.inputStyles[e.inputStyle](this),o=this.display=new E(t,i,r);o.wrapper.CodeMirror=this,Di(this),jo(this),e.lineWrapping&&(this.display.wrapper.className+=" CodeMirror-wrap"),ri(this),this.state={keyMaps:[],overlays:[],modeGen:0,overwrite:!1,delayingBlurEvent:!1,focused:!1,suppressEdits:!1,pasteIncoming:!1,cutIncoming:!1,selectingText:!1,draggingText:!1,highlight:new $s,keySeq:null,specialChars:null},e.autofocus&&!Ps&&o.input.focus(),ms&&ys<11&&setTimeout(function(){return n.display.input.reset(!0)},20),Ko(this),eo(),oi(this),this.curOp.forceUpdate=!0,Ji(this,i),e.autofocus&&!Ps||this.hasFocus()?setTimeout(c(_n,this),20):Fn(this);for(var s in Xa)Xa.hasOwnProperty(s)&&Xa[s](n,e[s],Ga);Hn(this),e.finishInit&&e.finishInit(this);for(var a=0;a400}var r=t.display;ta(r.scroller,"mousedown",pi(t,Oo)),ms&&ys<11?ta(r.scroller,"dblclick",pi(t,function(e){if(!Mt(t,e)){var n=Tn(t,e);if(n&&!Ro(t,e)&&!_e(t.display,e)){Lt(e);var i=t.findWordAt(n);pr(t.doc,i.anchor,i.head)}}})):ta(r.scroller,"dblclick",function(e){return Mt(t,e)||Lt(e)}),_s||ta(r.scroller,"contextmenu",function(e){return Vo(t,e)});var o,s={end:0};ta(r.scroller,"touchstart",function(e){if(!Mt(t,e)&&!n(e)&&!Ro(t,e)){r.input.ensurePolled(),clearTimeout(o);var i=+new Date;r.activeTouch={start:i,moved:!1,prev:i-s.end<=300?s:null},1==e.touches.length&&(r.activeTouch.left=e.touches[0].pageX,r.activeTouch.top=e.touches[0].pageY)}}),ta(r.scroller,"touchmove",function(){r.activeTouch&&(r.activeTouch.moved=!0)}),ta(r.scroller,"touchend",function(n){var o=r.activeTouch;if(o&&!_e(r,n)&&null!=o.left&&!o.moved&&new Date-o.start<300){var s,a=t.coordsChar(r.activeTouch,"page");s=!o.prev||i(o,o.prev)?new Pa(a,a):!o.prev.prev||i(o,o.prev.prev)?t.findWordAt(a):new Pa(_(a.line,0),j(t.doc,_(a.line+1,0))),t.setSelection(s.anchor,s.head),t.focus(),Lt(n)}e()}),ta(r.scroller,"touchcancel",e),ta(r.scroller,"scroll",function(){r.scroller.clientHeight&&(Zn(t,r.scroller.scrollTop),ti(t,r.scroller.scrollLeft,!0),Et(t,"scroll",t))}),ta(r.scroller,"mousewheel",function(e){return $i(t,e)}),ta(r.scroller,"DOMMouseScroll",function(e){return $i(t,e)}),ta(r.wrapper,"scroll",function(){return r.wrapper.scrollTop=r.wrapper.scrollLeft=0}),r.dragFunctions={enter:function(e){Mt(t,e)||Dt(e)},over:function(e){Mt(t,e)||(Zr(t,e),Dt(e))},start:function(e){return Jr(t,e)},drop:pi(t,Xr),leave:function(e){Mt(t,e)||Qr(t)}};var a=r.input.getField();ta(a,"keyup",function(e){return Mo.call(t,e)}),ta(a,"keydown",pi(t,To)),ta(a,"keypress",pi(t,Po)),ta(a,"focus",function(e){return _n(t,e)}),ta(a,"blur",function(e){return Fn(t,e)})}function Go(t,e,n,i){var r,o=t.doc;null==n&&(n="add"),"smart"==n&&(o.mode.indent?r=Xt(t,e).state:n="prev");var s=t.options.tabSize,a=M(o,e),l=h(a.text,null,s);a.stateAfter&&(a.stateAfter=null);var c,u=a.text.match(/^\s*/)[0];if(i||/\S/.test(a.text)){if("smart"==n&&((c=o.mode.indent(r,a.text.slice(u.length),a.text))==js||c>150)){if(!i)return;n="prev"}}else c=0,n="not";"prev"==n?c=e>o.first?h(M(o,e-1).text,null,s):0:"add"==n?c=l+t.options.indentUnit:"subtract"==n?c=l-t.options.indentUnit:"number"==typeof n&&(c=l+n),c=Math.max(0,c);var d="",f=0;if(t.options.indentWithTabs)for(var g=Math.floor(c/s);g;--g)f+=s,d+="\t";if(f1)if(Za&&Za.text.join("\n")==e){if(i.ranges.length%Za.text.length==0){l=[];for(var c=0;c=0;h--){var d=i.ranges[h],f=d.from(),p=d.to();d.empty()&&(n&&n>0?f=_(f.line,f.ch-n):t.state.overwrite&&!s?p=_(p.line,Math.min(M(o,p.line).text.length,p.ch+g(a).length)):Za&&Za.lineWise&&Za.text.join("\n")==e&&(f=p=_(f.line,0))),u=t.curOp.updateInput;var m={from:f,to:p,text:l?l[h%l.length]:a,origin:r||(s?"paste":t.state.cutIncoming?"cut":"+input")};Or(t.doc,m),xe(t,"inputRead",t,m)}e&&!s&&Zo(t,e),Kn(t),t.curOp.updateInput=u,t.curOp.typing=!0,t.state.pasteIncoming=t.state.cutIncoming=!1}function Jo(t,e){var n=t.clipboardData&&t.clipboardData.getData("Text");if(n)return t.preventDefault(),e.isReadOnly()||e.options.disableInput||fi(e,function(){return Xo(e,n,0,null,"paste")}),!0}function Zo(t,e){if(t.options.electricChars&&t.options.smartIndent)for(var n=t.doc.sel,i=n.ranges.length-1;i>=0;i--){var r=n.ranges[i];if(!(r.head.ch>100||i&&n.ranges[i-1].head.line==r.head.line)){var o=t.getModeAt(r.head),s=!1;if(o.electricChars){for(var a=0;a-1){s=Go(t,r.head.line,"smart");break}}else o.electricInput&&o.electricInput.test(M(t.doc,r.head.line).text.slice(0,r.head.ch))&&(s=Go(t,r.head.line,"smart"));s&&xe(t,"electricInput",t,r.head.line)}}}function Qo(t){for(var e=[],n=[],i=0;i=t.first+t.size)&&(e=new _(i,e.ch,e.sticky),c=M(t,i))}function s(i){var s;if(null==(s=r?vo(t.cm,c,e,n):po(c,e,n))){if(i||!o())return!1;e=go(r,t.cm,c,e.line,n)}else e=s;return!0}var a=e,l=n,c=M(t,e.line);if("char"==i)s();else if("column"==i)s(!0);else if("word"==i||"group"==i)for(var u=null,h="group"==i,d=t.cm&&t.cm.getHelper(e,"wordChars"),f=!0;!(n<0)||s(!f);f=!1){var p=c.text.charAt(e.ch)||"\n",g=w(p,d)?"w":h&&"\n"==p?"n":!h||/\s/.test(p)?null:"p";if(!h||f||g||(g="s"),u&&u!=g){n<0&&(n=1,s(),e.sticky="after");break}if(g&&(u=g),n>0&&!s(!f))break}var v=Er(t,e,a,l,!0);return z(a,v)&&(v.hitSide=!0),v}function is(t,e,n,i){var r,o=t.doc,s=e.left;if("page"==i){var a=Math.min(t.display.wrapper.clientHeight,window.innerHeight||document.documentElement.clientHeight),l=Math.max(a-.5*bn(t.display),3);r=(n>0?e.bottom:e.top)+n*l}else"line"==i&&(r=n>0?e.bottom+3:e.top-3);for(var c;c=dn(t,s,r),c.outside;){if(n<0?r<=0:r>=o.height){c.hitSide=!0;break}r+=5*n}return c}function rs(t,e){var n=qe(t,e.line);if(!n||n.hidden)return null;var i=M(t.doc,e.line),r=Be(n,i,e.line),o=kt(i,t.doc.direction),s="left";if(o){s=Ct(o,e.ch)%2?"right":"left"}var a=Ye(r.map,e.ch,s);return a.offset="right"==a.collapse?a.end:a.start,a}function os(t){for(var e=t;e;e=e.parentNode)if(/CodeMirror-gutter-wrapper/.test(e.className))return!0;return!1}function ss(t,e){return e&&(t.bad=!0),t}function as(t,e,n,i,r){function o(t){return function(e){return e.id==t}}function s(){u&&(c+=h,u=!1)}function a(t){t&&(s(),c+=t)}function l(e){if(1==e.nodeType){var n=e.getAttribute("cm-text");if(null!=n)return void a(n||e.textContent.replace(/\u200b/g,""));var c,d=e.getAttribute("cm-marker");if(d){var f=t.findMarks(_(i,0),_(r+1,0),o(+d));return void(f.length&&(c=f[0].find(0))&&a(P(t.doc,c.from,c.to).join(h)))}if("false"==e.getAttribute("contenteditable"))return;var p=/^(pre|div|p)$/i.test(e.nodeName);p&&s();for(var g=0;g=15&&(Cs=!1,bs=!0);var Is,Ds=As&&(xs||Cs&&(null==Ns||Ns<12.11)),_s=fs||ms&&ys>=9,Fs=function(e,n){var i=e.className,r=t(n).exec(i);if(r){var o=i.slice(r.index+r[0].length);e.className=i.slice(0,r.index)+(o?r[1]+o:"")}};Is=document.createRange?function(t,e,n,i){var r=document.createRange();return r.setEnd(i||t,n),r.setStart(t,e),r}:function(t,e,n){var i=document.body.createTextRange();try{i.moveToElementText(t.parentNode)}catch(t){return i}return i.collapse(!0),i.moveEnd("character",n),i.moveStart("character",e),i};var zs=function(t){t.select()};Es?zs=function(t){t.selectionStart=0,t.selectionEnd=t.value.length}:ms&&(zs=function(t){try{t.select()}catch(t){}});var $s=function(){this.id=null};$s.prototype.set=function(t,e){clearTimeout(this.id),this.id=setTimeout(e,t)};var Rs,Vs,Hs=30,js={toString:function(){return"CodeMirror.Pass"}},Bs={scroll:!1},Ws={origin:"*mouse"},Us={origin:"+move"},qs=[""],Ks=/[\u00df\u0587\u0590-\u05f4\u0600-\u06ff\u3040-\u309f\u30a0-\u30ff\u3400-\u4db5\u4e00-\u9fcc\uac00-\ud7af]/,Gs=/[\u0300-\u036f\u0483-\u0489\u0591-\u05bd\u05bf\u05c1\u05c2\u05c4\u05c5\u05c7\u0610-\u061a\u064b-\u065e\u0670\u06d6-\u06dc\u06de-\u06e4\u06e7\u06e8\u06ea-\u06ed\u0711\u0730-\u074a\u07a6-\u07b0\u07eb-\u07f3\u0816-\u0819\u081b-\u0823\u0825-\u0827\u0829-\u082d\u0900-\u0902\u093c\u0941-\u0948\u094d\u0951-\u0955\u0962\u0963\u0981\u09bc\u09be\u09c1-\u09c4\u09cd\u09d7\u09e2\u09e3\u0a01\u0a02\u0a3c\u0a41\u0a42\u0a47\u0a48\u0a4b-\u0a4d\u0a51\u0a70\u0a71\u0a75\u0a81\u0a82\u0abc\u0ac1-\u0ac5\u0ac7\u0ac8\u0acd\u0ae2\u0ae3\u0b01\u0b3c\u0b3e\u0b3f\u0b41-\u0b44\u0b4d\u0b56\u0b57\u0b62\u0b63\u0b82\u0bbe\u0bc0\u0bcd\u0bd7\u0c3e-\u0c40\u0c46-\u0c48\u0c4a-\u0c4d\u0c55\u0c56\u0c62\u0c63\u0cbc\u0cbf\u0cc2\u0cc6\u0ccc\u0ccd\u0cd5\u0cd6\u0ce2\u0ce3\u0d3e\u0d41-\u0d44\u0d4d\u0d57\u0d62\u0d63\u0dca\u0dcf\u0dd2-\u0dd4\u0dd6\u0ddf\u0e31\u0e34-\u0e3a\u0e47-\u0e4e\u0eb1\u0eb4-\u0eb9\u0ebb\u0ebc\u0ec8-\u0ecd\u0f18\u0f19\u0f35\u0f37\u0f39\u0f71-\u0f7e\u0f80-\u0f84\u0f86\u0f87\u0f90-\u0f97\u0f99-\u0fbc\u0fc6\u102d-\u1030\u1032-\u1037\u1039\u103a\u103d\u103e\u1058\u1059\u105e-\u1060\u1071-\u1074\u1082\u1085\u1086\u108d\u109d\u135f\u1712-\u1714\u1732-\u1734\u1752\u1753\u1772\u1773\u17b7-\u17bd\u17c6\u17c9-\u17d3\u17dd\u180b-\u180d\u18a9\u1920-\u1922\u1927\u1928\u1932\u1939-\u193b\u1a17\u1a18\u1a56\u1a58-\u1a5e\u1a60\u1a62\u1a65-\u1a6c\u1a73-\u1a7c\u1a7f\u1b00-\u1b03\u1b34\u1b36-\u1b3a\u1b3c\u1b42\u1b6b-\u1b73\u1b80\u1b81\u1ba2-\u1ba5\u1ba8\u1ba9\u1c2c-\u1c33\u1c36\u1c37\u1cd0-\u1cd2\u1cd4-\u1ce0\u1ce2-\u1ce8\u1ced\u1dc0-\u1de6\u1dfd-\u1dff\u200c\u200d\u20d0-\u20f0\u2cef-\u2cf1\u2de0-\u2dff\u302a-\u302f\u3099\u309a\ua66f-\ua672\ua67c\ua67d\ua6f0\ua6f1\ua802\ua806\ua80b\ua825\ua826\ua8c4\ua8e0-\ua8f1\ua926-\ua92d\ua947-\ua951\ua980-\ua982\ua9b3\ua9b6-\ua9b9\ua9bc\uaa29-\uaa2e\uaa31\uaa32\uaa35\uaa36\uaa43\uaa4c\uaab0\uaab2-\uaab4\uaab7\uaab8\uaabe\uaabf\uaac1\uabe5\uabe8\uabed\udc00-\udfff\ufb1e\ufe00-\ufe0f\ufe20-\ufe26\uff9e\uff9f]/,Ys=!1,Xs=!1,Js=null,Zs=function(){function t(t){return t<=247?n.charAt(t):1424<=t&&t<=1524?"R":1536<=t&&t<=1785?i.charAt(t-1536):1774<=t&&t<=2220?"r":8192<=t&&t<=8203?"w":8204==t?"b":"L"}function e(t,e,n){this.level=t,this.from=e,this.to=n}var n="bbbbbbbbbtstwsbbbbbbbbbbbbbbssstwNN%%%NNNNNN,N,N1111111111NNNNNNNLLLLLLLLLLLLLLLLLLLLLLLLLLNNNNNNLLLLLLLLLLLLLLLLLLLLLLLLLLNNNNbbbbbbsbbbbbbbbbbbbbbbbbbbbbbbbbb,N%%%%NNNNLNNNNN%%11NLNNN1LNNNNNLLLLLLLLLLLLLLLLLLLLLLLNLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLN",i="nnnnnnNNr%%r,rNNmmmmmmmmmmmrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrmmmmmmmmmmmmmmmmmmmmmnnnnnnnnnn%nnrrrmrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrmmmmmmmnNmmmmmmrrmmNmmmmrr1111111111",r=/[\u0590-\u05f4\u0600-\u06ff\u0700-\u08ac]/,o=/[stwN]/,s=/[LRr]/,a=/[Lb1n]/,l=/[1n]/;return function(n,i){var c="ltr"==i?"L":"R";if(0==n.length||"ltr"==i&&!r.test(n))return!1;for(var u=n.length,h=[],d=0;d=this.string.length},ca.prototype.sol=function(){return this.pos==this.lineStart},ca.prototype.peek=function(){return this.string.charAt(this.pos)||void 0},ca.prototype.next=function(){if(this.pose},ca.prototype.eatSpace=function(){for(var t=this,e=this.pos;/[\s\u00a0]/.test(this.string.charAt(this.pos));)++t.pos;return this.pos>e},ca.prototype.skipToEnd=function(){this.pos=this.string.length},ca.prototype.skipTo=function(t){var e=this.string.indexOf(t,this.pos);if(e>-1)return this.pos=e,!0},ca.prototype.backUp=function(t){this.pos-=t},ca.prototype.column=function(){return this.lastColumnPos0?null:(i&&!1!==e&&(this.pos+=i[0].length),i)}var r=function(t){return n?t.toLowerCase():t};if(r(this.string.substr(this.pos,t.length))==r(t))return!1!==e&&(this.pos+=t.length),!0},ca.prototype.current=function(){return this.string.slice(this.start,this.pos)},ca.prototype.hideFirstChars=function(t,e){this.lineStart+=t;try{return e()}finally{this.lineStart-=t}},ca.prototype.lookAhead=function(t){var e=this.lineOracle;return e&&e.lookAhead(t)},ca.prototype.baseToken=function(){var t=this.lineOracle;return t&&t.baseToken(this.pos)};var ua=function(t,e){this.state=t,this.lookAhead=e},ha=function(t,e,n,i){this.state=e,this.doc=t,this.line=n,this.maxLookAhead=i||0,this.baseTokens=null,this.baseTokenPos=1};ha.prototype.lookAhead=function(t){var e=this.doc.getLine(this.line+t);return null!=e&&t>this.maxLookAhead&&(this.maxLookAhead=t),e},ha.prototype.baseToken=function(t){var e=this;if(!this.baseTokens)return null;for(;this.baseTokens[this.baseTokenPos]<=t;)e.baseTokenPos+=2;var n=this.baseTokens[this.baseTokenPos+1];return{type:n&&n.replace(/( |^)overlay .*/,""),size:this.baseTokens[this.baseTokenPos]-t}},ha.prototype.nextLine=function(){this.line++,this.maxLookAhead>0&&this.maxLookAhead--},ha.fromSaved=function(t,e,n){return e instanceof ua?new ha(t,Ut(t.mode,e.state),n,e.lookAhead):new ha(t,Ut(t.mode,e),n)},ha.prototype.save=function(t){var e=!1!==t?Ut(this.doc.mode,this.state):this.state;return this.maxLookAhead>0?new ua(e,this.maxLookAhead):e};var da=function(t,e,n){this.start=t.start,this.end=t.pos,this.string=t.current(),this.type=e||null,this.state=n},fa=function(t,e,n){this.text=t,it(this,e),this.height=n?n(this):1};fa.prototype.lineNo=function(){return L(this)},Ot(fa);var pa,ga={},va={},ma=null,ya=null,ba={left:0,right:0,top:0,bottom:0},xa=function(t,e,n){this.cm=n;var r=this.vert=i("div",[i("div",null,null,"min-width: 1px")],"CodeMirror-vscrollbar"),o=this.horiz=i("div",[i("div",null,null,"height: 100%; min-height: 1px")],"CodeMirror-hscrollbar");t(r),t(o),ta(r,"scroll",function(){r.clientHeight&&e(r.scrollTop,"vertical")}),ta(o,"scroll",function(){o.clientWidth&&e(o.scrollLeft,"horizontal")}),this.checkedZeroWidth=!1,ms&&ys<8&&(this.horiz.style.minHeight=this.vert.style.minWidth="18px")};xa.prototype.update=function(t){var e=t.scrollWidth>t.clientWidth+1,n=t.scrollHeight>t.clientHeight+1,i=t.nativeBarWidth;if(n){this.vert.style.display="block",this.vert.style.bottom=e?i+"px":"0";var r=t.viewHeight-(e?i:0);this.vert.firstChild.style.height=Math.max(0,t.scrollHeight-t.clientHeight+r)+"px"}else this.vert.style.display="",this.vert.firstChild.style.height="0";if(e){this.horiz.style.display="block",this.horiz.style.right=n?i+"px":"0",this.horiz.style.left=t.barLeft+"px";var o=t.viewWidth-t.barLeft-(n?i:0);this.horiz.firstChild.style.width=Math.max(0,t.scrollWidth-t.clientWidth+o)+"px"}else this.horiz.style.display="",this.horiz.firstChild.style.width="0";return!this.checkedZeroWidth&&t.clientHeight>0&&(0==i&&this.zeroWidthHack(),this.checkedZeroWidth=!0),{right:n?i:0,bottom:e?i:0}},xa.prototype.setScrollLeft=function(t){this.horiz.scrollLeft!=t&&(this.horiz.scrollLeft=t),this.disableHoriz&&this.enableZeroWidthBar(this.horiz,this.disableHoriz,"horiz")},xa.prototype.setScrollTop=function(t){this.vert.scrollTop!=t&&(this.vert.scrollTop=t),this.disableVert&&this.enableZeroWidthBar(this.vert,this.disableVert,"vert")},xa.prototype.zeroWidthHack=function(){var t=As&&!Ss?"12px":"18px";this.horiz.style.height=this.vert.style.width=t,this.horiz.style.pointerEvents=this.vert.style.pointerEvents="none",this.disableHoriz=new $s,this.disableVert=new $s},xa.prototype.enableZeroWidthBar=function(t,e,n){function i(){var r=t.getBoundingClientRect();("vert"==n?document.elementFromPoint(r.right-1,(r.top+r.bottom)/2):document.elementFromPoint((r.right+r.left)/2,r.bottom-1))!=t?t.style.pointerEvents="none":e.set(1e3,i)}t.style.pointerEvents="auto",e.set(1e3,i)},xa.prototype.clear=function(){var t=this.horiz.parentNode;t.removeChild(this.horiz),t.removeChild(this.vert)};var wa=function(){};wa.prototype.update=function(){return{bottom:0,right:0}},wa.prototype.setScrollLeft=function(){},wa.prototype.setScrollTop=function(){},wa.prototype.clear=function(){};var Ca={native:xa,null:wa},ka=0,Sa=function(t,e,n){var i=t.display;this.viewport=e,this.visible=Rn(i,t.doc,e),this.editorIsHidden=!i.wrapper.offsetWidth,this.wrapperHeight=i.wrapper.clientHeight,this.wrapperWidth=i.wrapper.clientWidth,this.oldDisplayWidth=Ve(t),this.force=n,this.dims=wn(t),this.events=[]};Sa.prototype.signal=function(t,e){At(t,e)&&this.events.push(arguments)},Sa.prototype.finish=function(){for(var t=this,e=0;e=0&&F(t,r.to())<=0)return i}return-1};var Pa=function(t,e){this.anchor=t,this.head=e};Pa.prototype.from=function(){return V(this.anchor,this.head)},Pa.prototype.to=function(){return R(this.anchor,this.head)},Pa.prototype.empty=function(){return this.head.line==this.anchor.line&&this.head.ch==this.anchor.ch},Hr.prototype={chunkSize:function(){return this.lines.length},removeInner:function(t,e){for(var n=this,i=t,r=t+e;i1||!(this.children[0]instanceof Hr))){var l=[];this.collapse(l),this.children=[new Hr(l)],this.children[0].parent=this}},collapse:function(t){for(var e=this,n=0;n50){for(var a=o.lines.length%25+25,l=a;l10);t.parent.maybeSpill()}},iterN:function(t,e,n){for(var i=this,r=0;re.display.maxLineLength&&(e.display.maxLine=u,e.display.maxLineLength=h,e.display.maxLineChanged=!0)}null!=r&&e&&this.collapsed&&mi(e,r,o+1),this.lines.length=0,this.explicitlyCleared=!0,this.atomic&&this.doc.cantEdit&&(this.doc.cantEdit=!1,e&&kr(e.doc)),e&&xe(e,"markerCleared",e,this,r,o),n&&si(e),this.parent&&this.parent.clear()}},La.prototype.find=function(t,e){var n=this;null==t&&"bookmark"==this.type&&(t=1);for(var i,r,o=0;o=0;c--)Or(i,r[c]);l?br(this,l):this.cm&&Kn(this.cm)}),undo:vi(function(){Nr(this,"undo")}),redo:vi(function(){Nr(this,"redo")}),undoSelection:vi(function(){Nr(this,"undo",!0)}),redoSelection:vi(function(){Nr(this,"redo",!0)}),setExtending:function(t){this.extend=t},getExtending:function(){return this.extend},historySize:function(){for(var t=this.history,e=0,n=0,i=0;i=t.ch)&&e.push(r.marker.parent||r.marker)}return e},findMarks:function(t,e,n){t=j(this,t),e=j(this,e);var i=[],r=t.line;return this.iter(t.line,e.line+1,function(o){var s=o.markedSpans;if(s)for(var a=0;a=l.to||null==l.from&&r!=t.line||null!=l.from&&r==e.line&&l.from>=e.ch||n&&!n(l.marker)||i.push(l.marker.parent||l.marker)}++r}),i},getAllMarks:function(){var t=[];return this.iter(function(e){var n=e.markedSpans;if(n)for(var i=0;it)return e=t,!0;t-=o,++n}),j(this,_(n,e))},indexFromPos:function(t){t=j(this,t);var e=t.ch;if(t.linee&&(e=t.from),null!=t.to&&t.to0)r=new _(r.line,r.ch+1),t.replaceRange(o.charAt(r.ch-1)+o.charAt(r.ch-2),_(r.line,r.ch-2),r,"+transpose");else if(r.line>t.doc.first){var s=M(t.doc,r.line-1).text;s&&(r=new _(r.line,1),t.replaceRange(o.charAt(0)+t.doc.lineSeparator()+s.charAt(s.length-1),_(r.line-1,s.length-1),r,"+transpose"))}n.push(new Pa(r,r))}t.setSelections(n)})},newlineAndIndent:function(t){return fi(t,function(){for(var e=t.listSelections(),n=e.length-1;n>=0;n--)t.replaceRange(t.doc.lineSeparator(),e[n].anchor,e[n].head,"+input");e=t.listSelections();for(var i=0;it&&0==F(e,this.pos)&&n==this.button};var qa,Ka,Ga={toString:function(){return"CodeMirror.Init"}},Ya={},Xa={};qo.defaults=Ya,qo.optionHandlers=Xa;var Ja=[];qo.defineInitHook=function(t){return Ja.push(t)};var Za=null,Qa=function(t){this.cm=t,this.lastAnchorNode=this.lastAnchorOffset=this.lastFocusNode=this.lastFocusOffset=null,this.polling=new $s,this.composing=null,this.gracePeriod=!1,this.readDOMTimeout=null};Qa.prototype.init=function(t){function e(t){if(!Mt(r,t)){if(r.somethingSelected())Yo({lineWise:!1,text:r.getSelections()}),"cut"==t.type&&r.replaceSelection("",null,"cut");else{if(!r.options.lineWiseCopyCut)return;var e=Qo(r);Yo({lineWise:!0,text:e.text}),"cut"==t.type&&r.operation(function(){r.setSelections(e.ranges,0,Bs),r.replaceSelection("",null,"cut")})}if(t.clipboardData){t.clipboardData.clearData();var n=Za.text.join("\n");if(t.clipboardData.setData("Text",n),t.clipboardData.getData("Text")==n)return void t.preventDefault()}var s=es(),a=s.firstChild;r.display.lineSpace.insertBefore(s,r.display.lineSpace.firstChild),a.value=Za.text.join("\n");var l=document.activeElement;zs(a),setTimeout(function(){r.display.lineSpace.removeChild(s),l.focus(),l==o&&i.showPrimarySelection()},50)}}var n=this,i=this,r=i.cm,o=i.div=t.lineDiv;ts(o,r.options.spellcheck),ta(o,"paste",function(t){Mt(r,t)||Jo(t,r)||ys<=11&&setTimeout(pi(r,function(){return n.updateFromDOM()}),20)}),ta(o,"compositionstart",function(t){n.composing={data:t.data,done:!1}}),ta(o,"compositionupdate",function(t){n.composing||(n.composing={data:t.data,done:!1})}),ta(o,"compositionend",function(t){n.composing&&(t.data!=n.composing.data&&n.readFromDOMSoon(),n.composing.done=!0)}),ta(o,"touchstart",function(){return i.forceCompositionEnd()}),ta(o,"input",function(){n.composing||n.readFromDOMSoon()}),ta(o,"copy",e),ta(o,"cut",e)},Qa.prototype.prepareSelection=function(){var t=Pn(this.cm,!1);return t.focus=this.cm.state.focused,t},Qa.prototype.showSelection=function(t,e){t&&this.cm.display.view.length&&((t.focus||e)&&this.showPrimarySelection(),this.showMultipleSelections(t))},Qa.prototype.showPrimarySelection=function(){var t=window.getSelection(),e=this.cm,n=e.doc.sel.primary(),i=n.from(),r=n.to();if(e.display.viewTo==e.display.viewFrom||i.line>=e.display.viewTo||r.line=e.display.viewFrom&&rs(e,i)||{node:a[0].measure.map[2],offset:0},c=r.linet.firstLine()&&(i=_(i.line-1,M(t.doc,i.line-1).length)),r.ch==M(t.doc,r.line).text.length&&r.linee.viewTo-1)return!1;var o,s,a;i.line==e.viewFrom||0==(o=En(t,i.line))?(s=L(e.view[0].line),a=e.view[0].node):(s=L(e.view[o].line),a=e.view[o-1].node.nextSibling);var l,c,u=En(t,r.line);if(u==e.view.length-1?(l=e.viewTo-1,c=e.lineDiv.lastChild):(l=L(e.view[u+1].line)-1,c=e.view[u+1].node.previousSibling),!a)return!1;for(var h=t.doc.splitLines(as(t,a,c,s,l)),d=P(t.doc,_(s,0),_(l,M(t.doc,l).text.length));h.length>1&&d.length>1;)if(g(h)==g(d))h.pop(),d.pop(),l--;else{if(h[0]!=d[0])break;h.shift(),d.shift(),s++}for(var f=0,p=0,v=h[0],m=d[0],y=Math.min(v.length,m.length);fi.ch&&b.charCodeAt(b.length-p-1)==x.charCodeAt(x.length-p-1);)f--,p++;h[h.length-1]=b.slice(0,b.length-p).replace(/^\u200b+/,""),h[0]=h[0].slice(f).replace(/\u200b+$/,"");var C=_(s,f),k=_(l,d.length?g(d).length-p:0);return h.length>1||h[0]||F(C,k)?(Fr(t.doc,h,C,k,"+input"),!0):void 0},Qa.prototype.ensurePolled=function(){this.forceCompositionEnd()},Qa.prototype.reset=function(){this.forceCompositionEnd()},Qa.prototype.forceCompositionEnd=function(){this.composing&&(clearTimeout(this.readDOMTimeout),this.composing=null,this.updateFromDOM(),this.div.blur(),this.div.focus())},Qa.prototype.readFromDOMSoon=function(){var t=this;null==this.readDOMTimeout&&(this.readDOMTimeout=setTimeout(function(){if(t.readDOMTimeout=null,t.composing){if(!t.composing.done)return;t.composing=null}t.updateFromDOM()},80))},Qa.prototype.updateFromDOM=function(){var t=this;!this.cm.isReadOnly()&&this.pollContent()||fi(this.cm,function(){return mi(t.cm)})},Qa.prototype.setUneditable=function(t){t.contentEditable="false"},Qa.prototype.onKeyPress=function(t){0!=t.charCode&&(t.preventDefault(),this.cm.isReadOnly()||pi(this.cm,Xo)(this.cm,String.fromCharCode(null==t.charCode?t.keyCode:t.charCode),0))},Qa.prototype.readOnlyChanged=function(t){this.div.contentEditable=String("nocursor"!=t)},Qa.prototype.onContextMenu=function(){},Qa.prototype.resetPosition=function(){},Qa.prototype.needsContentAttribute=!0;var tl=function(t){this.cm=t,this.prevInput="",this.pollingFast=!1,this.polling=new $s,this.hasSelection=!1,this.composing=null};tl.prototype.init=function(t){function e(t){if(!Mt(r,t)){if(r.somethingSelected())Yo({lineWise:!1,text:r.getSelections()});else{if(!r.options.lineWiseCopyCut)return;var e=Qo(r);Yo({lineWise:!0,text:e.text}),"cut"==t.type?r.setSelections(e.ranges,null,Bs):(i.prevInput="",s.value=e.text.join("\n"),zs(s))}"cut"==t.type&&(r.state.cutIncoming=!0)}}var n=this,i=this,r=this.cm,o=this.wrapper=es(),s=this.textarea=o.firstChild;t.wrapper.insertBefore(o,t.wrapper.firstChild),Es&&(s.style.width="0px"),ta(s,"input",function(){ms&&ys>=9&&n.hasSelection&&(n.hasSelection=null),i.poll()}),ta(s,"paste",function(t){Mt(r,t)||Jo(t,r)||(r.state.pasteIncoming=!0,i.fastPoll())}),ta(s,"cut",e),ta(s,"copy",e),ta(t.scroller,"paste",function(e){_e(t,e)||Mt(r,e)||(r.state.pasteIncoming=!0,i.focus())}),ta(t.lineSpace,"selectstart",function(e){_e(t,e)||Lt(e)}),ta(s,"compositionstart",function(){var t=r.getCursor("from");i.composing&&i.composing.range.clear(),i.composing={start:t,range:r.markText(t,r.getCursor("to"),{className:"CodeMirror-composing"})}}),ta(s,"compositionend",function(){i.composing&&(i.poll(),i.composing.range.clear(),i.composing=null)})},tl.prototype.prepareSelection=function(){var t=this.cm,e=t.display,n=t.doc,i=Pn(t);if(t.options.moveInputWithCursor){var r=cn(t,n.sel.primary().head,"div"),o=e.wrapper.getBoundingClientRect(),s=e.lineDiv.getBoundingClientRect();i.teTop=Math.max(0,Math.min(e.wrapper.clientHeight-10,r.top+s.top-o.top)),i.teLeft=Math.max(0,Math.min(e.wrapper.clientWidth-10,r.left+s.left-o.left))}return i},tl.prototype.showSelection=function(t){var e=this.cm,i=e.display;n(i.cursorDiv,t.cursors),n(i.selectionDiv,t.selection),null!=t.teTop&&(this.wrapper.style.top=t.teTop+"px",this.wrapper.style.left=t.teLeft+"px")},tl.prototype.reset=function(t){if(!this.contextMenuPending&&!this.composing){var e=this.cm;if(e.somethingSelected()){this.prevInput="";var n=e.getSelection();this.textarea.value=n,e.state.focused&&zs(this.textarea),ms&&ys>=9&&(this.hasSelection=n)}else t||(this.prevInput=this.textarea.value="",ms&&ys>=9&&(this.hasSelection=null))}},tl.prototype.getField=function(){return this.textarea},tl.prototype.supportsTouch=function(){return!1},tl.prototype.focus=function(){if("nocursor"!=this.cm.options.readOnly&&(!Ps||s()!=this.textarea))try{this.textarea.focus()}catch(t){}},tl.prototype.blur=function(){this.textarea.blur()},tl.prototype.resetPosition=function(){this.wrapper.style.top=this.wrapper.style.left=0},tl.prototype.receivedFocus=function(){this.slowPoll()},tl.prototype.slowPoll=function(){var t=this;this.pollingFast||this.polling.set(this.cm.options.pollInterval,function(){t.poll(),t.cm.state.focused&&t.slowPoll()})},tl.prototype.fastPoll=function(){function t(){n.poll()||e?(n.pollingFast=!1,n.slowPoll()):(e=!0,n.polling.set(60,t))}var e=!1,n=this;n.pollingFast=!0,n.polling.set(20,t)},tl.prototype.poll=function(){var t=this,e=this.cm,n=this.textarea,i=this.prevInput;if(this.contextMenuPending||!e.state.focused||ia(n)&&!i&&!this.composing||e.isReadOnly()||e.options.disableInput||e.state.keySeq)return!1;var r=n.value;if(r==i&&!e.somethingSelected())return!1;if(ms&&ys>=9&&this.hasSelection===r||As&&/[\uf700-\uf7ff]/.test(r))return e.display.input.reset(),!1;if(e.doc.sel==e.display.selForContextMenu){var o=r.charCodeAt(0);if(8203!=o||i||(i="​"),8666==o)return this.reset(),this.cm.execCommand("undo")}for(var s=0,a=Math.min(i.length,r.length);s1e3||r.indexOf("\n")>-1?n.value=t.prevInput="":t.prevInput=r,t.composing&&(t.composing.range.clear(),t.composing.range=e.markText(t.composing.start,e.getCursor("to"),{className:"CodeMirror-composing"}))}),!0},tl.prototype.ensurePolled=function(){this.pollingFast&&this.poll()&&(this.pollingFast=!1)},tl.prototype.onKeyPress=function(){ms&&ys>=9&&(this.hasSelection=null),this.fastPoll()},tl.prototype.onContextMenu=function(t){function e(){if(null!=s.selectionStart){var t=r.somethingSelected(),e="​"+(t?s.value:"");s.value="⇚",s.value=e,i.prevInput=t?"":"​",s.selectionStart=1,s.selectionEnd=e.length,o.selForContextMenu=r.doc.sel}}function n(){if(i.contextMenuPending=!1,i.wrapper.style.cssText=u,s.style.cssText=c,ms&&ys<9&&o.scrollbars.setScrollTop(o.scroller.scrollTop=l),null!=s.selectionStart){(!ms||ms&&ys<9)&&e();var t=0,n=function(){o.selForContextMenu==r.doc.sel&&0==s.selectionStart&&s.selectionEnd>0&&"​"==i.prevInput?pi(r,Pr)(r):t++<10?o.detectingSelectAll=setTimeout(n,500):(o.selForContextMenu=null,o.input.reset())};o.detectingSelectAll=setTimeout(n,200)}}var i=this,r=i.cm,o=r.display,s=i.textarea,a=Tn(r,t),l=o.scroller.scrollTop;if(a&&!Cs){r.options.resetSelectionOnContextMenu&&-1==r.doc.sel.contains(a)&&pi(r,xr)(r.doc,Vi(a),Bs);var c=s.style.cssText,u=i.wrapper.style.cssText;i.wrapper.style.cssText="position: absolute";var h=i.wrapper.getBoundingClientRect();s.style.cssText="position: absolute; width: 30px; height: 30px;\n top: "+(t.clientY-h.top-5)+"px; left: "+(t.clientX-h.left-5)+"px;\n z-index: 1000; background: "+(ms?"rgba(255, 255, 255, .05)":"transparent")+";\n outline: none; border-width: 0; outline: none; overflow: hidden; opacity: .05; filter: alpha(opacity=5);";var d;if(bs&&(d=window.scrollY),o.input.focus(),bs&&window.scrollTo(null,d),o.input.reset(),r.somethingSelected()||(s.value=i.prevInput=" "),i.contextMenuPending=!0,o.selForContextMenu=r.doc.sel,clearTimeout(o.detectingSelectAll),ms&&ys>=9&&e(),_s){Dt(t);var f=function(){Tt(window,"mouseup",f),setTimeout(n,20)};ta(window,"mouseup",f)}else setTimeout(n,50)}},tl.prototype.readOnlyChanged=function(t){t||this.reset(),this.textarea.disabled="nocursor"==t},tl.prototype.setUneditable=function(){},tl.prototype.needsContentAttribute=!1,function(t){function e(e,i,r,o){t.defaults[e]=i,r&&(n[e]=o?function(t,e,n){n!=Ga&&r(t,e,n)}:r)}var n=t.optionHandlers;t.defineOption=e,t.Init=Ga,e("value","",function(t,e){return t.setValue(e)},!0),e("mode",null,function(t,e){t.doc.modeOption=e,qi(t)},!0),e("indentUnit",2,qi,!0),e("indentWithTabs",!1),e("smartIndent",!0),e("tabSize",4,function(t){Ki(t),en(t),mi(t)},!0),e("lineSeparator",null,function(t,e){if(t.doc.lineSep=e,e){var n=[],i=t.doc.first;t.doc.iter(function(t){for(var r=0;;){var o=t.text.indexOf(e,r);if(-1==o)break;r=o+e.length,n.push(_(i,o))}i++});for(var r=n.length-1;r>=0;r--)Fr(t.doc,e,n[r],_(n[r].line,n[r].ch+e.length))}}),e("specialChars",/[\u0000-\u001f\u007f-\u009f\u00ad\u061c\u200b-\u200f\u2028\u2029\ufeff]/g,function(t,e,n){t.state.specialChars=new RegExp(e.source+(e.test("\t")?"":"|\t"),"g"),n!=Ga&&t.refresh()}),e("specialCharPlaceholder",ce,function(t){return t.refresh()},!0),e("electricChars",!0),e("inputStyle",Ps?"contenteditable":"textarea",function(){throw new Error("inputStyle can not (yet) be changed in a running editor")},!0),e("spellcheck",!1,function(t,e){return t.getInputField().spellcheck=e},!0),e("rtlMoveVisually",!Ls),e("wholeLineUpdateBefore",!0),e("theme","default",function(t){jo(t),Bo(t)},!0),e("keyMap","default",function(t,e,n){var i=uo(e),r=n!=Ga&&uo(n);r&&r.detach&&r.detach(t,i),i.attach&&i.attach(t,r||null)}),e("extraKeys",null),e("configureMouse",null),e("lineWrapping",!1,Uo,!0),e("gutters",[],function(t){_i(t.options),Bo(t)},!0),e("fixedGutter",!0,function(t,e){t.display.gutters.style.left=e?Cn(t.display)+"px":"0",t.refresh()},!0),e("coverGutterNextToScrollbar",!1,function(t){return ni(t)},!0),e("scrollbarStyle","native",function(t){ri(t),ni(t),t.display.scrollbars.setScrollTop(t.doc.scrollTop),t.display.scrollbars.setScrollLeft(t.doc.scrollLeft)},!0),e("lineNumbers",!1,function(t){_i(t.options),Bo(t)},!0),e("firstLineNumber",1,Bo,!0),e("lineNumberFormatter",function(t){return t},Bo,!0),e("showCursorWhenSelecting",!1,Mn,!0),e("resetSelectionOnContextMenu",!0),e("lineWiseCopyCut",!0),e("pasteLinesPerSelection",!0),e("readOnly",!1,function(t,e){"nocursor"==e&&(Fn(t),t.display.input.blur()),t.display.input.readOnlyChanged(e)}),e("disableInput",!1,function(t,e){e||t.display.input.reset()},!0),e("dragDrop",!0,Wo),e("allowDropFileTypes",null),e("cursorBlinkRate",530),e("cursorScrollMargin",0),e("cursorHeight",1,Mn,!0),e("singleCursorHeightPerLine",!0,Mn,!0),e("workTime",100),e("workDelay",100),e("flattenSpans",!0,Ki,!0),e("addModeClass",!1,Ki,!0),e("pollInterval",100),e("undoDepth",200,function(t,e){return t.doc.history.undoDepth=e}),e("historyEventDelay",1250),e("viewportMargin",10,function(t){return t.refresh()},!0),e("maxHighlightLength",1e4,Ki,!0),e("moveInputWithCursor",!0,function(t,e){e||t.display.input.resetPosition()}),e("tabindex",null,function(t,e){return t.display.input.getField().tabIndex=e||""}),e("autofocus",null),e("direction","ltr",function(t,e){return t.doc.setDirection(e)},!0)}(qo),function(t){var e=t.optionHandlers,n=t.helpers={};t.prototype={constructor:t,focus:function(){window.focus(),this.display.input.focus()},setOption:function(t,n){var i=this.options,r=i[t];i[t]==n&&"mode"!=t||(i[t]=n,e.hasOwnProperty(t)&&pi(this,e[t])(this,n,r),Et(this,"optionChange",this,t))},getOption:function(t){return this.options[t]},getDoc:function(){return this.doc},addKeyMap:function(t,e){this.state.keyMaps[e?"push":"unshift"](uo(t))},removeKeyMap:function(t){for(var e=this.state.keyMaps,n=0;ni&&(Go(e,o.head.line,t,!0),i=o.head.line,r==e.doc.sel.primIndex&&Kn(e));else{var s=o.from(),a=o.to(),l=Math.max(i,s.line);i=Math.min(e.lastLine(),a.line-(a.ch?0:1))+1;for(var c=l;c0&&vr(e.doc,r,new Pa(s,u[r].to()),Bs)}}}),getTokenAt:function(t,e){return te(this,t,e)},getLineTokens:function(t,e){return te(this,_(t),e,!0)},getTokenTypeAt:function(t){t=j(this.doc,t);var e,n=Yt(this,M(this.doc,t.line)),i=0,r=(n.length-1)/2,o=t.ch;if(0==o)e=n[2];else for(;;){var s=i+r>>1;if((s?n[2*s-1]:0)>=o)r=s;else{if(!(n[2*s+1]o&&(t=o,r=!0),i=M(this.doc,t)}else i=t;return sn(this,i,{top:0,left:0},e||"page",n||r).top+(r?this.doc.height-yt(i):0)},defaultTextHeight:function(){return bn(this.display)},defaultCharWidth:function(){return xn(this.display)},getViewport:function(){return{from:this.display.viewFrom,to:this.display.viewTo}},addWidget:function(t,e,n,i,r){var o=this.display;t=cn(this,j(this.doc,t));var s=t.bottom,a=t.left;if(e.style.position="absolute",e.setAttribute("cm-ignore-events","true"),this.display.input.setUneditable(e),o.sizer.appendChild(e),"over"==i)s=t.top;else if("above"==i||"near"==i){var l=Math.max(o.wrapper.clientHeight,this.doc.height),c=Math.max(o.sizer.clientWidth,o.lineSpace.clientWidth);("above"==i||t.bottom+e.offsetHeight>l)&&t.top>e.offsetHeight?s=t.top-e.offsetHeight:t.bottom+e.offsetHeight<=l&&(s=t.bottom),a+e.offsetWidth>c&&(a=c-e.offsetWidth)}e.style.top=s+"px",e.style.left=e.style.right="","right"==r?(a=o.sizer.clientWidth-e.offsetWidth,e.style.right="0px"):("left"==r?a=0:"middle"==r&&(a=(o.sizer.clientWidth-e.offsetWidth)/2),e.style.left=a+"px"),n&&Wn(this,{left:a,top:s,right:a+e.offsetWidth,bottom:s+e.offsetHeight})},triggerOnKeyDown:gi(To),triggerOnKeyPress:gi(Po),triggerOnKeyUp:Mo,triggerOnMouseDown:gi(Oo),execCommand:function(t){if(ja.hasOwnProperty(t))return ja[t].call(null,this)},triggerElectric:gi(function(t){Zo(this,t)}),findPosH:function(t,e,n,i){var r=this,o=1;e<0&&(o=-1,e=-e);for(var s=j(this.doc,t),a=0;a0&&a(n.charAt(i-1));)--i;for(;r.5)&&Sn(this),Et(this,"refresh",this)}),swapDoc:gi(function(t){var e=this.doc;return e.cm=null,Ji(this,t),en(this),this.display.input.reset(),Gn(this,t.scrollLeft,t.scrollTop),this.curOp.forceScroll=!0,xe(this,"swapDoc",this,e),e}),getInputField:function(){return this.display.input.getField()},getWrapperElement:function(){return this.display.wrapper},getScrollerElement:function(){return this.display.scroller},getGutterElement:function(){return this.display.gutters}},Ot(t),t.registerHelper=function(e,i,r){n.hasOwnProperty(e)||(n[e]=t[e]={_global:[]}),n[e][i]=r},t.registerGlobalHelper=function(e,i,r,o){t.registerHelper(e,i,o),n[e]._global.push({pred:r,val:o})}}(qo);var el="iter insert remove copy getEditor constructor".split(" ");for(var nl in Da.prototype)Da.prototype.hasOwnProperty(nl)&&d(el,nl)<0&&(qo.prototype[nl]=function(t){return function(){return t.apply(this.doc,arguments)}}(Da.prototype[nl]));return Ot(Da),qo.inputStyles={textarea:tl,contenteditable:Qa},qo.defineMode=function(t){qo.defaults.mode||"null"==t||(qo.defaults.mode=t),Vt.apply(this,arguments)},qo.defineMIME=Ht,qo.defineMode("null",function(){return{token:function(t){return t.skipToEnd()}}}),qo.defineMIME("text/plain","null"),qo.defineExtension=function(t,e){qo.prototype[t]=e},qo.defineDocExtension=function(t,e){Da.prototype[t]=e},qo.fromTextArea=us,function(t){t.off=Tt,t.on=ta,t.wheelEventPixels=zi,t.Doc=Da,t.splitLines=na,t.countColumn=h,t.findColumn=f,t.isWordChar=x,t.Pass=js,t.signal=Et,t.Line=fa,t.changeEnd=Hi,t.scrollbarModel=Ca,t.Pos=_,t.cmpPos=F,t.modes=sa,t.mimeModes=aa,t.resolveMode=jt,t.getMode=Bt,t.modeExtensions=la,t.extendMode=Wt,t.copyState=Ut,t.startState=Kt,t.innerMode=qt,t.commands=ja,t.keyMap=Ha,t.keyName=co,t.isModifierKey=ao,t.lookupKey=so,t.normalizeKeyMap=oo,t.StringStream=ca,t.SharedTextMarker=Na,t.TextMarker=La,t.LineWidget=Aa,t.e_preventDefault=Lt,t.e_stopPropagation=Nt,t.e_stop=Dt,t.addClass=a,t.contains=o,t.rmClass=Fs,t.keyNames=za}(qo),qo.version="5.31.0",qo})},function(t,e,n){"use strict";var i=n(0),r=i.Model.extend({idAttribute:"name",defaults:{name:"",label:"",type:1,active:!0,private:!1,protected:!1},initialize:function(){var t=this.get("name"),e=this.get("label");t?e||this.set("label",t):this.set("name",e),this.set("name",r.escapeName(this.get("name")))},getFullName:function(){var t="";switch(this.get("type")){case 1:t=".";break;case 2:t="#"}return t+this.get("name")}},{TYPE_CLASS:1,TYPE_ID:2,escapeName:function(t){return(""+t).trim().replace(/([^a-z0-9\w-]+)/gi,"-")}});t.exports=r},function(t,e,n){"use strict";var i=(n(1),n(0)),r=i.$;t.exports=i.View.extend({events:{change:"onChange"},attributes:function(){return this.model.get("attributes")},initialize:function(t){var e=this.model,n=(e.get("name"),e.target);this.config=t.config||{},this.pfx=this.config.stylePrefix||"",this.ppfx=this.config.pStylePrefix||"",this.target=n,this.className=this.pfx+"trait",this.labelClass=this.ppfx+"label",this.fieldClass=this.ppfx+"field "+this.ppfx+"field-"+e.get("type"),this.inputhClass=this.ppfx+"input-holder",e.off("change:value",this.onValueChange),this.listenTo(e,"change:value",this.onValueChange),this.tmpl='
'},onChange:function(){this.model.set("value",this.getInputEl().value)},getValueForTarget:function(){return this.model.get("value")},setInputValue:function(t){this.getInputEl().value=t},onValueChange:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},i=this.model;this.target,i.get("name");if(n.fromTarget)this.setInputValue(i.get("value"));else{var r=this.getValueForTarget();i.setTargetValue(r)}},renderLabel:function(){this.$el.html('
'+this.getLabel()+"
")},getLabel:function(){var t=this.model,e=t.get("label")||t.get("name");return e.charAt(0).toUpperCase()+e.slice(1).replace(/-/g," ")},getInputEl:function(){if(!this.$input){var t=this.model,e=this.target,n=t.get("name"),i=t.get("placeholder")||t.get("default")||"",o=t.get("type")||"text",s=e.get("attributes"),a=t.get("min"),l=t.get("max"),c=t.get("changeProp")?e.get(n):t.get("value")||s[n],u=r('');c&&u.prop("value",c),a&&u.prop("min",a),l&&u.prop("max",l),this.$input=u}return this.$input.get(0)},getModelValue:function(){var t,e=this.model,n=this.target,i=e.get("name");if(e.get("changeProp"))t=n.get(i);else{var r=n.get("attributes");t=e.get("value")||r[i]}return t},renderField:function(){if(!this.$input){this.$el.append(this.tmpl);var t=this.getInputEl(),e=this.el.querySelector("."+this.inputhClass);e.insertBefore(t,e.childNodes[0])}},render:function(){return this.renderLabel(),this.renderField(),this.el.className=this.className,this}})},function(t,e,n){"use strict";var i,r;!function(o,s){i=s,void 0!==(r="function"==typeof i?i.call(e,n,e,t):i)&&(t.exports=r)}(0,function(){function t(t,e){return e=e||M,z.test(t)?e.getElementsByClassName(t.slice(1)):R.test(t)?e.getElementsByTagName(t):e.querySelectorAll(t)}function e(t){if(!E){E=M.implementation.createHTMLDocument();var e=E.createElement("base");e.href=M.location.href,E.head.appendChild(e)}return E.body.innerHTML=t,E.body.childNodes}function n(t){"loading"!==M.readyState?t():M.addEventListener("DOMContentLoaded",t)}function i(i,r){if(!i)return this;if(i.cash&&i!==P)return i;var o,s=i,a=0;if(_(i))s=F.test(i)?M.getElementById(i.slice(1)):$.test(i)?e(i):t(i,r);else if(D(i))return n(i),this;if(!s)return this;if(s.nodeType||s===P)this[0]=s,this.length=1;else for(o=this.length=s.length;a=0&&s.splice(i,1)):(o(s,function(n){t.removeEventListener(e,n)}),s=[]))}function x(t,e){return"&"+encodeURIComponent(t)+"="+encodeURIComponent(e).replace(/%20/g,"+")}function w(t){var e=[];return o(t.options,function(t){t.selected&&e.push(t.value)}),e.length?e:null}function C(t){var e=t.selectedIndex;return e>=0?t.options[e].value:null}function k(t){var e=t.type;if(!e)return null;switch(e.toLowerCase()){case"select-one":return C(t);case"select-multiple":return w(t);case"radio":case"checkbox":return t.checked?t.value:null;default:return t.value?t.value:null}}function S(t,e,n){if(n){var i=t.childNodes[0];t.insertBefore(e,i)}else t.appendChild(e)}function T(t,e,n){var i=_(e);if(!i&&e.length)return void o(e,function(e){return T(t,e,n)});o(t,i?function(t){return t.insertAdjacentHTML(n?"afterbegin":"beforeend",e)}:function(t,i){return S(t,0===i?e:e.cloneNode(!0),n)})}var E,M=document,P=window,A=Array.prototype,O=A.slice,L=A.filter,N=A.push,I=function(){},D=function(t){return typeof t==typeof I&&t.call},_=function(t){return"string"==typeof t},F=/^#[\w-]*$/,z=/^\.[\w-]*$/,$=/<.+>/,R=/^\w+$/,V=r.fn=r.prototype=i.prototype={cash:!0,length:0,push:N,splice:A.splice,map:A.map,init:i};Object.defineProperty(V,"constructor",{value:r}),r.parseHTML=e,r.noop=I,r.isFunction=D,r.isString=_,r.extend=V.extend=function(t){t=t||{};var e=O.call(arguments),n=e.length,i=1;for(1===e.length&&(t=this,i=0);i1?this.each(function(n){return n.style[t]=e}):P.getComputedStyle(this[0])[t];for(var n in t)this.css(n,t[n]);return this}}),o(["Width","Height"],function(t){var e=t.toLowerCase();V[e]=function(){return this[0].getBoundingClientRect()[e]},V["inner"+t]=function(){return this[0]["client"+t]},V["outer"+t]=function(e){return this[0]["offset"+t]+(e?m(this,"margin"+("Width"===t?"Left":"Top"))+m(this,"margin"+("Width"===t?"Right":"Bottom")):0)}}),V.extend({off:function(t,e){return this.each(function(n){return b(n,t,e)})},on:function(t,e,i,r){var o;if(!_(t)){for(var a in t)this.on(a,e,t[a]);return this}return D(e)&&(i=e,e=null),"ready"===t?(n(i),this):(e&&(o=i,i=function(t){for(var n=t.target;!s(n,e);){if(n===this)return n=!1;n=n.parentNode}n&&o.call(n,t)}),this.each(function(e){var n=i;r&&(n=function(){i.apply(this,arguments),b(e,t,n)}),y(e,t,n)}))},one:function(t,e,n){return this.on(t,e,n,!0)},ready:n,trigger:function(t,e){var n=M.createEvent("HTMLEvents");return n.data=e,n.initEvent(t,!0,!1),this.each(function(t){return t.dispatchEvent(n)})}}),V.extend({serialize:function(){var t="";return o(this[0].elements||this,function(e){if(!e.disabled&&"FIELDSET"!==e.tagName){var n=e.name;switch(e.type.toLowerCase()){case"file":case"reset":case"submit":case"button":break;case"select-multiple":var i=k(e);null!==i&&o(i,function(e){t+=x(n,e)});break;default:var r=k(e);null!==r&&(t+=x(n,r))}}}),t.substr(1)},val:function(t){return void 0===t?k(this[0]):this.each(function(e){return e.value=t})}}),V.extend({after:function(t){return r(t).insertAfter(this),this},append:function(t){return T(this,t),this},appendTo:function(t){return T(r(t),this),this},before:function(t){return r(t).insertBefore(this),this},clone:function(){return r(this.map(function(t){return t.cloneNode(!0)}))},empty:function(){return this.html(""),this},html:function(t){if(void 0===t)return this[0].innerHTML;var e=t.nodeType?t[0].outerHTML:t;return this.each(function(t){return t.innerHTML=e})},insertAfter:function(t){var e=this;return r(t).each(function(t,n){var i=t.parentNode,r=t.nextSibling;e.each(function(t){i.insertBefore(0===n?t:t.cloneNode(!0),r)})}),this},insertBefore:function(t){var e=this;return r(t).each(function(t,n){var i=t.parentNode;e.each(function(e){i.insertBefore(0===n?e:e.cloneNode(!0),t)})}),this},prepend:function(t){return T(this,t,!0),this},prependTo:function(t){return T(r(t),this,!0),this},remove:function(){return this.each(function(t){return t.parentNode.removeChild(t)})},text:function(t){return void 0===t?this[0].textContent:this.each(function(e){return e.textContent=t})}});var U=M.documentElement;return V.extend({position:function(){var t=this[0];return{left:t.offsetLeft,top:t.offsetTop}},offset:function(){var t=this[0].getBoundingClientRect();return{top:t.top+P.pageYOffset-U.clientTop,left:t.left+P.pageXOffset-U.clientLeft}},offsetParent:function(){return r(this[0].offsetParent)}}),V.extend({children:function(t){var e=[];return this.each(function(t){N.apply(e,t.children)}),e=l(e),t?e.filter(function(e){return s(e,t)}):e},closest:function(t){return!t||this.length<1?r():this.is(t)?this.filter(t):this.parent().closest(t)},is:function(t){if(!t)return!1;var e=!1,n=a(t);return this.each(function(i){return!(e=n(i,t))}),e},find:function(e){if(!e||e.nodeType)return r(e&&this.has(e).length?e:null);var n=[];return this.each(function(i){N.apply(n,t(e,i))}),l(n)},has:function(e){var n=_(e)?function(n){return 0!==t(e,n).length}:function(t){return t.contains(e)};return this.filter(n)},next:function(){return r(this[0].nextElementSibling)},not:function(t){if(!t)return this;var e=a(t);return this.filter(function(n){return!e(n,t)})},parent:function(){var t=[];return this.each(function(e){e&&e.parentNode&&t.push(e.parentNode)}),l(t)},parents:function(t){var e,n=[];return this.each(function(i){for(e=i;e&&e.parentNode&&e!==M.body.parentNode;)e=e.parentNode,(!t||t&&s(e,t))&&n.push(e)}),l(n)},prev:function(){return r(this[0].previousElementSibling)},siblings:function(){var t=this.parent().children(),e=this[0];return t.filter(function(t){return t!==e})}}),r})},function(t,e,n){"use strict";var i=n(1),r=n(7);t.exports=n(0).Collection.extend({model:r,getStyleable:function(){return(0,i.filter)(this.models,function(t){return t.get("active")&&!t.get("private")})},getValid:function(){return(0,i.filter)(this.models,function(t){return!t.get("private")})},getFullString:function(t){var e=[];return(t||this).forEach(function(t){return e.push(t.getFullName())}),e.join("").trim()}})},function(t,e,n){"use strict";var i=Object.assign||function(t){for(var e=1;e1&&void 0!==arguments[1]?arguments[1]:1,n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},r=this.parseValue(t);this.set(r,i({},n,{avoidStore:1})),e&&(this.set("value","",n),this.set(r,n))},setValueFromInput:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};this.setValue(t,e,i({},n,{fromInput:1}))},parseValue:function(t){var e={value:t};if(!this.get("functionName"))return e;var n=[],i=""+t,r=i.indexOf("(")+1,o=i.lastIndexOf(")");return n.push(r),o>=0&&n.push(o),e.value=String.prototype.substring.apply(i,n),e},getDefaultValue:function(){return this.get("defaults")},getFullValue:function(t){var e=this.get("functionName"),n=t||this.get("value");return e&&(n=e+"("+n+")"),n}})},function(t,e,n){"use strict";(function(e){n(5),n(14),n(36),n(37),n(38),n(40),n(17),n(34);t.exports=e.View.extend({initialize:function(t){this.config=t.config||{},this.pfx=this.config.stylePrefix||"",this.target=t.target||{},this.propTarget=t.propTarget||{},this.onChange=t.onChange,this.onInputRender=t.onInputRender||{},this.customValue=t.customValue||{};var e=this.collection;this.listenTo(e,"add",this.addTo),this.listenTo(e,"reset",this.render)},addTo:function(t){this.add(t)},add:function(t,e){var n=new t.typeView({model:t,name:t.get("name"),id:this.pfx+t.get("property"),target:this.target,propTarget:this.propTarget,onChange:this.onChange,onInputRender:this.onInputRender,config:this.config});"composite"!=t.get("type")&&(n.customValue=this.customValue),n.render();var i=n.el;e?e.appendChild(i):this.el.appendChild(i)},render:function(){var t=this,e=document.createDocumentFragment();return this.collection.each(function(n){return t.add(n,e)}),this.$el.append(e),this.$el.attr("class",this.pfx+"properties"),this}})}).call(e,n(0))},function(t,e,n){"use strict";(function(e){var i=(n(18),e.$);t.exports=n(5).extend({templateInput:function(){return""},init:function(){var t=this.model;this.listenTo(t,"change:unit",this.modelValueChanged),this.listenTo(t,"el:change",this.elementUpdated)},setValue:function(t){this.inputInst.setValue(t,{silent:1})},onRender:function(){var t=this.ppfx;if(!this.input){var e=this.model.input;e.ppfx=t,e.render();this.el.querySelector("."+t+"fields").appendChild(e.el),this.$input=e.inputEl,this.unit=e.unitEl,this.$unit=i(this.unit),this.input=this.$input.get(0),this.inputInst=e}}})}).call(e,n(0))},function(t,e,n){"use strict";var i=(n(0),n(3));t.exports=i.extend({tagName:"img",events:{dblclick:"openModal",click:"initResize"},initialize:function(t){var e=this.model;i.prototype.initialize.apply(this,arguments),this.listenTo(e,"change:src",this.updateSrc),this.listenTo(e,"dblclick active",this.openModal),this.classEmpty=this.ppfx+"plh-image";var n=this.config;n.modal&&(this.modal=n.modal),n.am&&(this.am=n.am)},updateSrc:function(){var t=this.model.get("src"),e=this.$el;e.attr("src",t),e[t?"removeClass":"addClass"](this.classEmpty)},openModal:function(t){var e=this.opts.config.em,n=e?e.get("Editor"):"";n&&this.model.get("editable")&&n.runCommand("open-assets",{target:this.model,onSelect:function(){n.Modal.close(),n.AssetManager.setTarget(null)}})},render:function(){this.updateAttributes(),this.updateClasses();var t=this.$el.attr("class")||"";return this.model.get("src")||this.$el.attr("class",(t+" "+this.classEmpty).trim()),this.$el.attr("onmousedown","return false"),this}})},function(t,e){var n;n=function(){return this}();try{n=n||Function("return this")()||(0,eval)("this")}catch(t){"object"==typeof window&&(n=window)}t.exports=n},function(t,e,n){"use strict";(function(e){var i=n(5),r=e.$;t.exports=i.extend({templateInput:function(){var t=this.pfx;return'\n
\n \n
\n '},inputValueChanged:function(){if(!this.model.get("detached")){for(var t=arguments.length,e=Array(t),n=0;n'),this.input=this.$input.get(0)),this.props||(this.props=t.get("properties")),!this.$props)){this.props.each(function(e,n){e&&"composite"==e.get("type")&&(this.props.remove(e),console.warn("Nested composite types not yet allowed.")),e.parent=t},this);var i=n(13),o=new i(this.getPropsConfig());this.$props=o.render().$el,this.$el.find("#"+this.pfx+"input-holder").append(this.$props)}},getPropsConfig:function(t){var e=this,n=this.model,i={config:this.config,collection:this.props,target:this.target,propTarget:this.propTarget,onChange:function(t,e,i){n.set("value",n.getFullValue(),i)},customValue:function(t,n){return e.valueOnIndex(n,t)}};return n.get("detached")&&delete i.onChange,i},valueOnIndex:function(t,e){var n=void 0,i=this.getTargetValue({ignoreDefault:1});if(i){n=i.split(" ")[t]}else n=e&&e.getTargetValue({ignoreCustomValue:1,ignoreDefault:1});return e&&(n=e.model.parseValue(n).value),n}})}).call(e,n(0))},function(t,e,n){"use strict";(function(e){var i=n(1),r=n(2),o=n(35),s=n(0);s.$;t.exports=o.extend({events:{"change input":"handleChange","change select":"handleUnitChange","click [data-arrow-up]":"upArrowClick","click [data-arrow-down]":"downArrowClick","mousedown [data-arrows]":"downIncrement"},template:function(){var t=this.ppfx;return'\n \n \n
\n
\n
\n
\n '},inputClass:function(){var t=this.ppfx;return this.opts.contClass||t+"field "+t+"field-integer"},initialize:function(){arguments.length>0&&void 0!==arguments[0]&&arguments[0];o.prototype.initialize.apply(this,arguments),(0,i.bindAll)(this,"moveIncrement","upIncrement"),this.doc=document,this.listenTo(this.model,"change:unit",this.handleModelChange)},setValue:function(t,e){var n=e||{},i=this.validateInputValue(t,{deepCheck:1}),r={value:i.value};(i.unit||i.force)&&(r.unit=i.unit),this.model.set(r,n),n.silent&&this.handleModelChange()},handleChange:function(t){t.stopPropagation(),this.setValue(this.getInputEl().value),this.elementUpdated()},handleUnitChange:function(t){t.stopPropagation();var e=this.getUnitEl().value;this.model.set("unit",e),this.elementUpdated()},elementUpdated:function(){this.model.trigger("el:change")},handleModelChange:function(){var t=this.model;this.getInputEl().value=t.get("value");var e=this.getUnitEl();e&&(e.value=t.get("unit")||"")},getUnitEl:function(){if(!this.unitEl){var t=this.model,e=t.get("units")||[];if(e.length){var n=[];e.forEach(function(e){var i=e==t.get("unit")?"selected":"";n.push("")});var i=document.createElement("div");i.innerHTML='",this.unitEl=i.firstChild}}return this.unitEl},upArrowClick:function(){var t=this.model,e=t.get("step"),n=parseInt(t.get("value"),10);n=this.normalizeValue(n+e);var i=this.validateInputValue(n);t.set("value",i.value),this.elementUpdated()},downArrowClick:function(){var t=this.model,e=t.get("step"),n=parseInt(t.get("value"),10),i=this.normalizeValue(n-e),r=this.validateInputValue(i);t.set("value",r.value),this.elementUpdated()},downIncrement:function(t){t.preventDefault(),this.moved=0;var e=this.model.get("value");e=this.normalizeValue(e),this.current={y:t.pageY,val:e},(0,r.on)(this.doc,"mousemove",this.moveIncrement),(0,r.on)(this.doc,"mouseup",this.upIncrement)},moveIncrement:function(t){this.moved=1;var e=this.model,n=e.get("step"),i=this.current,r=this.normalizeValue(i.val+(i.y-t.pageY)*n);return this.prValue=this.validateInputValue(r).value,e.set("value",this.prValue,{avoidStore:1}),!1},upIncrement:function(){var t=this.model,e=t.get("step");if((0,r.off)(this.doc,"mouseup",this.upIncrement),(0,r.off)(this.doc,"mousemove",this.moveIncrement),this.prValue&&this.moved){var n=this.prValue-e;t.set("value",n,{avoidStore:1}).set("value",n+e),this.elementUpdated()}},normalizeValue:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,n=this.model,i=n.get("step"),r=0;if(isNaN(t))return e;if(t=parseFloat(t),Math.floor(t)!==t){var o=i.toString().split(".")[1];r=o?o.length:0}return r?parseFloat(t.toFixed(r)):t},validateInputValue:function(t,n){var i=0,r=n||{},o=this.model,s=""!==t?t:o.get("defaults"),a=o.get("units")||[],l=o.get("unit")||a.length&&a[0]||"",c=o.get("max"),u=o.get("min");if(r.deepCheck){var h=o.get("fixedValues")||[];if(s){var d=new RegExp("^"+h.join("|"),"g");if(h.length&&d.test(s))s=s.match(d)[0],l="",i=1;else{var f=s+"";s+="",s=parseFloat(s.replace(",",".")),s=isNaN(s)?o.get("defaults"):s;var p=f.replace(s,"");e.indexOf(a,p)>=0&&(l=p)}}}return void 0!==c&&""!==c&&(s=s>c?c:s),void 0!==u&&""!==u&&(s=s1&&void 0!==arguments[1]?arguments[1]:{},r=i.el,o=i.config,a=i.resizer,l=o.keyHeight,c=o.keyWidth,d=o.currentUnit;p("add",0,i),e=n.get("StyleManager").getModelToStyle(h);var f=getComputedStyle(r),g=e.getStyle(),v=g[c]||f[c],m=g[l]||f[l];a.startDim.w=parseFloat(v),a.startDim.h=parseFloat(m),u=0,d&&(o.unitHeight=(0,s.getUnitFromValue)(m),o.unitWidth=(0,s.getUnitFromValue)(v))},onMove:function(){o.trigger("change:canvasOffset")},onEnd:function(t,e){p("remove",0,e),o.trigger("change:canvasOffset"),u=1},updateTarget:function(t,i){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};if(e){var o=r.store,s=r.selectedHandler,a=r.config,l=a.keyHeight,c=a.keyWidth,u=["tc","bc"].indexOf(s)>=0,h=["cl","cr"].indexOf(s)>=0,d=e.getStyle();u||(d[c]=i.w+a.unitWidth),h||(d[l]=i.h+a.unitHeight),e.setStyle(d,{avoidStore:1});n&&n.trigger("update:component:style:"+l+" update:component:style:"+c),o&&e.trigger("change:style",e,d,{})}}},"object"==(void 0===d?"undefined":r(d))&&(f=i({},f,d)),o.runCommand("resize",{el:t,options:f}))},updateToolbar:function(t){var e=this.config.em,n=t==e?e.get("selectedComponent"):t,i=this.canvas.getToolbarEl(),r=i.style;if(!n)return void(r.opacity=0);var o=n.get("toolbar");this.ppfx;if(e.get("Config").showToolbar&&o&&o.length){if(r.opacity="",r.display="",!this.toolbar){i.innerHTML="",this.toolbar=new l(o);var s=new a({collection:this.toolbar,editor:this.editor});i.appendChild(s.render().el)}this.toolbar.reset(o);var c=n.view;c&&this.updateToolbarPos(c.el)}else r.display="none"},updateToolbarPos:function(t,e){var n=this.canvas.getToolbarEl(),i=n.style,r=i.display;i.display="block";var o=this.canvas.getTargetToElementDim(n,t,{elPos:e,event:"toolbarPosUpdate"}),s=o.left+o.elementWidth-o.targetWidth;i.top=o.top+"px",i.left=s+"px",i.display=r},getCanvasPosition:function(){return this.canvas.getCanvasView().getPosition()},clean:function(){this.selEl&&this.selEl.removeClass(this.hoverClass)},getBadge:function(){return this.canvas.getBadgeEl()},onFrameScroll:function(t){var e=this.cacheEl;if(e){var n=this.getElementPos(e);this.updateBadge(e,n);var i=this.em.get("selectedComponent");i&&this.updateToolbarPos(i.view.el)}},updateAttached:function(t){var e=this.em.getSelected();if(e){var n=e.view;this.updateToolbarPos(n.el),this.showFixedElementOffset(n.el)}},getElementPos:function(t,e){return this.canvas.getCanvasView().getElementPos(t)},hideBadge:function(){this.getBadge().style.display="none"},cleanPrevious:function(t){t&&t.set({status:"",state:""})},getContentWindow:function(){return this.frameEl.contentWindow},run:function(t){this.editor=t&&t.get("Editor"),this.enable(),this.onSelect()},stop:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},i=this.em;this.stopSelectComponent(),!n.preserveSelected&&i.setSelected(null),this.clean(),this.hideBadge(),this.hideFixedElementOffset(),this.canvas.getToolbarEl().style.display="none",i.off("component:update",this.updateAttached,this),i.off("change:canvasOffset",this.updateAttached,this),i.off("change:selectedComponent",this.updateToolbar,this)}}},function(t,e,n){"use strict";(function(e,i){var r=n(53),o=e.$;t.exports=i.extend({},r,{init:function(t){i.bindAll(this,"startDraw","draw","endDraw","rollback"),this.config=t||{},this.hType=this.config.newFixedH?"height":"min-height",this.allowDraw=1},enable:function(){for(var t=arguments.length,e=Array(t),n=0;n0;for(o in C)(!C[o]&&n(i.mods,+o)>-1||C[o]&&-1==n(i.mods,+o))&&(a=!1);(0!=i.mods.length||C[16]||C[18]||C[17]||C[91])&&!a||!1===i.method(t,i)&&(t.preventDefault?t.preventDefault():t.returnValue=!1,t.stopPropagation&&t.stopPropagation(),t.cancelBubble&&(t.cancelBubble=!0))}}function s(t){var e,i=t.keyCode,r=n(M,i);if(r>=0&&M.splice(r,1),93!=i&&224!=i||(i=91),i in C){C[i]=!1;for(e in S)S[e]==i&&(l[e]=!1)}}function a(){for(x in C)C[x]=!1;for(x in S)l[x]=!1}function l(t,e,n){var i,r;i=v(t),void 0===n&&(n=e,e="all");for(var o=0;o1&&(r=m(t),t=[t[t.length-1]]),t=t[0],t=E(t),t in w||(w[t]=[]),w[t].push({shortcut:i[o],scope:e,method:n,key:i[o],mods:r})}function c(t,e){var n,r,o,s,a,l=[];for(n=v(t),s=0;s1&&(l=m(r),t=r[r.length-1]),t=E(t),void 0===e&&(e=p()),!w[t])return;for(o=0;o*\/]/.test(n)?i(null,"select-op"):"."==n&&t.match(/^-?[_a-z][_a-z0-9-]*/i)?i("qualifier","qualifier"):/[:;{}\[\]\(\)]/.test(n)?i(null,n):"u"==n&&t.match(/rl(-prefix)?\(/)||"d"==n&&t.match("omain(")||"r"==n&&t.match("egexp(")?(t.backUp(1),e.tokenize=s,i("property","word")):/[\w\\\-]/.test(n)?(t.eatWhile(/[\w\\\-]/),i("property","word")):i(null,null):/[\d.]/.test(t.peek())?(t.eatWhile(/[\w.%]/),i("number","unit")):t.match(/^-[\w\\\-]+/)?(t.eatWhile(/[\w\\\-]/),t.match(/^\s*:/,!1)?i("variable-2","variable-definition"):i("variable-2","variable")):t.match(/^\w+-/)?i("meta","meta"):void 0}function o(t){return function(e,n){for(var r,o=!1;null!=(r=e.next());){if(r==t&&!o){")"==t&&e.backUp(1);break}o=!o&&"\\"==r}return(r==t||!o&&")"!=t)&&(n.tokenize=null),i("string","string")}}function s(t,e){return t.next(),t.match(/\s*[\"\')]/,!1)?e.tokenize=null:e.tokenize=o(")"),i(null,"(")}function a(t,e,n){this.type=t,this.indent=e,this.prev=n}function l(t,e,n,i){return t.context=new a(n,e.indentation()+(!1===i?0:v),t.context),n}function c(t){return t.context.prev&&(t.context=t.context.prev),t.context.type}function u(t,e,n){return L[n.context.type](t,e,n)}function h(t,e,n,i){for(var r=i||1;r>0;r--)n.context=n.context.prev;return u(t,e,n)}function d(t){var e=t.current().toLowerCase();g=M.hasOwnProperty(e)?"atom":E.hasOwnProperty(e)?"keyword":"variable"}var f=n.inline;n.propertyKeywords||(n=t.resolveMode("text/css"));var p,g,v=e.indentUnit,m=n.tokenHooks,y=n.documentTypes||{},b=n.mediaTypes||{},x=n.mediaFeatures||{},w=n.mediaValueKeywords||{},C=n.propertyKeywords||{},k=n.nonStandardPropertyKeywords||{},S=n.fontProperties||{},T=n.counterDescriptors||{},E=n.colorKeywords||{},M=n.valueKeywords||{},P=n.allowNested,A=n.lineComment,O=!0===n.supportsAtComponent,L={};return L.top=function(t,e,n){if("{"==t)return l(n,e,"block");if("}"==t&&n.context.prev)return c(n);if(O&&/@component/.test(t))return l(n,e,"atComponentBlock");if(/^@(-moz-)?document$/.test(t))return l(n,e,"documentTypes");if(/^@(media|supports|(-moz-)?document|import)$/.test(t))return l(n,e,"atBlock");if(/^@(font-face|counter-style)/.test(t))return n.stateArg=t,"restricted_atBlock_before";if(/^@(-(moz|ms|o|webkit)-)?keyframes$/.test(t))return"keyframes";if(t&&"@"==t.charAt(0))return l(n,e,"at");if("hash"==t)g="builtin";else if("word"==t)g="tag";else{if("variable-definition"==t)return"maybeprop";if("interpolation"==t)return l(n,e,"interpolation");if(":"==t)return"pseudo";if(P&&"("==t)return l(n,e,"parens")}return n.context.type},L.block=function(t,e,n){if("word"==t){var i=e.current().toLowerCase();return C.hasOwnProperty(i)?(g="property","maybeprop"):k.hasOwnProperty(i)?(g="string-2","maybeprop"):P?(g=e.match(/^\s*:(?:\s|$)/,!1)?"property":"tag","block"):(g+=" error","maybeprop")}return"meta"==t?"block":P||"hash"!=t&&"qualifier"!=t?L.top(t,e,n):(g="error","block")},L.maybeprop=function(t,e,n){return":"==t?l(n,e,"prop"):u(t,e,n)},L.prop=function(t,e,n){if(";"==t)return c(n);if("{"==t&&P)return l(n,e,"propBlock");if("}"==t||"{"==t)return h(t,e,n);if("("==t)return l(n,e,"parens");if("hash"!=t||/^#([0-9a-fA-f]{3,4}|[0-9a-fA-f]{6}|[0-9a-fA-f]{8})$/.test(e.current())){if("word"==t)d(e);else if("interpolation"==t)return l(n,e,"interpolation")}else g+=" error";return"prop"},L.propBlock=function(t,e,n){return"}"==t?c(n):"word"==t?(g="property","maybeprop"):n.context.type},L.parens=function(t,e,n){return"{"==t||"}"==t?h(t,e,n):")"==t?c(n):"("==t?l(n,e,"parens"):"interpolation"==t?l(n,e,"interpolation"):("word"==t&&d(e),"parens")},L.pseudo=function(t,e,n){return"meta"==t?"pseudo":"word"==t?(g="variable-3",n.context.type):u(t,e,n)},L.documentTypes=function(t,e,n){return"word"==t&&y.hasOwnProperty(e.current())?(g="tag",n.context.type):L.atBlock(t,e,n)},L.atBlock=function(t,e,n){if("("==t)return l(n,e,"atBlock_parens");if("}"==t||";"==t)return h(t,e,n);if("{"==t)return c(n)&&l(n,e,P?"block":"top");if("interpolation"==t)return l(n,e,"interpolation");if("word"==t){var i=e.current().toLowerCase();g="only"==i||"not"==i||"and"==i||"or"==i?"keyword":b.hasOwnProperty(i)?"attribute":x.hasOwnProperty(i)?"property":w.hasOwnProperty(i)?"keyword":C.hasOwnProperty(i)?"property":k.hasOwnProperty(i)?"string-2":M.hasOwnProperty(i)?"atom":E.hasOwnProperty(i)?"keyword":"error"}return n.context.type},L.atComponentBlock=function(t,e,n){return"}"==t?h(t,e,n):"{"==t?c(n)&&l(n,e,P?"block":"top",!1):("word"==t&&(g="error"),n.context.type)},L.atBlock_parens=function(t,e,n){return")"==t?c(n):"{"==t||"}"==t?h(t,e,n,2):L.atBlock(t,e,n)},L.restricted_atBlock_before=function(t,e,n){return"{"==t?l(n,e,"restricted_atBlock"):"word"==t&&"@counter-style"==n.stateArg?(g="variable","restricted_atBlock_before"):u(t,e,n)},L.restricted_atBlock=function(t,e,n){return"}"==t?(n.stateArg=null,c(n)):"word"==t?(g="@font-face"==n.stateArg&&!S.hasOwnProperty(e.current().toLowerCase())||"@counter-style"==n.stateArg&&!T.hasOwnProperty(e.current().toLowerCase())?"error":"property","maybeprop"):"restricted_atBlock"},L.keyframes=function(t,e,n){return"word"==t?(g="variable","keyframes"):"{"==t?l(n,e,"top"):u(t,e,n)},L.at=function(t,e,n){return";"==t?c(n):"{"==t||"}"==t?h(t,e,n):("word"==t?g="tag":"hash"==t&&(g="builtin"),"at")},L.interpolation=function(t,e,n){return"}"==t?c(n):"{"==t||";"==t?h(t,e,n):("word"==t?g="variable":"variable"!=t&&"("!=t&&")"!=t&&(g="error"),"interpolation")},{startState:function(t){return{tokenize:null,state:f?"block":"top",stateArg:null,context:new a(f?"block":"top",t||0,null)}},token:function(t,e){if(!e.tokenize&&t.eatSpace())return null;var n=(e.tokenize||r)(t,e);return n&&"object"==typeof n&&(p=n[1],n=n[0]),g=n,"comment"!=p&&(e.state=L[e.state](p,t,e)),g},indent:function(t,e){var n=t.context,i=e&&e.charAt(0),r=n.indent;return"prop"!=n.type||"}"!=i&&")"!=i||(n=n.prev),n.prev&&("}"!=i||"block"!=n.type&&"top"!=n.type&&"interpolation"!=n.type&&"restricted_atBlock"!=n.type?(")"!=i||"parens"!=n.type&&"atBlock_parens"!=n.type)&&("{"!=i||"at"!=n.type&&"atBlock"!=n.type)||(r=Math.max(0,n.indent-v)):(n=n.prev,r=n.indent)),r},electricChars:"}",blockCommentStart:"/*",blockCommentEnd:"*/",blockCommentContinue:" * ",lineComment:A,fold:"brace"}});var i=["domain","regexp","url","url-prefix"],r=e(i),o=["all","aural","braille","handheld","print","projection","screen","tty","tv","embossed"],s=e(o),a=["width","min-width","max-width","height","min-height","max-height","device-width","min-device-width","max-device-width","device-height","min-device-height","max-device-height","aspect-ratio","min-aspect-ratio","max-aspect-ratio","device-aspect-ratio","min-device-aspect-ratio","max-device-aspect-ratio","color","min-color","max-color","color-index","min-color-index","max-color-index","monochrome","min-monochrome","max-monochrome","resolution","min-resolution","max-resolution","scan","grid","orientation","device-pixel-ratio","min-device-pixel-ratio","max-device-pixel-ratio","pointer","any-pointer","hover","any-hover"],l=e(a),c=["landscape","portrait","none","coarse","fine","on-demand","hover","interlace","progressive"],u=e(c),h=["align-content","align-items","align-self","alignment-adjust","alignment-baseline","anchor-point","animation","animation-delay","animation-direction","animation-duration","animation-fill-mode","animation-iteration-count","animation-name","animation-play-state","animation-timing-function","appearance","azimuth","backface-visibility","background","background-attachment","background-blend-mode","background-clip","background-color","background-image","background-origin","background-position","background-repeat","background-size","baseline-shift","binding","bleed","bookmark-label","bookmark-level","bookmark-state","bookmark-target","border","border-bottom","border-bottom-color","border-bottom-left-radius","border-bottom-right-radius","border-bottom-style","border-bottom-width","border-collapse","border-color","border-image","border-image-outset","border-image-repeat","border-image-slice","border-image-source","border-image-width","border-left","border-left-color","border-left-style","border-left-width","border-radius","border-right","border-right-color","border-right-style","border-right-width","border-spacing","border-style","border-top","border-top-color","border-top-left-radius","border-top-right-radius","border-top-style","border-top-width","border-width","bottom","box-decoration-break","box-shadow","box-sizing","break-after","break-before","break-inside","caption-side","caret-color","clear","clip","color","color-profile","column-count","column-fill","column-gap","column-rule","column-rule-color","column-rule-style","column-rule-width","column-span","column-width","columns","content","counter-increment","counter-reset","crop","cue","cue-after","cue-before","cursor","direction","display","dominant-baseline","drop-initial-after-adjust","drop-initial-after-align","drop-initial-before-adjust","drop-initial-before-align","drop-initial-size","drop-initial-value","elevation","empty-cells","fit","fit-position","flex","flex-basis","flex-direction","flex-flow","flex-grow","flex-shrink","flex-wrap","float","float-offset","flow-from","flow-into","font","font-feature-settings","font-family","font-kerning","font-language-override","font-size","font-size-adjust","font-stretch","font-style","font-synthesis","font-variant","font-variant-alternates","font-variant-caps","font-variant-east-asian","font-variant-ligatures","font-variant-numeric","font-variant-position","font-weight","grid","grid-area","grid-auto-columns","grid-auto-flow","grid-auto-rows","grid-column","grid-column-end","grid-column-gap","grid-column-start","grid-gap","grid-row","grid-row-end","grid-row-gap","grid-row-start","grid-template","grid-template-areas","grid-template-columns","grid-template-rows","hanging-punctuation","height","hyphens","icon","image-orientation","image-rendering","image-resolution","inline-box-align","justify-content","justify-items","justify-self","left","letter-spacing","line-break","line-height","line-stacking","line-stacking-ruby","line-stacking-shift","line-stacking-strategy","list-style","list-style-image","list-style-position","list-style-type","margin","margin-bottom","margin-left","margin-right","margin-top","marks","marquee-direction","marquee-loop","marquee-play-count","marquee-speed","marquee-style","max-height","max-width","min-height","min-width","move-to","nav-down","nav-index","nav-left","nav-right","nav-up","object-fit","object-position","opacity","order","orphans","outline","outline-color","outline-offset","outline-style","outline-width","overflow","overflow-style","overflow-wrap","overflow-x","overflow-y","padding","padding-bottom","padding-left","padding-right","padding-top","page","page-break-after","page-break-before","page-break-inside","page-policy","pause","pause-after","pause-before","perspective","perspective-origin","pitch","pitch-range","place-content","place-items","place-self","play-during","position","presentation-level","punctuation-trim","quotes","region-break-after","region-break-before","region-break-inside","region-fragment","rendering-intent","resize","rest","rest-after","rest-before","richness","right","rotation","rotation-point","ruby-align","ruby-overhang","ruby-position","ruby-span","shape-image-threshold","shape-inside","shape-margin","shape-outside","size","speak","speak-as","speak-header","speak-numeral","speak-punctuation","speech-rate","stress","string-set","tab-size","table-layout","target","target-name","target-new","target-position","text-align","text-align-last","text-decoration","text-decoration-color","text-decoration-line","text-decoration-skip","text-decoration-style","text-emphasis","text-emphasis-color","text-emphasis-position","text-emphasis-style","text-height","text-indent","text-justify","text-outline","text-overflow","text-shadow","text-size-adjust","text-space-collapse","text-transform","text-underline-position","text-wrap","top","transform","transform-origin","transform-style","transition","transition-delay","transition-duration","transition-property","transition-timing-function","unicode-bidi","user-select","vertical-align","visibility","voice-balance","voice-duration","voice-family","voice-pitch","voice-range","voice-rate","voice-stress","voice-volume","volume","white-space","widows","width","will-change","word-break","word-spacing","word-wrap","z-index","clip-path","clip-rule","mask","enable-background","filter","flood-color","flood-opacity","lighting-color","stop-color","stop-opacity","pointer-events","color-interpolation","color-interpolation-filters","color-rendering","fill","fill-opacity","fill-rule","image-rendering","marker","marker-end","marker-mid","marker-start","shape-rendering","stroke","stroke-dasharray","stroke-dashoffset","stroke-linecap","stroke-linejoin","stroke-miterlimit","stroke-opacity","stroke-width","text-rendering","baseline-shift","dominant-baseline","glyph-orientation-horizontal","glyph-orientation-vertical","text-anchor","writing-mode"],d=e(h),f=["scrollbar-arrow-color","scrollbar-base-color","scrollbar-dark-shadow-color","scrollbar-face-color","scrollbar-highlight-color","scrollbar-shadow-color","scrollbar-3d-light-color","scrollbar-track-color","shape-inside","searchfield-cancel-button","searchfield-decoration","searchfield-results-button","searchfield-results-decoration","zoom"],p=e(f),g=["font-family","src","unicode-range","font-variant","font-feature-settings","font-stretch","font-weight","font-style"],v=e(g),m=["additive-symbols","fallback","negative","pad","prefix","range","speak-as","suffix","symbols","system"],y=e(m),b=["aliceblue","antiquewhite","aqua","aquamarine","azure","beige","bisque","black","blanchedalmond","blue","blueviolet","brown","burlywood","cadetblue","chartreuse","chocolate","coral","cornflowerblue","cornsilk","crimson","cyan","darkblue","darkcyan","darkgoldenrod","darkgray","darkgreen","darkkhaki","darkmagenta","darkolivegreen","darkorange","darkorchid","darkred","darksalmon","darkseagreen","darkslateblue","darkslategray","darkturquoise","darkviolet","deeppink","deepskyblue","dimgray","dodgerblue","firebrick","floralwhite","forestgreen","fuchsia","gainsboro","ghostwhite","gold","goldenrod","gray","grey","green","greenyellow","honeydew","hotpink","indianred","indigo","ivory","khaki","lavender","lavenderblush","lawngreen","lemonchiffon","lightblue","lightcoral","lightcyan","lightgoldenrodyellow","lightgray","lightgreen","lightpink","lightsalmon","lightseagreen","lightskyblue","lightslategray","lightsteelblue","lightyellow","lime","limegreen","linen","magenta","maroon","mediumaquamarine","mediumblue","mediumorchid","mediumpurple","mediumseagreen","mediumslateblue","mediumspringgreen","mediumturquoise","mediumvioletred","midnightblue","mintcream","mistyrose","moccasin","navajowhite","navy","oldlace","olive","olivedrab","orange","orangered","orchid","palegoldenrod","palegreen","paleturquoise","palevioletred","papayawhip","peachpuff","peru","pink","plum","powderblue","purple","rebeccapurple","red","rosybrown","royalblue","saddlebrown","salmon","sandybrown","seagreen","seashell","sienna","silver","skyblue","slateblue","slategray","snow","springgreen","steelblue","tan","teal","thistle","tomato","turquoise","violet","wheat","white","whitesmoke","yellow","yellowgreen"],x=e(b),w=["above","absolute","activeborder","additive","activecaption","afar","after-white-space","ahead","alias","all","all-scroll","alphabetic","alternate","always","amharic","amharic-abegede","antialiased","appworkspace","arabic-indic","armenian","asterisks","attr","auto","auto-flow","avoid","avoid-column","avoid-page","avoid-region","background","backwards","baseline","below","bidi-override","binary","bengali","blink","block","block-axis","bold","bolder","border","border-box","both","bottom","break","break-all","break-word","bullets","button","button-bevel","buttonface","buttonhighlight","buttonshadow","buttontext","calc","cambodian","capitalize","caps-lock-indicator","caption","captiontext","caret","cell","center","checkbox","circle","cjk-decimal","cjk-earthly-branch","cjk-heavenly-stem","cjk-ideographic","clear","clip","close-quote","col-resize","collapse","color","color-burn","color-dodge","column","column-reverse","compact","condensed","contain","content","contents","content-box","context-menu","continuous","copy","counter","counters","cover","crop","cross","crosshair","currentcolor","cursive","cyclic","darken","dashed","decimal","decimal-leading-zero","default","default-button","dense","destination-atop","destination-in","destination-out","destination-over","devanagari","difference","disc","discard","disclosure-closed","disclosure-open","document","dot-dash","dot-dot-dash","dotted","double","down","e-resize","ease","ease-in","ease-in-out","ease-out","element","ellipse","ellipsis","embed","end","ethiopic","ethiopic-abegede","ethiopic-abegede-am-et","ethiopic-abegede-gez","ethiopic-abegede-ti-er","ethiopic-abegede-ti-et","ethiopic-halehame-aa-er","ethiopic-halehame-aa-et","ethiopic-halehame-am-et","ethiopic-halehame-gez","ethiopic-halehame-om-et","ethiopic-halehame-sid-et","ethiopic-halehame-so-et","ethiopic-halehame-ti-er","ethiopic-halehame-ti-et","ethiopic-halehame-tig","ethiopic-numeric","ew-resize","exclusion","expanded","extends","extra-condensed","extra-expanded","fantasy","fast","fill","fixed","flat","flex","flex-end","flex-start","footnotes","forwards","from","geometricPrecision","georgian","graytext","grid","groove","gujarati","gurmukhi","hand","hangul","hangul-consonant","hard-light","hebrew","help","hidden","hide","higher","highlight","highlighttext","hiragana","hiragana-iroha","horizontal","hsl","hsla","hue","icon","ignore","inactiveborder","inactivecaption","inactivecaptiontext","infinite","infobackground","infotext","inherit","initial","inline","inline-axis","inline-block","inline-flex","inline-grid","inline-table","inset","inside","intrinsic","invert","italic","japanese-formal","japanese-informal","justify","kannada","katakana","katakana-iroha","keep-all","khmer","korean-hangul-formal","korean-hanja-formal","korean-hanja-informal","landscape","lao","large","larger","left","level","lighter","lighten","line-through","linear","linear-gradient","lines","list-item","listbox","listitem","local","logical","loud","lower","lower-alpha","lower-armenian","lower-greek","lower-hexadecimal","lower-latin","lower-norwegian","lower-roman","lowercase","ltr","luminosity","malayalam","match","matrix","matrix3d","media-controls-background","media-current-time-display","media-fullscreen-button","media-mute-button","media-play-button","media-return-to-realtime-button","media-rewind-button","media-seek-back-button","media-seek-forward-button","media-slider","media-sliderthumb","media-time-remaining-display","media-volume-slider","media-volume-slider-container","media-volume-sliderthumb","medium","menu","menulist","menulist-button","menulist-text","menulist-textfield","menutext","message-box","middle","min-intrinsic","mix","mongolian","monospace","move","multiple","multiply","myanmar","n-resize","narrower","ne-resize","nesw-resize","no-close-quote","no-drop","no-open-quote","no-repeat","none","normal","not-allowed","nowrap","ns-resize","numbers","numeric","nw-resize","nwse-resize","oblique","octal","opacity","open-quote","optimizeLegibility","optimizeSpeed","oriya","oromo","outset","outside","outside-shape","overlay","overline","padding","padding-box","painted","page","paused","persian","perspective","plus-darker","plus-lighter","pointer","polygon","portrait","pre","pre-line","pre-wrap","preserve-3d","progress","push-button","radial-gradient","radio","read-only","read-write","read-write-plaintext-only","rectangle","region","relative","repeat","repeating-linear-gradient","repeating-radial-gradient","repeat-x","repeat-y","reset","reverse","rgb","rgba","ridge","right","rotate","rotate3d","rotateX","rotateY","rotateZ","round","row","row-resize","row-reverse","rtl","run-in","running","s-resize","sans-serif","saturation","scale","scale3d","scaleX","scaleY","scaleZ","screen","scroll","scrollbar","scroll-position","se-resize","searchfield","searchfield-cancel-button","searchfield-decoration","searchfield-results-button","searchfield-results-decoration","self-start","self-end","semi-condensed","semi-expanded","separate","serif","show","sidama","simp-chinese-formal","simp-chinese-informal","single","skew","skewX","skewY","skip-white-space","slide","slider-horizontal","slider-vertical","sliderthumb-horizontal","sliderthumb-vertical","slow","small","small-caps","small-caption","smaller","soft-light","solid","somali","source-atop","source-in","source-out","source-over","space","space-around","space-between","space-evenly","spell-out","square","square-button","start","static","status-bar","stretch","stroke","sub","subpixel-antialiased","super","sw-resize","symbolic","symbols","system-ui","table","table-caption","table-cell","table-column","table-column-group","table-footer-group","table-header-group","table-row","table-row-group","tamil","telugu","text","text-bottom","text-top","textarea","textfield","thai","thick","thin","threeddarkshadow","threedface","threedhighlight","threedlightshadow","threedshadow","tibetan","tigre","tigrinya-er","tigrinya-er-abegede","tigrinya-et","tigrinya-et-abegede","to","top","trad-chinese-formal","trad-chinese-informal","transform","translate","translate3d","translateX","translateY","translateZ","transparent","ultra-condensed","ultra-expanded","underline","unset","up","upper-alpha","upper-armenian","upper-greek","upper-hexadecimal","upper-latin","upper-norwegian","upper-roman","uppercase","urdu","url","var","vertical","vertical-text","visible","visibleFill","visiblePainted","visibleStroke","visual","w-resize","wait","wave","wider","window","windowframe","windowtext","words","wrap","wrap-reverse","x-large","x-small","xor","xx-large","xx-small"],C=e(w),k=i.concat(o).concat(a).concat(c).concat(h).concat(f).concat(b).concat(w);t.registerHelper("hintWords","css",k),t.defineMIME("text/css",{documentTypes:r,mediaTypes:s,mediaFeatures:l,mediaValueKeywords:u,propertyKeywords:d,nonStandardPropertyKeywords:p,fontProperties:v,counterDescriptors:y,colorKeywords:x,valueKeywords:C,tokenHooks:{"/":function(t,e){return!!t.eat("*")&&(e.tokenize=n,n(t,e))}},name:"css"}),t.defineMIME("text/x-scss",{mediaTypes:s,mediaFeatures:l,mediaValueKeywords:u,propertyKeywords:d,nonStandardPropertyKeywords:p,colorKeywords:x,valueKeywords:C,fontProperties:v,allowNested:!0,lineComment:"//",tokenHooks:{"/":function(t,e){return t.eat("/")?(t.skipToEnd(),["comment","comment"]):t.eat("*")?(e.tokenize=n,n(t,e)):["operator","operator"]},":":function(t){return!!t.match(/\s*\{/,!1)&&[null,null]},$:function(t){return t.match(/^[\w-]+/),t.match(/^\s*:/,!1)?["variable-2","variable-definition"]:["variable-2","variable"]},"#":function(t){return!!t.eat("{")&&[null,"interpolation"]}},name:"css",helperType:"scss"}),t.defineMIME("text/x-less",{mediaTypes:s,mediaFeatures:l,mediaValueKeywords:u,propertyKeywords:d,nonStandardPropertyKeywords:p,colorKeywords:x,valueKeywords:C,fontProperties:v,allowNested:!0,lineComment:"//",tokenHooks:{"/":function(t,e){return t.eat("/")?(t.skipToEnd(),["comment","comment"]):t.eat("*")?(e.tokenize=n,n(t,e)):["operator","operator"]},"@":function(t){return t.eat("{")?[null,"interpolation"]:!t.match(/^(charset|document|font-face|import|(-(moz|ms|o|webkit)-)?keyframes|media|namespace|page|supports)\b/,!1)&&(t.eatWhile(/[\w\\\-]/),t.match(/^\s*:/,!1)?["variable-2","variable-definition"]:["variable-2","variable"])},"&":function(){return["atom","atom"]}},name:"css",helperType:"less"}),t.defineMIME("text/x-gss",{documentTypes:r,mediaTypes:s,mediaFeatures:l,propertyKeywords:d,nonStandardPropertyKeywords:p,fontProperties:v,counterDescriptors:y,colorKeywords:x,valueKeywords:C,supportsAtComponent:!0,tokenHooks:{"/":function(t,e){return!!t.eat("*")&&(e.tokenize=n,n(t,e))}},name:"css",helperType:"gss"})})},function(t,e,n){"use strict";var i=n(0),r=n(28);t.exports=i.Model.extend({defaults:{id:"",content:"",visible:!0,buttons:[]},initialize:function(t){this.btn=this.get("buttons")||[],this.buttons=new r(this.btn),this.set("buttons",this.buttons)}})},function(t,e,n){"use strict";var i=n(0),r=n(111);t.exports=i.Collection.extend({model:r,deactivateAllExceptOne:function(t,e){this.forEach(function(n,i){n!==t&&(n.set("active",!1),e&&n.get("buttons").length&&n.get("buttons").deactivateAllExceptOne(t,e))})},deactivateAll:function(t){var e=t||"";this.forEach(function(t,n){t.get("context")==e&&(t.set("active",!1),t.get("buttons").length&&t.get("buttons").deactivateAll(e))})},disableAllButtons:function(t){var e=t||"";this.forEach(function(t,n){t.get("context")==e&&(t.set("disable",!0),t.get("buttons").length&&t.get("buttons").disableAllButtons(e))})},disableAllButtonsExceptOne:function(t,e){this.forEach(function(n,i){n!==t&&(n.set("disable",!0),e&&n.get("buttons").length&&n.get("buttons").disableAllButtonsExceptOne(t,e))})}})},function(t,e,n){"use strict";var i=n(0),r=n(30);t.exports=i.View.extend({initialize:function(t){var e=t.config||{};this.config=e,this.pfx=e.stylePrefix||"",this.ppfx=e.pStylePrefix||"",this.buttons=this.model.get("buttons"),this.className=this.pfx+"panel",this.id=this.pfx+this.model.get("id"),this.listenTo(this.model,"change:appendContent",this.appendContent),this.listenTo(this.model,"change:content",this.updateContent)},appendContent:function(){this.$el.append(this.model.get("appendContent"))},updateContent:function(){this.$el.html(this.model.get("content"))},initResize:function(){var t=this.config.em,e=t?t.get("Editor"):"",n=this.model.get("resizable");if(e&&n){var i,r,o,s=!0===n?[1,1,1,1]:n,a=s.length,l=0;2==a?(i=s[0],o=s[0],r=s[1],l=s[1]):4==a&&(i=s[0],r=s[1],o=s[2],l=s[3]);var c=e.Utils.Resizer.init({tc:i,cr:r,bc:o,cl:l,tl:0,tr:0,bl:0,br:0,appendTo:this.el,prefix:e.getConfig().stylePrefix,posFetcher:function(t){var e=t.getBoundingClientRect();return{left:0,top:0,width:e.width,height:e.height}}});c.blur=function(){},c.focus(this.el)}},render:function(){var t=this.$el,e=this.ppfx;if(t.attr("class",this.className+" "+e+"one-bg"),this.id&&t.attr("id",this.id),this.buttons.length){var n=new r({collection:this.buttons,config:this.config});t.append(n.render().el)}return t.append(this.model.get("content")),this}})},function(t,e,n){"use strict";(function(e){var i=n(0),r=n(113);t.exports=i.View.extend({initialize:function(t){this.opt=t||{},this.config=this.opt.config||{},this.pfx=this.config.stylePrefix||"",this.parentM=this.opt.parentM||null,this.listenTo(this.collection,"add",this.addTo),this.listenTo(this.collection,"reset",this.render),this.className=this.pfx+"buttons"},addTo:function(t){this.addToCollection(t)},addToCollection:function(t,e){var n=e||null,i=r,o=new i({model:t,config:this.config,parentM:this.parentM}),s=o.render().el;return n?n.appendChild(s):this.$el.append(s),s},render:function(){var t=document.createDocumentFragment();return this.$el.empty(),this.collection.each(function(e){this.addToCollection(e,t)},this),this.$el.append(t),this.$el.attr("class",e.result(this,"className")),this}})}).call(e,n(1))},function(t,e,n){"use strict";var i=Object.assign||function(t){for(var e=1;e1&&void 0!==arguments[1]?arguments[1]:{},n=e.model,o=void 0===n?{}:n,s=e.view,a=void 0===s?{}:s,l=this.getType(t);if(l)return new l.view(i({model:new l.model(o),config:r},a))},render:function(){return e.render().el}}}},function(t,e,n){"use strict";(function(t){Object.defineProperty(e,"__esModule",{value:!0});var n=t.Model,i=t.View;e.default={types:[],initialize:function(t,e){var n=this;this.model=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},i=void 0,r=void 0,o=void 0;if(t&&t.type){var s=n.getBaseType();o=n.getType(t.type),i=o?o.model:s.model,r=o?o.view:s.view}else{var a=n.recognizeType(t);o=a.type,i=o.model,r=o.view,t=a.attributes}var l=new i(t,e);return l.typeView=r,l};var i=this.init&&this.init.bind(this);i&&i()},recognizeType:function(t){for(var e=this.getTypes(),n=0;n\n \n
\n \n '},init:function(){var t=this.model;this.pfx;t.set("stackIndex",null),this.events["click [data-add-layer]"]="addLayer",this.listenTo(t,"change:stackIndex",this.indexChanged),this.listenTo(t,"updateValue",this.inputValueChanged),this.delegateEvents()},targetUpdated:function(){if(this.model.get("detached"))this.checkVisibility();else{for(var t=arguments.length,e=Array(t),n=0;n'},inputClass:function(){return this.ppfx+"field"},holderClass:function(){return this.ppfx+"input-holder"},initialize:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=t.ppfx||"";this.opts=t,this.ppfx=e,this.em=t.target||{},this.listenTo(this.model,"change:value",this.handleModelChange)},elementUpdated:function(){this.model.trigger("el:change")},setValue:function(t){var e=this.model,n=t||e.get("defaults"),i=this.getInputEl();i&&(i.value=n)},handleModelChange:function(t,e,n){this.setValue(e,n)},handleChange:function(t){t.stopPropagation(),this.model.set("value",this.getInputEl().value),this.elementUpdated()},getInputEl:function(){if(!this.inputEl){var t=this.model.get("defaults");this.inputEl=n('')}return this.inputEl.get(0)},render:function(){var t=this.$el;return t.addClass(this.inputClass()),t.html(this.template()),t.find("."+this.holderClass()).append(this.getInputEl()),this}})}).call(e,n(0))},function(t,e,n){"use strict";t.exports=n(5).extend({templateInput:function(){var t=(this.pfx,this.ppfx);return'\n
\n
\n '},onRender:function(){var t=this.pfx,e=this.ppfx,n=e+"radio-item-label",i=this.model,r=i.get("property"),o=i.get("list")||i.get("options")||[];if(!this.input&&o&&o.length){var s="";o.forEach(function(i){var o=i.className?i.className+" "+t+"icon "+n:"",a=r+"-"+i.value,l=i.name||i.value,c=i.title?'title="'+i.title+'"':"";s+='\n
\n \n \n
\n "});var a=this.el.querySelector("."+e+"field");a.innerHTML='
'+s+"
",this.input=a.firstChild}},getInputValue:function(){var t=this.getCheckedEl();return t?t.value:""},getCheckedEl:function(){var t=this.getInputEl();return t?t.querySelector("input:checked"):""},setValue:function(t){var e=this.model,n=t||e.get("value")||e.getDefaultValue(),i=this.getInputEl(),r=i?i.querySelector('[value="'+n+'"]'):"";if(r)r.checked=!0;else{var o=this.getCheckedEl();o&&(o.checked=!1)}}})},function(t,e,n){"use strict";(function(e){e.$;t.exports=n(5).extend({templateInput:function(){var t=this.pfx,e=this.ppfx;return'\n
\n \n
\n
\n
\n
\n '},onRender:function(){var t=this.pfx,e=this.model,n=e.get("list")||e.get("options")||[];if(!this.input){var i="";n.forEach(function(t){var e=t.name||t.value,n=t.style?t.style.replace(/"/g,"""):"",r=n?'style="'+n+'"':"",o=t.value.replace(/"/g,""");i+='"});var r=this.el.querySelector("#"+t+"input-holder");r.innerHTML="",this.input=r.firstChild}}})}).call(e,n(0))},function(t,e,n){"use strict";var i=Object.assign||function(t){for(var e=1;e1&&void 0!==arguments[1]?arguments[1]:{};e=i({},e,{silent:1}),this.inputInst.setValue(t,e)},onRender:function(){if(!this.input){var t=this.ppfx,e=new r({target:this.target,model:this.model,ppfx:t}),n=e.render();this.el.querySelector("."+t+"fields").appendChild(n.el),this.$input=n.inputEl,this.$color=n.colorEl,this.input=this.$input.get(0),this.inputInst=n}}})},function(t,e,n){"use strict";(function(e){var i=Object.assign||function(t){for(var e=1;e\n
\n
\n
\n
\n
\n '},inputClass:function(){var t=this.ppfx;return t+"field "+t+"field-color"},holderClass:function(){return this.ppfx+"input-holder"},setValue:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=this.model,i=t||n.get("defaults"),r=this.getInputEl(),o=this.getColorEl(),s="none"!=i?i:"";r.value=i,o.get(0).style.backgroundColor=s,e.fromTarget&&(o.spectrum("set",s),this.noneColor="none"==i)},getColorEl:function(){if(!this.colorEl){var t=this,e=this.ppfx,n=this.model,r=o('
'),s=r.get(0).style,a=this.em&&this.em.config?this.em.config.el:"",l=this.em&&this.em.getConfig&&this.em.getConfig("colorPicker")||{},c=function(t){return(1==t.getAlpha()?t.toHexString():t.toRgbString()).replace(/ /g,"")},u=0,h=void 0;this.$el.find("[data-colorp-c]").append(r),r.spectrum(i({containerClassName:e+"one-bg "+e+"two-color",appendTo:a||"body",maxSelectionSize:8,showPalette:!0,showAlpha:!0,chooseText:"Ok",cancelText:"⨯",palette:[]},l,{move:function(t){var e=c(t);s.backgroundColor=e,n.setValueFromInput(e,0)},change:function(e){u=1;var i=c(e);s.backgroundColor=i,n.setValueFromInput(i),t.noneColor=0},show:function(t){u=0,h=c(t)},hide:function(e){!u&&h&&(t.noneColor&&(h=""),s.backgroundColor=h,r.spectrum("set",h),n.setValueFromInput(h,0))}})),this.colorEl=r}return this.colorEl},render:function(){return r.prototype.render.call(this),this.getColorEl(),this}})}).call(e,n(0))},function(t,e,n){"use strict";(function(e){var i=n(5),r=e.$;t.exports=i.extend({templateInput:function(){var t=this.pfx;this.ppfx;return'\n
\n
\n
\n \n
\n
\n
\n
\n
\n
\n
\n
\n '},init:function(){var t=this.em;this.modal=t.get("Modal"),this.am=t.get("AssetManager"),this.events["click #"+this.pfx+"close"]="removeFile",this.events["click #"+this.pfx+"images"]="openAssetManager",this.delegateEvents()},onRender:function(){if(!this.$input){var t=this.model.getDefaultValue();this.$input=r('')}this.$preview||(this.$preview=this.$el.find("#"+this.pfx+"preview-file")),this.$previewBox||(this.$previewBox=this.$el.find("#"+this.pfx+"preview-box")),this.setValue(this.componentValue,0)},setValue:function(t,e){i.prototype.setValue.apply(this,arguments),this.setPreviewView(t&&t!=this.model.getDefaultValue()),this.setPreview(t)},setPreviewView:function(t){var e=this.$previewBox;e&&e[t?"addClass":"removeClass"](this.pfx+"show")},spreadUrl:function(t){this.model.set("value",t),this.setPreviewView(1)},setPreview:function(t){var e=this.$preview;t=t&&t.indexOf("url(")<0?"url("+t+")":t,e&&e.css("background-image",t)},cleanValue:function(){this.setPreviewView(0),this.model.set({value:""},{silent:!0})},removeFile:function(){this.model.set("value",this.model.getDefaultValue());for(var t=arguments.length,e=Array(t),n=0;n\n
\n '},getInfo:function(){var t=this.pfx,e=this.model,n=e.get("name"),i=e.get("width"),r=e.get("height"),o=e.get("unitDim"),s=i&&r?i+"x"+r+o:"";return n=n||e.getFilename(),'\n
'+n+'
\n
'+s+"
\n "},init:function(t){var e=this.pfx;this.className+=" "+e+"asset-image"},onClick:function(){var t=this.config.onClick,e=this.model;this.collection.trigger("deselectAll"),this.$el.addClass(this.pfx+"highlight"),"function"==typeof t?t(e):this.updateTarget(this.collection.target)},onDblClick:function(){var t=this.em,e=this.config.onDblClick,n=this.model;"function"==typeof e?e(n):(this.updateTarget(this.collection.target),t&&t.get("Modal").close());var i=this.collection.onSelect;"function"==typeof i&&i(this.model)},onRemove:function(t){t.stopImmediatePropagation(),this.model.collection.remove(this.model)}})},function(t,e,n){"use strict";(function(e,n){t.exports=e.View.extend({initialize:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};this.options=t,this.collection=t.collection;var e=t.config||{};this.config=e,this.pfx=e.stylePrefix||"",this.ppfx=e.pStylePrefix||"",this.em=e.em,this.className=this.pfx+"asset",this.listenTo(this.model,"destroy remove",this.remove),this.model.view=this;var n=this.init&&this.init.bind(this);n&&n(t)},template:function(){var t=this.pfx;return'\n
\n '+this.getPreview()+'\n
\n
\n '+this.getInfo()+'\n
\n
\n ⨯\n
\n '},updateTarget:function(t){t&&t.set&&(t.set("attributes",n.clone(t.get("attributes"))),t.set("src",this.model.get("src")))},getPreview:function(){return""},getInfo:function(){return""},render:function(){var t=this.el;return t.innerHTML=this.template(this,this.model),t.className=this.className,this}})}).call(e,n(0),n(1))},function(t,e,n){"use strict";(function(e,i){var r=n(24),o=function(t){return t&&t.__esModule?t:{default:t}}(r);t.exports=e.View.extend({template:i.template('\n
\n
<%= title %>
\n multiple/>\n
\n
\n '),events:{},initialize:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};this.options=t;var e=t.config||{};this.config=e,this.pfx=e.stylePrefix||"",this.ppfx=e.pStylePrefix||"",this.target=this.options.globalCollection||{},this.uploadId=this.pfx+"uploadFile",this.disabled=void 0!==e.disableUpload?e.disableUpload:!e.upload&&!e.embedAsBase64,this.events["change #"+this.uploadId]="uploadFile";var n=e.uploadFile;n?this.uploadFile=n.bind(this):e.embedAsBase64&&(this.uploadFile=this.constructor.embedAsBase64),this.delegateEvents()},onUploadStart:function(){var t=this.config.em;t&&t.trigger("asset:upload:start")},onUploadEnd:function(t){var e=this.config.em;e&&e.trigger("asset:upload:end",t)},onUploadError:function(t){var e=this.config.em;console.error(t),this.onUploadEnd(t),e&&e.trigger("asset:upload:error",t)},onUploadResponse:function(t){var e=this.config.em,n=this.config,i=this.target,r="string"==typeof t?JSON.parse(t):t;e&&e.trigger("asset:upload:response",r),n.autoAdd&&i&&i.add(r.data,{at:0}),this.onUploadEnd(t)},uploadFile:function(t){for(var e=this,n=t.dataTransfer?t.dataTransfer.files:t.target.files,i=new FormData,r=this.config,s=r.params,a=0;a'+i.dropzoneContent+""),h(),"draggable"in o&&[o,a].forEach(function(t){t.ondragover=d,t.ondragleave=f,t.ondrop=p})},render:function(){return this.$el.html(this.template({title:this.config.uploadText,uploadId:this.uploadId,disabled:this.disabled,pfx:this.pfx})),this.initDrop(),this.$el.attr("class",this.pfx+"file-uploader"),this}},{embedAsBase64:function(t){var e=this,n=t.dataTransfer?t.dataTransfer.files:t.target.files,i={data:[]};if(!FileReader)return void this.onUploadError(new Error("Unsupported platform, FileReader is not defined"));var r=[],o=/^(.+)\/(.+)$/,s=!0,a=!1,l=void 0;try{for(var c,u=n[Symbol.iterator]();!(s=(c=u.next()).done);s=!0){var h=c.value;!function(t){var e=new Promise(function(e,n){var i=new FileReader;i.addEventListener("load",function(r){var s=void 0,a=t.name,l=o.exec(t.type);if("image"===(s=l?l[1]:t.type)){var c={src:i.result,name:a,type:s,height:0,width:0},u=new Image;u.addEventListener("error",function(t){n(t)}),u.addEventListener("load",function(){c.height=u.height,c.width=u.width,e(c)}),u.src=c.src}else e(s?{src:i.result,name:a,type:s}:i.result)}),i.addEventListener("error",function(t){n(t)}),i.addEventListener("abort",function(t){n("Aborted")}),i.readAsDataURL(t)});r.push(e)}(h)}}catch(t){a=!0,l=t}finally{try{!s&&u.return&&u.return()}finally{if(a)throw l}}Promise.all(r).then(function(t){i.data=t,e.onUploadResponse(i)},function(t){e.onUploadError(t)})}})}).call(e,n(0),n(1))},function(t,e,n){"use strict";(function(e){var i=n(47),r=function(t){return t&&t.__esModule?t:{default:t}}(i),o=n(0),s=n(10);t.exports=o.Model.extend(r.default).extend({defaults:{selectors:{},selectorsAdd:"",style:{},mediaText:"",state:"",stylable:!0,important:0},initialize:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};this.config=t||{};var n=e.em,i=this.config.selectors||[];if(this.em=n,n){var r=n.get("SelectorManager"),o=[];i.forEach(function(t){o.push(r.add(t))}),i=o}this.set("selectors",new s(i))},selectorsToString:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=[],n=this.get("state"),i=this.get("selectorsAdd"),r=this.get("selectors").getFullString(),o=n?":"+n:"";return r&&e.push(""+r+o),i&&!t.skipAdd&&e.push(i),e.join(", ")},toCSS:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e="",n=this.get("mediaText"),i=this.styleToString(t),r=this.selectorsToString();return r&&i&&(e=r+"{"+i+"}"),n&&e&&(e="@media "+n+"{"+e+"}"),e},compare:function(t,n,i,r){var o=r||{},s=n||"",a=i||"",l=o.selectorsAdd||"";t instanceof Array||t.models||(t=[t]);var c=e.map(t.models||t,function(t){return t.get("name")}),u=e.map(this.get("selectors").models,function(t){return t.get("name")});if(c.length!==u.length)return!1;for(var h=0;h0&&void 0!==arguments[0]?arguments[0]:{},n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};(0,r.isString)(e)&&(e=l(e));var s=this.getStyle(),a=i({},e);this.set("style",a,n);var c=(0,o.shallowDiff)(s,a);return(0,r.keys)(c).forEach(function(e){return t.trigger("change:style:"+e)}),a},addStyle:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"",n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};"string"==typeof t?t={prop:e}:n=e||{},t=this.extendStyle(t),this.setStyle(t,n)},removeStyle:function(t){var e=this.getStyle();delete e[t],this.setStyle(e)},styleToString:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=[],n=this.getStyle();for(var i in n){var o=t.important,s=(0,r.isArray)(o)?o.indexOf(i)>=0:o,a=n[i]+(s?" !important":"");e.push(i+":"+a+";")}return e.join("")}}},function(t,e,n){"use strict";var i=n(0);t.exports=i.View.extend({itemView:"",itemsView:"",itemType:"type",initialize:function(t,e){this.config=e||{}},addTo:function(t){this.add(t)},add:function(t,e){var n=e||null,i=this.itemView,r=t.get(this.itemType);this.itemsView&&this.itemsView[r]&&(i=this.itemsView[r]);var o=new i({model:t,config:this.config},this.config),s=o.render().el;n?n.appendChild(s):this.$el.append(s)},render:function(){var t=document.createDocumentFragment();return this.$el.empty(),this.collection.length&&this.collection.each(function(e){this.add(e,t)},this),this.$el.append(t),this}})},function(t,e,n){"use strict";var i=n(1),r=n(0);t.exports=r.Collection.extend({initialize:function(t,e){this.on("add",this.onAdd),this.config=e&&e.config?e.config:null,e&&(e.sm||e.em)&&(this.editor=e.sm||e.em),this.model=function(t,n){var i;!n.sm&&e&&e.sm&&(n.sm=e.sm),!n.em&&e&&e.em&&(n.em=e.em),e&&e.config&&(n.config=e.config),e&&e.componentTypes&&(n.componentTypes=e.componentTypes);for(var r=e.componentTypes,o=0;o1&&void 0!==arguments[1]?arguments[1]:{};if("string"==typeof t){var n=this.editor.get("Parser").parseHtml(t);t=n.html;var i=this.editor.get("CssComposer");if(n.css&&i){var o=e.avoidUpdateStyle;i.addCollection(n.css,{extend:1,avoidUpdateStyle:o})}}return r.Collection.prototype.add.apply(this,[t,e])},onAdd:function(t,e,n){var r=this.editor,o=t.get("style"),s=r&&r.getConfig("avoidInlineStyle");if(!(0,i.isEmpty)(o)&&!s&&r&&r.get&&r.get("Config").forceClass){var a=this.editor.get("CssComposer"),l=this.editor.get("SelectorManager").add(t.cid);t.set({style:{}}),t.get("classes").add(l);a.add(l).set("style",o)}}})},function(t,e,n){"use strict";(function(e){var i=n(1);t.exports=e.View.extend({initialize:function(t){this.opts=t||{},this.config=t.config||{};var e=this.collection;this.listenTo(e,"add",this.addTo),this.listenTo(e,"reset",this.resetChildren)},addTo:function(t){var e=this.config.em,n=this.collection.indexOf(t);this.addToCollection(t,null,n),e&&!t.opt.temporary&&(e.trigger("add:component",t),e.trigger("component:add",t))},addToCollection:function(t,e,r){this.compView||(this.compView=n(3));for(var o=e||null,s=this.compView,a=this.opts.componentTypes,l=t.get("type"),c=0;c':"")+'\n\n
\n
\n
\n \n '+t.getIcon()+'\n \n
\n
\n
\n
'+(r||"")+'
\n
\n \n
\n
\n '},initialize:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};this.opt=t,this.level=t.level,this.config=t.config,this.em=t.config.em,this.ppfx=this.em.get("Config").stylePrefix,this.sorter=t.sorter||"",this.pfx=this.config.stylePrefix;var e=this.pfx,n=this.ppfx,i=this.model,r=i.get("components");i.set("open",!1),this.listenTo(r,"remove add change reset",this.checkChildren),this.listenTo(i,"destroy remove",this.remove),this.listenTo(i,"change:status",this.updateStatus),this.listenTo(i,"change:open",this.updateOpening),this.listenTo(i,"change:style:display",this.updateVisibility),this.className=e+"item no-select",this.editBtnCls=e+"nav-item-edit",this.inputNameCls=n+"nav-comp-name",this.caretCls=n+"nav-item-caret",this.titleCls=e+"title",this.$el.data("model",i),this.$el.data("collection",r)},getVisibilityEl:function(){return this.eyeEl||(this.eyeEl=this.$el.children("#"+this.pfx+"btn-eye")),this.eyeEl},updateVisibility:function(){var t=this.pfx,e=this.model,n=t+"hide",i="none"==e.getStyle().display,r=i?"addClass":"removeClass";this.$el[r](n),this.getVisibilityEl()[r]("fa-eye-slash")},toggleVisibility:function(t){t&&t.stopPropagation();var e=this.model,n=e.getStyle();"none"==n.display?delete n.display:n.display="none",e.setStyle(n)},handleEdit:function(t){t.stopPropagation();var e=this.getInputName();e.readOnly=!1,e.focus()},handleEditEnd:function(t){t.stopPropagation();var e=this.getInputName();e.readOnly=!0,this.model.set("custom-name",e.value)},getInputName:function(){return this.inputName||(this.inputName=this.el.querySelector("."+this.inputNameCls)),this.inputName},updateOpening:function(){var t=this.opt.opened||{},e=this.model;e.get("open")?(this.$el.addClass("open"),this.getCaret().addClass("fa-chevron-down"),t[e.cid]=e):(this.$el.removeClass("open"),this.getCaret().removeClass("fa-chevron-down"),delete t[e.cid])},toggleOpening:function(t){t.stopPropagation(),this.model.get("components").length&&this.model.set("open",!this.model.get("open"))},handleSelect:function(t){t.stopPropagation(),this.em&&this.em.setSelected(this.model,{fromLayers:1})},startSort:function(t){t.stopPropagation(),0===t.button&&this.sorter&&this.sorter.startSort(t.target)},freeze:function(){this.$el.addClass(this.pfx+"opac50"),this.model.set("open",0)},unfreeze:function(){this.$el.removeClass(this.pfx+"opac50")},updateStatus:function(t){r.prototype.updateStatus.apply(this,arguments)},isVisible:function(){var t=this.model.get("style"),e=t.display;if(!e||"none"!=e)return 1},checkChildren:function(){var t=this.model,e=this.countChildren(t),n=this.pfx,i=n+"no-chld",r=this.$el.children("."+n+"title-c").children("."+n+"title");this.$counter||(this.$counter=this.$el.children("#"+n+"counter")),e?(r.removeClass(i),this.$counter.html(e)):(r.addClass(i),this.$counter.empty(),t.set("open",0))},countChildren:function(t){var e=0;return t.get("components").each(function(t){var n=this.opt.isCountable,i=this.config.hideTextnode;n&&!n(t,i)||e++},this),e},getCaret:function(){if(!this.caret){var t=this.pfx;this.caret=this.$el.children("."+t+"title-c").find("#"+t+"caret")}return this.caret},render:function(){var t=this.model,e=this.pfx,r=this.isVisible(),s=this.$el,a=this.level+1;s.html(this.template(t)),(0,i.isUndefined)(o)&&(o=n(56));var l=new o({collection:t.get("components"),config:this.config,sorter:this.sorter,opened:this.opt.opened,parent:t,level:a}).render().$el;return s.find("."+e+"children").append(l),t.get("draggable")&&this.config.sortable||s.children("#"+e+"move").remove(),!r&&(this.className+=" "+e+"hide"),s.attr("class",this.className),this.updateOpening(),this.updateStatus(),this.updateVisibility(),this}})},function(t,e,n){"use strict";var i=n(0),r=n(55);t.exports=i.View.extend({initialize:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};this.opt=t;var e=t.config||{};if(this.level=t.level,this.config=e,this.preview=t.preview,this.ppfx=e.pStylePrefix||"",this.pfx=e.stylePrefix||"",this.parent=t.parent,this.listenTo(this.collection,"add",this.addTo),this.listenTo(this.collection,"reset resetNavigator",this.render),this.className=this.pfx+"items",e.sortable&&!this.opt.sorter){var n=this.pfx,i=e.em.get("Utils");this.opt.sorter=new i.Sorter({container:e.sortContainer||this.el,containerSel:"."+n+"items",itemSel:"."+n+"item",ppfx:this.ppfx,ignoreViewChildren:1,avoidSelectOnEnd:1,pfx:n,nested:1})}this.sorter=this.opt.sorter||"",this.$el.data("collection",this.collection),this.parent&&this.$el.data("model",this.parent)},addTo:function(t){var e=this.collection.indexOf(t);this.addToCollection(t,null,e)},addToCollection:function(t,e,n){var i=this.level,o=e||null,s=r;if(this.isCountable(t,this.config.hideTextnode)){var a=new s({level:i,model:t,config:this.config,sorter:this.sorter,isCountable:this.isCountable,opened:this.opt.opened}),l=a.render().el;if(o)o.appendChild(l);else if(void 0!==n){var c="before";this.$el.children().length==n&&(n--,c="after"),n<0?this.$el.append(l):this.$el.children().eq(n)[c](l)}else this.$el.append(l);return l}},isCountable:function(t,e){var n=t.get("type"),i=t.get("tagName");return!(("textnode"==n||"br"==i)&&e||!t.get("layerable"))},render:function(){var t=this,e=document.createDocumentFragment();return this.el.innerHTML="",this.collection.each(function(n){return t.addToCollection(n,e)}),this.el.appendChild(e),this.$el.attr("class",this.className),this}})},function(t,e,n){"use strict";var i=n(0);t.exports=i.Model.extend({defaults:{id:"",label:"",open:!0,attributes:{}}})},function(t,e,n){"use strict";t.exports=n(59)},function(t,e,n){"use strict";function i(t){return t&&t.__esModule?t:{default:t}}var r=n(9),o=i(r),s=n(1);(0,i(n(60)).default)(),t.exports=function(){var t=n(61),e=n(62),i=n(220),r=new i,a=[];return{$:o.default,editors:a,plugins:r,version:"0.12.60",init:function(){var n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},i=n.container;if(!i)throw new Error("'container' is required");(0,s.defaults)(n,t),n.el=i instanceof window.HTMLElement?i:document.querySelector(i);var o=new e(n).init();return n.plugins.forEach(function(t){var e=r.get(t);e?e(o,n.pluginsOpts[t]||{}):console.warn("Plugin "+t+" not found")}),o.getModel().loadOnStart(),n.autorender&&o.render(),a.push(o),o}}}()},function(t,e,n){"use strict";Object.defineProperty(e,"__esModule",{value:!0}),e.default=function(){if(function(){for(var t=void 0,e=window.navigator.userAgent,n=[["edge",/Edge\/([0-9\._]+)/],["ie",/MSIE\s(7\.0)/],["ie",/MSIE\s([0-9\.]+);.*Trident\/[4-7].0/],["ie",/Trident\/7\.0.*rv\:([0-9\.]+).*\).*Gecko$/]],i=0;i0&&void 0!==arguments[0]?arguments[0]:{};this.config=e,this.set("Config",e),this.set("modules",[]),e.el&&e.fromElement&&(this.config.components=e.el.innerHTML),o.forEach(function(e){return t.loadModule(e)}),this.on("change:selectedComponent",this.componentSelected,this),this.on("change:changesCount",this.updateChanges,this)},getConfig:function(t){var e=this.config;return(0,r.isUndefined)(t)?e:e[t]},loadOnStart:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null,n=this.get("StorageManager");this.get("toLoad").forEach(function(t){t.onLoad()});var i=function(){t.get("modules").forEach(function(e){return e.postLoad&&e.postLoad(t)}),e&&e()};n&&n.getConfig().autoload?this.load(i):i()},updateChanges:function(){var t=this.get("StorageManager"),e=this.get("changesCount");this.config.noticeOnUnload&&e?window.onbeforeunload=function(t){return 1}:window.onbeforeunload=null,t.isAutosave()&&e>=t.getStepsBeforeSave()&&this.store()},loadModule:function(t){var e=this.config,n=new t,r=n.name.charAt(0).toLowerCase()+n.name.slice(1),o=e[r]||e[n.name]||{};o.pStylePrefix=e.pStylePrefix||"";var s=this.get("StorageManager");if(n.storageKey&&n.store&&n.load&&s){o.stm=s;var a=this.get("storables");a.push(n),this.set("storables",a)}return o.em=this,n.init(i({},o)),!n.private&&this.set(n.name,n),n.onLoad&&this.get("toLoad").push(n),this.get("modules").push(n),this},init:function(t){this.set("Editor",t)},getEditor:function(){return this.get("Editor")},handleUpdates:function(t,e){var n=this,i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};i.temporary||(a&&clearInterval(a),a=setTimeout(function(){i.avoidStore||n.set("changesCount",n.get("changesCount")+1,i)},0))},componentSelected:function(t,e,n){this.get("selectedComponent")?(this.trigger("select-comp",[t,e,n]),this.trigger("component:selected",arguments)):this.trigger("deselect-comp")},getSelected:function(){return this.get("selectedComponent")},setSelected:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=t;t instanceof window.HTMLElement&&(n=l(t).data("model")),n&&!n.get("selectable")||this.set("selectedComponent",n,e)},setComponents:function(t){return this.get("DomComponents").setComponents(t)},getComponents:function(){var t=this.get("DomComponents"),e=this.get("CodeManager");if(t&&e){var n=t.getComponents();return e.getCode(n,"json")}},setStyle:function(t){for(var e=this.get("CssComposer").getAll(),n=0,i=e.length;n"+i+"<\/script>":""},getCss:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=this.config,n=e.wrappesIsBody,i=t.avoidProtected,r=this.get("CssComposer"),o=this.get("DomComponents").getComponent();return(i?"":e.protectedCss)+this.get("CodeManager").getCode(o,"css",{cssc:r,wrappesIsBody:n})},getJs:function(){var t=this.get("DomComponents").getWrapper();return this.get("CodeManager").getCode(t,"js").trim()},store:function(t){var e=this,n=this.get("StorageManager"),i={};if(n)return this.get("storables").forEach(function(t){var e=t.store(1);for(var n in e)i[n]=e[n]}),n.store(i,function(){t&&t(),e.set("changesCount",0),e.trigger("storage:store",i)}),i},load:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null;this.getCacheLoad(1,function(n){t.get("storables").forEach(function(t){return t.load(n)}),e&&e(n)})},getCacheLoad:function(t,e){var n=this,i=t?1:0;if(this.cacheLoad&&!i)return this.cacheLoad;var r=this.get("StorageManager"),o=[];if(!r)return{};this.get("storables").forEach(function(t){var e=t.storageKey;e="function"==typeof e?e():e,(e instanceof Array?e:[e]).forEach(function(t){o.push(t)})}),r.load(o,function(t){n.cacheLoad=t,e&&e(t),n.trigger("storage:load",t)})},getDeviceModel:function(){var t=this.get("device");return this.get("DeviceManager").get(t)},runDefault:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=this.get("Commands").get(this.config.defaultCommand);e&&!this.defaultRunning&&(e.stop(this,this,t),e.run(this,this,t),this.defaultRunning=1)},stopDefault:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=this.get("Commands").get(this.config.defaultCommand);e&&(e.stop(this,this,t),this.defaultRunning=0)},refreshCanvas:function(){this.set("canvasOffset",this.get("Canvas").getOffset())},clearSelection:function(t){(t||window).getSelection().removeAllRanges()},getCurrentMedia:function(){var t=this.config,e=this.getDeviceModel(),n=t.mediaCondition,i=t.devicePreviewMode,r=e&&e.get("widthMedia");return e&&r&&!i?"("+n+": "+r+")":""},data:function(t,e,n){if(t["_gjs-data"]||(t["_gjs-data"]={}),(0,r.isUndefined)(n))return t["_gjs-data"][e];t["_gjs-data"][e]=n}})},function(t,e,n){"use strict";t.exports=function(){var t=n(66),e=n(67),i=n(68);return{name:"Utils",init:function(){return this},Sorter:t,Resizer:e,Dragger:i}}},function(t,e,n){"use strict";(function(e,i){var r=n(1),o=n(2),s=e.$;t.exports=e.View.extend({initialize:function(t){this.opt=t||{},i.bindAll(this,"startSort","onMove","endMove","rollback","udpateOffset","moveDragHelper");var e=t||{};this.elT=0,this.elL=0,this.borderOffset=e.borderOffset||10;var n=e.container;this.el="string"==typeof n?document.querySelector(n):n,this.$el=s(this.el),this.containerSel=e.containerSel||"div",this.itemSel=e.itemSel||"div",this.draggable=e.draggable||!0,this.nested=e.nested||0,this.pfx=e.pfx||"",this.ppfx=e.ppfx||"",this.freezeClass=e.freezeClass||this.pfx+"freezed",this.onStart=e.onStart||"",this.onEndMove=e.onEndMove||"",this.direction=e.direction||"v",this.onMoveClb=e.onMove||"",this.relative=e.relative||0,this.ignoreViewChildren=e.ignoreViewChildren||0,this.ignoreModels=e.ignoreModels||0,this.plh=e.placer||"",this.wmargin=e.wmargin||0,this.offTop=e.offsetTop||0,this.offLeft=e.offsetLeft||0,this.document=e.document||document,this.$document=s(this.document),this.dropContent=null,this.em=e.em||"",this.dragHelper=null,this.canvasRelative=e.canvasRelative||0,this.selectOnEnd=!e.avoidSelectOnEnd,this.em&&this.em.on&&(this.em.on("change:canvasOffset",this.udpateOffset),this.udpateOffset())},getContainerEl:function(){if(!this.el){var t=this.opt.container;this.el="string"==typeof t?document.querySelector(t):t,this.$el=s(this.el)}return this.el},getDocuments:function(){var t=this.em,e=t&&t.get("Canvas").getBody().ownerDocument,n=[document];return e&&n.push(e),n},udpateOffset:function(){var t=this.em.get("canvasOffset");this.offTop=t.top,this.offLeft=t.left},setDropContent:function(t){this.dropContent=t},toggleSortCursor:function(t){var e=this.em;document.body,this.ppfx||this.pfx,e&&e.get("Canvas").getBody();t?e&&e.get("Canvas").startAutoscroll():e&&e.get("Canvas").stopAutoscroll()},setDragHelper:function(t,e){for(var n=e||"",i=t.cloneNode(1),r=t.getBoundingClientRect(),o=getComputedStyle(t),a="",l=0;ls+c-10||ra+l-10)return 1},getCurrentPos:function(){var t=this.eventMove;return{x:t.pageX||0,y:t.pageY||0}},getDim:function(t){var e,n,i,r;if(this.canvasRelative&&this.em){var o=this.em.get("Canvas").getElementPos(t),s=window.getComputedStyle(t),a=parseFloat(s.marginTop),l=parseFloat(s.marginBottom),c=parseFloat(s.marginRight),u=parseFloat(s.marginLeft);e=o.top-a,n=o.left-u,i=o.height+a+l,r=o.width+u+c}else{var h=this.offset(t);e=this.relative?t.offsetTop:h.top-(this.wmargin?-1:1)*this.elT,n=this.relative?t.offsetLeft:h.left-(this.wmargin?-1:1)*this.elL,i=t.offsetHeight,r=t.offsetWidth}return[e,n,i,r]},getChildrenDim:function(t){var e=[];if(!t)return e;var n=this.getTargetModel(t);n&&n.view&&!this.ignoreViewChildren&&(t=n.view.getChildrenContainer());for(var i=t.children,r=0,o=i.length;rs||s>a+c-r||l+r>o||o>l+u-r)&&(i=1),!!i},findPosition:function(t,e,n){for(var i={index:0,method:"before"},r=0,o=0,s=0,a=0,l=0,c=0,u=0,h=0,d=0,f=t.length;do||a&&c>=a||r&&s0&&void 0!==arguments[0]?arguments[0]:{};return i(this,t),this.setOptions(e),(0,o.bindAll)(this,"handleKeyDown","handleMouseDown","move","stop"),this}return r(t,[{key:"getConfig",value:function(){return this.opts}},{key:"setOptions",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};this.opts=(0,o.defaults)(t,a),this.setup()}},{key:"setup",value:function(){var t=this.opts,e=t.prefix||"",n=t.appendTo||document.body,i=this.container;for(i||(i=document.createElement("div"),i.className=e+"resizer-c",n.appendChild(i),this.container=i);i.firstChild;)i.removeChild(i.firstChild);var r={};["tl","tc","tr","cl","cr","bl","bc","br"].forEach(function(e){return r[e]=t[e]?l(e,t):""});for(var o in r){var s=r[o];s&&i.appendChild(s)}this.handlers=r,this.mousePosFetcher=t.mousePosFetcher,this.updateTarget=t.updateTarget,this.posFetcher=t.posFetcher,this.onStart=t.onStart,this.onMove=t.onMove,this.onEnd=t.onEnd}},{key:"isHandler",value:function(t){var e=this.handlers;for(var n in e)if(e[n]===t)return!0;return!1}},{key:"getFocusedEl",value:function(){return this.el}},{key:"getDocumentEl",value:function(){return[this.el.ownerDocument,document]}},{key:"getElementPos",value:function(t){var e=this.posFetcher||"";return e?e(t):c(t)}},{key:"focus",value:function(t){if(!t||t!==this.el){this.el=t;var e=this.getElementPos(t),n=this.container,i=n.style;i.left=e.left+"px",i.top=e.top+"px",i.width=e.width+"px",i.height=e.height+"px",n.style.display="block",(0,s.on)(this.getDocumentEl(),"mousedown",this.handleMouseDown)}}},{key:"blur",value:function(){this.container.style.display="none",this.el&&((0,s.off)(this.getDocumentEl(),"mousedown",this.handleMouseDown),this.el=null)}},{key:"start",value:function(t){if(0===t.button){t.preventDefault(),t.stopPropagation();var e=this.el,n=this,i=this.opts||{},r="data-"+i.prefix+"handler",a=this.getElementPos(e);this.handlerAttr=t.target.getAttribute(r),this.clickedHandler=t.target,this.startDim={t:a.top,l:a.left,w:a.width,h:a.height},this.rectDim={t:a.top,l:a.left,w:a.width,h:a.height},this.startPos={x:t.clientX,y:t.clientY};var l=this.getDocumentEl();(0,s.on)(l,"mousemove",this.move),(0,s.on)(l,"keydown",this.handleKeyDown),(0,s.on)(l,"mouseup",this.stop),(0,o.isFunction)(this.onStart)&&this.onStart(t,{docs:l,config:i,el:e,resizer:n}),this.move(t)}}},{key:"move",value:function(t){var e=this.onMove,n=this.mousePosFetcher,i=n?n(t):{x:t.clientX,y:t.clientY};this.currentPos=i,this.delta={x:i.x-this.startPos.x,y:i.y-this.startPos.y},this.keys={shift:t.shiftKey,ctrl:t.ctrlKey,alt:t.altKey},this.rectDim=this.calc(this),this.updateRect(0),e&&e(t),0===t.which&&this.stop(t)}},{key:"stop",value:function(t){var e=this.opts,n=this.getDocumentEl();(0,s.off)(n,"mousemove",this.move),(0,s.off)(n,"keydown",this.handleKeyDown),(0,s.off)(n,"mouseup",this.stop),this.updateRect(1),(0,o.isFunction)(this.onEnd)&&this.onEnd(t,{docs:n,config:e})}},{key:"updateRect",value:function(t){var e=this.el,n=this,i=this.opts,r=this.rectDim,s=this.container.style,a=this.updateTarget,l=this.getSelectedHandler(),c=i.unitHeight,u=i.unitWidth;if((0,o.isFunction)(a))a(e,r,{store:t,selectedHandler:l,resizer:n,config:i});else{var h=e.style;h.width=r.w+u,h.height=r.h+c}var d=this.getElementPos(e);s.left=d.left+"px",s.top=d.top+"px",s.width=d.width+"px",s.height=d.height+"px"}},{key:"getSelectedHandler",value:function(){var t=this.handlers;if(this.selectedHandler)for(var e in t)if(t[e]===this.selectedHandler)return e}},{key:"handleKeyDown",value:function(t){27===t.keyCode&&(this.rectDim=this.startDim,this.stop(t))}},{key:"handleMouseDown",value:function(t){var e=t.target;this.isHandler(e)?(this.selectedHandler=e,this.start(t)):e!==this.el&&(this.selectedHandler="",this.blur())}},{key:"calc",value:function(t){var e=void 0,n=this.opts||{},i=n.step,r=this.startDim,o=n.minDim,a=n.maxDim,l=t.delta.x,c=t.delta.y,u=r.w,h=r.h,d={t:0,l:0,w:u,h:h};if(t){var f=t.handlerAttr;~f.indexOf("r")&&(e=(0,s.normalizeFloat)(u+l*i,i),e=Math.max(o,e),a&&(e=Math.min(a,e)),d.w=e),~f.indexOf("b")&&(e=(0,s.normalizeFloat)(h+c*i,i),e=Math.max(o,e),a&&(e=Math.min(a,e)),d.h=e),~f.indexOf("l")&&(e=(0,s.normalizeFloat)(u-l*i,i),e=Math.max(o,e),a&&(e=Math.min(a,e)),d.w=e),~f.indexOf("t")&&(e=(0,s.normalizeFloat)(h-c*i,i),e=Math.max(o,e),a&&(e=Math.min(a,e)),d.h=e);var p=n.ratioDefault?!t.keys.shift:t.keys.shift;if(f.indexOf("c")<0&&p){var g=r.w/r.h;d.w/d.h>g?d.h=Math.round(d.w/g):d.w=Math.round(d.h*g)}return~f.indexOf("l")&&(d.l=r.w-d.w),~f.indexOf("t")&&(d.t=r.h-d.h),d}}}]),t}();t.exports={init:function(t){return new u(t)}}},function(t,e,n){"use strict";(function(e){var n=e.$,i=function(t,e){var n=e||window,i=t.getBoundingClientRect();return{left:i.left+n.pageXOffset,top:i.top+n.pageYOffset,width:i.width,height:i.height}};t.exports={setKey:function(t,e){},getElementRect:function(t){var e=this.opts.posFetcher||"";return e?e(t,{avoidFrameOffset:1}):i(t)},init:function(t){return this.setOptions(t),this.handleMouseDown=this.handleMouseDown.bind(this),this.drag=this.drag.bind(this),this.move=this.move.bind(this),this.stop=this.stop.bind(this),this.setKey("up, right, down, left",this.handleKey),this},setOptions:function(t){this.opts=t||{}},focus:function(t){if(!t||t!==this.el){this.getDocumentEl(t),this.blur(),this.el=t,this.handlers=this.opts.dragHandlers||[t];var e=this.getElementRect(t);this.elRect=e,this.startTop=e.top,this.startLeft=e.left,this.getDocumentEl().on("mousedown",this.handleMouseDown)}},blur:function(){this.getDocumentEl().off("mousedown",this.handleMouseDown),this.el=null},start:function(t){this.startPos=this.getMousePos(t);var e=this.getDocumentEl();e.on("mousemove",this.drag),e.on("mouseup",this.stop);var n=this.opts.onStart;"function"==typeof n&&n(t,{docs:e,el:this.el,start:this.startPos,elRect:this.elRect}),this.drag(t)},stop:function(t){var e=this.getDocumentEl();e.off("mousemove",this.drag),e.off("mouseup",this.stop),this.lockedAxis=null;var n=this.opts.onEnd;"function"==typeof n&&n(t,{docs:e,delta:this.delta,end:{x:this.startLeft+this.delta.x,y:this.startTop+this.delta.y}})},handleMouseDown:function(t){var e=t.target;this.isHandler(e)&&this.start(t)},isHandler:function(t){var e=this.handlers;for(var n in e)if(e[n]===t)return!0;return!1},handleKey:function(t,e){switch(e.shortcut){case"up":this.move(0,-1);break;case"right":this.move(1,0);break;case"down":this.move(0,1);break;case"left":this.move(-1,0)}},getDocumentEl:function(t){var t=t||this.el;if(!this.$doc){var e=[document];t&&e.push(t.ownerDocument),this.$doc=n(e)}return this.$doc},getMousePos:function(t){var e=this.opts.mousePosFetcher;return e?e(t):{x:t.clientX,y:t.clientY}},drag:function(t){var e=this.lockedAxis,n=this.getMousePos(t),i={x:n.x-this.startPos.x,y:n.y-this.startPos.y};if(t.shiftKey){if(!e){var r=i.x,o=i.y,s=Math.abs(r),a=Math.abs(o);o>=s||o<=-s?e="x":(r>a||r<-a)&&(e="y")}}else e=null;"x"===e&&(i.x=this.startPos.x),"y"===e&&(i.y=this.startPos.y),this.lockedAxis=e,this.delta=i,this.move(i.x,i.y);var l=this.opts.onDrag;"function"==typeof l&&l(t,{delta:i,current:{x:this.startLeft+i.x,y:this.startTop+i.y},lockedAxis:e}),0===t.which&&this.stop(t)},move:function(t,e){this.moveX(t),this.moveY(e)},moveX:function(t){var e=this.el,n=(this.opts,this.startLeft+t),i=this.opts.setX;"function"==typeof i?i(n,{el:e,start:this.startLeft,delta:t}):e.style.left=n+"px"},moveY:function(t){var e=this.el,n=(this.opts,this.startTop+t),i=this.opts.setY;"function"==typeof i?i(n,{el:e,start:this.startTop,delta:t}):e.style.top=n+"px"}}}).call(e,n(0))},function(t,e,n){"use strict";var i="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t},r=Object.assign||function(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{};return e=r({},a,n),t=e.em,this.em=t,this},onLoad:function(){var t=e.defaults;for(var n in t){var i=t[n];this.add(n,i.keys,i.handler)}},add:function(t,e,r){var a=this.em,l=a.get("Commands"),c=a.getEditor(),u={id:t,keys:e,handler:r};return n[t]&&this.remove(t),n[t]=u,s(e,function(e,n){r=(0,o.isString)(r)?l.get(r):r,"object"==(void 0===r?"undefined":i(r))?r.run(c):r(c);var s=[t,n.shortcut,e];a.trigger.apply(a,["keymap:emit"].concat(s)),a.trigger.apply(a,["keymap:emit:"+t].concat(s))}),a.trigger("keymap:add",u),u},get:function(t){return n[t]},getAll:function(){return n},remove:function(t){var e=this.em,i=this.get(t);if(i)return delete n[t],s.unbind(i.keys),e&&e.trigger("keymap:remove",i),i}}}},function(t,e,n){"use strict";var i=Object.assign||function(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{};n=i({},a,s),t=n.em,this.em=t,e=new o.default({track:!0,register:[]}),e.changeUndoType("change",{condition:!1});var l={on:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};if(!r&&(r=t.previousAttributes()),!n.avoidStore){var i={object:t,before:r,after:t.toJSON()};return r=null,i}},undo:function(t,e,n,i){t.set(e)},redo:function(t,e,n,i){t.set(n)}};return["style","attributes","content","src"].forEach(function(t){return e.addUndoType("change:"+t,l)}),e.on("undo redo",function(){return t.trigger("change:selectedComponent change:canvasOffset")}),["undo","redo"].forEach(function(n){return e.on(n,function(){return t.trigger(n)})}),this},getConfig:function(){return n},add:function(t){return e.register(t),this},remove:function(t){return e.unregister(t),this},removeAll:function(){return e.unregisterAll(),this},start:function(){return e.startTracking(),this},stop:function(){return e.stopTracking(),this},undo:function(){return t.get("Canvas").isInputFocused()||e.undo(1),this},undoAll:function(){return e.undoAll(),this},redo:function(){return t.get("Canvas").isInputFocused()||e.redo(1),this},redoAll:function(){return e.redoAll(),this},hasUndo:function(){return e.isAvailable("undo")},hasRedo:function(){return e.isAvailable("redo")},getStack:function(){return e.stack},clear:function(){return e.clear(),this},getInstance:function(){return e}}}},function(t,e,n){var i,r,o;/*! +/*! grapesjs - 0.15.8 */ +!function(t,e){"object"==typeof exports&&"object"==typeof module?module.exports=e():"function"==typeof define&&define.amd?define([],e):"object"==typeof exports?exports.grapesjs=e():t.grapesjs=e()}(window,(function(){return function(t){var e={};function n(r){if(e[r])return e[r].exports;var i=e[r]={i:r,l:!1,exports:{}};return t[r].call(i.exports,i,i.exports,n),i.l=!0,i.exports}return n.m=t,n.c=e,n.d=function(t,e,r){n.o(t,e)||Object.defineProperty(t,e,{enumerable:!0,get:r})},n.r=function(t){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(t,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(t,"__esModule",{value:!0})},n.t=function(t,e){if(1&e&&(t=n(t)),8&e)return t;if(4&e&&"object"==typeof t&&t&&t.__esModule)return t;var r=Object.create(null);if(n.r(r),Object.defineProperty(r,"default",{enumerable:!0,value:t}),2&e&&"string"!=typeof t)for(var i in t)n.d(r,i,function(e){return t[e]}.bind(null,i));return r},n.n=function(t){var e=t&&t.__esModule?function(){return t.default}:function(){return t};return n.d(e,"a",e),e},n.o=function(t,e){return Object.prototype.hasOwnProperty.call(t,e)},n.p="",n(n.s=85)}([function(t,e,n){(function(t,n){var r;!function(){var i="object"==typeof self&&self.self===self&&self||"object"==typeof t&&t.global===t&&t||this||{},o=i._,a=Array.prototype,s=Object.prototype,l="undefined"!=typeof Symbol?Symbol.prototype:null,c=a.push,u=a.slice,h=s.toString,d=s.hasOwnProperty,f=Array.isArray,p=Object.keys,g=Object.create,v=function(){},m=function(t){return t instanceof m?t:this instanceof m?void(this._wrapped=t):new m(t)};e.nodeType?i._=m:(!n.nodeType&&n.exports&&(e=n.exports=m),e._=m),m.VERSION="1.9.1";var y,b=function(t,e,n){if(void 0===e)return t;switch(null==n?3:n){case 1:return function(n){return t.call(e,n)};case 3:return function(n,r,i){return t.call(e,n,r,i)};case 4:return function(n,r,i,o){return t.call(e,n,r,i,o)}}return function(){return t.apply(e,arguments)}},w=function(t,e,n){return m.iteratee!==y?m.iteratee(t,e):null==t?m.identity:m.isFunction(t)?b(t,e,n):m.isObject(t)&&!m.isArray(t)?m.matcher(t):m.property(t)};m.iteratee=y=function(t,e){return w(t,e,1/0)};var x=function(t,e){return e=null==e?t.length-1:+e,function(){for(var n=Math.max(arguments.length-e,0),r=Array(n),i=0;i=0&&e<=T};m.each=m.forEach=function(t,e,n){var r,i;if(e=b(e,n),j(t))for(r=0,i=t.length;r0?0:a-1;for(i||(r=e[o?o[s]:s],s+=t);s>=0&&s=3;return e(t,b(n,i,4),r,o)}};m.reduce=m.foldl=m.inject=E(1),m.reduceRight=m.foldr=E(-1),m.find=m.detect=function(t,e,n){var r=(j(t)?m.findIndex:m.findKey)(t,e,n);if(void 0!==r&&-1!==r)return t[r]},m.filter=m.select=function(t,e,n){var r=[];return e=w(e,n),m.each(t,(function(t,n,i){e(t,n,i)&&r.push(t)})),r},m.reject=function(t,e,n){return m.filter(t,m.negate(w(e)),n)},m.every=m.all=function(t,e,n){e=w(e,n);for(var r=!j(t)&&m.keys(t),i=(r||t).length,o=0;o=0},m.invoke=x((function(t,e,n){var r,i;return m.isFunction(e)?i=e:m.isArray(e)&&(r=e.slice(0,-1),e=e[e.length-1]),m.map(t,(function(t){var o=i;if(!o){if(r&&r.length&&(t=k(t,r)),null==t)return;o=t[e]}return null==o?o:o.apply(t,n)}))})),m.pluck=function(t,e){return m.map(t,m.property(e))},m.where=function(t,e){return m.filter(t,m.matcher(e))},m.findWhere=function(t,e){return m.find(t,m.matcher(e))},m.max=function(t,e,n){var r,i,o=-1/0,a=-1/0;if(null==e||"number"==typeof e&&"object"!=typeof t[0]&&null!=t)for(var s=0,l=(t=j(t)?t:m.values(t)).length;so&&(o=r);else e=w(e,n),m.each(t,(function(t,n,r){((i=e(t,n,r))>a||i===-1/0&&o===-1/0)&&(o=t,a=i)}));return o},m.min=function(t,e,n){var r,i,o=1/0,a=1/0;if(null==e||"number"==typeof e&&"object"!=typeof t[0]&&null!=t)for(var s=0,l=(t=j(t)?t:m.values(t)).length;sr||void 0===n)return 1;if(n0?0:i-1;o>=0&&o0?a=o>=0?o:Math.max(o+s,a):s=o>=0?Math.min(o+1,s):o+s+1;else if(n&&o&&s)return r[o=n(r,i)]===i?o:-1;if(i!=i)return(o=e(u.call(r,a,s),m.isNaN))>=0?o+a:-1;for(o=t>0?a:s-1;o>=0&&oe?(r&&(clearTimeout(r),r=null),s=c,a=t.apply(i,o),r||(i=o=null)):r||!1===n.trailing||(r=setTimeout(l,u)),a};return c.cancel=function(){clearTimeout(r),s=0,r=i=o=null},c},m.debounce=function(t,e,n){var r,i,o=function(e,n){r=null,n&&(i=t.apply(e,n))},a=x((function(a){if(r&&clearTimeout(r),n){var s=!r;r=setTimeout(o,e),s&&(i=t.apply(this,a))}else r=m.delay(o,e,this,a);return i}));return a.cancel=function(){clearTimeout(r),r=null},a},m.wrap=function(t,e){return m.partial(e,t)},m.negate=function(t){return function(){return!t.apply(this,arguments)}},m.compose=function(){var t=arguments,e=t.length-1;return function(){for(var n=e,r=t[e].apply(this,arguments);n--;)r=t[n].call(this,r);return r}},m.after=function(t,e){return function(){if(--t<1)return e.apply(this,arguments)}},m.before=function(t,e){var n;return function(){return--t>0&&(n=e.apply(this,arguments)),t<=1&&(e=null),n}},m.once=m.partial(m.before,2),m.restArguments=x;var F=!{toString:null}.propertyIsEnumerable("toString"),R=["valueOf","isPrototypeOf","toString","propertyIsEnumerable","hasOwnProperty","toLocaleString"],_=function(t,e){var n=R.length,r=t.constructor,i=m.isFunction(r)&&r.prototype||s,o="constructor";for(S(t,o)&&!m.contains(e,o)&&e.push(o);n--;)(o=R[n])in t&&t[o]!==i[o]&&!m.contains(e,o)&&e.push(o)};m.keys=function(t){if(!m.isObject(t))return[];if(p)return p(t);var e=[];for(var n in t)S(t,n)&&e.push(n);return F&&_(t,e),e},m.allKeys=function(t){if(!m.isObject(t))return[];var e=[];for(var n in t)e.push(n);return F&&_(t,e),e},m.values=function(t){for(var e=m.keys(t),n=e.length,r=Array(n),i=0;i1&&(r=b(r,e[1])),e=m.allKeys(t)):(r=$,e=A(e,!1,!1),t=Object(t));for(var i=0,o=e.length;i1&&(n=e[1])):(e=m.map(A(e,!1,!1),String),r=function(t,n){return!m.contains(e,n)}),m.pick(t,r,n)})),m.defaults=V(m.allKeys,!0),m.create=function(t,e){var n=C(t);return e&&m.extendOwn(n,e),n},m.clone=function(t){return m.isObject(t)?m.isArray(t)?t.slice():m.extend({},t):t},m.tap=function(t,e){return e(t),t},m.isMatch=function(t,e){var n=m.keys(e),r=n.length;if(null==t)return!r;for(var i=Object(t),o=0;o":">",'"':""","'":"'","`":"`"},U=m.invert(B),q=function(t){var e=function(e){return t[e]},n="(?:"+m.keys(t).join("|")+")",r=RegExp(n),i=RegExp(n,"g");return function(t){return t=null==t?"":""+t,r.test(t)?t.replace(i,e):t}};m.escape=q(B),m.unescape=q(U),m.result=function(t,e,n){m.isArray(e)||(e=[e]);var r=e.length;if(!r)return m.isFunction(n)?n.call(t):n;for(var i=0;i/g,interpolate:/<%=([\s\S]+?)%>/g,escape:/<%-([\s\S]+?)%>/g};var K=/(.)^/,Y={"'":"'","\\":"\\","\r":"r","\n":"n","\u2028":"u2028","\u2029":"u2029"},X=/\\|'|\r|\n|\u2028|\u2029/g,J=function(t){return"\\"+Y[t]};m.template=function(t,e,n){!e&&n&&(e=n),e=m.defaults({},e,m.templateSettings);var r,i=RegExp([(e.escape||K).source,(e.interpolate||K).source,(e.evaluate||K).source].join("|")+"|$","g"),o=0,a="__p+='";t.replace(i,(function(e,n,r,i,s){return a+=t.slice(o,s).replace(X,J),o=s+e.length,n?a+="'+\n((__t=("+n+"))==null?'':_.escape(__t))+\n'":r?a+="'+\n((__t=("+r+"))==null?'':__t)+\n'":i&&(a+="';\n"+i+"\n__p+='"),e})),a+="';\n",e.variable||(a="with(obj||{}){\n"+a+"}\n"),a="var __t,__p='',__j=Array.prototype.join,print=function(){__p+=__j.call(arguments,'');};\n"+a+"return __p;\n";try{r=new Function(e.variable||"obj","_",a)}catch(t){throw t.source=a,t}var s=function(t){return r.call(this,t,m)},l=e.variable||"obj";return s.source="function("+l+"){\n"+a+"}",s},m.chain=function(t){var e=m(t);return e._chain=!0,e};var Z=function(t,e){return t._chain?m(e).chain():e};m.mixin=function(t){return m.each(m.functions(t),(function(e){var n=m[e]=t[e];m.prototype[e]=function(){var t=[this._wrapped];return c.apply(t,arguments),Z(this,n.apply(m,t))}})),m},m.mixin(m),m.each(["pop","push","reverse","shift","sort","splice","unshift"],(function(t){var e=a[t];m.prototype[t]=function(){var n=this._wrapped;return e.apply(n,arguments),"shift"!==t&&"splice"!==t||0!==n.length||delete n[0],Z(this,n)}})),m.each(["concat","join","slice"],(function(t){var e=a[t];m.prototype[t]=function(){return Z(this,e.apply(this._wrapped,arguments))}})),m.prototype.value=function(){return this._wrapped},m.prototype.valueOf=m.prototype.toJSON=m.prototype.value,m.prototype.toString=function(){return String(this._wrapped)},void 0===(r=function(){return m}.apply(e,[]))||(n.exports=r)}()}).call(this,n(23),n(66)(t))},function(t,e,n){(function(r){var i,o,a;a="object"==typeof self&&self.self===self&&self||"object"==typeof r&&r.global===r&&r,i=[n(0),n(21),e],void 0===(o=function(t,e,n){a.Backbone=function(t,e,n,r){var i=t.Backbone,o=Array.prototype.slice;e.VERSION="1.3.3",e.$=r,e.noConflict=function(){return t.Backbone=i,this},e.emulateHTTP=!1,e.emulateJSON=!1;var a=function(t,e,r){n.each(e,(function(e,i){n[i]&&(t.prototype[i]=function(t,e,r){switch(t){case 1:return function(){return n[e](this[r])};case 2:return function(t){return n[e](this[r],t)};case 3:return function(t,i){return n[e](this[r],s(t,this),i)};case 4:return function(t,i,o){return n[e](this[r],s(t,this),i,o)};default:return function(){var t=o.call(arguments);return t.unshift(this[r]),n[e].apply(n,t)}}}(e,i,r))}))},s=function(t,e){return n.isFunction(t)?t:n.isObject(t)&&!e._isModel(t)?l(t):n.isString(t)?function(e){return e.get(t)}:t},l=function(t){var e=n.matches(t);return function(t){return e(t.attributes)}},c=e.Events={},u=/\s+/,h=function(t,e,r,i,o){var a,s=0;if(r&&"object"==typeof r){void 0!==i&&"context"in o&&void 0===o.context&&(o.context=i);for(a=n.keys(r);sthis.length&&(i=this.length),i<0&&(i+=this.length+1);var o,a,s=[],l=[],c=[],u=[],h={},d=e.add,f=e.merge,p=e.remove,g=!1,v=this.comparator&&null==i&&!1!==e.sort,m=n.isString(this.comparator)?this.comparator:null;for(a=0;a7),this._useHashChange=this._wantsHashChange&&this._hasHashChange,this._wantsPushState=!!this.options.pushState,this._hasPushState=!(!this.history||!this.history.pushState),this._usePushState=this._wantsPushState&&this._hasPushState,this.fragment=this.getFragment(),this.root=("/"+this.root+"/").replace(N,"/"),this._wantsHashChange&&this._wantsPushState){if(!this._hasPushState&&!this.atRoot()){var e=this.root.slice(0,-1)||"/";return this.location.replace(e+"#"+this.getPath()),!0}this._hasPushState&&this.atRoot()&&this.navigate(this.getHash(),{replace:!0})}if(!this._hasHashChange&&this._wantsHashChange&&!this._usePushState){this.iframe=document.createElement("iframe"),this.iframe.src="javascript:0",this.iframe.style.display="none",this.iframe.tabIndex=-1;var r=document.body,i=r.insertBefore(this.iframe,r.firstChild).contentWindow;i.document.open(),i.document.close(),i.location.hash="#"+this.fragment}var o=window.addEventListener||function(t,e){return attachEvent("on"+t,e)};if(this._usePushState?o("popstate",this.checkUrl,!1):this._useHashChange&&!this.iframe?o("hashchange",this.checkUrl,!1):this._wantsHashChange&&(this._checkUrlInterval=setInterval(this.checkUrl,this.interval)),!this.options.silent)return this.loadUrl()},stop:function(){var t=window.removeEventListener||function(t,e){return detachEvent("on"+t,e)};this._usePushState?t("popstate",this.checkUrl,!1):this._useHashChange&&!this.iframe&&t("hashchange",this.checkUrl,!1),this.iframe&&(document.body.removeChild(this.iframe),this.iframe=null),this._checkUrlInterval&&clearInterval(this._checkUrlInterval),A.started=!1},route:function(t,e){this.handlers.unshift({route:t,callback:e})},checkUrl:function(t){var e=this.getFragment();if(e===this.fragment&&this.iframe&&(e=this.getHash(this.iframe.contentWindow)),e===this.fragment)return!1;this.iframe&&this.navigate(e),this.loadUrl()},loadUrl:function(t){return!!this.matchRoot()&&(t=this.fragment=this.getFragment(t),n.some(this.handlers,(function(e){if(e.route.test(t))return e.callback(t),!0})))},navigate:function(t,e){if(!A.started)return!1;e&&!0!==e||(e={trigger:!!e}),t=this.getFragment(t||"");var n=this.root;""!==t&&"?"!==t.charAt(0)||(n=n.slice(0,-1)||"/");var r=n+t;if(t=this.decodeFragment(t.replace(I,"")),this.fragment!==t){if(this.fragment=t,this._usePushState)this.history[e.replace?"replaceState":"pushState"]({},document.title,r);else{if(!this._wantsHashChange)return this.location.assign(r);if(this._updateHash(this.location,t,e.replace),this.iframe&&t!==this.getHash(this.iframe.contentWindow)){var i=this.iframe.contentWindow;e.replace||(i.document.open(),i.document.close()),this._updateHash(i.location,t,e.replace)}}return e.trigger?this.loadUrl(t):void 0}},_updateHash:function(t,e,n){if(n){var r=t.href.replace(/(javascript:|#).*$/,"");t.replace(r+"#"+e)}else t.hash="#"+e}}),e.history=new A,y.extend=b.extend=P.extend=O.extend=A.extend=function(t,e){var r,i=this;return r=t&&n.has(t,"constructor")?t.constructor:function(){return i.apply(this,arguments)},n.extend(r,i,e),r.prototype=n.create(i.prototype,t),r.prototype.constructor=r,r.__super__=i.prototype,r};var F=function(){throw new Error('A "url" property or function must be specified')},R=function(t,e){var n=e.error;e.error=function(r){n&&n.call(e.context,t,r,e),t.trigger("error",t,r,e)}};return e}(a,n,t,e)}.apply(e,i))||(t.exports=o)}).call(this,n(23))},function(t,e){t.exports=function(t,e,n){return e in t?Object.defineProperty(t,e,{value:n,enumerable:!0,configurable:!0,writable:!0}):t[e]=n,t}},function(t,e,n){"use strict";n.d(e,"k",(function(){return v})),n.d(e,"p",(function(){return s})),n.d(e,"o",(function(){return l})),n.d(e,"i",(function(){return f})),n.d(e,"m",(function(){return o})),n.d(e,"f",(function(){return m})),n.d(e,"c",(function(){return y})),n.d(e,"a",(function(){return h})),n.d(e,"l",(function(){return g})),n.d(e,"e",(function(){return x})),n.d(e,"j",(function(){return C})),n.d(e,"d",(function(){return p})),n.d(e,"q",(function(){return a})),n.d(e,"n",(function(){return d})),n.d(e,"g",(function(){return b})),n.d(e,"h",(function(){return c})),n.d(e,"b",(function(){return O}));var r=n(0),i=window.Element.prototype,o=i.matches||i.webkitMatchesSelector||i.mozMatchesSelector||i.msMatchesSelector,a=function(t,e){var n={},i=Object(r.keys)(e);for(var o in t)if(t.hasOwnProperty(o)){var a=t[o],s=e[o];i.indexOf(o)>=0?a!==s&&(n[o]=s):n[o]=null}for(var l in e)e.hasOwnProperty(l)&&Object(r.isUndefined)(t[l])&&(n[l]=e[l]);return n},s=function(t,e,n){e=e.split(/\s+/),t=t instanceof Array?t:[t];for(var r=function(r){t.forEach((function(t){return t.addEventListener(e[r],n)}))},i=0;i1&&void 0!==arguments[1]?arguments[1]:1,n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:0,r=0;if(isNaN(t))return n;if(t=parseFloat(t),Math.floor(t)!==t){var i=e.toString().split(".")[1];r=i?i.length:0}return r?parseFloat(t.toFixed(r)):t},f=function(t){return"draggable"in document.createElement("i")&&(t?t.get("Config").nativeDnD:1)},p=function(t){return Object(r.isElement)(t)||g(t)?t:t&&t.getEl?t.getEl():void 0},g=function(t){return t&&3===t.nodeType},v=function(t){return t&&!g(t)&&!function(t){return t&&8===t.nodeType}(t)},m=function(t,e){var n=t;return Object(r.isElement)(t)&&(n=e(t).data("model")),n},y=function(t){var e,n={top:0,left:0,width:0,height:0};if(!t)return n;if(g(t)){var r=document.createRange();r.selectNode(t),e=r.getBoundingClientRect(),r.detach()}return e||(t.getBoundingClientRect?t.getBoundingClientRect():n)},b=function(t){return t.touches&&t.touches[0]?t.touches[0]:t},w=function(t){return t.which||t.keyCode},x=function(t){return String.fromCharCode(w(t))},C=function(t){return 27===w(t)},O=function(t){return t.charAt(0).toUpperCase()+t.substring(1)}},function(t,e,n){"use strict";n.r(e);var r=n(6),i=n.n(r),o=n(2),a=n.n(o),s=n(0),l=n(3),c=n(20),u=n(1),h=n.n(u),d=n(18),f=n(7),p=n(9);function g(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function v(t){for(var e=1;e1&&void 0!==arguments[1]?arguments[1]:{},n=this.target,r=this.get("name");if(!Object(s.isUndefined)(t))if(this.get("changeProp"))n.set(r,t,e);else{var i=v({},n.get("attributes"));i[r]=t,n.set("attributes",i,e)}},setValueFromInput:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:1,n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},r={value:t};this.set(r,v({},n,{avoidStore:1})),e&&(this.set("value","",n),this.set(r,n))},getInitValue:function(){var t,e=this.target,n=this.get("name");if(e){var r=e.get("attributes");t=this.get("changeProp")?e.get(n):r[n]}return t||this.get("value")||this.get("default")}}),y=h.a.Collection.extend({model:m,initialize:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};this.em=e.em||"",this.listenTo(this,"add",this.handleAdd),this.listenTo(this,"reset",this.handleReset)},handleReset:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=e.previousModels,r=void 0===n?[]:n;r.forEach((function(t){return t.trigger("remove")}))},handleAdd:function(t){var e=this.target;e&&(t.target=e)},setTarget:function(t){this.target=t},add:function(t,e){var n=this.em;if(Object(s.isString)(t)||Object(s.isArray)(t)){var r=n&&n.get&&n.get("TraitManager"),i=function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return{build:function(e){var n=[];"string"==typeof e&&(e=[e]);for(var r=0;r0&&void 0!==arguments[0]?arguments[0]:{},n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},r=n.em,i=this.parent(),o=i&&i.attributes;if(o&&o.propagate){var a={},l=o.propagate;l.forEach((function(t){return a[t]=i.get(t)})),a.propagate=l,a=w({},a,{},e),this.set(a)}var c=this.get("propagate");c&&this.set("propagate",Object(s.isArray)(c)?c:[c]),n&&n.config&&n.config.voidElements.indexOf(this.get("tagName"))>=0&&this.set("void",!0),n.em=r,this.opt=n,this.em=r,this.config=n.config||{},this.set("attributes",w({},this.defaults.attributes||{},{},this.get("attributes")||{})),this.ccid=C.createId(this),this.initClasses(),this.initTraits(),this.initComponents(),this.initToolbar(),this.listenTo(this,"change:script",this.scriptUpdated),this.listenTo(this,"change:tagName",this.tagUpdated),this.listenTo(this,"change:attributes",this.attrUpdated),this.listenTo(this,"change:attributes:id",this._idUpdated),this.set("status",""),["classes","traits","components"].forEach((function(e){var n="add remove ".concat("components"!==e?"change":"");t.listenTo(t.get(e),n.trim(),(function(){for(var n=arguments.length,r=new Array(n),i=0;i2&&void 0!==arguments[2]?arguments[2]:{},i=this.get("attributes"),o=i.class;o&&this.setClass(o),delete i.class;var a=i.style;a&&this.setStyle(a),delete i.style;var c=w({},this.previous("attributes")),u=Object(l.q)(c,this.get("attributes"));Object(s.keys)(u).forEach((function(t){return n.trigger("change:attributes:".concat(t),n,u[t],r)}))},setAttributes:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return this.set("attributes",w({},t),e),this},addAttributes:function(t){var e=w({},this.getAttributes(),{},t);return this.setAttributes(e),this},getStyle:function(){var t=this.em;if(t&&t.getConfig("avoidInlineStyle")){var e=this.get("state"),n=t.get("CssComposer").getIdRule(this.getId(),{state:e});if(this.rule=n,n)return n.getStyle()}return c.a.getStyle.call(this)},setStyle:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},r=this.em,i=this.opt;if(r&&r.getConfig("avoidInlineStyle")&&!i.temporary){var o=this.get("style")||{};e=w({},e=Object(s.isString)(e)?this.parseStyle(e):e,{},o);var a=this.get("state"),u=r.get("CssComposer"),h=this.getStyle();this.rule=u.setIdRule(this.getId(),e,w({},n,{state:a}));var d=Object(l.q)(h,e);this.set("style",{},{silent:1}),Object(s.keys)(d).forEach((function(e){return t.trigger("change:style:".concat(e))}))}else e=c.a.setStyle.apply(this,arguments);return e},getAttributes:function(){var t,e=this.em,n=[],r=w({},this.get("attributes")),i=e&&e.get("SelectorManager"),o=this.getId();(this.get("classes").forEach((function(t){return n.push(Object(s.isString)(t)?t:t.get("name"))})),n.length&&(r.class=n.join(" ")),Object(s.has)(r,"id"))||(!function(t){return t&&t.getConfig("avoidInlineStyle")}(e)?Object(s.isEmpty)(this.getStyle())||(t=1):t=i&&i.get(o,i.Selector.TYPE_ID),t&&(r.id=this.getId()));return r},addClass:function(t){var e=this.em.get("SelectorManager").addClass(t);return this.get("classes").add(e)},setClass:function(t){return this.get("classes").reset(),this.addClass(t)},removeClass:function(t){var e=[];t=Object(s.isArray)(t)?t:[t];var n=this.get("classes"),r=f.a.TYPE_CLASS;return t.forEach((function(t){t.split(" ").forEach((function(t){var i=n.where({name:t,type:r})[0];i&&e.push(n.remove(i))}))})),e},getClasses:function(){var t=this.getAttributes().class;return t?t.split(" "):[]},initClasses:function(){var t=[this,"change:classes",this.initClasses],e=this.get("classes")||[],n=Object(s.isString)(e)?e.split(" "):e;this.stopListening.apply(this,t);var r=this.normalizeClasses(n),i=new p.a([]);return this.set("classes",i),i.add(r),this.listenTo.apply(this,t),this},initComponents:function(){var t=[this,"change:components",this.initComponents];this.stopListening.apply(this,t);var e=new d.a(null,this.opt);e.parent=this;var n=this.get("components"),r=!this.opt.avoidChildren;return this.set("components",e),r&&e.add(Object(s.isFunction)(n)?n(this):n),this.listenTo.apply(this,t),this},initTraits:function(t){var e=this.em,n=[this,"change:traits",this.initTraits];this.stopListening.apply(this,n),this.loadTraits();var r=w({},this.get("attributes")),i=this.get("traits");return i.each((function(t){if(!t.get("changeProp")){var e=t.get("name"),n=t.getInitValue();e&&n&&(r[e]=n)}})),i.length&&this.set("attributes",r),this.listenTo.apply(this,n),t&&e&&e.trigger("component:toggled"),this},append:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=this.components().add(t,e);return Object(s.isArray)(n)?n:[n]},components:function(t){var e=this.get("components");return Object(s.isUndefined)(t)?e:(e.reset(),t&&this.append(t))},parent:function(){var t=this.collection;return t&&t.parent},scriptUpdated:function(){this.set("scriptUpdated",1)},initToolbar:function(){var t=this.em,e=t&&t.getConfig("stylePrefix")||"";if(!this.get("toolbar")){var n=[];this.collection&&n.push({attributes:{class:"fa fa-arrow-up"},command:function(t){return t.runCommand("core:component-exit",{force:1})}}),this.get("draggable")&&n.push({attributes:{class:"fa fa-arrows ".concat(e,"no-touch-actions"),draggable:!0},command:"tlb-move"}),this.get("copyable")&&n.push({attributes:{class:"fa fa-clone"},command:"tlb-clone"}),this.get("removable")&&n.push({attributes:{class:"fa fa-trash-o"},command:"tlb-delete"}),this.set("toolbar",n)}},loadTraits:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};if(t=t||this.get("traits"),!((t=Object(s.isFunction)(t)?t(this):t)instanceof y)){var n=new y([],this.opt);n.setTarget(this),t.length&&(t.forEach((function(t){return t.attributes&&delete t.attributes.value})),n.add(t)),this.set("traits",n,e)}return this},getTrait:function(t){return this.get("traits").filter((function(e){return e.get("id")===t||e.get("name")===t}))[0]},updateTrait:function(t,e){var n=this.em,r=this.getTrait(t);return r&&r.set(e),n&&n.trigger("component:toggled"),this},getTraitIndex:function(t){var e=this.getTrait(t);return e?this.get("traits").indexOf(e):e},removeTrait:function(t){var e=this,n=this.em,r=(Object(s.isArray)(t)?t:[t]).map((function(t){return e.getTrait(t)})),i=this.get("traits").remove(r);return n&&n.trigger("component:toggled"),i},addTrait:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=this.em,r=this.get("traits").add(t,e);return n&&n.trigger("component:toggled"),r},normalizeClasses:function(t){var e=[],n=this.em;if(n){var r=n.get("SelectorManager");if(r)return t.forEach((function(t){var n="";n="string"==typeof t?t:t.name;var i=r.add(n);e.push(i)})),e}},clone:function(){var t=this.em,e=this.getStyle(),n=w({},this.attributes),r=w({},this.opt);n.attributes=w({},n.attributes),delete n.attributes.id,n.components=[],n.classes=[],n.traits=[],this.get("components").each((function(t,e){n.components[e]=t.clone()})),this.get("traits").each((function(t,e){n.traits[e]=t.clone()})),this.get("classes").each((function(t,e){n.classes[e]=t.get("name")})),n.status="",n.view="",r.collection=null,t&&t.getConfig("avoidInlineStyle")&&!Object(s.isEmpty)(e)&&(n.style=e);var i=new this.constructor(n,r);return t&&t.trigger("component:clone",i),this.trigger("component:clone",i),i},getName:function(){var t=this.get("name")||this.get("custom-name"),e=this.get("tagName");e="div"==e?"box":e;var n=this.get("type")||e;return n=n.charAt(0).toUpperCase()+n.slice(1),t||n},getIcon:function(){var t=this.get("icon");return t?t+" ":""},toHTML:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=this,n=[],r=e.get("tagName"),i=e.get("void"),o=t.attributes,a=this.getAttrToHTML();for(var l in o&&(Object(s.isFunction)(o)?a=o(e,a)||{}:Object(s.isObject)(o)&&(a=o)),a){var c=a[l],u=Object(s.isString)(c)?c.replace(/"/g,"""):c;Object(s.isUndefined)(u)||(Object(s.isBoolean)(u)?u&&n.push(l):n.push("".concat(l,'="').concat(u,'"')))}var h=n.length?" ".concat(n.join(" ")):"",d="<".concat(r).concat(h).concat(i?"/":"",">").concat(e.get("content"));return e.get("components").each((function(e){return d+=e.toHTML(t)})),!i&&(d+="")),d},getAttrToHTML:function(){var t=this.getAttributes();return delete t.style,t},toJSON:function(){for(var t=arguments.length,e=new Array(t),n=0;n1?r-1:0),o=1;o0&&void 0!==arguments[0]&&arguments[0];var t=this.em,e=this.getId();if(e){var n=C.createId(this);this.setId(n);var r=t&&t.get("CssComposer").getIdRule(e),i=r&&r.get("selectors").at(0);return i&&i.set("name",n),this}},_getStyleRule:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=t.id,n=this.em,r=e||this.getId();return n&&n.get("CssComposer").getIdRule(r)},_getStyleSelector:function(t){var e=this._getStyleRule(t);return e&&e.get("selectors").at(0)},_idUpdated:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};if(!n.idUpdate){var r=this.ccid,i=this.get("attributes")||{},o=i.id,a=(this.previous("attributes")||{}).id||r,s=C.getList(this);if(s[o])return this.setId(a,{idUpdate:1});delete s[a],s[o]=this,this.ccid=o;var l=this._getStyleSelector({id:a});l&&l.set({name:o,label:o})}}},{isComponent:function(t){return{tagName:t.tagName?t.tagName.toLowerCase():""}},createId:function(t){var e,n=C.getList(t),r=t.get("attributes").id;return r?(e=C.getIncrementId(r,n),t.setId(e)):e=C.getNewId(n),n[e]=t,e},getNewId:function(t){for(var e=Object.keys(t).length.toString().length+2,n=(Math.random()+1.1).toString(36).slice(-e),r="i".concat(n);t[r];)r=C.getNewId(t);return r},getIncrementId:function(t,e){for(var n=1,r=t;e[r];)n++,r="".concat(t,"-").concat(n);return r},getList:function(t){var e=t.opt&&t.opt.domc;return e?e.componentsById:{}},checkId:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[],n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},r=Object(s.isArray)(t)?t:[t];r.forEach((function(t){var r=t.attributes,i=void 0===r?{}:r,o=t.components,a=i.id;if(a&&n[a]){var l=C.getIncrementId(a,n);i.id=l,Object(s.isArray)(e)&&e.forEach((function(t){var e=t.selectors;e.forEach((function(t,n){t==="#".concat(a)&&(e[n]="#".concat(l))}))}))}o&&C.checkId(o,e,n)}))}});e.default=C},function(t,e,n){"use strict";n.r(e);var r=n(2),i=n.n(r),o=n(1),a=n.n(o),s=n(0),l=n(18),c=n(30),u=n(9),h=n(11);function d(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function f(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{},e=this.model,n=t.config||{},r=n.em,i=e.opt||{},o=this.$el,a=n.draggableComponents;this.opts=t,this.modelOpt=i,this.config=n,this.em=r||"",this.pfx=n.stylePrefix||"",this.ppfx=n.pStylePrefix||"",this.attr=e.get("attributes"),this.classe=this.attr.class||[],this.listenTo(e,"change:style",this.updateStyle),this.listenTo(e,"change:attributes",this.renderAttributes),this.listenTo(e,"change:highlightable",this.updateHighlight),this.listenTo(e,"change:status",this.updateStatus),this.listenTo(e,"change:state",this.updateState),this.listenTo(e,"change:script",this.reset),this.listenTo(e,"change:content",this.updateContent),this.listenTo(e,"change",this.handleChange),this.listenTo(e,"active",this.onActive),o.data("model",e),e.view=this,this.initClasses(),this.initComponents({avoidRender:1}),this.events=f({},this.events,{},a&&{dragstart:"handleDragStart"}),this.delegateEvents(),!i.temporary&&this.init(this._clbObj())},_clbObj:function(){var t=this.em,e=this.model,n=this.el;return{editor:t&&t.getEditor(),model:e,el:n}},init:function(){},removed:function(){},onActive:function(){},remove:function(){return a.a.View.prototype.remove.apply(this,arguments),this.removed(this._clbObj()),this},handleDragStart:function(t){t.preventDefault(),t.stopPropagation(),this.em.get("Commands").run("tlb-move",{target:this.model,event:t})},initClasses:function(){var t=this.model,e=t.get("classes");e instanceof u.a&&(this.stopListening(t,"change:classes",this.initClasses),this.listenTo(t,"change:classes",this.initClasses),this.listenTo(e,"add remove change",this.updateClasses),e.length&&this.importClasses())},initComponents:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=this.model,n=this.$el,r=this.childrenView,i="change:components",o=e.get("components"),a=[e,i,this.initComponents];o instanceof l.a&&(n.data("collection",o),r&&r.remove(),this.stopListening.apply(this,a),!t.avoidRender&&this.renderChildren(),this.listenTo.apply(this,a))},handleChange:function(){var t=this.model;for(var e in t.emitUpdate(),t.changed)t.emitUpdate(e)},importClasses:function(){var t=this.config.em.get("SelectorManager");t&&this.model.get("classes").each((function(e){t.add(e.get("name"))}))},updateState:function(t){var e="hc-state";this.model.get("state")?this.$el.addClass(e):this.$el.removeClass(e)},updateStatus:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=(this.em,this.el),n=this.model.get("status"),r=this.pfx,i=this.ppfx,o="".concat(r,"selected"),a="".concat(o,"-parent"),s="".concat(i,"freezed"),l="".concat(i,"hovered"),c=[o,a,s,l];this.$el.removeClass(c.join(" "));var u=e.getAttribute("class")||"",h="";switch(n){case"selected":h="".concat(u," ").concat(o);break;case"selected-parent":h="".concat(u," ").concat(a);break;case"freezed":h="".concat(u," ").concat(s);break;case"freezed-selected":h="".concat(u," ").concat(s," ").concat(o);break;case"hovered":h=t.avoidHover?"":"".concat(u," ").concat(l)}(h=h.trim())&&e.setAttribute("class",h)},updateHighlight:function(){var t=this.model.get("highlightable");this.setAttribute("data-highlightable",t?1:"")},updateStyle:function(){var t=this.em,e=this.model;if(t&&t.get("avoidInlineStyle")){this.el.id=e.getId();var n=e.getStyle();!Object(s.isEmpty)(n)&&e.setStyle(n)}else this.setAttribute("style",e.styleToString())},updateClasses:function(){var t=this.model.get("classes").pluck("name").join(" ");this.setAttribute("class",t),this.updateStatus()},setAttribute:function(t,e){var n=this.$el;e?n.attr(t,e):n.removeAttr(t)},getClasses:function(){return this.model.getClasses().join(" ")},updateAttributes:function(){var t=[],e=this.model,n=this.$el,r=this.el,i=this.config,o=e.attributes,a=o.highlightable,l=o.textable,c=f({"data-gjs-type":o.type||"default"},i.draggableComponents?{draggable:!0}:{},{},a?{"data-highlightable":1}:{},{},l?{contenteditable:"false","data-gjs-textable":"true"}:{});Object(s.each)(r.attributes,(function(e){return t.push(e.nodeName)})),t.forEach((function(t){return n.removeAttr(t)}));var u=f({},c,{},e.getAttributes());Object(s.keys)(u).forEach((function(t){return!1===u[t]&&delete u[t]})),n.attr(u),this.updateStyle()},updateContent:function(){this.getChildrenContainer().innerHTML=this.model.get("content")},prevDef:function(t){t.preventDefault()},updateScript:function(){var t=this.model,e=this.em;t.get("script")&&e&&e.get("Canvas").getCanvasView().updateScript(this)},getChildrenContainer:function(){var t=this.el;return"function"==typeof this.getChildrenSelector?t=this.el.querySelector(this.getChildrenSelector()):this.getTemplate,t},reset:function(){var t=this.el,e=this.model,n=e.components();this.el="",this._ensureElement(),this.$el.data({model:e,collection:n}),Object(h.d)(t,this.el),this.render()},renderChildren:function(){this.updateContent();var t=this.getChildrenContainer(),e=new c.a({collection:this.model.get("components"),config:this.config,componentTypes:this.opts.componentTypes});e.render(t),this.childrenView=e;for(var n=Array.prototype.slice.call(e.el.childNodes),r=0,i=n.length;r1&&void 0!==arguments[1]?arguments[1]:{},n=e.config,r=void 0===n?{}:n,o=this.get("name"),a=this.get("label");o?a||this.set("label",o):this.set("name",a);var s=this.get("name"),l=r.escapeName,c=l?l(s):i.escapeName(s);this.set("name",c)},getFullName:function(){var t="";switch(this.get("type")){case 1:t=".";break;case 2:t="#"}return t+this.get("name")}},{TYPE_CLASS:1,TYPE_ID:2,escapeName:function(t){return"".concat(t).trim().replace(/([^a-z0-9\w-\:]+)/gi,"-")}});e.a=i},function(t,e,n){var r=n(72),i=n(73),o=n(74);t.exports=function(t){return r(t)||i(t)||o()}},function(t,e,n){"use strict";var r=n(0),i=n(1),o=n.n(i),a=n(7);e.a=o.a.Collection.extend({model:a.a,modelId:function(t){return"".concat(t.name,"_").concat(t.type||a.a.TYPE_CLASS)},getStyleable:function(){return Object(r.filter)(this.models,(function(t){return t.get("active")&&!t.get("private")}))},getValid:function(){return Object(r.filter)(this.models,(function(t){return!t.get("private")}))},getFullString:function(t){var e=[];return(t||this).forEach((function(t){return e.push(t.getFullName())})),e.join("").trim()}})},function(t,e,n){t.exports=function(){"use strict";var t=navigator.userAgent,e=navigator.platform,n=/gecko\/\d/i.test(t),r=/MSIE \d/.test(t),i=/Trident\/(?:[7-9]|\d{2,})\..*rv:(\d+)/.exec(t),o=/Edge\/(\d+)/.exec(t),a=r||i||o,s=a&&(r?document.documentMode||6:+(o||i)[1]),l=!o&&/WebKit\//.test(t),c=l&&/Qt\/\d+\.\d+/.test(t),u=!o&&/Chrome\//.test(t),h=/Opera\//.test(t),d=/Apple Computer/.test(navigator.vendor),f=/Mac OS X 1\d\D([8-9]|\d\d)\D/.test(t),p=/PhantomJS/.test(t),g=!o&&/AppleWebKit/.test(t)&&/Mobile\/\w+/.test(t),v=/Android/.test(t),m=g||v||/webOS|BlackBerry|Opera Mini|Opera Mobi|IEMobile/i.test(t),y=g||/Mac/.test(e),b=/\bCrOS\b/.test(t),w=/win/i.test(e),x=h&&t.match(/Version\/(\d*\.\d*)/);x&&(x=Number(x[1])),x&&x>=15&&(h=!1,l=!0);var C=y&&(c||h&&(null==x||x<12.11)),O=n||a&&s>=9;function S(t){return new RegExp("(^|\\s)"+t+"(?:$|\\s)\\s*")}var k,T=function(t,e){var n=t.className,r=S(e).exec(n);if(r){var i=n.slice(r.index+r[0].length);t.className=n.slice(0,r.index)+(i?r[1]+i:"")}};function P(t){for(var e=t.childNodes.length;e>0;--e)t.removeChild(t.firstChild);return t}function j(t,e){return P(t).appendChild(e)}function E(t,e,n,r){var i=document.createElement(t);if(n&&(i.className=n),r&&(i.style.cssText=r),"string"==typeof e)i.appendChild(document.createTextNode(e));else if(e)for(var o=0;o=e)return a+(e-o);a+=s-o,a+=n-a%n,o=s+1}}g?I=function(t){t.selectionStart=0,t.selectionEnd=t.value.length}:a&&(I=function(t){try{t.select()}catch(t){}});var V=function(){this.id=null};function z(t,e){for(var n=0;n=e)return r+Math.min(a,e-i);if(i+=o-r,r=o+1,(i+=n-i%n)>=e)return r}}var G=[""];function K(t){for(;G.length<=t;)G.push(Y(G)+" ");return G[t]}function Y(t){return t[t.length-1]}function X(t,e){for(var n=[],r=0;r"€"&&(t.toUpperCase()!=t.toLowerCase()||Q.test(t))}function et(t,e){return e?!!(e.source.indexOf("\\w")>-1&&tt(t))||e.test(t):tt(t)}function nt(t){for(var e in t)if(t.hasOwnProperty(e)&&t[e])return!1;return!0}var rt=/[\u0300-\u036f\u0483-\u0489\u0591-\u05bd\u05bf\u05c1\u05c2\u05c4\u05c5\u05c7\u0610-\u061a\u064b-\u065e\u0670\u06d6-\u06dc\u06de-\u06e4\u06e7\u06e8\u06ea-\u06ed\u0711\u0730-\u074a\u07a6-\u07b0\u07eb-\u07f3\u0816-\u0819\u081b-\u0823\u0825-\u0827\u0829-\u082d\u0900-\u0902\u093c\u0941-\u0948\u094d\u0951-\u0955\u0962\u0963\u0981\u09bc\u09be\u09c1-\u09c4\u09cd\u09d7\u09e2\u09e3\u0a01\u0a02\u0a3c\u0a41\u0a42\u0a47\u0a48\u0a4b-\u0a4d\u0a51\u0a70\u0a71\u0a75\u0a81\u0a82\u0abc\u0ac1-\u0ac5\u0ac7\u0ac8\u0acd\u0ae2\u0ae3\u0b01\u0b3c\u0b3e\u0b3f\u0b41-\u0b44\u0b4d\u0b56\u0b57\u0b62\u0b63\u0b82\u0bbe\u0bc0\u0bcd\u0bd7\u0c3e-\u0c40\u0c46-\u0c48\u0c4a-\u0c4d\u0c55\u0c56\u0c62\u0c63\u0cbc\u0cbf\u0cc2\u0cc6\u0ccc\u0ccd\u0cd5\u0cd6\u0ce2\u0ce3\u0d3e\u0d41-\u0d44\u0d4d\u0d57\u0d62\u0d63\u0dca\u0dcf\u0dd2-\u0dd4\u0dd6\u0ddf\u0e31\u0e34-\u0e3a\u0e47-\u0e4e\u0eb1\u0eb4-\u0eb9\u0ebb\u0ebc\u0ec8-\u0ecd\u0f18\u0f19\u0f35\u0f37\u0f39\u0f71-\u0f7e\u0f80-\u0f84\u0f86\u0f87\u0f90-\u0f97\u0f99-\u0fbc\u0fc6\u102d-\u1030\u1032-\u1037\u1039\u103a\u103d\u103e\u1058\u1059\u105e-\u1060\u1071-\u1074\u1082\u1085\u1086\u108d\u109d\u135f\u1712-\u1714\u1732-\u1734\u1752\u1753\u1772\u1773\u17b7-\u17bd\u17c6\u17c9-\u17d3\u17dd\u180b-\u180d\u18a9\u1920-\u1922\u1927\u1928\u1932\u1939-\u193b\u1a17\u1a18\u1a56\u1a58-\u1a5e\u1a60\u1a62\u1a65-\u1a6c\u1a73-\u1a7c\u1a7f\u1b00-\u1b03\u1b34\u1b36-\u1b3a\u1b3c\u1b42\u1b6b-\u1b73\u1b80\u1b81\u1ba2-\u1ba5\u1ba8\u1ba9\u1c2c-\u1c33\u1c36\u1c37\u1cd0-\u1cd2\u1cd4-\u1ce0\u1ce2-\u1ce8\u1ced\u1dc0-\u1de6\u1dfd-\u1dff\u200c\u200d\u20d0-\u20f0\u2cef-\u2cf1\u2de0-\u2dff\u302a-\u302f\u3099\u309a\ua66f-\ua672\ua67c\ua67d\ua6f0\ua6f1\ua802\ua806\ua80b\ua825\ua826\ua8c4\ua8e0-\ua8f1\ua926-\ua92d\ua947-\ua951\ua980-\ua982\ua9b3\ua9b6-\ua9b9\ua9bc\uaa29-\uaa2e\uaa31\uaa32\uaa35\uaa36\uaa43\uaa4c\uaab0\uaab2-\uaab4\uaab7\uaab8\uaabe\uaabf\uaac1\uabe5\uabe8\uabed\udc00-\udfff\ufb1e\ufe00-\ufe0f\ufe20-\ufe26\uff9e\uff9f]/;function it(t){return t.charCodeAt(0)>=768&&rt.test(t)}function ot(t,e,n){for(;(n<0?e>0:en?-1:1;;){if(e==n)return e;var i=(e+n)/2,o=r<0?Math.ceil(i):Math.floor(i);if(o==e)return t(o)?e:n;t(o)?n=o:e=o+r}}var st=null;function lt(t,e,n){var r;st=null;for(var i=0;ie)return i;o.to==e&&(o.from!=o.to&&"before"==n?r=i:st=i),o.from==e&&(o.from!=o.to&&"before"!=n?r=i:st=i)}return null!=r?r:st}var ct=function(){var t="bbbbbbbbbtstwsbbbbbbbbbbbbbbssstwNN%%%NNNNNN,N,N1111111111NNNNNNNLLLLLLLLLLLLLLLLLLLLLLLLLLNNNNNNLLLLLLLLLLLLLLLLLLLLLLLLLLNNNNbbbbbbsbbbbbbbbbbbbbbbbbbbbbbbbbb,N%%%%NNNNLNNNNN%%11NLNNN1LNNNNNLLLLLLLLLLLLLLLLLLLLLLLNLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLN",e="nnnnnnNNr%%r,rNNmmmmmmmmmmmrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrmmmmmmmmmmmmmmmmmmmmmnnnnnnnnnn%nnrrrmrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrmmmmmmmnNmmmmmmrrmmNmmmmrr1111111111",n=/[\u0590-\u05f4\u0600-\u06ff\u0700-\u08ac]/,r=/[stwN]/,i=/[LRr]/,o=/[Lb1n]/,a=/[1n]/;function s(t,e,n){this.level=t,this.from=e,this.to=n}return function(l,c){var u="ltr"==c?"L":"R";if(0==l.length||"ltr"==c&&!n.test(l))return!1;for(var h,d=l.length,f=[],p=0;p-1&&(r[e]=i.slice(0,o).concat(i.slice(o+1)))}}}function gt(t,e){var n=ft(t,e);if(n.length)for(var r=Array.prototype.slice.call(arguments,2),i=0;i0}function bt(t){t.prototype.on=function(t,e){dt(this,t,e)},t.prototype.off=function(t,e){pt(this,t,e)}}function wt(t){t.preventDefault?t.preventDefault():t.returnValue=!1}function xt(t){t.stopPropagation?t.stopPropagation():t.cancelBubble=!0}function Ct(t){return null!=t.defaultPrevented?t.defaultPrevented:0==t.returnValue}function Ot(t){wt(t),xt(t)}function St(t){return t.target||t.srcElement}function kt(t){var e=t.which;return null==e&&(1&t.button?e=1:2&t.button?e=3:4&t.button&&(e=2)),y&&t.ctrlKey&&1==e&&(e=3),e}var Tt,Pt,jt=function(){if(a&&s<9)return!1;var t=E("div");return"draggable"in t||"dragDrop"in t}();function Et(t){if(null==Tt){var e=E("span","​");j(t,E("span",[e,document.createTextNode("x")])),0!=t.firstChild.offsetHeight&&(Tt=e.offsetWidth<=1&&e.offsetHeight>2&&!(a&&s<8))}var n=Tt?E("span","​"):E("span"," ",null,"display: inline-block; width: 1px; margin-right: -1px");return n.setAttribute("cm-text",""),n}function Mt(t){if(null!=Pt)return Pt;var e=j(t,document.createTextNode("AخA")),n=k(e,0,1).getBoundingClientRect(),r=k(e,1,2).getBoundingClientRect();return P(t),!(!n||n.left==n.right)&&(Pt=r.right-n.right<3)}var Dt,At=3!="\n\nb".split(/\n/).length?function(t){for(var e=0,n=[],r=t.length;e<=r;){var i=t.indexOf("\n",e);-1==i&&(i=t.length);var o=t.slice(e,"\r"==t.charAt(i-1)?i-1:i),a=o.indexOf("\r");-1!=a?(n.push(o.slice(0,a)),e+=a+1):(n.push(o),e=i+1)}return n}:function(t){return t.split(/\r\n?|\n/)},Lt=window.getSelection?function(t){try{return t.selectionStart!=t.selectionEnd}catch(t){return!1}}:function(t){var e;try{e=t.ownerDocument.selection.createRange()}catch(t){}return!(!e||e.parentElement()!=t)&&0!=e.compareEndPoints("StartToEnd",e)},Nt="oncopy"in(Dt=E("div"))||(Dt.setAttribute("oncopy","return;"),"function"==typeof Dt.oncopy),It=null,Ft={},Rt={};function _t(t,e){arguments.length>2&&(e.dependencies=Array.prototype.slice.call(arguments,2)),Ft[t]=e}function Vt(t){if("string"==typeof t&&Rt.hasOwnProperty(t))t=Rt[t];else if(t&&"string"==typeof t.name&&Rt.hasOwnProperty(t.name)){var e=Rt[t.name];"string"==typeof e&&(e={name:e}),(t=Z(e,t)).name=e.name}else{if("string"==typeof t&&/^[\w\-]+\/[\w\-]+\+xml$/.test(t))return Vt("application/xml");if("string"==typeof t&&/^[\w\-]+\/[\w\-]+\+json$/.test(t))return Vt("application/json")}return"string"==typeof t?{name:t}:t||{name:"null"}}function zt(t,e){e=Vt(e);var n=Ft[e.name];if(!n)return zt(t,"text/plain");var r=n(t,e);if(Ht.hasOwnProperty(e.name)){var i=Ht[e.name];for(var o in i)i.hasOwnProperty(o)&&(r.hasOwnProperty(o)&&(r["_"+o]=r[o]),r[o]=i[o])}if(r.name=e.name,e.helperType&&(r.helperType=e.helperType),e.modeProps)for(var a in e.modeProps)r[a]=e.modeProps[a];return r}var Ht={};function $t(t,e){R(e,Ht.hasOwnProperty(t)?Ht[t]:Ht[t]={})}function Wt(t,e){if(!0===e)return e;if(t.copyState)return t.copyState(e);var n={};for(var r in e){var i=e[r];i instanceof Array&&(i=i.concat([])),n[r]=i}return n}function Bt(t,e){for(var n;t.innerMode&&(n=t.innerMode(e))&&n.mode!=t;)e=n.state,t=n.mode;return n||{mode:t,state:e}}function Ut(t,e,n){return!t.startState||t.startState(e,n)}var qt=function(t,e,n){this.pos=this.start=0,this.string=t,this.tabSize=e||8,this.lastColumnPos=this.lastColumnValue=0,this.lineStart=0,this.lineOracle=n};function Gt(t,e){if((e-=t.first)<0||e>=t.size)throw new Error("There is no line "+(e+t.first)+" in the document.");for(var n=t;!n.lines;)for(var r=0;;++r){var i=n.children[r],o=i.chunkSize();if(e=t.first&&en?ee(n,Gt(t,n).text.length):function(t,e){var n=t.ch;return null==n||n>e?ee(t.line,e):n<0?ee(t.line,0):t}(e,Gt(t,e.line).text.length)}function ce(t,e){for(var n=[],r=0;r=this.string.length},qt.prototype.sol=function(){return this.pos==this.lineStart},qt.prototype.peek=function(){return this.string.charAt(this.pos)||void 0},qt.prototype.next=function(){if(this.pose},qt.prototype.eatSpace=function(){for(var t=this.pos;/[\s\u00a0]/.test(this.string.charAt(this.pos));)++this.pos;return this.pos>t},qt.prototype.skipToEnd=function(){this.pos=this.string.length},qt.prototype.skipTo=function(t){var e=this.string.indexOf(t,this.pos);if(e>-1)return this.pos=e,!0},qt.prototype.backUp=function(t){this.pos-=t},qt.prototype.column=function(){return this.lastColumnPos0?null:(r&&!1!==e&&(this.pos+=r[0].length),r)}var i=function(t){return n?t.toLowerCase():t};if(i(this.string.substr(this.pos,t.length))==i(t))return!1!==e&&(this.pos+=t.length),!0},qt.prototype.current=function(){return this.string.slice(this.start,this.pos)},qt.prototype.hideFirstChars=function(t,e){this.lineStart+=t;try{return e()}finally{this.lineStart-=t}},qt.prototype.lookAhead=function(t){var e=this.lineOracle;return e&&e.lookAhead(t)},qt.prototype.baseToken=function(){var t=this.lineOracle;return t&&t.baseToken(this.pos)};var ue=function(t,e){this.state=t,this.lookAhead=e},he=function(t,e,n,r){this.state=e,this.doc=t,this.line=n,this.maxLookAhead=r||0,this.baseTokens=null,this.baseTokenPos=1};function de(t,e,n,r){var i=[t.state.modeGen],o={};xe(t,e.text,t.doc.mode,n,(function(t,e){return i.push(t,e)}),o,r);for(var a=n.state,s=function(r){n.baseTokens=i;var s=t.state.overlays[r],l=1,c=0;n.state=!0,xe(t,e.text,s.mode,n,(function(t,e){for(var n=l;ct&&i.splice(l,1,t,i[l+1],r),l+=2,c=Math.min(t,r)}if(e)if(s.opaque)i.splice(n,l-n,t,"overlay "+e),l=n+2;else for(;nt.options.maxHighlightLength&&Wt(t.doc.mode,r.state),o=de(t,e,r);i&&(r.state=i),e.stateAfter=r.save(!i),e.styles=o.styles,o.classes?e.styleClasses=o.classes:e.styleClasses&&(e.styleClasses=null),n===t.doc.highlightFrontier&&(t.doc.modeFrontier=Math.max(t.doc.modeFrontier,++t.doc.highlightFrontier))}return e.styles}function pe(t,e,n){var r=t.doc,i=t.display;if(!r.mode.startState)return new he(r,!0,e);var o=function(t,e,n){for(var r,i,o=t.doc,a=n?-1:e-(t.doc.mode.innerMode?1e3:100),s=e;s>a;--s){if(s<=o.first)return o.first;var l=Gt(o,s-1),c=l.stateAfter;if(c&&(!n||s+(c instanceof ue?c.lookAhead:0)<=o.modeFrontier))return s;var u=_(l.text,null,t.options.tabSize);(null==i||r>u)&&(i=s-1,r=u)}return i}(t,e,n),a=o>r.first&&Gt(r,o-1).stateAfter,s=a?he.fromSaved(r,a,o):new he(r,Ut(r.mode),o);return r.iter(o,e,(function(n){ge(t,n.text,s);var r=s.line;n.stateAfter=r==e-1||r%5==0||r>=i.viewFrom&&re.start)return o}throw new Error("Mode "+t.name+" failed to advance stream.")}he.prototype.lookAhead=function(t){var e=this.doc.getLine(this.line+t);return null!=e&&t>this.maxLookAhead&&(this.maxLookAhead=t),e},he.prototype.baseToken=function(t){if(!this.baseTokens)return null;for(;this.baseTokens[this.baseTokenPos]<=t;)this.baseTokenPos+=2;var e=this.baseTokens[this.baseTokenPos+1];return{type:e&&e.replace(/( |^)overlay .*/,""),size:this.baseTokens[this.baseTokenPos]-t}},he.prototype.nextLine=function(){this.line++,this.maxLookAhead>0&&this.maxLookAhead--},he.fromSaved=function(t,e,n){return e instanceof ue?new he(t,Wt(t.mode,e.state),n,e.lookAhead):new he(t,Wt(t.mode,e),n)},he.prototype.save=function(t){var e=!1!==t?Wt(this.doc.mode,this.state):this.state;return this.maxLookAhead>0?new ue(e,this.maxLookAhead):e};var ye=function(t,e,n){this.start=t.start,this.end=t.pos,this.string=t.current(),this.type=e||null,this.state=n};function be(t,e,n,r){var i,o,a=t.doc,s=a.mode,l=Gt(a,(e=le(a,e)).line),c=pe(t,e.line,n),u=new qt(l.text,t.options.tabSize,c);for(r&&(o=[]);(r||u.post.options.maxHighlightLength?(s=!1,a&&ge(t,e,r,h.pos),h.pos=e.length,l=null):l=we(me(n,h,r.state,d),o),d){var f=d[0].name;f&&(l="m-"+(l?f+" "+l:f))}if(!s||u!=l){for(;c=e:o.to>e);(r||(r=[])).push(new Se(a,o.from,s?null:o.to))}}return r}(n,i,a),l=function(t,e,n){var r;if(t)for(var i=0;i=e:o.to>e)||o.from==e&&"bookmark"==a.type&&(!n||o.marker.insertLeft)){var s=null==o.from||(a.inclusiveLeft?o.from<=e:o.from0&&s)for(var b=0;be)&&(!n||Le(n,o.marker)<0)&&(n=o.marker)}return n}function _e(t,e,n,r,i){var o=Gt(t,e),a=Oe&&o.markedSpans;if(a)for(var s=0;s=0&&h<=0||u<=0&&h>=0)&&(u<=0&&(l.marker.inclusiveRight&&i.inclusiveLeft?ne(c.to,n)>=0:ne(c.to,n)>0)||u>=0&&(l.marker.inclusiveRight&&i.inclusiveLeft?ne(c.from,r)<=0:ne(c.from,r)<0)))return!0}}}function Ve(t){for(var e;e=Ie(t);)t=e.find(-1,!0).line;return t}function ze(t,e){var n=Gt(t,e),r=Ve(n);return n==r?e:Jt(r)}function He(t,e){if(e>t.lastLine())return e;var n,r=Gt(t,e);if(!$e(t,r))return e;for(;n=Fe(r);)r=n.find(1,!0).line;return Jt(r)+1}function $e(t,e){var n=Oe&&e.markedSpans;if(n)for(var r=void 0,i=0;ie.maxLineLength&&(e.maxLineLength=n,e.maxLine=t)}))}var Ge=function(t,e,n){this.text=t,Me(this,e),this.height=n?n(this):1};function Ke(t){t.parent=null,Ee(t)}Ge.prototype.lineNo=function(){return Jt(this)},bt(Ge);var Ye={},Xe={};function Je(t,e){if(!t||/^\s*$/.test(t))return null;var n=e.addModeClass?Xe:Ye;return n[t]||(n[t]=t.replace(/\S+/g,"cm-$&"))}function Ze(t,e){var n=M("span",null,null,l?"padding-right: .1px":null),r={pre:M("pre",[n],"CodeMirror-line"),content:n,col:0,pos:0,cm:t,trailingSpace:!1,splitSpaces:t.getOption("lineWrapping")};e.measure={};for(var i=0;i<=(e.rest?e.rest.length:0);i++){var o=i?e.rest[i-1]:e.line,a=void 0;r.pos=0,r.addToken=tn,Mt(t.display.measure)&&(a=ut(o,t.doc.direction))&&(r.addToken=en(r.addToken,a)),r.map=[],rn(o,r,fe(t,o,e!=t.display.externalMeasured&&Jt(o))),o.styleClasses&&(o.styleClasses.bgClass&&(r.bgClass=N(o.styleClasses.bgClass,r.bgClass||"")),o.styleClasses.textClass&&(r.textClass=N(o.styleClasses.textClass,r.textClass||""))),0==r.map.length&&r.map.push(0,0,r.content.appendChild(Et(t.display.measure))),0==i?(e.measure.map=r.map,e.measure.cache={}):((e.measure.maps||(e.measure.maps=[])).push(r.map),(e.measure.caches||(e.measure.caches=[])).push({}))}if(l){var s=r.content.lastChild;(/\bcm-tab\b/.test(s.className)||s.querySelector&&s.querySelector(".cm-tab"))&&(r.content.className="cm-tab-wrap-hack")}return gt(t,"renderLine",t,e.line,r.pre),r.pre.className&&(r.textClass=N(r.pre.className,r.textClass||"")),r}function Qe(t){var e=E("span","•","cm-invalidchar");return e.title="\\u"+t.charCodeAt(0).toString(16),e.setAttribute("aria-label",e.title),e}function tn(t,e,n,r,i,o,l){if(e){var c,u=t.splitSpaces?function(t,e){if(t.length>1&&!/ /.test(t))return t;for(var n=e,r="",i=0;ic&&h.from<=c);d++);if(h.to>=u)return t(n,r,i,o,a,s,l);t(n,r.slice(0,h.to-c),i,o,null,s,l),o=null,r=r.slice(h.to-c),c=h.to}}}function nn(t,e,n,r){var i=!r&&n.widgetNode;i&&t.map.push(t.pos,t.pos+e,i),!r&&t.cm.display.input.needsContentAttribute&&(i||(i=t.content.appendChild(document.createElement("span"))),i.setAttribute("cm-marker",n.id)),i&&(t.cm.display.input.setUneditable(i),t.content.appendChild(i)),t.pos+=e,t.trailingSpace=!1}function rn(t,e,n){var r=t.markedSpans,i=t.text,o=0;if(r)for(var a,s,l,c,u,h,d,f=i.length,p=0,g=1,v="",m=0;;){if(m==p){l=c=u=s="",d=null,h=null,m=1/0;for(var y=[],b=void 0,w=0;wp||C.collapsed&&x.to==p&&x.from==p)){if(null!=x.to&&x.to!=p&&m>x.to&&(m=x.to,c=""),C.className&&(l+=" "+C.className),C.css&&(s=(s?s+";":"")+C.css),C.startStyle&&x.from==p&&(u+=" "+C.startStyle),C.endStyle&&x.to==m&&(b||(b=[])).push(C.endStyle,x.to),C.title&&((d||(d={})).title=C.title),C.attributes)for(var O in C.attributes)(d||(d={}))[O]=C.attributes[O];C.collapsed&&(!h||Le(h.marker,C)<0)&&(h=x)}else x.from>p&&m>x.from&&(m=x.from)}if(b)for(var S=0;S=f)break;for(var T=Math.min(f,m);;){if(v){var P=p+v.length;if(!h){var j=P>T?v.slice(0,T-p):v;e.addToken(e,j,a?a+l:l,u,p+j.length==m?c:"",s,d)}if(P>=T){v=v.slice(T-p),p=T;break}p=P,u=""}v=i.slice(o,o=n[g++]),a=Je(n[g++],e.cm.options)}}else for(var E=1;En)return{map:t.measure.maps[i],cache:t.measure.caches[i],before:!0}}function Dn(t,e,n,r){return Nn(t,Ln(t,e),n,r)}function An(t,e){if(e>=t.display.viewFrom&&e=n.lineN&&e2&&o.push((l.bottom+c.top)/2-n.top)}}o.push(n.bottom-n.top)}}(t,e.view,e.rect),e.hasHeights=!0),(o=function(t,e,n,r){var i,o=Rn(e.map,n,r),l=o.node,c=o.start,u=o.end,h=o.collapse;if(3==l.nodeType){for(var d=0;d<4;d++){for(;c&&it(e.line.text.charAt(o.coverStart+c));)--c;for(;o.coverStart+u1}(t))return e;var n=screen.logicalXDPI/screen.deviceXDPI,r=screen.logicalYDPI/screen.deviceYDPI;return{left:e.left*n,right:e.right*n,top:e.top*r,bottom:e.bottom*r}}(t.display.measure,i))}else{var f;c>0&&(h=r="right"),i=t.options.lineWrapping&&(f=l.getClientRects()).length>1?f["right"==r?f.length-1:0]:l.getBoundingClientRect()}if(a&&s<9&&!c&&(!i||!i.left&&!i.right)){var p=l.parentNode.getClientRects()[0];i=p?{left:p.left,right:p.left+or(t.display),top:p.top,bottom:p.bottom}:Fn}for(var g=i.top-e.rect.top,v=i.bottom-e.rect.top,m=(g+v)/2,y=e.view.measure.heights,b=0;be)&&(i=(o=l-s)-1,e>=l&&(a="right")),null!=i){if(r=t[c+2],s==l&&n==(r.insertLeft?"left":"right")&&(a=n),"left"==n&&0==i)for(;c&&t[c-2]==t[c-3]&&t[c-1].insertLeft;)r=t[2+(c-=3)],a="left";if("right"==n&&i==l-s)for(;c=0&&(n=t[i]).left==n.right;i--);return n}function Vn(t){if(t.measure&&(t.measure.cache={},t.measure.heights=null,t.rest))for(var e=0;e=r.text.length?(l=r.text.length,c="before"):l<=0&&(l=0,c="after"),!s)return a("before"==c?l-1:l,"before"==c);function u(t,e,n){return a(n?t-1:t,1==s[e].level!=n)}var h=lt(s,l,c),d=st,f=u(l,h,"before"==c);return null!=d&&(f.other=u(l,d,"before"!=c)),f}function Yn(t,e){var n=0;e=le(t.doc,e),t.options.lineWrapping||(n=or(t.display)*e.ch);var r=Gt(t.doc,e.line),i=Be(r)+Sn(t.display);return{left:n,right:n,top:i,bottom:i+r.height}}function Xn(t,e,n,r,i){var o=ee(t,e,n);return o.xRel=i,r&&(o.outside=r),o}function Jn(t,e,n){var r=t.doc;if((n+=t.display.viewOffset)<0)return Xn(r.first,0,null,-1,-1);var i=Zt(r,n),o=r.first+r.size-1;if(i>o)return Xn(r.first+r.size-1,Gt(r,o).text.length,null,1,1);e<0&&(e=0);for(var a=Gt(r,i);;){var s=er(t,a,i,e,n),l=Re(a,s.ch+(s.xRel>0||s.outside>0?1:0));if(!l)return s;var c=l.find(1);if(c.line==i)return c;a=Gt(r,i=c.line)}}function Zn(t,e,n,r){r-=Bn(e);var i=e.text.length,o=at((function(e){return Nn(t,n,e-1).bottom<=r}),i,0);return{begin:o,end:i=at((function(e){return Nn(t,n,e).top>r}),o,i)}}function Qn(t,e,n,r){return n||(n=Ln(t,e)),Zn(t,e,n,Un(t,e,Nn(t,n,r),"line").top)}function tr(t,e,n,r){return!(t.bottom<=n)&&(t.top>n||(r?t.left:t.right)>e)}function er(t,e,n,r,i){i-=Be(e);var o=Ln(t,e),a=Bn(e),s=0,l=e.text.length,c=!0,u=ut(e,t.doc.direction);if(u){var h=(t.options.lineWrapping?rr:nr)(t,e,n,o,u,r,i);s=(c=1!=h.level)?h.from:h.to-1,l=c?h.to:h.from-1}var d,f,p=null,g=null,v=at((function(e){var n=Nn(t,o,e);return n.top+=a,n.bottom+=a,!!tr(n,r,i,!1)&&(n.top<=i&&n.left<=r&&(p=e,g=n),!0)}),s,l),m=!1;if(g){var y=r-g.left=w.bottom?1:0}return Xn(n,v=ot(e.text,v,1),f,m,r-d)}function nr(t,e,n,r,i,o,a){var s=at((function(s){var l=i[s],c=1!=l.level;return tr(Kn(t,ee(n,c?l.to:l.from,c?"before":"after"),"line",e,r),o,a,!0)}),0,i.length-1),l=i[s];if(s>0){var c=1!=l.level,u=Kn(t,ee(n,c?l.from:l.to,c?"after":"before"),"line",e,r);tr(u,o,a,!0)&&u.top>a&&(l=i[s-1])}return l}function rr(t,e,n,r,i,o,a){var s=Zn(t,e,r,a),l=s.begin,c=s.end;/\s/.test(e.text.charAt(c-1))&&c--;for(var u=null,h=null,d=0;d=c||f.to<=l)){var p=Nn(t,r,1!=f.level?Math.min(c,f.to)-1:Math.max(l,f.from)).right,g=pg)&&(u=f,h=g)}}return u||(u=i[i.length-1]),u.fromc&&(u={from:u.from,to:c,level:u.level}),u}function ir(t){if(null!=t.cachedTextHeight)return t.cachedTextHeight;if(null==In){In=E("pre",null,"CodeMirror-line-like");for(var e=0;e<49;++e)In.appendChild(document.createTextNode("x")),In.appendChild(E("br"));In.appendChild(document.createTextNode("x"))}j(t.measure,In);var n=In.offsetHeight/50;return n>3&&(t.cachedTextHeight=n),P(t.measure),n||1}function or(t){if(null!=t.cachedCharWidth)return t.cachedCharWidth;var e=E("span","xxxxxxxxxx"),n=E("pre",[e],"CodeMirror-line-like");j(t.measure,n);var r=e.getBoundingClientRect(),i=(r.right-r.left)/10;return i>2&&(t.cachedCharWidth=i),i||10}function ar(t){for(var e=t.display,n={},r={},i=e.gutters.clientLeft,o=e.gutters.firstChild,a=0;o;o=o.nextSibling,++a){var s=t.display.gutterSpecs[a].className;n[s]=o.offsetLeft+o.clientLeft+i,r[s]=o.clientWidth}return{fixedPos:sr(e),gutterTotalWidth:e.gutters.offsetWidth,gutterLeft:n,gutterWidth:r,wrapperWidth:e.wrapper.clientWidth}}function sr(t){return t.scroller.getBoundingClientRect().left-t.sizer.getBoundingClientRect().left}function lr(t){var e=ir(t.display),n=t.options.lineWrapping,r=n&&Math.max(5,t.display.scroller.clientWidth/or(t.display)-3);return function(i){if($e(t.doc,i))return 0;var o=0;if(i.widgets)for(var a=0;a=t.display.viewTo)return null;if((e-=t.display.viewFrom)<0)return null;for(var n=t.display.view,r=0;re)&&(i.updateLineNumbers=e),t.curOp.viewChanged=!0,e>=i.viewTo)Oe&&ze(t.doc,e)i.viewFrom?pr(t):(i.viewFrom+=r,i.viewTo+=r);else if(e<=i.viewFrom&&n>=i.viewTo)pr(t);else if(e<=i.viewFrom){var o=gr(t,n,n+r,1);o?(i.view=i.view.slice(o.index),i.viewFrom=o.lineN,i.viewTo+=r):pr(t)}else if(n>=i.viewTo){var a=gr(t,e,e,-1);a?(i.view=i.view.slice(0,a.index),i.viewTo=a.lineN):pr(t)}else{var s=gr(t,e,e,-1),l=gr(t,n,n+r,1);s&&l?(i.view=i.view.slice(0,s.index).concat(an(t,s.lineN,l.lineN)).concat(i.view.slice(l.index)),i.viewTo+=r):pr(t)}var c=i.externalMeasured;c&&(n=i.lineN&&e=r.viewTo)){var o=r.view[hr(t,e)];if(null!=o.node){var a=o.changes||(o.changes=[]);-1==z(a,n)&&a.push(n)}}}function pr(t){t.display.viewFrom=t.display.viewTo=t.doc.first,t.display.view=[],t.display.viewOffset=0}function gr(t,e,n,r){var i,o=hr(t,e),a=t.display.view;if(!Oe||n==t.doc.first+t.doc.size)return{index:o,lineN:n};for(var s=t.display.viewFrom,l=0;l0){if(o==a.length-1)return null;i=s+a[o].size-e,o++}else i=s-e;e+=i,n+=i}for(;ze(t.doc,n)!=n;){if(o==(r<0?0:a.length-1))return null;n+=r*a[o-(r<0?1:0)].size,o+=r}return{index:o,lineN:n}}function vr(t){for(var e=t.display.view,n=0,r=0;r=t.display.viewTo||s.to().linee||e==n&&a.to==e)&&(r(Math.max(a.from,e),Math.min(a.to,n),1==a.level?"rtl":"ltr",o),i=!0)}i||r(e,n,"ltr")}(g,n||0,null==r?d:r,(function(t,e,i,h){var v="ltr"==i,m=f(t,v?"left":"right"),y=f(e-1,v?"right":"left"),b=null==n&&0==t,w=null==r&&e==d,x=0==h,C=!g||h==g.length-1;if(y.top-m.top<=3){var O=(c?w:b)&&C,S=(c?b:w)&&x?s:(v?m:y).left,k=O?l:(v?y:m).right;u(S,m.top,k-S,m.bottom)}else{var T,P,j,E;v?(T=c&&b&&x?s:m.left,P=c?l:p(t,i,"before"),j=c?s:p(e,i,"after"),E=c&&w&&C?l:y.right):(T=c?p(t,i,"before"):s,P=!c&&b&&x?l:m.right,j=!c&&w&&C?s:y.left,E=c?p(e,i,"after"):l),u(T,m.top,P-T,m.bottom),m.bottom0?e.blinker=setInterval((function(){return e.cursorDiv.style.visibility=(n=!n)?"":"hidden"}),t.options.cursorBlinkRate):t.options.cursorBlinkRate<0&&(e.cursorDiv.style.visibility="hidden")}}function Or(t){t.state.focused||(t.display.input.focus(),kr(t))}function Sr(t){t.state.delayingBlurEvent=!0,setTimeout((function(){t.state.delayingBlurEvent&&(t.state.delayingBlurEvent=!1,Tr(t))}),100)}function kr(t,e){t.state.delayingBlurEvent&&(t.state.delayingBlurEvent=!1),"nocursor"!=t.options.readOnly&&(t.state.focused||(gt(t,"focus",t,e),t.state.focused=!0,L(t.display.wrapper,"CodeMirror-focused"),t.curOp||t.display.selForContextMenu==t.doc.sel||(t.display.input.reset(),l&&setTimeout((function(){return t.display.input.reset(!0)}),20)),t.display.input.receivedFocus()),Cr(t))}function Tr(t,e){t.state.delayingBlurEvent||(t.state.focused&&(gt(t,"blur",t,e),t.state.focused=!1,T(t.display.wrapper,"CodeMirror-focused")),clearInterval(t.display.blinker),setTimeout((function(){t.state.focused||(t.display.shift=!1)}),150))}function Pr(t){for(var e=t.display,n=e.lineDiv.offsetTop,r=0;r.005||d<-.005)&&(Xt(i.line,l),jr(i.line),i.rest))for(var f=0;ft.display.sizerWidth){var p=Math.ceil(c/or(t.display));p>t.display.maxLineLength&&(t.display.maxLineLength=p,t.display.maxLine=i.line,t.display.maxLineChanged=!0)}}}}function jr(t){if(t.widgets)for(var e=0;e=a&&(o=Zt(e,Be(Gt(e,l))-t.wrapper.clientHeight),a=l)}return{from:o,to:Math.max(a,o+1)}}function Mr(t,e){var n=t.display,r=ir(t.display);e.top<0&&(e.top=0);var i=t.curOp&&null!=t.curOp.scrollTop?t.curOp.scrollTop:n.scroller.scrollTop,o=En(t),a={};e.bottom-e.top>o&&(e.bottom=e.top+o);var s=t.doc.height+kn(n),l=e.tops-r;if(e.topi+o){var u=Math.min(e.top,(c?s:e.bottom)-o);u!=i&&(a.scrollTop=u)}var h=t.curOp&&null!=t.curOp.scrollLeft?t.curOp.scrollLeft:n.scroller.scrollLeft,d=jn(t)-(t.options.fixedGutter?n.gutters.offsetWidth:0),f=e.right-e.left>d;return f&&(e.right=e.left+d),e.left<10?a.scrollLeft=0:e.leftd+h-3&&(a.scrollLeft=e.right+(f?0:10)-d),a}function Dr(t,e){null!=e&&(Nr(t),t.curOp.scrollTop=(null==t.curOp.scrollTop?t.doc.scrollTop:t.curOp.scrollTop)+e)}function Ar(t){Nr(t);var e=t.getCursor();t.curOp.scrollToPos={from:e,to:e,margin:t.options.cursorScrollMargin}}function Lr(t,e,n){null==e&&null==n||Nr(t),null!=e&&(t.curOp.scrollLeft=e),null!=n&&(t.curOp.scrollTop=n)}function Nr(t){var e=t.curOp.scrollToPos;e&&(t.curOp.scrollToPos=null,Ir(t,Yn(t,e.from),Yn(t,e.to),e.margin))}function Ir(t,e,n,r){var i=Mr(t,{left:Math.min(e.left,n.left),top:Math.min(e.top,n.top)-r,right:Math.max(e.right,n.right),bottom:Math.max(e.bottom,n.bottom)+r});Lr(t,i.scrollLeft,i.scrollTop)}function Fr(t,e){Math.abs(t.doc.scrollTop-e)<2||(n||li(t,{top:e}),Rr(t,e,!0),n&&li(t),ri(t,100))}function Rr(t,e,n){e=Math.min(t.display.scroller.scrollHeight-t.display.scroller.clientHeight,e),(t.display.scroller.scrollTop!=e||n)&&(t.doc.scrollTop=e,t.display.scrollbars.setScrollTop(e),t.display.scroller.scrollTop!=e&&(t.display.scroller.scrollTop=e))}function _r(t,e,n,r){e=Math.min(e,t.display.scroller.scrollWidth-t.display.scroller.clientWidth),(n?e==t.doc.scrollLeft:Math.abs(t.doc.scrollLeft-e)<2)&&!r||(t.doc.scrollLeft=e,hi(t),t.display.scroller.scrollLeft!=e&&(t.display.scroller.scrollLeft=e),t.display.scrollbars.setScrollLeft(e))}function Vr(t){var e=t.display,n=e.gutters.offsetWidth,r=Math.round(t.doc.height+kn(t.display));return{clientHeight:e.scroller.clientHeight,viewHeight:e.wrapper.clientHeight,scrollWidth:e.scroller.scrollWidth,clientWidth:e.scroller.clientWidth,viewWidth:e.wrapper.clientWidth,barLeft:t.options.fixedGutter?n:0,docHeight:r,scrollHeight:r+Pn(t)+e.barHeight,nativeBarWidth:e.nativeBarWidth,gutterWidth:n}}var zr=function(t,e,n){this.cm=n;var r=this.vert=E("div",[E("div",null,null,"min-width: 1px")],"CodeMirror-vscrollbar"),i=this.horiz=E("div",[E("div",null,null,"height: 100%; min-height: 1px")],"CodeMirror-hscrollbar");r.tabIndex=i.tabIndex=-1,t(r),t(i),dt(r,"scroll",(function(){r.clientHeight&&e(r.scrollTop,"vertical")})),dt(i,"scroll",(function(){i.clientWidth&&e(i.scrollLeft,"horizontal")})),this.checkedZeroWidth=!1,a&&s<8&&(this.horiz.style.minHeight=this.vert.style.minWidth="18px")};zr.prototype.update=function(t){var e=t.scrollWidth>t.clientWidth+1,n=t.scrollHeight>t.clientHeight+1,r=t.nativeBarWidth;if(n){this.vert.style.display="block",this.vert.style.bottom=e?r+"px":"0";var i=t.viewHeight-(e?r:0);this.vert.firstChild.style.height=Math.max(0,t.scrollHeight-t.clientHeight+i)+"px"}else this.vert.style.display="",this.vert.firstChild.style.height="0";if(e){this.horiz.style.display="block",this.horiz.style.right=n?r+"px":"0",this.horiz.style.left=t.barLeft+"px";var o=t.viewWidth-t.barLeft-(n?r:0);this.horiz.firstChild.style.width=Math.max(0,t.scrollWidth-t.clientWidth+o)+"px"}else this.horiz.style.display="",this.horiz.firstChild.style.width="0";return!this.checkedZeroWidth&&t.clientHeight>0&&(0==r&&this.zeroWidthHack(),this.checkedZeroWidth=!0),{right:n?r:0,bottom:e?r:0}},zr.prototype.setScrollLeft=function(t){this.horiz.scrollLeft!=t&&(this.horiz.scrollLeft=t),this.disableHoriz&&this.enableZeroWidthBar(this.horiz,this.disableHoriz,"horiz")},zr.prototype.setScrollTop=function(t){this.vert.scrollTop!=t&&(this.vert.scrollTop=t),this.disableVert&&this.enableZeroWidthBar(this.vert,this.disableVert,"vert")},zr.prototype.zeroWidthHack=function(){var t=y&&!f?"12px":"18px";this.horiz.style.height=this.vert.style.width=t,this.horiz.style.pointerEvents=this.vert.style.pointerEvents="none",this.disableHoriz=new V,this.disableVert=new V},zr.prototype.enableZeroWidthBar=function(t,e,n){t.style.pointerEvents="auto",e.set(1e3,(function r(){var i=t.getBoundingClientRect();("vert"==n?document.elementFromPoint(i.right-1,(i.top+i.bottom)/2):document.elementFromPoint((i.right+i.left)/2,i.bottom-1))!=t?t.style.pointerEvents="none":e.set(1e3,r)}))},zr.prototype.clear=function(){var t=this.horiz.parentNode;t.removeChild(this.horiz),t.removeChild(this.vert)};var Hr=function(){};function $r(t,e){e||(e=Vr(t));var n=t.display.barWidth,r=t.display.barHeight;Wr(t,e);for(var i=0;i<4&&n!=t.display.barWidth||r!=t.display.barHeight;i++)n!=t.display.barWidth&&t.options.lineWrapping&&Pr(t),Wr(t,Vr(t)),n=t.display.barWidth,r=t.display.barHeight}function Wr(t,e){var n=t.display,r=n.scrollbars.update(e);n.sizer.style.paddingRight=(n.barWidth=r.right)+"px",n.sizer.style.paddingBottom=(n.barHeight=r.bottom)+"px",n.heightForcer.style.borderBottom=r.bottom+"px solid transparent",r.right&&r.bottom?(n.scrollbarFiller.style.display="block",n.scrollbarFiller.style.height=r.bottom+"px",n.scrollbarFiller.style.width=r.right+"px"):n.scrollbarFiller.style.display="",r.bottom&&t.options.coverGutterNextToScrollbar&&t.options.fixedGutter?(n.gutterFiller.style.display="block",n.gutterFiller.style.height=r.bottom+"px",n.gutterFiller.style.width=e.gutterWidth+"px"):n.gutterFiller.style.display=""}Hr.prototype.update=function(){return{bottom:0,right:0}},Hr.prototype.setScrollLeft=function(){},Hr.prototype.setScrollTop=function(){},Hr.prototype.clear=function(){};var Br={native:zr,null:Hr};function Ur(t){t.display.scrollbars&&(t.display.scrollbars.clear(),t.display.scrollbars.addClass&&T(t.display.wrapper,t.display.scrollbars.addClass)),t.display.scrollbars=new Br[t.options.scrollbarStyle]((function(e){t.display.wrapper.insertBefore(e,t.display.scrollbarFiller),dt(e,"mousedown",(function(){t.state.focused&&setTimeout((function(){return t.display.input.focus()}),0)})),e.setAttribute("cm-not-content","true")}),(function(e,n){"horizontal"==n?_r(t,e):Fr(t,e)}),t),t.display.scrollbars.addClass&&L(t.display.wrapper,t.display.scrollbars.addClass)}var qr=0;function Gr(t){var e;t.curOp={cm:t,viewChanged:!1,startHeight:t.doc.height,forceUpdate:!1,updateInput:0,typing:!1,changeObjs:null,cursorActivityHandlers:null,cursorActivityCalled:0,selectionChanged:!1,updateMaxLine:!1,scrollLeft:null,scrollTop:null,scrollToPos:null,focus:!1,id:++qr},e=t.curOp,sn?sn.ops.push(e):e.ownsGroup=sn={ops:[e],delayedCallbacks:[]}}function Kr(t){var e=t.curOp;e&&function(t,e){var n=t.ownsGroup;if(n)try{!function(t){var e=t.delayedCallbacks,n=0;do{for(;n=n.viewTo)||n.maxLineChanged&&e.options.lineWrapping,t.update=t.mustUpdate&&new oi(e,t.mustUpdate&&{top:t.scrollTop,ensure:t.scrollToPos},t.forceUpdate)}function Xr(t){var e=t.cm,n=e.display;t.updatedDisplay&&Pr(e),t.barMeasure=Vr(e),n.maxLineChanged&&!e.options.lineWrapping&&(t.adjustWidthTo=Dn(e,n.maxLine,n.maxLine.text.length).left+3,e.display.sizerWidth=t.adjustWidthTo,t.barMeasure.scrollWidth=Math.max(n.scroller.clientWidth,n.sizer.offsetLeft+t.adjustWidthTo+Pn(e)+e.display.barWidth),t.maxScrollLeft=Math.max(0,n.sizer.offsetLeft+t.adjustWidthTo-jn(e))),(t.updatedDisplay||t.selectionChanged)&&(t.preparedSelection=n.input.prepareSelection())}function Jr(t){var e=t.cm;null!=t.adjustWidthTo&&(e.display.sizer.style.minWidth=t.adjustWidthTo+"px",t.maxScrollLeft(window.innerHeight||document.documentElement.clientHeight)&&(i=!1),null!=i&&!p){var o=E("div","​",null,"position: absolute;\n top: "+(e.top-n.viewOffset-Sn(t.display))+"px;\n height: "+(e.bottom-e.top+Pn(t)+n.barHeight)+"px;\n left: "+e.left+"px; width: "+Math.max(2,e.right-e.left)+"px;");t.display.lineSpace.appendChild(o),o.scrollIntoView(i),t.display.lineSpace.removeChild(o)}}}(e,function(t,e,n,r){var i;null==r&&(r=0),t.options.lineWrapping||e!=n||(n="before"==(e=e.ch?ee(e.line,"before"==e.sticky?e.ch-1:e.ch,"after"):e).sticky?ee(e.line,e.ch+1,"before"):e);for(var o=0;o<5;o++){var a=!1,s=Kn(t,e),l=n&&n!=e?Kn(t,n):s,c=Mr(t,i={left:Math.min(s.left,l.left),top:Math.min(s.top,l.top)-r,right:Math.max(s.left,l.left),bottom:Math.max(s.bottom,l.bottom)+r}),u=t.doc.scrollTop,h=t.doc.scrollLeft;if(null!=c.scrollTop&&(Fr(t,c.scrollTop),Math.abs(t.doc.scrollTop-u)>1&&(a=!0)),null!=c.scrollLeft&&(_r(t,c.scrollLeft),Math.abs(t.doc.scrollLeft-h)>1&&(a=!0)),!a)break}return i}(e,le(r,t.scrollToPos.from),le(r,t.scrollToPos.to),t.scrollToPos.margin));var i=t.maybeHiddenMarkers,o=t.maybeUnhiddenMarkers;if(i)for(var a=0;a=t.display.viewTo)){var n=+new Date+t.options.workTime,r=pe(t,e.highlightFrontier),i=[];e.iter(r.line,Math.min(e.first+e.size,t.display.viewTo+500),(function(o){if(r.line>=t.display.viewFrom){var a=o.styles,s=o.text.length>t.options.maxHighlightLength?Wt(e.mode,r.state):null,l=de(t,o,r,!0);s&&(r.state=s),o.styles=l.styles;var c=o.styleClasses,u=l.classes;u?o.styleClasses=u:c&&(o.styleClasses=null);for(var h=!a||a.length!=o.styles.length||c!=u&&(!c||!u||c.bgClass!=u.bgClass||c.textClass!=u.textClass),d=0;!h&&dn)return ri(t,t.options.workDelay),!0})),e.highlightFrontier=r.line,e.modeFrontier=Math.max(e.modeFrontier,r.line),i.length&&Qr(t,(function(){for(var e=0;e=n.viewFrom&&e.visible.to<=n.viewTo&&(null==n.updateLineNumbers||n.updateLineNumbers>=n.viewTo)&&n.renderedView==n.view&&0==vr(t))return!1;di(t)&&(pr(t),e.dims=ar(t));var i=r.first+r.size,o=Math.max(e.visible.from-t.options.viewportMargin,r.first),a=Math.min(i,e.visible.to+t.options.viewportMargin);n.viewFroma&&n.viewTo-a<20&&(a=Math.min(i,n.viewTo)),Oe&&(o=ze(t.doc,o),a=He(t.doc,a));var s=o!=n.viewFrom||a!=n.viewTo||n.lastWrapHeight!=e.wrapperHeight||n.lastWrapWidth!=e.wrapperWidth;!function(t,e,n){var r=t.display;0==r.view.length||e>=r.viewTo||n<=r.viewFrom?(r.view=an(t,e,n),r.viewFrom=e):(r.viewFrom>e?r.view=an(t,e,r.viewFrom).concat(r.view):r.viewFromn&&(r.view=r.view.slice(0,hr(t,n)))),r.viewTo=n}(t,o,a),n.viewOffset=Be(Gt(t.doc,n.viewFrom)),t.display.mover.style.top=n.viewOffset+"px";var c=vr(t);if(!s&&0==c&&!e.force&&n.renderedView==n.view&&(null==n.updateLineNumbers||n.updateLineNumbers>=n.viewTo))return!1;var u=function(t){if(t.hasFocus())return null;var e=A();if(!e||!D(t.display.lineDiv,e))return null;var n={activeElt:e};if(window.getSelection){var r=window.getSelection();r.anchorNode&&r.extend&&D(t.display.lineDiv,r.anchorNode)&&(n.anchorNode=r.anchorNode,n.anchorOffset=r.anchorOffset,n.focusNode=r.focusNode,n.focusOffset=r.focusOffset)}return n}(t);return c>4&&(n.lineDiv.style.display="none"),function(t,e,n){var r=t.display,i=t.options.lineNumbers,o=r.lineDiv,a=o.firstChild;function s(e){var n=e.nextSibling;return l&&y&&t.display.currentWheelTarget==e?e.style.display="none":e.parentNode.removeChild(e),n}for(var c=r.view,u=r.viewFrom,h=0;h-1&&(f=!1),hn(t,d,u,n)),f&&(P(d.lineNumber),d.lineNumber.appendChild(document.createTextNode(te(t.options,u)))),a=d.node.nextSibling}else{var p=yn(t,d,u,n);o.insertBefore(p,a)}u+=d.size}for(;a;)a=s(a)}(t,n.updateLineNumbers,e.dims),c>4&&(n.lineDiv.style.display=""),n.renderedView=n.view,function(t){if(t&&t.activeElt&&t.activeElt!=A()&&(t.activeElt.focus(),t.anchorNode&&D(document.body,t.anchorNode)&&D(document.body,t.focusNode))){var e=window.getSelection(),n=document.createRange();n.setEnd(t.anchorNode,t.anchorOffset),n.collapse(!1),e.removeAllRanges(),e.addRange(n),e.extend(t.focusNode,t.focusOffset)}}(u),P(n.cursorDiv),P(n.selectionDiv),n.gutters.style.height=n.sizer.style.minHeight=0,s&&(n.lastWrapHeight=e.wrapperHeight,n.lastWrapWidth=e.wrapperWidth,ri(t,400)),n.updateLineNumbers=null,!0}function si(t,e){for(var n=e.viewport,r=!0;(r&&t.options.lineWrapping&&e.oldDisplayWidth!=jn(t)||(n&&null!=n.top&&(n={top:Math.min(t.doc.height+kn(t.display)-En(t),n.top)}),e.visible=Er(t.display,t.doc,n),!(e.visible.from>=t.display.viewFrom&&e.visible.to<=t.display.viewTo)))&&ai(t,e);r=!1){Pr(t);var i=Vr(t);mr(t),$r(t,i),ui(t,i),e.force=!1}e.signal(t,"update",t),t.display.viewFrom==t.display.reportedViewFrom&&t.display.viewTo==t.display.reportedViewTo||(e.signal(t,"viewportChange",t,t.display.viewFrom,t.display.viewTo),t.display.reportedViewFrom=t.display.viewFrom,t.display.reportedViewTo=t.display.viewTo)}function li(t,e){var n=new oi(t,e);if(ai(t,n)){Pr(t),si(t,n);var r=Vr(t);mr(t),$r(t,r),ui(t,r),n.finish()}}function ci(t){var e=t.gutters.offsetWidth;t.sizer.style.marginLeft=e+"px"}function ui(t,e){t.display.sizer.style.minHeight=e.docHeight+"px",t.display.heightForcer.style.top=e.docHeight+"px",t.display.gutters.style.height=e.docHeight+t.display.barHeight+Pn(t)+"px"}function hi(t){var e=t.display,n=e.view;if(e.alignWidgets||e.gutters.firstChild&&t.options.fixedGutter){for(var r=sr(e)-e.scroller.scrollLeft+t.doc.scrollLeft,i=e.gutters.offsetWidth,o=r+"px",a=0;as.clientWidth,u=s.scrollHeight>s.clientHeight;if(i&&c||o&&u){if(o&&y&&l)t:for(var d=e.target,f=a.view;d!=s;d=d.parentNode)for(var p=0;p=0&&ne(t,r.to())<=0)return n}return-1};var Oi=function(t,e){this.anchor=t,this.head=e};function Si(t,e,n){var r=t&&t.options.selectionsMayTouch,i=e[n];e.sort((function(t,e){return ne(t.from(),e.from())})),n=z(e,i);for(var o=1;o0:l>=0){var c=ae(s.from(),a.from()),u=oe(s.to(),a.to()),h=s.empty()?a.from()==a.head:s.from()==s.head;o<=n&&--n,e.splice(--o,2,new Oi(h?u:c,h?c:u))}}return new Ci(e,n)}function ki(t,e){return new Ci([new Oi(t,e||t)],0)}function Ti(t){return t.text?ee(t.from.line+t.text.length-1,Y(t.text).length+(1==t.text.length?t.from.ch:0)):t.to}function Pi(t,e){if(ne(t,e.from)<0)return t;if(ne(t,e.to)<=0)return Ti(e);var n=t.line+e.text.length-(e.to.line-e.from.line)-1,r=t.ch;return t.line==e.to.line&&(r+=Ti(e).ch-e.to.ch),ee(n,r)}function ji(t,e){for(var n=[],r=0;r1&&t.remove(s.line+1,p-1),t.insert(s.line+1,m)}cn(t,"change",t,e)}function Ni(t,e,n){!function t(r,i,o){if(r.linked)for(var a=0;as-(t.cm?t.cm.options.historyEventDelay:500)||"*"==e.origin.charAt(0)))&&(o=function(t,e){return e?(Vi(t.done),Y(t.done)):t.done.length&&!Y(t.done).ranges?Y(t.done):t.done.length>1&&!t.done[t.done.length-2].ranges?(t.done.pop(),Y(t.done)):void 0}(i,i.lastOp==r)))a=Y(o.changes),0==ne(e.from,e.to)&&0==ne(e.from,a.to)?a.to=Ti(e):o.changes.push(_i(t,e));else{var l=Y(i.done);for(l&&l.ranges||$i(t.sel,i.done),o={changes:[_i(t,e)],generation:i.generation},i.done.push(o);i.done.length>i.undoDepth;)i.done.shift(),i.done[0].ranges||i.done.shift()}i.done.push(n),i.generation=++i.maxGeneration,i.lastModTime=i.lastSelTime=s,i.lastOp=i.lastSelOp=r,i.lastOrigin=i.lastSelOrigin=e.origin,a||gt(t,"historyAdded")}function Hi(t,e,n,r){var i=t.history,o=r&&r.origin;n==i.lastSelOp||o&&i.lastSelOrigin==o&&(i.lastModTime==i.lastSelTime&&i.lastOrigin==o||function(t,e,n,r){var i=e.charAt(0);return"*"==i||"+"==i&&n.ranges.length==r.ranges.length&&n.somethingSelected()==r.somethingSelected()&&new Date-t.history.lastSelTime<=(t.cm?t.cm.options.historyEventDelay:500)}(t,o,Y(i.done),e))?i.done[i.done.length-1]=e:$i(e,i.done),i.lastSelTime=+new Date,i.lastSelOrigin=o,i.lastSelOp=n,r&&!1!==r.clearRedo&&Vi(i.undone)}function $i(t,e){var n=Y(e);n&&n.ranges&&n.equals(t)||e.push(t)}function Wi(t,e,n,r){var i=e["spans_"+t.id],o=0;t.iter(Math.max(t.first,n),Math.min(t.first+t.size,r),(function(n){n.markedSpans&&((i||(i=e["spans_"+t.id]={}))[o]=n.markedSpans),++o}))}function Bi(t){if(!t)return null;for(var e,n=0;n-1&&(Y(s)[h]=c[h],delete c[h])}}}return r}function Gi(t,e,n,r){if(r){var i=t.anchor;if(n){var o=ne(e,i)<0;o!=ne(n,i)<0?(i=e,e=n):o!=ne(e,n)<0&&(e=n)}return new Oi(i,e)}return new Oi(n||e,e)}function Ki(t,e,n,r,i){null==i&&(i=t.cm&&(t.cm.display.shift||t.extend)),Qi(t,new Ci([Gi(t.sel.primary(),e,n,i)],0),r)}function Yi(t,e,n){for(var r=[],i=t.cm&&(t.cm.display.shift||t.extend),o=0;o=e.ch:s.to>e.ch))){if(i&&(gt(l,"beforeCursorEnter"),l.explicitlyCleared)){if(o.markedSpans){--a;continue}break}if(!l.atomic)continue;if(n){var h=l.find(r<0?1:-1),d=void 0;if((r<0?u:c)&&(h=ao(t,h,-r,h&&h.line==e.line?o:null)),h&&h.line==e.line&&(d=ne(h,n))&&(r<0?d<0:d>0))return io(t,h,e,r,i)}var f=l.find(r<0?-1:1);return(r<0?c:u)&&(f=ao(t,f,r,f.line==e.line?o:null)),f?io(t,f,e,r,i):null}}return e}function oo(t,e,n,r,i){var o=r||1,a=io(t,e,n,o,i)||!i&&io(t,e,n,o,!0)||io(t,e,n,-o,i)||!i&&io(t,e,n,-o,!0);return a||(t.cantEdit=!0,ee(t.first,0))}function ao(t,e,n,r){return n<0&&0==e.ch?e.line>t.first?le(t,ee(e.line-1)):null:n>0&&e.ch==(r||Gt(t,e.line)).text.length?e.line0)){var u=[l,1],h=ne(c.from,s.from),d=ne(c.to,s.to);(h<0||!a.inclusiveLeft&&!h)&&u.push({from:c.from,to:s.from}),(d>0||!a.inclusiveRight&&!d)&&u.push({from:s.to,to:c.to}),i.splice.apply(i,u),l+=u.length-3}}return i}(t,e.from,e.to);if(r)for(var i=r.length-1;i>=0;--i)uo(t,{from:r[i].from,to:r[i].to,text:i?[""]:e.text,origin:e.origin});else uo(t,e)}}function uo(t,e){if(1!=e.text.length||""!=e.text[0]||0!=ne(e.from,e.to)){var n=ji(t,e);zi(t,e,n,t.cm?t.cm.curOp.id:NaN),po(t,e,n,Pe(t,e));var r=[];Ni(t,(function(t,n){n||-1!=z(r,t.history)||(yo(t.history,e),r.push(t.history)),po(t,e,null,Pe(t,e))}))}}function ho(t,e,n){var r=t.cm&&t.cm.state.suppressEdits;if(!r||n){for(var i,o=t.history,a=t.sel,s="undo"==e?o.done:o.undone,l="undo"==e?o.undone:o.done,c=0;c=0;--f){var p=d(f);if(p)return p.v}}}}function fo(t,e){if(0!=e&&(t.first+=e,t.sel=new Ci(X(t.sel.ranges,(function(t){return new Oi(ee(t.anchor.line+e,t.anchor.ch),ee(t.head.line+e,t.head.ch))})),t.sel.primIndex),t.cm)){dr(t.cm,t.first,t.first-e,e);for(var n=t.cm.display,r=n.viewFrom;rt.lastLine())){if(e.from.lineo&&(e={from:e.from,to:ee(o,Gt(t,o).text.length),text:[e.text[0]],origin:e.origin}),e.removed=Kt(t,e.from,e.to),n||(n=ji(t,e)),t.cm?function(t,e,n){var r=t.doc,i=t.display,o=e.from,a=e.to,s=!1,l=o.line;t.options.lineWrapping||(l=Jt(Ve(Gt(r,o.line))),r.iter(l,a.line+1,(function(t){if(t==i.maxLine)return s=!0,!0}))),r.sel.contains(e.from,e.to)>-1&&mt(t),Li(r,e,n,lr(t)),t.options.lineWrapping||(r.iter(l,o.line+e.text.length,(function(t){var e=Ue(t);e>i.maxLineLength&&(i.maxLine=t,i.maxLineLength=e,i.maxLineChanged=!0,s=!1)})),s&&(t.curOp.updateMaxLine=!0)),function(t,e){if(t.modeFrontier=Math.min(t.modeFrontier,e),!(t.highlightFrontiern;r--){var i=Gt(t,r).stateAfter;if(i&&(!(i instanceof ue)||r+i.lookAhead1||!(this.children[0]instanceof wo))){var s=[];this.collapse(s),this.children=[new wo(s)],this.children[0].parent=this}},collapse:function(t){for(var e=0;e50){for(var a=i.lines.length%25+25,s=a;s10);t.parent.maybeSpill()}},iterN:function(t,e,n){for(var r=0;r0||0==a&&!1!==o.clearWhenEmpty)return o;if(o.replacedWith&&(o.collapsed=!0,o.widgetNode=M("span",[o.replacedWith],"CodeMirror-widget"),r.handleMouseEvents||o.widgetNode.setAttribute("cm-ignore-events","true"),r.insertLeft&&(o.widgetNode.insertLeft=!0)),o.collapsed){if(_e(t,e.line,e,n,o)||e.line!=n.line&&_e(t,n.line,e,n,o))throw new Error("Inserting collapsed marker partially overlapping an existing one");Oe=!0}o.addToHistory&&zi(t,{from:e,to:n,origin:"markText"},t.sel,NaN);var s,l=e.line,c=t.cm;if(t.iter(l,n.line+1,(function(t){c&&o.collapsed&&!c.options.lineWrapping&&Ve(t)==c.display.maxLine&&(s=!0),o.collapsed&&l!=e.line&&Xt(t,0),function(t,e){t.markedSpans=t.markedSpans?t.markedSpans.concat([e]):[e],e.marker.attachLine(t)}(t,new Se(o,l==e.line?e.ch:null,l==n.line?n.ch:null)),++l})),o.collapsed&&t.iter(e.line,n.line+1,(function(e){$e(t,e)&&Xt(e,0)})),o.clearOnEnter&&dt(o,"beforeCursorEnter",(function(){return o.clear()})),o.readOnly&&(Ce=!0,(t.history.done.length||t.history.undone.length)&&t.clearHistory()),o.collapsed&&(o.id=++So,o.atomic=!0),c){if(s&&(c.curOp.updateMaxLine=!0),o.collapsed)dr(c,e.line,n.line+1);else if(o.className||o.startStyle||o.endStyle||o.css||o.attributes||o.title)for(var u=e.line;u<=n.line;u++)fr(c,u,"text");o.atomic&&no(c.doc),cn(c,"markerAdded",c,o)}return o}ko.prototype.clear=function(){if(!this.explicitlyCleared){var t=this.doc.cm,e=t&&!t.curOp;if(e&&Gr(t),yt(this,"clear")){var n=this.find();n&&cn(this,"clear",n.from,n.to)}for(var r=null,i=null,o=0;ot.display.maxLineLength&&(t.display.maxLine=c,t.display.maxLineLength=u,t.display.maxLineChanged=!0)}null!=r&&t&&this.collapsed&&dr(t,r,i+1),this.lines.length=0,this.explicitlyCleared=!0,this.atomic&&this.doc.cantEdit&&(this.doc.cantEdit=!1,t&&no(t.doc)),t&&cn(t,"markerCleared",t,this,r,i),e&&Kr(t),this.parent&&this.parent.clear()}},ko.prototype.find=function(t,e){var n,r;null==t&&"bookmark"==this.type&&(t=1);for(var i=0;i=0;l--)co(this,r[l]);s?Zi(this,s):this.cm&&Ar(this.cm)})),undo:ni((function(){ho(this,"undo")})),redo:ni((function(){ho(this,"redo")})),undoSelection:ni((function(){ho(this,"undo",!0)})),redoSelection:ni((function(){ho(this,"redo",!0)})),setExtending:function(t){this.extend=t},getExtending:function(){return this.extend},historySize:function(){for(var t=this.history,e=0,n=0,r=0;r=t.ch)&&e.push(i.marker.parent||i.marker)}return e},findMarks:function(t,e,n){t=le(this,t),e=le(this,e);var r=[],i=t.line;return this.iter(t.line,e.line+1,(function(o){var a=o.markedSpans;if(a)for(var s=0;s=l.to||null==l.from&&i!=t.line||null!=l.from&&i==e.line&&l.from>=e.ch||n&&!n(l.marker)||r.push(l.marker.parent||l.marker)}++i})),r},getAllMarks:function(){var t=[];return this.iter((function(e){var n=e.markedSpans;if(n)for(var r=0;rt)return e=t,!0;t-=o,++n})),le(this,ee(n,e))},indexFromPos:function(t){var e=(t=le(this,t)).ch;if(t.linee&&(e=t.from),null!=t.to&&t.to-1)return e.state.draggingText(t),void setTimeout((function(){return e.display.input.focus()}),20);try{var u=t.dataTransfer.getData("Text");if(u){var h;if(e.state.draggingText&&!e.state.draggingText.copy&&(h=e.listSelections()),to(e.doc,ki(n,n)),h)for(var d=0;d=0;e--)go(t.doc,"",r[e].from,r[e].to,"+delete");Ar(t)}))}function Zo(t,e,n){var r=ot(t.text,e+n,n);return r<0||r>t.text.length?null:r}function Qo(t,e,n){var r=Zo(t,e.ch,n);return null==r?null:new ee(e.line,r,n<0?"after":"before")}function ta(t,e,n,r,i){if(t){var o=ut(n,e.doc.direction);if(o){var a,s=i<0?Y(o):o[0],l=i<0==(1==s.level)?"after":"before";if(s.level>0||"rtl"==e.doc.direction){var c=Ln(e,n);a=i<0?n.text.length-1:0;var u=Nn(e,c,a).top;a=at((function(t){return Nn(e,c,t).top==u}),i<0==(1==s.level)?s.from:s.to-1,a),"before"==l&&(a=Zo(n,a,1))}else a=i<0?s.to:s.from;return new ee(r,a,l)}}return new ee(r,i<0?n.text.length:0,i<0?"before":"after")}Wo.basic={Left:"goCharLeft",Right:"goCharRight",Up:"goLineUp",Down:"goLineDown",End:"goLineEnd",Home:"goLineStartSmart",PageUp:"goPageUp",PageDown:"goPageDown",Delete:"delCharAfter",Backspace:"delCharBefore","Shift-Backspace":"delCharBefore",Tab:"defaultTab","Shift-Tab":"indentAuto",Enter:"newlineAndIndent",Insert:"toggleOverwrite",Esc:"singleSelection"},Wo.pcDefault={"Ctrl-A":"selectAll","Ctrl-D":"deleteLine","Ctrl-Z":"undo","Shift-Ctrl-Z":"redo","Ctrl-Y":"redo","Ctrl-Home":"goDocStart","Ctrl-End":"goDocEnd","Ctrl-Up":"goLineUp","Ctrl-Down":"goLineDown","Ctrl-Left":"goGroupLeft","Ctrl-Right":"goGroupRight","Alt-Left":"goLineStart","Alt-Right":"goLineEnd","Ctrl-Backspace":"delGroupBefore","Ctrl-Delete":"delGroupAfter","Ctrl-S":"save","Ctrl-F":"find","Ctrl-G":"findNext","Shift-Ctrl-G":"findPrev","Shift-Ctrl-F":"replace","Shift-Ctrl-R":"replaceAll","Ctrl-[":"indentLess","Ctrl-]":"indentMore","Ctrl-U":"undoSelection","Shift-Ctrl-U":"redoSelection","Alt-U":"redoSelection",fallthrough:"basic"},Wo.emacsy={"Ctrl-F":"goCharRight","Ctrl-B":"goCharLeft","Ctrl-P":"goLineUp","Ctrl-N":"goLineDown","Alt-F":"goWordRight","Alt-B":"goWordLeft","Ctrl-A":"goLineStart","Ctrl-E":"goLineEnd","Ctrl-V":"goPageDown","Shift-Ctrl-V":"goPageUp","Ctrl-D":"delCharAfter","Ctrl-H":"delCharBefore","Alt-D":"delWordAfter","Alt-Backspace":"delWordBefore","Ctrl-K":"killLine","Ctrl-T":"transposeChars","Ctrl-O":"openLine"},Wo.macDefault={"Cmd-A":"selectAll","Cmd-D":"deleteLine","Cmd-Z":"undo","Shift-Cmd-Z":"redo","Cmd-Y":"redo","Cmd-Home":"goDocStart","Cmd-Up":"goDocStart","Cmd-End":"goDocEnd","Cmd-Down":"goDocEnd","Alt-Left":"goGroupLeft","Alt-Right":"goGroupRight","Cmd-Left":"goLineLeft","Cmd-Right":"goLineRight","Alt-Backspace":"delGroupBefore","Ctrl-Alt-Backspace":"delGroupAfter","Alt-Delete":"delGroupAfter","Cmd-S":"save","Cmd-F":"find","Cmd-G":"findNext","Shift-Cmd-G":"findPrev","Cmd-Alt-F":"replace","Shift-Cmd-Alt-F":"replaceAll","Cmd-[":"indentLess","Cmd-]":"indentMore","Cmd-Backspace":"delWrappedLineLeft","Cmd-Delete":"delWrappedLineRight","Cmd-U":"undoSelection","Shift-Cmd-U":"redoSelection","Ctrl-Up":"goDocStart","Ctrl-Down":"goDocEnd",fallthrough:["basic","emacsy"]},Wo.default=y?Wo.macDefault:Wo.pcDefault;var ea={selectAll:so,singleSelection:function(t){return t.setSelection(t.getCursor("anchor"),t.getCursor("head"),W)},killLine:function(t){return Jo(t,(function(e){if(e.empty()){var n=Gt(t.doc,e.head.line).text.length;return e.head.ch==n&&e.head.line0)i=new ee(i.line,i.ch+1),t.replaceRange(o.charAt(i.ch-1)+o.charAt(i.ch-2),ee(i.line,i.ch-2),i,"+transpose");else if(i.line>t.doc.first){var a=Gt(t.doc,i.line-1).text;a&&(i=new ee(i.line,1),t.replaceRange(o.charAt(0)+t.doc.lineSeparator()+a.charAt(a.length-1),ee(i.line-1,a.length-1),i,"+transpose"))}n.push(new Oi(i,i))}t.setSelections(n)}))},newlineAndIndent:function(t){return Qr(t,(function(){for(var e=t.listSelections(),n=e.length-1;n>=0;n--)t.replaceRange(t.doc.lineSeparator(),e[n].anchor,e[n].head,"+input");e=t.listSelections();for(var r=0;r-1&&(ne((i=c.ranges[i]).from(),e)<0||e.xRel>0)&&(ne(i.to(),e)>0||e.xRel<0)?function(t,e,n,r){var i=t.display,o=!1,c=ti(t,(function(e){l&&(i.scroller.draggable=!1),t.state.draggingText=!1,pt(i.wrapper.ownerDocument,"mouseup",c),pt(i.wrapper.ownerDocument,"mousemove",u),pt(i.scroller,"dragstart",h),pt(i.scroller,"drop",c),o||(wt(e),r.addNew||Ki(t.doc,n,null,null,r.extend),l||a&&9==s?setTimeout((function(){i.wrapper.ownerDocument.body.focus(),i.input.focus()}),20):i.input.focus())})),u=function(t){o=o||Math.abs(e.clientX-t.clientX)+Math.abs(e.clientY-t.clientY)>=10},h=function(){return o=!0};l&&(i.scroller.draggable=!0),t.state.draggingText=c,c.copy=!r.moveOnDrag,i.scroller.dragDrop&&i.scroller.dragDrop(),dt(i.wrapper.ownerDocument,"mouseup",c),dt(i.wrapper.ownerDocument,"mousemove",u),dt(i.scroller,"dragstart",h),dt(i.scroller,"drop",c),Sr(t),setTimeout((function(){return i.input.focus()}),20)}(t,r,e,o):function(t,e,n,r){var i=t.display,o=t.doc;wt(e);var a,s,l=o.sel,c=l.ranges;if(r.addNew&&!r.extend?(s=o.sel.contains(n),a=s>-1?c[s]:new Oi(n,n)):(a=o.sel.primary(),s=o.sel.primIndex),"rectangle"==r.unit)r.addNew||(a=new Oi(n,n)),n=ur(t,e,!0,!0),s=-1;else{var u=ma(t,n,r.unit);a=r.extend?Gi(a,u.anchor,u.head,r.extend):u}r.addNew?-1==s?(s=c.length,Qi(o,Si(t,c.concat([a]),s),{scroll:!1,origin:"*mouse"})):c.length>1&&c[s].empty()&&"char"==r.unit&&!r.extend?(Qi(o,Si(t,c.slice(0,s).concat(c.slice(s+1)),0),{scroll:!1,origin:"*mouse"}),l=o.sel):Xi(o,s,a,B):(s=0,Qi(o,new Ci([a],0),B),l=o.sel);var h=n;function d(e){if(0!=ne(h,e))if(h=e,"rectangle"==r.unit){for(var i=[],c=t.options.tabSize,u=_(Gt(o,n.line).text,n.ch,c),d=_(Gt(o,e.line).text,e.ch,c),f=Math.min(u,d),p=Math.max(u,d),g=Math.min(n.line,e.line),v=Math.min(t.lastLine(),Math.max(n.line,e.line));g<=v;g++){var m=Gt(o,g).text,y=q(m,f,c);f==p?i.push(new Oi(ee(g,y),ee(g,y))):m.length>y&&i.push(new Oi(ee(g,y),ee(g,q(m,p,c))))}i.length||i.push(new Oi(n,n)),Qi(o,Si(t,l.ranges.slice(0,s).concat(i),s),{origin:"*mouse",scroll:!1}),t.scrollIntoView(e)}else{var b,w=a,x=ma(t,e,r.unit),C=w.anchor;ne(x.anchor,C)>0?(b=x.head,C=ae(w.from(),x.anchor)):(b=x.anchor,C=oe(w.to(),x.head));var O=l.ranges.slice(0);O[s]=function(t,e){var n=e.anchor,r=e.head,i=Gt(t.doc,n.line);if(0==ne(n,r)&&n.sticky==r.sticky)return e;var o=ut(i);if(!o)return e;var a=lt(o,n.ch,n.sticky),s=o[a];if(s.from!=n.ch&&s.to!=n.ch)return e;var l,c=a+(s.from==n.ch==(1!=s.level)?0:1);if(0==c||c==o.length)return e;if(r.line!=n.line)l=(r.line-n.line)*("ltr"==t.doc.direction?1:-1)>0;else{var u=lt(o,r.ch,r.sticky),h=u-a||(r.ch-n.ch)*(1==s.level?-1:1);l=u==c-1||u==c?h<0:h>0}var d=o[c+(l?-1:0)],f=l==(1==d.level),p=f?d.from:d.to,g=f?"after":"before";return n.ch==p&&n.sticky==g?e:new Oi(new ee(n.line,p,g),r)}(t,new Oi(le(o,C),b)),Qi(o,Si(t,O,s),B)}}var f=i.wrapper.getBoundingClientRect(),p=0;function g(e){t.state.selectingText=!1,p=1/0,e&&(wt(e),i.input.focus()),pt(i.wrapper.ownerDocument,"mousemove",v),pt(i.wrapper.ownerDocument,"mouseup",m),o.history.lastSelOrigin=null}var v=ti(t,(function(e){0!==e.buttons&&kt(e)?function e(n){var a=++p,s=ur(t,n,!0,"rectangle"==r.unit);if(s)if(0!=ne(s,h)){t.curOp.focus=A(),d(s);var l=Er(i,o);(s.line>=l.to||s.linef.bottom?20:0;c&&setTimeout(ti(t,(function(){p==a&&(i.scroller.scrollTop+=c,e(n))})),50)}}(e):g(e)})),m=ti(t,g);t.state.selectingText=m,dt(i.wrapper.ownerDocument,"mousemove",v),dt(i.wrapper.ownerDocument,"mouseup",m)}(t,r,e,o)}(e,r,o,t):St(t)==n.scroller&&wt(t):2==i?(r&&Ki(e.doc,r),setTimeout((function(){return n.input.focus()}),20)):3==i&&(O?e.display.input.onContextMenu(t):Sr(e)))}}function ma(t,e,n){if("char"==n)return new Oi(e,e);if("word"==n)return t.findWordAt(e);if("line"==n)return new Oi(ee(e.line,0),le(t.doc,ee(e.line+1,0)));var r=n(t,e);return new Oi(r.from,r.to)}function ya(t,e,n,r){var i,o;if(e.touches)i=e.touches[0].clientX,o=e.touches[0].clientY;else try{i=e.clientX,o=e.clientY}catch(e){return!1}if(i>=Math.floor(t.display.gutters.getBoundingClientRect().right))return!1;r&&wt(e);var a=t.display,s=a.lineDiv.getBoundingClientRect();if(o>s.bottom||!yt(t,n))return Ct(e);o-=s.top-a.viewOffset;for(var l=0;l=i)return gt(t,n,t,Zt(t.doc,o),t.display.gutterSpecs[l].className,e),Ct(e)}}function ba(t,e){return ya(t,e,"gutterClick",!0)}function wa(t,e){On(t.display,e)||function(t,e){return!!yt(t,"gutterContextMenu")&&ya(t,e,"gutterContextMenu",!1)}(t,e)||vt(t,e,"contextmenu")||O||t.display.input.onContextMenu(e)}function xa(t){t.display.wrapper.className=t.display.wrapper.className.replace(/\s*cm-s-\S+/g,"")+t.options.theme.replace(/(^|\s)\s*/g," cm-s-"),Hn(t)}ga.prototype.compare=function(t,e,n){return this.time+400>t&&0==ne(e,this.pos)&&n==this.button};var Ca={toString:function(){return"CodeMirror.Init"}},Oa={},Sa={};function ka(t,e,n){if(!e!=!(n&&n!=Ca)){var r=t.display.dragFunctions,i=e?dt:pt;i(t.display.scroller,"dragstart",r.start),i(t.display.scroller,"dragenter",r.enter),i(t.display.scroller,"dragover",r.over),i(t.display.scroller,"dragleave",r.leave),i(t.display.scroller,"drop",r.drop)}}function Ta(t){t.options.lineWrapping?(L(t.display.wrapper,"CodeMirror-wrap"),t.display.sizer.style.minWidth="",t.display.sizerWidth=null):(T(t.display.wrapper,"CodeMirror-wrap"),qe(t)),cr(t),dr(t),Hn(t),setTimeout((function(){return $r(t)}),100)}function Pa(t,e){var n=this;if(!(this instanceof Pa))return new Pa(t,e);this.options=e=e?R(e):{},R(Oa,e,!1);var r=e.value;"string"==typeof r?r=new Do(r,e.mode,null,e.lineSeparator,e.direction):e.mode&&(r.modeOption=e.mode),this.doc=r;var i=new Pa.inputStyles[e.inputStyle](this),o=this.display=new vi(t,r,i,e);for(var c in o.wrapper.CodeMirror=this,xa(this),e.lineWrapping&&(this.display.wrapper.className+=" CodeMirror-wrap"),Ur(this),this.state={keyMaps:[],overlays:[],modeGen:0,overwrite:!1,delayingBlurEvent:!1,focused:!1,suppressEdits:!1,pasteIncoming:-1,cutIncoming:-1,selectingText:!1,draggingText:!1,highlight:new V,keySeq:null,specialChars:null},e.autofocus&&!m&&o.input.focus(),a&&s<11&&setTimeout((function(){return n.display.input.reset(!0)}),20),function(t){var e=t.display;dt(e.scroller,"mousedown",ti(t,va)),dt(e.scroller,"dblclick",a&&s<11?ti(t,(function(e){if(!vt(t,e)){var n=ur(t,e);if(n&&!ba(t,e)&&!On(t.display,e)){wt(e);var r=t.findWordAt(n);Ki(t.doc,r.anchor,r.head)}}})):function(e){return vt(t,e)||wt(e)}),dt(e.scroller,"contextmenu",(function(e){return wa(t,e)}));var n,r={end:0};function i(){e.activeTouch&&(n=setTimeout((function(){return e.activeTouch=null}),1e3),(r=e.activeTouch).end=+new Date)}function o(t,e){if(null==e.left)return!0;var n=e.left-t.left,r=e.top-t.top;return n*n+r*r>400}dt(e.scroller,"touchstart",(function(i){if(!vt(t,i)&&!function(t){if(1!=t.touches.length)return!1;var e=t.touches[0];return e.radiusX<=1&&e.radiusY<=1}(i)&&!ba(t,i)){e.input.ensurePolled(),clearTimeout(n);var o=+new Date;e.activeTouch={start:o,moved:!1,prev:o-r.end<=300?r:null},1==i.touches.length&&(e.activeTouch.left=i.touches[0].pageX,e.activeTouch.top=i.touches[0].pageY)}})),dt(e.scroller,"touchmove",(function(){e.activeTouch&&(e.activeTouch.moved=!0)})),dt(e.scroller,"touchend",(function(n){var r=e.activeTouch;if(r&&!On(e,n)&&null!=r.left&&!r.moved&&new Date-r.start<300){var a,s=t.coordsChar(e.activeTouch,"page");a=!r.prev||o(r,r.prev)?new Oi(s,s):!r.prev.prev||o(r,r.prev.prev)?t.findWordAt(s):new Oi(ee(s.line,0),le(t.doc,ee(s.line+1,0))),t.setSelection(a.anchor,a.head),t.focus(),wt(n)}i()})),dt(e.scroller,"touchcancel",i),dt(e.scroller,"scroll",(function(){e.scroller.clientHeight&&(Fr(t,e.scroller.scrollTop),_r(t,e.scroller.scrollLeft,!0),gt(t,"scroll",t))})),dt(e.scroller,"mousewheel",(function(e){return xi(t,e)})),dt(e.scroller,"DOMMouseScroll",(function(e){return xi(t,e)})),dt(e.wrapper,"scroll",(function(){return e.wrapper.scrollTop=e.wrapper.scrollLeft=0})),e.dragFunctions={enter:function(e){vt(t,e)||Ot(e)},over:function(e){vt(t,e)||(function(t,e){var n=ur(t,e);if(n){var r=document.createDocumentFragment();br(t,n,r),t.display.dragCursor||(t.display.dragCursor=E("div",null,"CodeMirror-cursors CodeMirror-dragcursors"),t.display.lineSpace.insertBefore(t.display.dragCursor,t.display.cursorDiv)),j(t.display.dragCursor,r)}}(t,e),Ot(e))},start:function(e){return function(t,e){if(a&&(!t.state.draggingText||+new Date-Ao<100))Ot(e);else if(!vt(t,e)&&!On(t.display,e)&&(e.dataTransfer.setData("Text",t.getSelection()),e.dataTransfer.effectAllowed="copyMove",e.dataTransfer.setDragImage&&!d)){var n=E("img",null,null,"position: fixed; left: 0; top: 0;");n.src="data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==",h&&(n.width=n.height=1,t.display.wrapper.appendChild(n),n._top=n.offsetTop),e.dataTransfer.setDragImage(n,0,0),h&&n.parentNode.removeChild(n)}}(t,e)},drop:ti(t,Lo),leave:function(e){vt(t,e)||No(t)}};var l=e.input.getField();dt(l,"keyup",(function(e){return ha.call(t,e)})),dt(l,"keydown",ti(t,ua)),dt(l,"keypress",ti(t,da)),dt(l,"focus",(function(e){return kr(t,e)})),dt(l,"blur",(function(e){return Tr(t,e)}))}(this),Ro(),Gr(this),this.curOp.forceUpdate=!0,Ii(this,r),e.autofocus&&!m||this.hasFocus()?setTimeout(F(kr,this),20):Tr(this),Sa)Sa.hasOwnProperty(c)&&Sa[c](n,e[c],Ca);di(this),e.finishInit&&e.finishInit(this);for(var u=0;u150)){if(!r)return;n="prev"}}else c=0,n="not";"prev"==n?c=e>o.first?_(Gt(o,e-1).text,null,a):0:"add"==n?c=l+t.options.indentUnit:"subtract"==n?c=l-t.options.indentUnit:"number"==typeof n&&(c=l+n),c=Math.max(0,c);var h="",d=0;if(t.options.indentWithTabs)for(var f=Math.floor(c/a);f;--f)d+=a,h+="\t";if(da,l=At(e),c=null;if(s&&r.ranges.length>1)if(Ma&&Ma.text.join("\n")==e){if(r.ranges.length%Ma.text.length==0){c=[];for(var u=0;u=0;d--){var f=r.ranges[d],p=f.from(),g=f.to();f.empty()&&(n&&n>0?p=ee(p.line,p.ch-n):t.state.overwrite&&!s?g=ee(g.line,Math.min(Gt(o,g.line).text.length,g.ch+Y(l).length)):s&&Ma&&Ma.lineWise&&Ma.text.join("\n")==e&&(p=g=ee(p.line,0)));var v={from:p,to:g,text:c?c[d%c.length]:l,origin:i||(s?"paste":t.state.cutIncoming>a?"cut":"+input")};co(t.doc,v),cn(t,"inputRead",t,v)}e&&!s&&Na(t,e),Ar(t),t.curOp.updateInput<2&&(t.curOp.updateInput=h),t.curOp.typing=!0,t.state.pasteIncoming=t.state.cutIncoming=-1}function La(t,e){var n=t.clipboardData&&t.clipboardData.getData("Text");if(n)return t.preventDefault(),e.isReadOnly()||e.options.disableInput||Qr(e,(function(){return Aa(e,n,0,null,"paste")})),!0}function Na(t,e){if(t.options.electricChars&&t.options.smartIndent)for(var n=t.doc.sel,r=n.ranges.length-1;r>=0;r--){var i=n.ranges[r];if(!(i.head.ch>100||r&&n.ranges[r-1].head.line==i.head.line)){var o=t.getModeAt(i.head),a=!1;if(o.electricChars){for(var s=0;s-1){a=Ea(t,i.head.line,"smart");break}}else o.electricInput&&o.electricInput.test(Gt(t.doc,i.head.line).text.slice(0,i.head.ch))&&(a=Ea(t,i.head.line,"smart"));a&&cn(t,"electricInput",t,i.head.line)}}}function Ia(t){for(var e=[],n=[],r=0;r=e.text.length?(n.ch=e.text.length,n.sticky="before"):n.ch<=0&&(n.ch=0,n.sticky="after");var o=lt(i,n.ch,n.sticky),a=i[o];if("ltr"==t.doc.direction&&a.level%2==0&&(r>0?a.to>n.ch:a.from=a.from&&d>=u.begin)){var f=h?"before":"after";return new ee(n.line,d,f)}}var p=function(t,e,r){for(var o=function(t,e){return e?new ee(n.line,l(t,1),"before"):new ee(n.line,t,"after")};t>=0&&t0==(1!=a.level),c=s?r.begin:l(r.end,-1);if(a.from<=c&&c0?u.end:l(u.begin,-1);return null==v||r>0&&v==e.text.length||!(g=p(r>0?0:i.length-1,r,c(v)))?null:g}(t.cm,s,e,n):Qo(s,e,n))){if(r||(a=e.line+n)=t.first+t.size||(e=new ee(a,e.ch,e.sticky),!(s=Gt(t,a))))return!1;e=ta(i,t.cm,s,e.line,n)}else e=o;return!0}if("char"==r)l();else if("column"==r)l(!0);else if("word"==r||"group"==r)for(var c=null,u="group"==r,h=t.cm&&t.cm.getHelper(e,"wordChars"),d=!0;!(n<0)||l(!d);d=!1){var f=s.text.charAt(e.ch)||"\n",p=et(f,h)?"w":u&&"\n"==f?"n":!u||/\s/.test(f)?null:"p";if(!u||d||p||(p="s"),c&&c!=p){n<0&&(n=1,l(),e.sticky="after");break}if(p&&(c=p),n>0&&!l(!d))break}var g=oo(t,e,o,a,!0);return re(o,g)&&(g.hitSide=!0),g}function Va(t,e,n,r){var i,o,a=t.doc,s=e.left;if("page"==r){var l=Math.min(t.display.wrapper.clientHeight,window.innerHeight||document.documentElement.clientHeight),c=Math.max(l-.5*ir(t.display),3);i=(n>0?e.bottom:e.top)+n*c}else"line"==r&&(i=n>0?e.bottom+3:e.top-3);for(;(o=Jn(t,s,i)).outside;){if(n<0?i<=0:i>=a.height){o.hitSide=!0;break}i+=5*n}return o}var za=function(t){this.cm=t,this.lastAnchorNode=this.lastAnchorOffset=this.lastFocusNode=this.lastFocusOffset=null,this.polling=new V,this.composing=null,this.gracePeriod=!1,this.readDOMTimeout=null};function Ha(t,e){var n=An(t,e.line);if(!n||n.hidden)return null;var r=Gt(t.doc,e.line),i=Mn(n,r,e.line),o=ut(r,t.doc.direction),a="left";o&&(a=lt(o,e.ch)%2?"right":"left");var s=Rn(i.map,e.ch,a);return s.offset="right"==s.collapse?s.end:s.start,s}function $a(t,e){return e&&(t.bad=!0),t}function Wa(t,e,n){var r;if(e==t.display.lineDiv){if(!(r=t.display.lineDiv.childNodes[n]))return $a(t.clipPos(ee(t.display.viewTo-1)),!0);e=null,n=0}else for(r=e;;r=r.parentNode){if(!r||r==t.display.lineDiv)return null;if(r.parentNode&&r.parentNode==t.display.lineDiv)break}for(var i=0;i=e.display.viewTo||o.line=e.display.viewFrom&&Ha(e,i)||{node:l[0].measure.map[2],offset:0},u=o.liner.firstLine()&&(a=ee(a.line-1,Gt(r.doc,a.line-1).length)),s.ch==Gt(r.doc,s.line).text.length&&s.linei.viewTo-1)return!1;a.line==i.viewFrom||0==(t=hr(r,a.line))?(e=Jt(i.view[0].line),n=i.view[0].node):(e=Jt(i.view[t].line),n=i.view[t-1].node.nextSibling);var l,c,u=hr(r,s.line);if(u==i.view.length-1?(l=i.viewTo-1,c=i.lineDiv.lastChild):(l=Jt(i.view[u+1].line)-1,c=i.view[u+1].node.previousSibling),!n)return!1;for(var h=r.doc.splitLines(function(t,e,n,r,i){var o="",a=!1,s=t.doc.lineSeparator(),l=!1;function c(){a&&(o+=s,l&&(o+=s),a=l=!1)}function u(t){t&&(c(),o+=t)}function h(e){if(1==e.nodeType){var n=e.getAttribute("cm-text");if(n)return void u(n);var o,d=e.getAttribute("cm-marker");if(d){var f=t.findMarks(ee(r,0),ee(i+1,0),(v=+d,function(t){return t.id==v}));return void(f.length&&(o=f[0].find(0))&&u(Kt(t.doc,o.from,o.to).join(s)))}if("false"==e.getAttribute("contenteditable"))return;var p=/^(pre|div|p|li|table|br)$/i.test(e.nodeName);if(!/^br$/i.test(e.nodeName)&&0==e.textContent.length)return;p&&c();for(var g=0;g1&&d.length>1;)if(Y(h)==Y(d))h.pop(),d.pop(),l--;else{if(h[0]!=d[0])break;h.shift(),d.shift(),e++}for(var f=0,p=0,g=h[0],v=d[0],m=Math.min(g.length,v.length);fa.ch&&y.charCodeAt(y.length-p-1)==b.charCodeAt(b.length-p-1);)f--,p++;h[h.length-1]=y.slice(0,y.length-p).replace(/^\u200b+/,""),h[0]=h[0].slice(f).replace(/\u200b+$/,"");var x=ee(e,f),C=ee(l,d.length?Y(d).length-p:0);return h.length>1||h[0]||ne(x,C)?(go(r.doc,h,x,C,"+input"),!0):void 0},za.prototype.ensurePolled=function(){this.forceCompositionEnd()},za.prototype.reset=function(){this.forceCompositionEnd()},za.prototype.forceCompositionEnd=function(){this.composing&&(clearTimeout(this.readDOMTimeout),this.composing=null,this.updateFromDOM(),this.div.blur(),this.div.focus())},za.prototype.readFromDOMSoon=function(){var t=this;null==this.readDOMTimeout&&(this.readDOMTimeout=setTimeout((function(){if(t.readDOMTimeout=null,t.composing){if(!t.composing.done)return;t.composing=null}t.updateFromDOM()}),80))},za.prototype.updateFromDOM=function(){var t=this;!this.cm.isReadOnly()&&this.pollContent()||Qr(this.cm,(function(){return dr(t.cm)}))},za.prototype.setUneditable=function(t){t.contentEditable="false"},za.prototype.onKeyPress=function(t){0==t.charCode||this.composing||(t.preventDefault(),this.cm.isReadOnly()||ti(this.cm,Aa)(this.cm,String.fromCharCode(null==t.charCode?t.keyCode:t.charCode),0))},za.prototype.readOnlyChanged=function(t){this.div.contentEditable=String("nocursor"!=t)},za.prototype.onContextMenu=function(){},za.prototype.resetPosition=function(){},za.prototype.needsContentAttribute=!0;var Ua=function(t){this.cm=t,this.prevInput="",this.pollingFast=!1,this.polling=new V,this.hasSelection=!1,this.composing=null};Ua.prototype.init=function(t){var e=this,n=this,r=this.cm;this.createField(t);var i=this.textarea;function o(t){if(!vt(r,t)){if(r.somethingSelected())Da({lineWise:!1,text:r.getSelections()});else{if(!r.options.lineWiseCopyCut)return;var e=Ia(r);Da({lineWise:!0,text:e.text}),"cut"==t.type?r.setSelections(e.ranges,null,W):(n.prevInput="",i.value=e.text.join("\n"),I(i))}"cut"==t.type&&(r.state.cutIncoming=+new Date)}}t.wrapper.insertBefore(this.wrapper,t.wrapper.firstChild),g&&(i.style.width="0px"),dt(i,"input",(function(){a&&s>=9&&e.hasSelection&&(e.hasSelection=null),n.poll()})),dt(i,"paste",(function(t){vt(r,t)||La(t,r)||(r.state.pasteIncoming=+new Date,n.fastPoll())})),dt(i,"cut",o),dt(i,"copy",o),dt(t.scroller,"paste",(function(e){if(!On(t,e)&&!vt(r,e)){if(!i.dispatchEvent)return r.state.pasteIncoming=+new Date,void n.focus();var o=new Event("paste");o.clipboardData=e.clipboardData,i.dispatchEvent(o)}})),dt(t.lineSpace,"selectstart",(function(e){On(t,e)||wt(e)})),dt(i,"compositionstart",(function(){var t=r.getCursor("from");n.composing&&n.composing.range.clear(),n.composing={start:t,range:r.markText(t,r.getCursor("to"),{className:"CodeMirror-composing"})}})),dt(i,"compositionend",(function(){n.composing&&(n.poll(),n.composing.range.clear(),n.composing=null)}))},Ua.prototype.createField=function(t){this.wrapper=Ra(),this.textarea=this.wrapper.firstChild},Ua.prototype.prepareSelection=function(){var t=this.cm,e=t.display,n=t.doc,r=yr(t);if(t.options.moveInputWithCursor){var i=Kn(t,n.sel.primary().head,"div"),o=e.wrapper.getBoundingClientRect(),a=e.lineDiv.getBoundingClientRect();r.teTop=Math.max(0,Math.min(e.wrapper.clientHeight-10,i.top+a.top-o.top)),r.teLeft=Math.max(0,Math.min(e.wrapper.clientWidth-10,i.left+a.left-o.left))}return r},Ua.prototype.showSelection=function(t){var e=this.cm.display;j(e.cursorDiv,t.cursors),j(e.selectionDiv,t.selection),null!=t.teTop&&(this.wrapper.style.top=t.teTop+"px",this.wrapper.style.left=t.teLeft+"px")},Ua.prototype.reset=function(t){if(!this.contextMenuPending&&!this.composing){var e=this.cm;if(e.somethingSelected()){this.prevInput="";var n=e.getSelection();this.textarea.value=n,e.state.focused&&I(this.textarea),a&&s>=9&&(this.hasSelection=n)}else t||(this.prevInput=this.textarea.value="",a&&s>=9&&(this.hasSelection=null))}},Ua.prototype.getField=function(){return this.textarea},Ua.prototype.supportsTouch=function(){return!1},Ua.prototype.focus=function(){if("nocursor"!=this.cm.options.readOnly&&(!m||A()!=this.textarea))try{this.textarea.focus()}catch(t){}},Ua.prototype.blur=function(){this.textarea.blur()},Ua.prototype.resetPosition=function(){this.wrapper.style.top=this.wrapper.style.left=0},Ua.prototype.receivedFocus=function(){this.slowPoll()},Ua.prototype.slowPoll=function(){var t=this;this.pollingFast||this.polling.set(this.cm.options.pollInterval,(function(){t.poll(),t.cm.state.focused&&t.slowPoll()}))},Ua.prototype.fastPoll=function(){var t=!1,e=this;e.pollingFast=!0,e.polling.set(20,(function n(){e.poll()||t?(e.pollingFast=!1,e.slowPoll()):(t=!0,e.polling.set(60,n))}))},Ua.prototype.poll=function(){var t=this,e=this.cm,n=this.textarea,r=this.prevInput;if(this.contextMenuPending||!e.state.focused||Lt(n)&&!r&&!this.composing||e.isReadOnly()||e.options.disableInput||e.state.keySeq)return!1;var i=n.value;if(i==r&&!e.somethingSelected())return!1;if(a&&s>=9&&this.hasSelection===i||y&&/[\uf700-\uf7ff]/.test(i))return e.display.input.reset(),!1;if(e.doc.sel==e.display.selForContextMenu){var o=i.charCodeAt(0);if(8203!=o||r||(r="​"),8666==o)return this.reset(),this.cm.execCommand("undo")}for(var l=0,c=Math.min(r.length,i.length);l1e3||i.indexOf("\n")>-1?n.value=t.prevInput="":t.prevInput=i,t.composing&&(t.composing.range.clear(),t.composing.range=e.markText(t.composing.start,e.getCursor("to"),{className:"CodeMirror-composing"}))})),!0},Ua.prototype.ensurePolled=function(){this.pollingFast&&this.poll()&&(this.pollingFast=!1)},Ua.prototype.onKeyPress=function(){a&&s>=9&&(this.hasSelection=null),this.fastPoll()},Ua.prototype.onContextMenu=function(t){var e=this,n=e.cm,r=n.display,i=e.textarea;e.contextMenuPending&&e.contextMenuPending();var o=ur(n,t),c=r.scroller.scrollTop;if(o&&!h){n.options.resetSelectionOnContextMenu&&-1==n.doc.sel.contains(o)&&ti(n,Qi)(n.doc,ki(o),W);var u,d=i.style.cssText,f=e.wrapper.style.cssText,p=e.wrapper.offsetParent.getBoundingClientRect();if(e.wrapper.style.cssText="position: static",i.style.cssText="position: absolute; width: 30px; height: 30px;\n top: "+(t.clientY-p.top-5)+"px; left: "+(t.clientX-p.left-5)+"px;\n z-index: 1000; background: "+(a?"rgba(255, 255, 255, .05)":"transparent")+";\n outline: none; border-width: 0; outline: none; overflow: hidden; opacity: .05; filter: alpha(opacity=5);",l&&(u=window.scrollY),r.input.focus(),l&&window.scrollTo(null,u),r.input.reset(),n.somethingSelected()||(i.value=e.prevInput=" "),e.contextMenuPending=m,r.selForContextMenu=n.doc.sel,clearTimeout(r.detectingSelectAll),a&&s>=9&&v(),O){Ot(t);var g=function(){pt(window,"mouseup",g),setTimeout(m,20)};dt(window,"mouseup",g)}else setTimeout(m,50)}function v(){if(null!=i.selectionStart){var t=n.somethingSelected(),o="​"+(t?i.value:"");i.value="⇚",i.value=o,e.prevInput=t?"":"​",i.selectionStart=1,i.selectionEnd=o.length,r.selForContextMenu=n.doc.sel}}function m(){if(e.contextMenuPending==m&&(e.contextMenuPending=!1,e.wrapper.style.cssText=f,i.style.cssText=d,a&&s<9&&r.scrollbars.setScrollTop(r.scroller.scrollTop=c),null!=i.selectionStart)){(!a||a&&s<9)&&v();var t=0,o=function(){r.selForContextMenu==n.doc.sel&&0==i.selectionStart&&i.selectionEnd>0&&"​"==e.prevInput?ti(n,so)(n):t++<10?r.detectingSelectAll=setTimeout(o,500):(r.selForContextMenu=null,r.input.reset())};r.detectingSelectAll=setTimeout(o,200)}}},Ua.prototype.readOnlyChanged=function(t){t||this.reset(),this.textarea.disabled="nocursor"==t},Ua.prototype.setUneditable=function(){},Ua.prototype.needsContentAttribute=!1,function(t){var e=t.optionHandlers;function n(n,r,i,o){t.defaults[n]=r,i&&(e[n]=o?function(t,e,n){n!=Ca&&i(t,e,n)}:i)}t.defineOption=n,t.Init=Ca,n("value","",(function(t,e){return t.setValue(e)}),!0),n("mode",null,(function(t,e){t.doc.modeOption=e,Mi(t)}),!0),n("indentUnit",2,Mi,!0),n("indentWithTabs",!1),n("smartIndent",!0),n("tabSize",4,(function(t){Di(t),Hn(t),dr(t)}),!0),n("lineSeparator",null,(function(t,e){if(t.doc.lineSep=e,e){var n=[],r=t.doc.first;t.doc.iter((function(t){for(var i=0;;){var o=t.text.indexOf(e,i);if(-1==o)break;i=o+e.length,n.push(ee(r,o))}r++}));for(var i=n.length-1;i>=0;i--)go(t.doc,e,n[i],ee(n[i].line,n[i].ch+e.length))}})),n("specialChars",/[\u0000-\u001f\u007f-\u009f\u00ad\u061c\u200b-\u200f\u2028\u2029\ufeff\ufff9-\ufffc]/g,(function(t,e,n){t.state.specialChars=new RegExp(e.source+(e.test("\t")?"":"|\t"),"g"),n!=Ca&&t.refresh()})),n("specialCharPlaceholder",Qe,(function(t){return t.refresh()}),!0),n("electricChars",!0),n("inputStyle",m?"contenteditable":"textarea",(function(){throw new Error("inputStyle can not (yet) be changed in a running editor")}),!0),n("spellcheck",!1,(function(t,e){return t.getInputField().spellcheck=e}),!0),n("autocorrect",!1,(function(t,e){return t.getInputField().autocorrect=e}),!0),n("autocapitalize",!1,(function(t,e){return t.getInputField().autocapitalize=e}),!0),n("rtlMoveVisually",!w),n("wholeLineUpdateBefore",!0),n("theme","default",(function(t){xa(t),gi(t)}),!0),n("keyMap","default",(function(t,e,n){var r=Xo(e),i=n!=Ca&&Xo(n);i&&i.detach&&i.detach(t,r),r.attach&&r.attach(t,i||null)})),n("extraKeys",null),n("configureMouse",null),n("lineWrapping",!1,Ta,!0),n("gutters",[],(function(t,e){t.display.gutterSpecs=fi(e,t.options.lineNumbers),gi(t)}),!0),n("fixedGutter",!0,(function(t,e){t.display.gutters.style.left=e?sr(t.display)+"px":"0",t.refresh()}),!0),n("coverGutterNextToScrollbar",!1,(function(t){return $r(t)}),!0),n("scrollbarStyle","native",(function(t){Ur(t),$r(t),t.display.scrollbars.setScrollTop(t.doc.scrollTop),t.display.scrollbars.setScrollLeft(t.doc.scrollLeft)}),!0),n("lineNumbers",!1,(function(t,e){t.display.gutterSpecs=fi(t.options.gutters,e),gi(t)}),!0),n("firstLineNumber",1,gi,!0),n("lineNumberFormatter",(function(t){return t}),gi,!0),n("showCursorWhenSelecting",!1,mr,!0),n("resetSelectionOnContextMenu",!0),n("lineWiseCopyCut",!0),n("pasteLinesPerSelection",!0),n("selectionsMayTouch",!1),n("readOnly",!1,(function(t,e){"nocursor"==e&&(Tr(t),t.display.input.blur()),t.display.input.readOnlyChanged(e)})),n("disableInput",!1,(function(t,e){e||t.display.input.reset()}),!0),n("dragDrop",!0,ka),n("allowDropFileTypes",null),n("cursorBlinkRate",530),n("cursorScrollMargin",0),n("cursorHeight",1,mr,!0),n("singleCursorHeightPerLine",!0,mr,!0),n("workTime",100),n("workDelay",100),n("flattenSpans",!0,Di,!0),n("addModeClass",!1,Di,!0),n("pollInterval",100),n("undoDepth",200,(function(t,e){return t.doc.history.undoDepth=e})),n("historyEventDelay",1250),n("viewportMargin",10,(function(t){return t.refresh()}),!0),n("maxHighlightLength",1e4,Di,!0),n("moveInputWithCursor",!0,(function(t,e){e||t.display.input.resetPosition()})),n("tabindex",null,(function(t,e){return t.display.input.getField().tabIndex=e||""})),n("autofocus",null),n("direction","ltr",(function(t,e){return t.doc.setDirection(e)}),!0),n("phrases",null)}(Pa),function(t){var e=t.optionHandlers,n=t.helpers={};t.prototype={constructor:t,focus:function(){window.focus(),this.display.input.focus()},setOption:function(t,n){var r=this.options,i=r[t];r[t]==n&&"mode"!=t||(r[t]=n,e.hasOwnProperty(t)&&ti(this,e[t])(this,n,i),gt(this,"optionChange",this,t))},getOption:function(t){return this.options[t]},getDoc:function(){return this.doc},addKeyMap:function(t,e){this.state.keyMaps[e?"push":"unshift"](Xo(t))},removeKeyMap:function(t){for(var e=this.state.keyMaps,n=0;nn&&(Ea(this,i.head.line,t,!0),n=i.head.line,r==this.doc.sel.primIndex&&Ar(this));else{var o=i.from(),a=i.to(),s=Math.max(n,o.line);n=Math.min(this.lastLine(),a.line-(a.ch?0:1))+1;for(var l=s;l0&&Xi(this.doc,r,new Oi(o,c[r].to()),W)}}})),getTokenAt:function(t,e){return be(this,t,e)},getLineTokens:function(t,e){return be(this,ee(t),e,!0)},getTokenTypeAt:function(t){t=le(this.doc,t);var e,n=fe(this,Gt(this.doc,t.line)),r=0,i=(n.length-1)/2,o=t.ch;if(0==o)e=n[2];else for(;;){var a=r+i>>1;if((a?n[2*a-1]:0)>=o)i=a;else{if(!(n[2*a+1]o&&(t=o,i=!0),r=Gt(this.doc,t)}else r=t;return Un(this,r,{top:0,left:0},e||"page",n||i).top+(i?this.doc.height-Be(r):0)},defaultTextHeight:function(){return ir(this.display)},defaultCharWidth:function(){return or(this.display)},getViewport:function(){return{from:this.display.viewFrom,to:this.display.viewTo}},addWidget:function(t,e,n,r,i){var o,a,s,l=this.display,c=(t=Kn(this,le(this.doc,t))).bottom,u=t.left;if(e.style.position="absolute",e.setAttribute("cm-ignore-events","true"),this.display.input.setUneditable(e),l.sizer.appendChild(e),"over"==r)c=t.top;else if("above"==r||"near"==r){var h=Math.max(l.wrapper.clientHeight,this.doc.height),d=Math.max(l.sizer.clientWidth,l.lineSpace.clientWidth);("above"==r||t.bottom+e.offsetHeight>h)&&t.top>e.offsetHeight?c=t.top-e.offsetHeight:t.bottom+e.offsetHeight<=h&&(c=t.bottom),u+e.offsetWidth>d&&(u=d-e.offsetWidth)}e.style.top=c+"px",e.style.left=e.style.right="","right"==i?(u=l.sizer.clientWidth-e.offsetWidth,e.style.right="0px"):("left"==i?u=0:"middle"==i&&(u=(l.sizer.clientWidth-e.offsetWidth)/2),e.style.left=u+"px"),n&&(o=this,a={left:u,top:c,right:u+e.offsetWidth,bottom:c+e.offsetHeight},null!=(s=Mr(o,a)).scrollTop&&Fr(o,s.scrollTop),null!=s.scrollLeft&&_r(o,s.scrollLeft))},triggerOnKeyDown:ei(ua),triggerOnKeyPress:ei(da),triggerOnKeyUp:ha,triggerOnMouseDown:ei(va),execCommand:function(t){if(ea.hasOwnProperty(t))return ea[t].call(null,this)},triggerElectric:ei((function(t){Na(this,t)})),findPosH:function(t,e,n,r){var i=1;e<0&&(i=-1,e=-e);for(var o=le(this.doc,t),a=0;a0&&a(e.charAt(n-1));)--n;for(;r.5)&&cr(this),gt(this,"refresh",this)})),swapDoc:ei((function(t){var e=this.doc;return e.cm=null,this.state.selectingText&&this.state.selectingText(),Ii(this,t),Hn(this),this.display.input.reset(),Lr(this,t.scrollLeft,t.scrollTop),this.curOp.forceScroll=!0,cn(this,"swapDoc",this,e),e})),phrase:function(t){var e=this.options.phrases;return e&&Object.prototype.hasOwnProperty.call(e,t)?e[t]:t},getInputField:function(){return this.display.input.getField()},getWrapperElement:function(){return this.display.wrapper},getScrollerElement:function(){return this.display.scroller},getGutterElement:function(){return this.display.gutters}},bt(t),t.registerHelper=function(e,r,i){n.hasOwnProperty(e)||(n[e]=t[e]={_global:[]}),n[e][r]=i},t.registerGlobalHelper=function(e,r,i,o){t.registerHelper(e,r,o),n[e]._global.push({pred:i,val:o})}}(Pa);var qa="iter insert remove copy getEditor constructor".split(" ");for(var Ga in Do.prototype)Do.prototype.hasOwnProperty(Ga)&&z(qa,Ga)<0&&(Pa.prototype[Ga]=function(t){return function(){return t.apply(this.doc,arguments)}}(Do.prototype[Ga]));return bt(Do),Pa.inputStyles={textarea:Ua,contenteditable:za},Pa.defineMode=function(t){Pa.defaults.mode||"null"==t||(Pa.defaults.mode=t),_t.apply(this,arguments)},Pa.defineMIME=function(t,e){Rt[t]=e},Pa.defineMode("null",(function(){return{token:function(t){return t.skipToEnd()}}})),Pa.defineMIME("text/plain","null"),Pa.defineExtension=function(t,e){Pa.prototype[t]=e},Pa.defineDocExtension=function(t,e){Do.prototype[t]=e},Pa.fromTextArea=function(t,e){if((e=e?R(e):{}).value=t.value,!e.tabindex&&t.tabIndex&&(e.tabindex=t.tabIndex),!e.placeholder&&t.placeholder&&(e.placeholder=t.placeholder),null==e.autofocus){var n=A();e.autofocus=n==t||null!=t.getAttribute("autofocus")&&n==document.body}function r(){t.value=s.getValue()}var i;if(t.form&&(dt(t.form,"submit",r),!e.leaveSubmitMethodAlone)){var o=t.form;i=o.submit;try{var a=o.submit=function(){r(),o.submit=i,o.submit(),o.submit=a}}catch(t){}}e.finishInit=function(e){e.save=r,e.getTextArea=function(){return t},e.toTextArea=function(){e.toTextArea=isNaN,r(),t.parentNode.removeChild(e.getWrapperElement()),t.style.display="",t.form&&(pt(t.form,"submit",r),"function"==typeof t.form.submit&&(t.form.submit=i))}},t.style.display="none";var s=Pa((function(e){return t.parentNode.insertBefore(e,t.nextSibling)}),e);return s},function(t){t.off=pt,t.on=dt,t.wheelEventPixels=wi,t.Doc=Do,t.splitLines=At,t.countColumn=_,t.findColumn=q,t.isWordChar=tt,t.Pass=$,t.signal=gt,t.Line=Ge,t.changeEnd=Ti,t.scrollbarModel=Br,t.Pos=ee,t.cmpPos=ne,t.modes=Ft,t.mimeModes=Rt,t.resolveMode=Vt,t.getMode=zt,t.modeExtensions=Ht,t.extendMode=$t,t.copyState=Wt,t.startState=Ut,t.innerMode=Bt,t.commands=ea,t.keyMap=Wo,t.keyName=Yo,t.isModifierKey=Go,t.lookupKey=qo,t.normalizeKeyMap=Uo,t.StringStream=qt,t.SharedTextMarker=Po,t.TextMarker=ko,t.LineWidget=Co,t.e_preventDefault=wt,t.e_stopPropagation=xt,t.e_stop=Ot,t.addClass=L,t.contains=D,t.rmClass=T,t.keyNames=Vo}(Pa),Pa.version="5.48.4",Pa}()},function(t,e,n){"use strict";n.d(e,"c",(function(){return i})),n.d(e,"d",(function(){return o})),n.d(e,"a",(function(){return a})),n.d(e,"b",(function(){return s}));var r=n(0),i=function(t){for(;t.firstChild;)t.removeChild(t.firstChild)},o=function(t,e){t.parentNode.replaceChild(e,t)},a=function(t,e,n){var i=t.childNodes,o=i.length,a=Object(r.isUndefined)(n)?o:n;a>=o?t.appendChild(e):t.insertBefore(e,i[a])},s=function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:[],n=Array.isArray(e)?e:[e];n.forEach((function(e){var n=e.tag||"div",i=e.attributes||{},o=document.createElement(n);Object(r.each)(i,(function(t,e){o.setAttribute(e,t)})),t.appendChild(o)}))}},function(t,e,n){"use strict";n.r(e);var r=n(2),i=n.n(r),o=n(6),a=n.n(o),s=n(1),l=n.n(s),c=n(0),u=n(3),h=n(29),d=l.a.View.extend({events:function(){return this.model.get("events")||{mousedown:"handleClick"}},attributes:function(){return this.model.get("attributes")},initialize:function(t){this.editor=t.config.editor},handleClick:function(t){t.preventDefault(),t.stopPropagation(),this.execCommand(t)},execCommand:function(t){var e={event:t},n=this.model.get("command"),r=this.editor;"function"==typeof n&&n(r,null,e),"string"==typeof n&&r.runCommand(n,e)},render:function(){var t=this.editor,e=this.$el,n=this.model,r=n.get("id"),i=n.get("label"),o=t.getConfig("stylePrefix");return e.addClass("".concat(o,"toolbar-item")),r&&e.addClass("".concat(o,"toolbar-item__").concat(r)),i&&e.append(i),this}}),f=h.a.extend({itemView:d,initialize:function(t){this.config={editor:t.editor||""},this.listenTo(this.collection,"reset",this.render)}}),p=l.a.Model.extend({defaults:{command:"",attributes:{}}}),g=l.a.Collection.extend({model:p});function v(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}var m,y=l.a.$;e.default={init:function(t){Object(c.bindAll)(this,"onHover","onOut","onClick","onFrameScroll")},enable:function(){this.frameOff=this.canvasOff=this.adjScroll=null,this.startSelectComponent();var t=this.config.em;m=1,t.on("component:update",this.updateAttached,this),t.on("change:canvasOffset",this.updateAttached,this)},startSelectComponent:function(){this.toggleSelectComponent(1)},stopSelectComponent:function(){this.toggleSelectComponent()},toggleSelectComponent:function(t){var e=this.em,n=t?"on":"off",r={on:u.p,off:u.o},i=this.getCanvasBody(),o=this.getContentWindow();r[n](i,"mouseover",this.onHover),r[n](i,"mouseout",this.onOut),r[n](i,"click touchend",this.onClick),r[n](o,"scroll resize",this.onFrameScroll),e[n]("component:toggled",this.onSelect,this),e[n]("change:componentHovered",this.onHovered,this)},onHover:function(t){t.stopPropagation();var e=t.target,n=y(e),r=n.data("model");if(!r)for(var i=n.parent();!r&&i.length>0;)r=i.data("model"),i=i.parent();if(this.adjScroll||(this.adjScroll=1,this.updateAttached()),r&&!r.get("hoverable")){for(var o=r&&r.parent();o&&!o.get("hoverable");)o=o.parent();r=o}this.em.setHovered(r,{forceChange:1})},onHovered:function(t,e){var n=e&&e.getEl();if(n){var r=this.getElementPos(n);this.updateBadge(n,r),this.updateHighlighter(n,r),this.showElementOffset(n,r)}},onOut:function(t){t&&t.stopPropagation(),this.hideBadge(),this.hideHighlighter(),this.hideElementOffset()},showElementOffset:function(t,e){var n=y(t).data("model");n&&"selected"==n.get("status")||!m||this.editor.runCommand("show-offset",{el:t,elPos:e,force:1})},hideElementOffset:function(t,e){var n=this.editor;n&&n.stopCommand("show-offset")},showFixedElementOffset:function(t,e){this.editor.runCommand("show-offset",{el:t,elPos:e,state:"Fixed"})},hideFixedElementOffset:function(t,e){this.editor&&this.editor.stopCommand("show-offset",{state:"Fixed"})},hideHighlighter:function(){this.canvas.getHighlighter().style.display="none"},onClick:function(t){var e=this.em;if(t.stopPropagation(),t.preventDefault(),e.get("_cmpDrag"))return e.set("_cmpDrag");var n=y(t.target),r=n.data("model");if(!r)for(var i=n.parent();!r&&i.length>0;)r=i.data("model"),i=i.parent();if(r)if(r.get("selectable"))this.select(r,t);else{for(var o=r.parent();o&&!o.get("selectable");)o=o.parent();this.select(o,t)}},select:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};if(t){var n=e.ctrlKey||e.metaKey,r=e.shiftKey,i=this.editor,o=i.getConfig("multipleSelection"),a=this.em;if(n&&o)i.selectToggle(t);else if(r&&o){a.clearSelection(i.Canvas.getWindow());var s,l,u=t.collection,h=u.indexOf(t);i.getSelectedAll();if(i.getSelectedAll().forEach((function(t){var e=t.collection,n=e.indexOf(t);e===u&&(nh&&(l=Object(c.isUndefined)(l)?n:Math.min(l,n)))})),!Object(c.isUndefined)(s))for(;s!==h;)i.selectAdd(u.at(s)),s++;if(!Object(c.isUndefined)(l))for(;l!==h;)i.selectAdd(u.at(l)),l--;i.selectAdd(t)}else i.select(t);this.initResize(t)}},updateBadge:function(t,e){var n=y(t),r=this.canvas.getConfig(),i=r.pStylePrefix||"",o=r.customBadgeLabel;this.cacheEl=t;var a=n.data("model");if(a&&a.get("badgable")){var s=this.getBadge(),l=a.getIcon(),c="".concat(i,"badge"),u="".concat(l?'
').concat(l,"
"):"",'\n
').concat(a.getName(),"
");u=o?o(a):u,s.innerHTML=u;var h=s.style;h.display="block";var d=this.getCanvasPosition();if(d){var f=d.top,p=d.left,g=e.top-(s?s.offsetHeight:0),v=s?s.offsetWidth:0,m=g1&&void 0!==arguments[1]?arguments[1]:{},i=r.el,o=r.config,a=r.resizer,s=o.keyHeight,l=o.keyWidth,c=o.currentUnit,d=o.keepAutoHeight,f=o.keepAutoWidth;g("add",0,r),e=n.get("StyleManager").getModelToStyle(h);var p=getComputedStyle(i),v=e.getStyle(),y=v[l];o.autoWidth=f&&"auto"===y,isNaN(parseFloat(y))&&(y=p[l]);var b=v[s];o.autoHeight=d&&"auto"===b,isNaN(parseFloat(b))&&(b=p[s]),a.startDim.w=parseFloat(y),a.startDim.h=parseFloat(b),m=0,c&&(o.unitHeight=Object(u.h)(b),o.unitWidth=Object(u.h)(y))},onMove:function(){o.trigger("change:canvasOffset")},onEnd:function(t,e){g("remove",0,e),o.trigger("change:canvasOffset"),m=1},updateTarget:function(t,i){var o=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};if(e){var a=o.store,s=o.selectedHandler,l=o.config,c=l.keyHeight,u=l.keyWidth,h=l.autoHeight,d=l.autoWidth,f=l.unitWidth,p=l.unitHeight,g=["tc","bc"].indexOf(s)>=0,v=["cl","cr"].indexOf(s)>=0,m=e.getStyle();if(!g){var y=r.getBody().offsetWidth,b=i.w=a.height)&&(o.top=o.elementTop+o.elementHeight);var s=o.elementLeft+o.elementWidth,l=s-o.targetWidth;s>o.canvasWidth&&(l-=s-o.canvasWidth),l=l<0?0:l,i.top="".concat(o.top).concat("px"),i.left="".concat(l).concat("px"),i.opacity=""}},getCanvasPosition:function(){return this.canvas.getCanvasView().getPosition()},clean:function(){this.selEl&&this.selEl.removeClass(this.hoverClass)},getBadge:function(){return this.canvas.getBadgeEl()},onFrameScroll:function(){var t=this.cacheEl;if(t){var e=this.getElementPos(t);this.updateBadge(t,e);var n=this.em.getSelected(),r=n&&n.getEl();r&&this.updateToolbarPos(r)}},updateAttached:function(){var t=this.resizer,e=this.em.getSelected(),n=e&&e.view;if(n){var r=n.el;this.updateToolbarPos(r),this.showFixedElementOffset(r),t&&t.updateContainer()}},getElementPos:function(t,e){return this.canvas.getCanvasView().getElementPos(t)},hideBadge:function(){this.getBadge().style.display="none"},cleanPrevious:function(t){t&&t.set({status:"",state:""})},getContentWindow:function(){return this.frameEl.contentWindow},run:function(t){this.editor=t&&t.get("Editor"),this.enable(),this.onSelect()},stop:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},r=this.em,i=this.editor;this.stopSelectComponent(),!n.preserveSelected&&r.setSelected(null),this.clean(),this.onOut(),this.hideFixedElementOffset(),this.canvas.getToolbarEl().style.display="none",i&&i.stopCommand("resize"),r.off("component:update",this.updateAttached,this),r.off("change:canvasOffset",this.updateAttached,this)}}},function(t,e){t.exports=function(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}},function(t,e){function n(t,e){for(var n=0;n')},inputClass:function(){return"".concat(this.ppfx,"field")},holderClass:function(){return"".concat(this.ppfx,"input-holder")},initialize:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=t.ppfx||"";this.opts=t,this.ppfx=e,this.em=t.target||{},this.listenTo(this.model,"change:value",this.handleModelChange)},elementUpdated:function(){this.model.trigger("el:change")},setValue:function(t){var e=this.model,n=t||e.get("defaults"),r=this.getInputEl();r&&(r.value=n)},handleModelChange:function(t,e,n){this.setValue(e,n)},handleChange:function(t){t.stopPropagation();var e=this.getInputEl().value;this.model.set({value:e},{fromInput:1}),this.elementUpdated()},getInputEl:function(){if(!this.inputEl){var t=this.model,e=t.get("placeholder")||t.get("defaults")||"";this.inputEl=o(''))}return this.inputEl.get(0)},render:function(){this.inputEl=null;var t=this.$el;return t.addClass(this.inputClass()),t.html(this.template()),t.find(".".concat(this.holderClass())).append(this.getInputEl()),this}})},function(t,e,n){"use strict";n.r(e);var r=n(1),i=n.n(r),o=n(11);e.default=i.a.View.extend({initialize:function(t){this.config=t.config||{},this.pfx=this.config.stylePrefix||"",this.target=t.target||{},this.propTarget=t.propTarget||{},this.onChange=t.onChange,this.onInputRender=t.onInputRender||{},this.customValue=t.customValue||{},this.properties=[];var e=this.collection;this.listenTo(e,"add",this.addTo),this.listenTo(e,"reset",this.render)},addTo:function(t,e,n){this.add(t,null,n)},add:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},r=e||this.el,i=new t.typeView({model:t,name:t.get("name"),id:this.pfx+t.get("property"),target:this.target,propTarget:this.propTarget,onChange:this.onChange,onInputRender:this.onInputRender,config:this.config});"composite"!=t.get("type")&&(i.customValue=this.customValue),i.render();var a=i.el;this.properties.push(i),Object(o.a)(r,a,n.at)},render:function(){var t=this;this.properties=[];var e=document.createDocumentFragment();return this.collection.each((function(n){return t.add(n,e)})),this.$el.append(e),this.$el.attr("class","".concat(this.pfx,"properties")),this}})},function(t,e,n){"use strict";n.d(e,"a",(function(){return p}));var r=n(2),i=n.n(r),o=n(13),a=n.n(o),s=n(14),l=n.n(s),c=n(0),u=n(3);function h(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function d(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{};return a()(this,t),this.opts={container:null,onStart:null,onDrag:null,onEnd:null,setPosition:null,getPosition:null,guidesStatic:null,guidesTarget:null,snapOffset:5,doc:0,scale:1},Object(c.bindAll)(this,"drag","stop","keyHandle","handleScroll"),this.setOptions(e),this.delta=f(),this}return l()(t,[{key:"setOptions",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};this.opts=d({},this.opts,{},t)}},{key:"toggleDrag",value:function(t){var e=this.getDocumentEl(),n=this.getContainerEl(),r=this.getWindowEl(),i=t?"on":"off",o={on:u.p,off:u.o};o[i](n,"mousemove dragover",this.drag),o[i](e,"mouseup dragend touchend",this.stop),o[i](e,"keydown",this.keyHandle),o[i](r,"scroll",this.handleScroll)}},{key:"handleScroll",value:function(){var t=this.lastScroll,e=this.delta,n=this.getScrollInfo(),r={x:n.x-t.x,y:n.y-t.y};this.move(e.x+r.x,e.y+r.y),this.lastScrollDiff=r}},{key:"start",value:function(t){var e=this.opts,n=e.onStart;this.toggleDrag(1),this.startPointer=this.getPointerPos(t),this.guidesStatic=Object(c.result)(e,"guidesStatic")||[],this.guidesTarget=Object(c.result)(e,"guidesTarget")||[],Object(c.isFunction)(n)&&n(t,this),this.startPosition=this.getStartPosition(),this.lastScrollDiff=f(),this.globScrollDiff=f(),this.drag(t)}},{key:"drag",value:function(t){var e=this,n=this.opts,r=this.lastScrollDiff,i=this.globScrollDiff,o=n.onDrag,a=this.startPointer,s=this.getPointerPos(t),l={x:i.x+r.x,y:i.y+r.y};this.globScrollDiff=l;var u={x:s.x-a.x+l.x,y:s.y-a.y+l.y};this.lastScrollDiff=f();var h=this.lockedAxis;"x"===(h=t.shiftKey?!h&&this.detectAxisLock(u.x,u.y):null)?u.x=a.x:"y"===h&&(u.y=a.y);var p=function(r){["x","y"].forEach((function(t){return r[t]=r[t]*Object(c.result)(n,"scale")})),e.delta=r,e.move(r.x,r.y),Object(c.isFunction)(o)&&o(t,e)},g=d({},u);if(this.currentPointer=s,this.lockedAxis=h,this.lastScroll=this.getScrollInfo(),p(u),this.guidesTarget.length){var v=this.snapGuides(g),m=v.newDelta,y=v.trgX,b=v.trgY;(y||b)&&p(m)}0===t.which&&this.stop(t)}},{key:"snapGuides",value:function(t){var e=this,n=t,r=this.trgX,i=this.trgY;return this.guidesTarget.forEach((function(n){n.x&&e.trgX||n.y&&e.trgY||(n.active=0,e.guidesStatic.forEach((function(o){if(!(n.y&&o.x||n.x&&o.y)){var a=n.y&&o.y,s=a?"y":"x",l=n[s],u=o[s],h=t[s],d=a?i:r;if(e.isPointIn(l,u)&&Object(c.isUndefined)(d)){var f=h-(l-u);e.setGuideLock(n,f)}}})))})),r=this.trgX,i=this.trgY,["x","y"].forEach((function(r){var i=r.toUpperCase(),o=e["trg".concat(i)];o&&!e.isPointIn(t[r],o.lock)&&(e.setGuideLock(o,null),o=null),o&&!Object(c.isUndefined)(o.lock)&&(n[r]=o.lock)})),{newDelta:n,trgX:this.trgX,trgY:this.trgY}}},{key:"isPointIn",value:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},r=n.offset,i=r||this.opts.snapOffset;return t>=e&&t<=e+i||t<=e&&t>=e-i}},{key:"setGuideLock",value:function(t,e){var n=Object(c.isUndefined)(t.x)?"Y":"X",r="trg".concat(n);return null!==e?(t.active=1,t.lock=e,this[r]=t):(delete t.active,delete t.lock,delete this[r]),t}},{key:"stop",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=this.delta,r=e.cancel,i=r?0:n.x,o=r?0:n.y;this.toggleDrag(),this.lockedAxis=null,this.move(i,o,1);var a=this.opts.onEnd;Object(c.isFunction)(a)&&a(t,this,{cancelled:r})}},{key:"keyHandle",value:function(t){Object(u.j)(t)&&this.stop(t,{cancel:1})}},{key:"move",value:function(t,e,n){var r=this.el,i=this.opts,o=this.startPosition;if(o){var a=i.setPosition,s=o.x+t,l=o.y+e;this.position={x:s,y:l,end:n},Object(c.isFunction)(a)&&a(this.position),r&&(r.style.left="".concat(s,"px"),r.style.top="".concat(l,"px"))}}},{key:"getContainerEl",value:function(){var t=this.opts.container;return t?[t]:this.getDocumentEl()}},{key:"getWindowEl",value:function(){return this.getContainerEl().map((function(t){var e=t.ownerDocument||t;return e.defaultView||e.parentWindow}))}},{key:"getDocumentEl",value:function(t){var e=this.opts.doc;if(t=t||this.el,!this.docs){var n=[document];t&&n.push(t.ownerDocument),e&&n.push(e),this.docs=n}return this.docs}},{key:"getPointerPos",value:function(t){var e=this.opts.getPointerPosition,n=Object(u.g)(t);return e?e(t):{x:n.clientX,y:n.clientY}}},{key:"getStartPosition",value:function(){var t=this.el,e=this.opts.getPosition,n=f();return Object(c.isFunction)(e)?n=e():t&&(n={x:parseFloat(t.style.left),y:parseFloat(t.style.top)}),n}},{key:"getScrollInfo",value:function(){var t=this.opts.doc,e=t&&t.body;return{y:e?e.scrollTop:0,x:e?e.scrollLeft:0}}},{key:"detectAxisLock",value:function(t,e){var n=t,r=e,i=Math.abs(n),o=Math.abs(r);return r>=i||r<=-i?"x":n>o||n<-o?"y":void 0}}]),t}()},function(t,e,n){"use strict";var r,i=n(6),o=n.n(i),a=n(2),s=n.n(a),l=n(1),c=n.n(l),u=n(0);function h(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function d(t){for(var e=1;e1&&void 0!==arguments[1]?arguments[1]:{};this.opt=e,this.listenTo(this,"add",this.onAdd),this.config=e.config,this.em=e.em;var n=this.em;this.model=function(t,r){var i,o=e.componentTypes;r.em=e.em,r.config=e.config,r.componentTypes=o,r.domc=e.domc;for(var a=0;a1&&void 0!==arguments[1]?arguments[1]:{},i=this.em,o=i.get("CssComposer"),a=i.get("Parser").parseHtml(t);return r||(r=n(4).default),r.checkId(a.html,a.css,this.opt.domc.componentsById),a.css&&o&&!e.temporary&&o.addCollection(a.css,d({},e,{extend:1})),a.html},add:function(t){var e=this,n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};Object(u.isString)(t)?t=this.parseString(t,n):Object(u.isArray)(t)&&t.forEach((function(r,i){Object(u.isString)(r)&&(t[i]=e.parseString(r,n))}));var r=Object(u.isArray)(t);return t=(r?t:[t]).filter((function(t){return t})).map((function(t){return e.processDef(t)})),t=r?t:t[0],c.a.Collection.prototype.add.apply(this,[t,n])},processDef:function(t){if(t.cid&&t.ccid)return t;var e=this.em,n=this.config,r=(void 0===n?{}:n).processor,i=t;if(r){var a=r(i=d({},i));a&&(Object(u.each)(i,(function(t,e){return delete i[e]})),Object(u.extend)(i,a))}if(i.$$typeof&&"object"==o()(i.props)){(i=d({},i)).props=d({},i.props);var s=e.get("DomComponents"),l=e.get("Parser").parserHtml;Object(u.each)(i,(function(t,e){Object(u.includes)(["props","type"],e)||delete i[e]}));var c=i.props,h=c.children;delete c.children,delete i.props;var f=l.splitPropsFromAttr(c);i.attributes=f.attrs,h&&(i.components=h),i.type?s.getType(i.type)||(i.tagName=i.type,delete i.type):i.type="textnode",Object(u.extend)(i,f.props)}return i},onAdd:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},r=this.em,i=t.getStyle(),o=r&&r.getConfig("avoidInlineStyle");if(!Object(u.isEmpty)(i)&&!o&&r&&r.get&&r.getConfig("forceClass")&&!n.temporary){var a=t.cid;r.get("CssComposer").setClassRule(a,i);t.setStyle({}),t.addClass(a)}}})},function(t,e,n){"use strict";n.r(e);var r=n(1),i=n.n(r),o=i.a.$;e.default=i.a.View.extend({initialize:function(t){this.config=t||{},this.editorModel=this.em=this.config.em||{},this.pfx=this.config.stylePrefix,this.ppfx=this.config.pStylePrefix,this.hoverClass=this.pfx+"hover",this.badgeClass=this.pfx+"badge",this.plhClass=this.pfx+"placeholder",this.freezClass=this.ppfx+"freezed",this.canvas=this.em.get&&this.em.get("Canvas"),this.em.get&&this.setElement(this.getCanvas()),this.canvas&&(this.$canvas=this.$el,this.$wrapper=o(this.getCanvasWrapper()),this.frameEl=this.canvas.getFrameEl(),this.canvasTool=this.getCanvasTools(),this.bodyEl=this.getCanvasBody()),this.init(this.config)},onFrameScroll:function(t){},getCanvas:function(){return this.canvas.getElement()},getCanvasBody:function(){return this.canvas.getBody()},getCanvasWrapper:function(){return this.canvas.getWrapperEl()},getCanvasTools:function(){return this.canvas.getToolsEl()},offset:function(t){var e=t.getBoundingClientRect();return{top:e.top+t.ownerDocument.body.scrollTop,left:e.left+t.ownerDocument.body.scrollLeft}},init:function(t){},callRun:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=this.id;if(t.trigger("run:".concat(n,":before"),e),!e||!e.abort){var r=e.sender||t,i=this.run(t,r,e);return t.trigger("run:".concat(n),i,e),t.trigger("run",n,i,e),i}t.trigger("abort:".concat(n),e)},callStop:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=this.id,r=e.sender||t;t.trigger("stop:".concat(n,":before"),e);var i=this.stop(t,r,e);return t.trigger("stop:".concat(n),i,e),t.trigger("stop",n,i,e),i},stopCommand:function(){this.em.get("Commands").stop(this.id)},run:function(t,e){},stop:function(t,e){}})},function(t,e,n){"use strict";var r=n(2),i=n.n(r),o=n(0),a=n(3),s=n(26);function l(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function c(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{},n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};Object(o.isString)(e)&&(e=u(e));var r=this.getStyle(),i=c({},e);this.set("style",i,n);var s=Object(a.q)(r,i);return Object(o.keys)(s).forEach((function(e){var n=t.em;t.trigger("change:style:".concat(e)),n&&(n.trigger("styleable:change",t,e),n.trigger("styleable:change:".concat(e),t,e))})),i},addStyle:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"",n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};"string"==typeof t?t={prop:e}:n=e||{},t=this.extendStyle(t),this.setStyle(t,n)},removeStyle:function(t){var e=this.getStyle();delete e[t],this.setStyle(e)},styleToString:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=[],n=this.getStyle();for(var r in n){var i=t.important,a=Object(o.isArray)(i)?i.indexOf(r)>=0:i,s="".concat(n[r]).concat(a?" !important":"");s&&e.push("".concat(r,":").concat(s,";"))}return e.join("")},getSelectors:function(){return this.get("selectors")||this.get("classes")}}},function(t,e,n){"use strict";var r,i; +/*! cash-dom 1.3.7, https://github.com/kenwheeler/cash @license MIT */void 0===(i="function"==typeof(r=function(){var t,e=document,n=window,r=Array.prototype,i=r.slice,o=r.filter,a=r.push,s=function(){},l=function(t){return"function"==typeof t&&t.call},c=function(t){return"string"==typeof t},u=/^#[\w-]*$/,h=/^\.[\w-]*$/,d=/<.+>/,f=/^\w+$/;function p(t,n){return n=n||e,h.test(t)?n.getElementsByClassName(t.slice(1)):f.test(t)?n.getElementsByTagName(t):n.querySelectorAll(t)}function g(n){if(!t){var r=(t=e.implementation.createHTMLDocument(null)).createElement("base");r.href=e.location.href,t.head.appendChild(r)}return t.body.innerHTML=n,t.body.childNodes}function v(t){"loading"!==e.readyState?setTimeout(t):e.addEventListener("DOMContentLoaded",t)}function m(t,r){if(!t)return this;if(t.cash&&t!==n)return t;var i,o=t,a=0;if(c(t))o=u.test(t)?e.getElementById(t.slice(1)):d.test(t)?g(t):p(t,r);else if(l(t))return v(t),this;if(!o)return this;if(o.nodeType||o===n)this[0]=o,this.length=1;else for(i=this.length=o.length;a=0&&o.splice(r,1)):(w(o,(function(n){t.removeEventListener(e,n)})),o=[]))}function H(t,e){return"&"+encodeURIComponent(t)+"="+encodeURIComponent(e).replace(/%20/g,"+")}function $(t){var e=t.type;if(!e)return null;switch(e.toLowerCase()){case"select-one":return function(t){var e=t.selectedIndex;return e>=0?t.options[e].value:null}(t);case"select-multiple":return function(t){var e=[];return w(t.options,(function(t){t.selected&&e.push(t.value)})),e.length?e:null}(t);case"radio":case"checkbox":return t.checked?t.value:null;default:return t.value?t.value:null}}function W(t,e,n){var r=c(e);r||!e.length?w(t,r?function(t){return t.insertAdjacentHTML(n?"afterbegin":"beforeend",e)}:function(t,r){return function(t,e,n){if(n){var r=t.childNodes[0];t.insertBefore(e,r)}else t.appendChild(e)}(t,0===r?e:e.cloneNode(!0),n)}):w(e,(function(e){return W(t,e,n)}))}y.prefixedProp=_,y.camelCase=R,b.extend({css:function(t,e){if(c(t))return t=_(t),arguments.length>1?this.each((function(n){return n.style[t]=e})):n.getComputedStyle(this[0])[t];for(var r in t)this.css(r,t[r]);return this}}),w(["Width","Height"],(function(t){var e=t.toLowerCase();b[e]=function(){return this[0].getBoundingClientRect()[e]},b["inner"+t]=function(){return this[0]["client"+t]},b["outer"+t]=function(e){return this[0]["offset"+t]+(e?V(this,"margin"+("Width"===t?"Left":"Top"))+V(this,"margin"+("Width"===t?"Right":"Bottom")):0)}})),b.extend({off:function(t,e){return this.each((function(n){return z(n,t,e)}))},on:function(t,e,n,r){var i;if(!c(t)){for(var o in t)this.on(o,e,t[o]);return this}return l(e)&&(n=e,e=null),"ready"===t?(v(n),this):(e&&(i=n,n=function(t){for(var n=t.target;!x(n,e);){if(n===this)return!1;n=n.parentNode}n&&i.call(n,t)}),this.each((function(e){var i=n;r&&(i=function(){n.apply(this,arguments),z(e,t,i)}),function(t,e,n){var r=P(t,"_cashEvents")||T(t,"_cashEvents",{});r[e]=r[e]||[],r[e].push(n),t.addEventListener(e,n)}(e,t,i)})))},one:function(t,e,n){return this.on(t,e,n,!0)},ready:v,trigger:function(t,n){var r=e.createEvent("HTMLEvents");return r.data=n,r.initEvent(t,!0,!1),this.each((function(t){return t.dispatchEvent(r)}))}}),b.extend({serialize:function(){var t="";return w(this[0].elements||this,(function(e){if(!e.disabled&&"FIELDSET"!==e.tagName){var n=e.name;switch(e.type.toLowerCase()){case"file":case"reset":case"submit":case"button":break;case"select-multiple":var r=$(e);null!==r&&w(r,(function(e){t+=H(n,e)}));break;default:var i=$(e);null!==i&&(t+=H(n,i))}}})),t.substr(1)},val:function(t){return void 0===t?$(this[0]):this.each((function(e){return e.value=t}))}}),b.extend({after:function(t){return y(t).insertAfter(this),this},append:function(t){return W(this,t),this},appendTo:function(t){return W(y(t),this),this},before:function(t){return y(t).insertBefore(this),this},clone:function(){return y(this.map((function(t){return t.cloneNode(!0)})))},empty:function(){return this.html(""),this},html:function(t){if(void 0===t)return this[0].innerHTML;var e=t.nodeType?t[0].outerHTML:t;return this.each((function(t){return t.innerHTML=e}))},insertAfter:function(t){var e=this;return y(t).each((function(t,n){var r=t.parentNode,i=t.nextSibling;e.each((function(t){r.insertBefore(0===n?t:t.cloneNode(!0),i)}))})),this},insertBefore:function(t){var e=this;return y(t).each((function(t,n){var r=t.parentNode;e.each((function(e){r.insertBefore(0===n?e:e.cloneNode(!0),t)}))})),this},prepend:function(t){return W(this,t,!0),this},prependTo:function(t){return W(y(t),this,!0),this},remove:function(){return this.each((function(t){return t.parentNode.removeChild(t)}))},text:function(t){return void 0===t?this[0].textContent:this.each((function(e){return e.textContent=t}))}});var B=e.documentElement;return b.extend({position:function(){var t=this[0];return{left:t.offsetLeft,top:t.offsetTop}},offset:function(){var t=this[0].getBoundingClientRect();return{top:t.top+n.pageYOffset-B.clientTop,left:t.left+n.pageXOffset-B.clientLeft}},offsetParent:function(){return y(this[0].offsetParent)}}),b.extend({children:function(t){var e=[];return this.each((function(t){a.apply(e,t.children)})),e=O(e),t?e.filter((function(e){return x(e,t)})):e},closest:function(t){return!t||this.length<1?y():this.is(t)?this.filter(t):this.parent().closest(t)},is:function(t){if(!t)return!1;var e=!1,n=C(t);return this.each((function(r){return!(e=n(r,t))})),e},find:function(t){if(!t||t.nodeType)return y(t&&this.has(t).length?t:null);var e=[];return this.each((function(n){a.apply(e,p(t,n))})),O(e)},has:function(t){var e=c(t)?function(e){return 0!==p(t,e).length}:function(e){return e.contains(t)};return this.filter(e)},next:function(){return y(this[0].nextElementSibling)},not:function(t){if(!t)return this;var e=C(t);return this.filter((function(n){return!e(n,t)}))},parent:function(){var t=[];return this.each((function(e){e&&e.parentNode&&t.push(e.parentNode)})),O(t)},parents:function(t){var n,r=[];return this.each((function(i){for(n=i;n&&n.parentNode&&n!==e.body.parentNode;)n=n.parentNode,(!t||t&&x(n,t))&&r.push(n)})),O(r)},prev:function(){return y(this[0].previousElementSibling)},siblings:function(){var t=this.parent().children(),e=this[0];return t.filter((function(t){return t!==e}))}}),y})?r.call(e,n,e,t):r)||(t.exports=i)},function(t,e,n){"use strict";n.r(e);var r=n(2),i=n.n(r),o=n(1),a=n.n(o),s=n(27),l=n(0),c=n(3);function u(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function h(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{},e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=this.get("id")||"",r=this.get("name")||"";!this.get("property")&&this.set("property",(r||n).replace(/ /g,"-"));var i=this.get("property");!this.get("id")&&this.set("id",i),!r&&this.set("name",Object(c.b)(i).replace(/-/g," ")),d.callInit(this,t,e)},init:function(){},clearValue:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return this.set({value:void 0},t),this},setValue:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:1,n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},r=this.parseValue(t);this.set(r,h({},n,{avoidStore:1})),e&&(this.set("value","",n),this.set(r,n))},setValueFromInput:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};this.setValue(t,e,h({},n,{fromInput:1}))},parseValue:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n={value:t},r="!important";if(Object(l.isString)(t)&&-1!==t.indexOf(r)&&(n.value=t.replace(r,"").trim(),n.important=1),!this.get("functionName")&&!e.complete)return n;var i=[],o="".concat(n.value),a=o.indexOf("(")+1,s=o.lastIndexOf(")"),c=o.substring(0,a-1);if(c&&(n.functionName=c),i.push(a),s>=0&&i.push(s),n.value=String.prototype.substring.apply(o,i),e.numeric){var u=parseFloat(n.value);n.unit=n.value.replace(u,""),n.value=u}return n},getDefaultValue:function(){return this.get("defaults")},getFullValue:function(t){var e=this.get("functionName"),n=Object(l.isUndefined)(t)?this.get("value"):t,r=!Object(l.isUndefined)(n);return e&&r&&(n="".concat(e,"(").concat(n,")")),r&&this.get("important")&&(n="".concat(n," !important")),n||""}},{callParentInit:function(t,e,n){var r=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{};t.prototype.initialize.apply(e,[n,h({},r,{skipInit:1})])},callInit:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};!n.skipInit&&t.init(e,n)}}),f=d;function p(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}var g=f.extend({defaults:function(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{},e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};f.callParentInit(f,this,t,e);var r=this.get("properties")||[],i=n(22).default;this.set("properties",new i(r)),this.listenTo(this,"change:value",this.updateValues),f.callInit(this,t,e)},clearValue:function(){arguments.length>0&&void 0!==arguments[0]&&arguments[0];return this.get("properties").each((function(t){return t.clearValue()})),f.prototype.clearValue.apply(this,arguments)},updateValues:function(){var t=this.getFullValue().split(this.getSplitSeparator());this.get("properties").each((function(e,n){var r=t.length;t[n]||t[n%r+(1!=r&&r%2?1:0)]}))},getSplitSeparator:function(){return new RegExp("".concat(this.get("separator"),"(?![^\\(]*\\))"))},getDefaultValue:function(t){var e=this.get("defaults");return e&&!t?e:(e="",this.get("properties").each((function(t,n){return e+="".concat(t.getDefaultValue()," ")})),e.trim())},getFullValue:function(){return this.get("detached")?"":this.get("properties").getFullValue()},getPropertyAt:function(t){return this.get("properties").at(t)}}),v=a.a.Model.extend({defaults:{index:"",value:"",values:{},active:!1,preview:!1,properties:[]},initialize:function(){var t=this,e=this.get("properties"),n=this.get("value");if(this.set("properties",e instanceof Q?e:new Q(e)),this.get("properties").forEach((function(e){var n=t.collection;e.parent=n&&n.property})),!n){var r="",i=this.get("values");for(var o in i)r+=" "+i[o];this.set("value",r.trim())}},getPropertyAt:function(t){return this.get("properties").at(t)},getPropertyValue:function(t){var e="";return this.get("properties").each((function(n){n.get("property")==t&&(e=n.getFullValue())})),e},getFullValue:function(){var t=[];return this.get("properties").each((function(e){return t.push(e.getFullValue())})),t.join(" ")}});function m(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function y(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{},e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};g.callParentInit(g,this,t,e);var n=this.get("layers"),r=new b(n);r.property=this,r.properties=this.get("properties"),this.set("layers",r),g.callInit(this,t,e)},getLayers:function(){return this.get("layers")},getCurrentLayer:function(){return this.getLayers().filter((function(t){return t.get("active")}))[0]},getFullValue:function(){return this.get("detached")?"":this.get("layers").getFullValue()},getLayersFromTarget:function(t){}}),C=a.a.View.extend({template:function(t){var e=this.pfx;return'\n
\n ').concat(this.templateLabel(t),'\n
\n
\n ').concat(this.templateInput(t),"\n
\n ")},templateLabel:function(t){var e=this.pfx,n=t.get("icon")||"",r=t.get("info")||"",i=t.parent;return'\n \n ').concat(t.get("name"),"\n \n ").concat(i?"":'"),"\n ")},templateInput:function(t){return'\n
\n \n
\n ')},events:i()({change:"inputValueChanged"},"click [".concat("data-clear-style","]"),"clear"),initialize:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};Object(l.bindAll)(this,"targetUpdated"),this.config=e.config||{};var n=this.config.em;this.em=n,this.pfx=this.config.stylePrefix||"",this.ppfx=this.config.pStylePrefix||"",this.target=e.target||{},this.propTarget=e.propTarget||{},this.onChange=e.onChange,this.onInputRender=e.onInputRender||{},this.customValue=e.customValue||{};var r=this.model;this.property=r.get("property"),this.input=null;var i=this.pfx;this.inputHolderId="#"+i+"input-holder",this.sector=r.collection&&r.collection.sector,r.view=this,r.get("value")||r.set("value",r.getDefaultValue()),n&&n.on("update:component:style:".concat(this.property),this.targetUpdated);var o=r.get("requires");o&&Object.keys(o).forEach((function(e){n&&n.on("component:styleUpdate:".concat(e),t.targetUpdated)})),this.listenTo(this.propTarget,"update styleManager:update",this.targetUpdated),this.listenTo(r,"destroy remove",this.remove),this.listenTo(r,"change:value",this.modelValueChanged),this.listenTo(r,"targetUpdated",this.targetUpdated),this.listenTo(r,"change:visible",this.updateVisibility),this.listenTo(r,"change:status",this.updateStatus);var a=this.init&&this.init.bind(this);a&&a()},updateStatus:function(){var t=this.model,e=t.get("status"),n=t.parent,r=this.pfx,i=this.ppfx,o=this.config,a="".concat(i,"four-color"),s="".concat(i,"color-warn"),l=this.$el.children(".".concat(r,"label")),c=this.getClearEl(),u=c?c.style:{};switch(l.removeClass("".concat(a," ").concat(s)),u.display="none",e){case"updated":!n&&l.addClass(a),o.clearProperties&&(u.display="inline");break;case"computed":l.addClass(s)}},clear:function(t){var e=this;t&&t.stopPropagation(),this.model.clearValue(),setTimeout((function(){return e.targetUpdated()}))},getClearEl:function(){return this.clearEl||(this.clearEl=this.el.querySelector("[".concat("data-clear-style","]"))),this.clearEl},getTarget:function(){return this.getTargetModel()},getTargetModel:function(){return this.propTarget&&this.propTarget.model},getHelperModel:function(){return this.propTarget&&this.propTarget.helper},inputValueChanged:function(t){t&&t.stopPropagation(),this.model.setValue(this.getInputValue(),1,{fromInput:1}),this.elementUpdated()},elementUpdated:function(){this.setStatus("updated")},setStatus:function(t){this.model.set("status",t);var e=this.model.parent;e&&t&&e.set("status",t)},emitUpdateTarget:Object(l.debounce)((function(){var t=this.config.em;t&&t.trigger("styleManager:update:target",this.getTarget())})),targetUpdated:function(){if(this.emitUpdateTarget(),this.checkVisibility()){var t=this.config,e=t.em,n=this.model,r=n.get("property"),i="",o="",a=this.getTargetValue({ignoreDefault:1}),s=n.getDefaultValue(),l=this.getComputedValue();a?(i=a,t.highlightChanged&&(o="updated")):l&&t.showComputed&&l!=s?(i=l,t.highlightComputed&&(o="computed")):(i=s,o=""),n.setValue(i,0,{fromTarget:1}),this.setStatus(o),e&&(e.trigger("styleManager:change",this,r,i),e.trigger("styleManager:change:".concat(r),this,i))}},checkVisibility:function(){var t=1;return this.config.hideNotStylable&&(this.isTargetStylable()&&this.isComponentStylable()?this.show():(this.hide(),t=0),this.sector&&this.sector.trigger("updateVisibility")),t},getTargetValue:function(){var t,e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},n=this.model,r=this.getTargetModel(),i=this.customValue;if(!r)return t;if((t=r.getStyle()[n.get("property")])||e.ignoreDefault||(t=n.getDefaultValue()),"function"==typeof i&&!e.ignoreCustomValue){var o=n.collection.indexOf(n),a=i(this,o);a&&(t=a)}return t},getComputedValue:function(){var t=this.propTarget,e=t.computed||{},n=t.computedDefault||{},r=this.config.avoidComputed||[],i=this.model.get("property"),o=r.indexOf(i)<0,a=e[i],s=n[Object(c.a)(i)];return e&&o&&s!==a&&a},getInputValue:function(){var t=this.getInputEl();return t?t.value:""},modelValueChanged:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},r=this.config.em,i=this.model,o=i.getFullValue(),a=this.getTarget(),s=i.get("property"),l=this.onChange;if(n.fromInput||this.setValue(o),a&&this.isTargetStylable()&&this.isComponentStylable()){n.fromTarget||(l&&!n.fromParent?l(a,this,n):this.updateTargetStyle(o,null,n));var c=r&&r.getSelected();r&&c&&(r.trigger("component:update",c),r.trigger("component:styleUpdate",c,s),r.trigger("component:styleUpdate:".concat(s),c))}},updateTargetStyle:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"",n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},r=e||this.model.get("property"),i=this.getTarget(),o=i.getStyle();t?o[r]=t:delete o[r],i.setStyle(o,n);var a=this.getHelperModel();a&&a.setStyle(o,n)},isTargetStylable:function(t){var e=t||this.getTarget(),n=this.model,r=n.get("id"),i=n.get("property"),o=n.get("toRequire"),a=e.get("unstylable"),s=e.get("stylable-require"),c=n.get("requires"),u=n.get("requiresParent"),h=this.sector?this.sector.collection:null,d=this.em?this.em.getSelected():null,f=e.get("stylable");if(Object(l.isArray)(f)&&(f=f.indexOf(i)>=0),Object(l.isArray)(a)&&(f=a.indexOf(i)<0),o&&(f=!t||s&&(s.indexOf(r)>=0||s.indexOf(i)>=0)),h&&c){var p=Object.keys(c);h.each((function(t){t.get("properties").each((function(t){if(Object(l.includes)(p,t.id)){var e=c[t.id];f=f&&Object(l.includes)(e,t.get("value"))}}))}))}if(u){var g=d&&d.parent(),v=g&&g.getEl();if(v){var m=window.getComputedStyle(v);Object(l.each)(u,(function(t,e){f=f&&m[e]&&Object(l.includes)(t,m[e])}))}else f=!1}return f},isComponentStylable:function(){var t=this.em,e=t&&t.getSelected();return!e||this.isTargetStylable(e)},setRawValue:function(t){this.setValue(this.model.parseValue(t))},setValue:function(t){var e=this.model,n=Object(l.isUndefined)(t)?e.getDefaultValue():t,r=this.getInputEl();r&&(r.value=n)},getInputEl:function(){return this.input||(this.input=this.el.querySelector("input")),this.input},updateVisibility:function(){this.el.style.display=this.model.get("visible")?"block":"none"},show:function(){this.model.set("visible",1)},hide:function(){this.model.set("visible",0)},cleanValue:function(){this.setValue("")},clearCached:function(){this.clearEl=null,this.input=null,this.$input=null},render:function(){this.clearCached();var t=this.pfx,e=this.model,n=this.el,r=e.get("property"),i=e.get("full"),o="".concat(t,"property");n.innerHTML=this.template(e),n.className="".concat(o," ").concat(t).concat(e.get("type")," ").concat(o,"__").concat(r),n.className+=i?" ".concat(o,"--full"):"",this.updateStatus();var a=this.onRender&&this.onRender.bind(this);a&&a(),this.setValue(e.get("value"),{targetUpdate:1})}}),O=a.a.$,S=C.extend({templateInput:function(){var t=this.pfx;return'\n
\n \n
\n ')},inputValueChanged:function(){if(!this.model.get("detached")){for(var t=arguments.length,e=new Array(t),n=0;n'),this.input=this.$input.get(0)),this.props||(this.props=t.get("properties")),!this.$props)){this.props.each((function(e,n){e&&"composite"==e.get("type")&&(this.props.remove(e),console.warn("Nested composite types not yet allowed.")),e.parent=t}),this);var r=new(0,n(16).default)(this.getPropsConfig());this.$props=r.render().$el,this.properties=r.properties,this.$el.find("#".concat(this.pfx,"input-holder")).append(this.$props)}},getPropsConfig:function(t){var e=this,n=this.model,r={config:this.config,collection:this.props,target:this.target,propTarget:this.propTarget,onChange:function(t,e,r){n.set("value",n.getFullValue(),r)},customValue:function(t,n){return e.valueOnIndex(n,t)}};return n.get("detached")&&delete r.onChange,r},valueOnIndex:function(t,e){var n,r=this.getTargetValue({ignoreDefault:1});r?n=r.split(this.model.getSplitSeparator())[t]:n=e&&e.getTargetValue({ignoreCustomValue:1,ignoreDefault:1});return n},clearCached:function(){C.prototype.clearCached.apply(this,arguments),this.$input=null,this.props=null,this.$props=null}}),k=n(16),T=a.a.View.extend({events:{click:"active","click [data-close-layer]":"remove","mousedown [data-move-layer]":"initSorter","touchstart [data-move-layer]":"initSorter"},template:function(t){var e=this.pfx,n=this.ppfx,r=this.config,i="".concat(r.textLayer," ").concat(t.get("index"));return'\n
\n \n
\n
').concat(i,'
\n
\n \t
\n
\n
\n ⨯\n
\n
\n
\n ')},initialize:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=this.model;this.stackModel=t.stackModel||{},this.config=t.config||{},this.pfx=this.config.stylePrefix||"",this.ppfx=this.config.pStylePrefix||"",this.sorter=t.sorter||null,this.propsConfig=t.propsConfig||{},this.customPreview=t.onPreview,this.listenTo(e,"destroy remove",this.remove),this.listenTo(e,"change:active",this.updateVisibility),this.listenTo(e.get("properties"),"change",this.updatePreview),e.view=this,e.set({droppable:0,draggable:1}),this.$el.data("model",e)},initSorter:function(t){this.sorter&&this.sorter.startSort(this.el)},remove:function(t){t&&t.stopPropagation&&t.stopPropagation();var e=this.model,n=e.collection,r=this.stackModel;a.a.View.prototype.remove.apply(this,arguments),n.contains(e)&&n.remove(e),r&&r.set&&(r.set({stackIndex:null},{silent:!0}),r.trigger("updateValue"))},onPreview:function(t){var e=t.split(" "),n=[];return this.model.get("properties").each((function(t,r){var i=e[r]||"";if(i&&"integer"==t.get("type")){var o=parseInt(i,10),a=i.replace(o,"");i=(o=(o=(o=isNaN(o)?0:o)>3?3:o)<-3?-3:o)+a}n.push(i)})),n.join(" ")},updatePreview:function(){var t=this.stackModel,e=this.customPreview,n=this.getPreviewEl(),r=this.model.getFullValue(),i=e?e(r):this.onPreview(r);i&&t&&n&&(n.style[t.get("property")]=i)},getPropertiesWrapper:function(){return this.propsWrapEl||(this.propsWrapEl=this.el.querySelector("[data-properties]")),this.propsWrapEl},getPreviewEl:function(){return this.previewEl||(this.previewEl=this.el.querySelector("[data-preview]")),this.previewEl},active:function(){var t=this.model,e=t.collection;e.active(e.indexOf(t))},updateVisibility:function(){var t=this.pfx,e=this.getPropertiesWrapper(),n=this.model.get("active");e.style.display=n?"":"none",this.$el[n?"addClass":"removeClass"]("".concat(t,"active"))},render:function(){var t=this.propsConfig,e=this.model,n=this.el,r=this.pfx,i=e.get("preview"),o=new k.default({collection:e.get("properties"),config:this.config,target:t.target,customValue:t.customValue,propTarget:t.propTarget,onChange:t.onChange}).render().el;return n.innerHTML=this.template(e),n.className="".concat(r,"layer").concat(i?"":" ".concat(r,"no-preview")),this.getPropertiesWrapper().appendChild(o),this.updateVisibility(),this.updatePreview(),this}}),P=a.a.View.extend({initialize:function(t){this.config=t.config||{},this.stackModel=t.stackModel,this.preview=t.preview,this.pfx=this.config.stylePrefix||"",this.ppfx=this.config.pStylePrefix||"",this.propsConfig=t.propsConfig;var e=this.pfx,n=this.ppfx,r=this.collection;this.className="".concat(e,"layers ").concat(n,"field"),this.listenTo(r,"add",this.addTo),this.listenTo(r,"deselectAll",this.deselectAll),this.listenTo(r,"reset",this.render);var i=this.config.em||"",o=i?i.get("Utils"):"";this.sorter=o?new o.Sorter({container:this.el,ignoreViewChildren:1,containerSel:".".concat(e,"layers"),itemSel:".".concat(e,"layer"),pfx:this.config.pStylePrefix}):"",r.view=this,this.$el.data("model",r),this.$el.data("collection",r)},addTo:function(t){var e=this.collection.indexOf(t);this.addToCollection(t,null,e)},addToCollection:function(t,e,n){var r=e||null,i=this.stackModel,o=this.config,a=this.sorter,s=this.propsConfig;void 0!==this.preview&&t.set("preview",this.preview);var l=new T({model:t,config:o,sorter:a,stackModel:i,propsConfig:s}).render().el;if(r)r.appendChild(l);else if(void 0!==n){var c="before";this.$el.children().length==n&&(n--,c="after"),n<0?this.$el.append(l):this.$el.children().eq(n)[c](l)}else this.$el.append(l);return l},deselectAll:function(){this.$el.find("."+this.pfx+"layer").removeClass(this.pfx+"active")},render:function(){var t=document.createDocumentFragment();return this.$el.empty(),this.collection.each((function(e){this.addToCollection(e,t)}),this),this.$el.append(t),this.$el.attr("class",this.className),this.sorter&&(this.sorter.plh=null),this}}),j=S.extend({templateInput:function(){var t=this.pfx;this.ppfx;return'\n
\n \n
\n
\n ')},init:function(){var t=this.model;this.pfx;t.set("stackIndex",null),this.events["click [data-add-layer]"]="addLayer",this.listenTo(t,"change:stackIndex",this.indexChanged),this.listenTo(t,"updateValue",this.inputValueChanged),this.delegateEvents()},clear:function(t){t&&t.stopPropagation(),this.model.get("layers").reset(),this.model.clearValue(),this.targetUpdated()},targetUpdated:function(){if(this.model.get("detached"))this.checkVisibility();else{for(var t=arguments.length,e=new Array(t),n=0;n\n
\n
\n \n
\n
\n
\n
\n
\n
\n
\n \n ')},init:function(){var t=this.em;this.modal=t.get("Modal"),this.am=t.get("AssetManager"),this.events["click #"+this.pfx+"close"]="removeFile",this.events["click #"+this.pfx+"images"]="openAssetManager",this.delegateEvents()},onRender:function(){if(!this.$input){var t=this.model.getDefaultValue();this.$input=E(''))}this.$preview||(this.$preview=this.$el.find("#"+this.pfx+"preview-file")),this.$previewBox||(this.$previewBox=this.$el.find("#"+this.pfx+"preview-box")),this.setValue(this.componentValue,0)},clearCached:function(){C.prototype.clearCached.apply(this,arguments),this.$preview=null,this.$previewBox=null},setValue:function(t,e){C.prototype.setValue.apply(this,arguments),this.setPreviewView(t&&t!=this.model.getDefaultValue()),this.setPreview(t)},setPreviewView:function(t){var e=this.$previewBox;e&&e[t?"addClass":"removeClass"]("".concat(this.pfx,"show"))},spreadUrl:function(t){this.model.set("value",t),this.setPreviewView(1)},setPreview:function(t){var e=this.$preview;t=t&&t.indexOf("url(")<0?"url(".concat(t,")"):t,e&&e.css("background-image",t)},cleanValue:function(){this.setPreviewView(0),this.model.set({value:""},{silent:!0})},removeFile:function(){this.model.set("value",this.model.getDefaultValue());for(var t=arguments.length,e=new Array(t),n=0;n1&&void 0!==arguments[1]?arguments[1]:{};e=I({},e,{silent:1}),this.inputInst.setValue(t,e)},onRender:function(){if(!this.input){var t=this.ppfx,e=new L.a({target:this.target,model:this.model,ppfx:t}).render();this.el.querySelector(".".concat(t,"fields")).appendChild(e.el),this.$input=e.inputEl,this.$color=e.colorEl,this.input=this.$input.get(0),this.inputInst=e}}}),R=n(8),_=n.n(R);function V(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}var z=f.extend({defaults:function(){return function(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:[];return this.set("options",t),this},addOption:function(t){if(t){var e=this.getOptions();this.setOptions([].concat(_()(e),[t]))}return this}});function H(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}var $=z.extend({defaults:function(){return function(t){for(var e=1;e\n \n
\n
\n
\n \n ')},initialize:function(){for(var t=arguments.length,e=new Array(t),n=0;n").concat(e,"")}));var r=this.el.querySelector("#".concat(t,"input-holder"));r.innerHTML=""),this.input=r.firstChild}}})),B=C.extend({templateInput:function(){this.pfx;var t=this.ppfx;return'\n
\n
\n ')},onRender:function(){var t=this.pfx,e=this.ppfx,n="".concat(e,"radio-item-label"),r=this.model,i=r.get("property"),o=r.get("list")||r.get("options")||[];if(!this.input&&o&&o.length){var a="";o.forEach((function(r){var o=r.className?"".concat(r.className," ").concat(t,"icon ").concat(n):"",s="".concat(i,"-").concat(r.value),l=r.name||r.value,c=r.title?'title="'.concat(r.title,'"'):"";a+='\n
\n \n \n
\n ")}));var s=this.el.querySelector(".".concat(e,"field"));s.innerHTML='
').concat(a,"
"),this.input=s.firstChild}},getInputValue:function(){var t=this.getCheckedEl();return t?t.value:""},getCheckedEl:function(){var t=this.getInputEl();return t?t.querySelector("input:checked"):""},setValue:function(t){var e=this.model,n=t||e.get("value")||e.getDefaultValue(),r=this.getInputEl(),i=r?r.querySelector('[value="'.concat(n,'"]')):"";if(i)i.checked=!0;else{var o=this.getCheckedEl();o&&(o.checked=!1)}}}),U=n(28);function q(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}var G=f.extend({defaults:function(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{};return this.set({value:void 0,unit:void 0},t),this},parseValue:function(t){var e=f.prototype.parseValue.apply(this,arguments),n=this.input.validateInputValue(e.value,{deepCheck:1}),r=n.value,i=n.unit;return e.value=r,e.unit=i,e},getFullValue:function(){var t=this.get("value"),e=this.get("unit");return t=Object(l.isUndefined)(t)?"":t,e=!Object(l.isUndefined)(e)&&t?e:"",t="".concat(t).concat(e),f.prototype.getFullValue.apply(this,[t])}});function K(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}var Y=G.extend({defaults:function(t){for(var e=1;e\n \n \n ')},getSliderEl:function(){return this.slider||(this.slider=this.el.querySelector("input[type=range]")),this.slider},inputValueChanged:function(){var t=this.model,e=t.get("step");this.getInputEl().value=this.getSliderEl().value;var n=this.getInputValue()-e;t.set("value",n,{avoidStore:1}).set("value",n+e),this.elementUpdated()},inputValueChangedSoft:function(){this.getInputEl().value=this.getSliderEl().value,this.model.set("value",this.getInputValue(),{avoidStore:1}),this.elementUpdated()},setValue:function(t){var e=this.model.parseValue(t);this.getSliderEl().value=parseFloat(e.value),A.prototype.setValue.apply(this,arguments)},onRender:function(){A.prototype.onRender.apply(this,arguments),this.model.get("showInput")||(this.inputInst.el.style.display="none")},clearCached:function(){A.prototype.clearCached.apply(this,arguments),this.slider=null}});function Z(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}var Q=e.default=a.a.Collection.extend(s.a).extend({types:[{id:"stack",model:x,view:j,isType:function(t){if(t&&"stack"==t.type)return t}},{id:"composite",model:g,view:S,isType:function(t){if(t&&"composite"==t.type)return t}},{id:"file",model:f,view:M,isType:function(t){if(t&&"file"==t.type)return t}},{id:"color",model:f,view:F,isType:function(t){if(t&&"color"==t.type)return t}},{id:"select",model:$,view:W,isType:function(t){if(t&&"select"==t.type)return t}},{id:"radio",model:z,view:B,isType:function(t){if(t&&"radio"==t.type)return t}},{id:"slider",model:Y,view:J,isType:function(t){if(t&&"slider"==t.type)return t}},{id:"integer",model:G,view:A,isType:function(t){if(t&&"integer"==t.type)return t}},{id:"base",model:f,view:C,isType:function(t){return t.type="base",t}}],deepClone:function(){var t=this.clone();return t.reset(t.map((function(t){var e=t.clone();return e.typeView=t.typeView,e}))),t},parseValue:function(t){var e=this,n=[];return t.split(" ").forEach((function(t,r){var o=e.at(r);o&&n.push(function(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{},n={},r={};return Object(o.each)(e,(function(e,i){if(0===i.indexOf(t.modelAttrStart)){var a=i.replace("data-gjs-",""),s=e.length,l=e&&Object(o.isString)(e),c=l&&e.substr(0,1),u=l&&e.substr(s-1);e="false"!==(e="true"===e||e)&&e;try{e="{"==c&&"}"==u||"["==c&&"]"==u?JSON.parse(e):e}catch(t){}n[a]=e}else r[i]=e})),{props:n,attrs:r}},parseStyle:function(t){for(var e={},n=t.split(";"),r=0,i=n.length;r0&&void 0!==arguments[0]?arguments[0]:{},o=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};if(i&&i.type){var a=n.getBaseType();t=(r=n.getType(i.type))?r.model:a.model,e=r?r.view:a.view}else{var s=n.recognizeType(i);t=(r=s.type).model,e=r.view,i=s.attributes}var l=new t(i,o);return l.typeView=e,l};var r=this.init&&this.init.bind(this);r&&r()},recognizeType:function(t){for(var e=this.getTypes(),n=0;n\n \n
\n
\n
\n
\n ')},inputClass:function(){var t=this.ppfx;return this.opts.contClass||"".concat(t,"field ").concat(t,"field-integer")},initialize:function(){arguments.length>0&&void 0!==arguments[0]&&arguments[0];s.a.prototype.initialize.apply(this,arguments),Object(o.bindAll)(this,"moveIncrement","upIncrement"),this.doc=document,this.listenTo(this.model,"change:unit",this.handleModelChange)},setValue:function(t,e){var n=e||{},r=this.validateInputValue(t,{deepCheck:1}),i={value:r.value};(r.unit||r.force)&&(i.unit=r.unit),this.model.set(i,n),n.silent&&this.handleModelChange()},handleChange:function(t){t.stopPropagation(),this.setValue(this.getInputEl().value),this.elementUpdated()},handleUnitChange:function(t){t.stopPropagation();var e=this.getUnitEl().value;this.model.set("unit",e),this.elementUpdated()},elementUpdated:function(){this.model.trigger("el:change")},handleModelChange:function(){var t=this.model;this.getInputEl().value=t.get("value");var e=this.getUnitEl();e&&(e.value=t.get("unit")||"")},getUnitEl:function(){if(!this.unitEl){var t=this.model,e=t.get("units")||[];if(e.length){var n=[];e.forEach((function(e){var r=e==t.get("unit")?"selected":"";n.push(""))}));var r=document.createElement("div");r.innerHTML='"),this.unitEl=r.firstChild}}return this.unitEl},upArrowClick:function(){var t=this.model,e=t.get("step"),n=parseInt(t.get("value"),10);n=this.normalizeValue(n+e);var r=this.validateInputValue(n);t.set("value",r.value),this.elementUpdated()},downArrowClick:function(){var t=this.model,e=t.get("step"),n=parseInt(t.get("value"),10),r=this.normalizeValue(n-e),i=this.validateInputValue(r);t.set("value",i.value),this.elementUpdated()},downIncrement:function(t){t.preventDefault(),this.moved=0;var e=this.model.get("value");e=this.normalizeValue(e),this.current={y:t.pageY,val:e},Object(a.p)(this.doc,"mousemove",this.moveIncrement),Object(a.p)(this.doc,"mouseup",this.upIncrement)},moveIncrement:function(t){this.moved=1;var e=this.model,n=e.get("step"),r=this.current,i=this.normalizeValue(r.val+(r.y-t.pageY)*n);return this.prValue=this.validateInputValue(i).value,e.set("value",this.prValue,{avoidStore:1}),!1},upIncrement:function(){var t=this.model,e=t.get("step");if(Object(a.o)(this.doc,"mouseup",this.upIncrement),Object(a.o)(this.doc,"mousemove",this.moveIncrement),this.prValue&&this.moved){var n=this.prValue-e;t.set("value",n,{avoidStore:1}).set("value",n+e),this.elementUpdated()}},normalizeValue:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:0,n=this.model,r=n.get("step"),i=0;if(isNaN(t))return e;if(t=parseFloat(t),Math.floor(t)!==t){var o=r.toString().split(".")[1];i=o?o.length:0}return i?parseFloat(t.toFixed(i)):t},validateInputValue:function(t,e){var n=0,r=e||{},i=this.model,a=Object(o.isUndefined)(t)?"":t,s=i.get("units")||[],l=i.get("unit")||s.length&&s[0]||"",c=i.get("max"),u=i.get("min");if(r.deepCheck){var h=i.get("fixedValues")||[];if(a){var d=new RegExp("^"+h.join("|"),"g");if(h.length&&d.test(a))a=a.match(d)[0],l="",n=1;else{var f=a+"";a+="",a=parseFloat(a.replace(",",".")),a=isNaN(a)?"":a;var p=f.replace(a,"");Object(o.indexOf)(s,p)>=0&&(l=p)}}}return Object(o.isUndefined)(c)||""===c||(a=a>c?c:a),Object(o.isUndefined)(u)||""===u||(a=a2&&void 0!==arguments[2]?arguments[2]:{},i=this.config.em,o=t.view,a=t.opt.temporary,s=r.temporary;if(o){o.remove.apply(o);var l=o.childrenView,c=o.scriptContainer;if(l&&l.stopListening(),c&&c.remove(),t.components().forEach((function(t){return n.removeChildren(t,e,r)})),i&&!s){var u=t.getId(),h=i.get("DomComponents");delete h.componentsById[u];var d=i.get("CssComposer").getAll();if(d.remove(d.filter((function(t){return t.getSelectors().getFullString()==="#".concat(u)}))),!a){var f=i.get("Commands"),p=t.get("style-signature"),g={target:t};p&&f.run("core:component-style-clear",g),t.removed(),i.trigger("component:remove",t)}}}},addTo:function(t){arguments.length>1&&void 0!==arguments[1]&&arguments[1];var e=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},n=this.config.em,r=this.collection.indexOf(t);if(this.addToCollection(t,null,r),n&&!e.temporary){var i=function t(e){n.trigger("component:add",e),e.components().forEach((function(e){return t(e)}))};i(t)}},addToCollection:function(t,e,r){this.compView||(this.compView=n(5).default);for(var i=this.config,a=e||null,s=this.opts.componentTypes,l=t.get("type"),c=this.compView,u=0;u'):"",'\n
\n
\n
\n \n ').concat(g?'').concat(g,""):"",'\n ').concat(p,'\n
\n
\n
\n
').concat(a||"",'
\n
\n \n
\n
')},initialize:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};this.opt=t,this.level=t.level,this.config=t.config,this.em=t.config.em,this.ppfx=this.em.get("Config").stylePrefix,this.sorter=t.sorter||"",this.pfx=this.config.stylePrefix;var e=this.pfx,n=this.ppfx,r=this.model,i=r.get("components"),o=r.get("type")||"default";r.set("open",!1),this.listenTo(i,"remove add reset",this.checkChildren),this.listenTo(r,"change:status",this.updateStatus),this.listenTo(r,"change:open",this.updateOpening),this.listenTo(r,"change:style:display",this.updateVisibility),this.className="".concat(e,"layer ").concat(e,"layer__t-").concat(o," no-select ").concat(n,"two-color"),this.inputNameCls="".concat(n,"layer-name"),this.clsTitleC="".concat(e,"layer-title-c"),this.clsTitle="".concat(e,"layer-title"),this.clsCaret="".concat(e,"layer-caret"),this.clsCount="".concat(e,"layer-count"),this.clsMove="".concat(e,"layer-move"),this.clsChildren="".concat(e,"layer-children"),this.clsNoChild="".concat(e,"layer-no-chld"),this.clsEdit="".concat(this.inputNameCls,"--edit"),this.clsNoEdit="".concat(this.inputNameCls,"--no-edit"),this.$el.data("model",r),this.$el.data("collection",i),r.viewLayer=this},getVisibilityEl:function(){return this.eyeEl||(this.eyeEl=this.$el.children(".".concat(this.pfx,"layer-vis"))),this.eyeEl},updateVisibility:function(){var t=this.pfx,e=this.model,n="".concat(t,"layer-hidden"),r="none"==e.getStyle().display?"addClass":"removeClass";this.$el[r](n),this.getVisibilityEl()[r]("fa-eye-slash")},toggleVisibility:function(t){t&&t.stopPropagation();var e=this.model,n=e.getStyle();"none"==n.display?delete n.display:n.display="none",e.setStyle(n)},handleEdit:function(t){t&&t.stopPropagation();var e=this.em,n=this.$el,r=this.clsNoEdit,i=this.clsEdit,o=this.getInputName();o.contentEditable=!0,o.focus(),e&&e.setEditing(1),n.find(".".concat(this.inputNameCls)).removeClass(r).addClass(i)},handleEditEnd:function(t){t&&t.stopPropagation();var e=this.em,n=this.$el,r=this.clsNoEdit,i=this.clsEdit,o=this.getInputName(),a=o.textContent;o.scrollLeft=0,o.contentEditable=!1,this.model.set({name:a}),e&&e.setEditing(0),n.find(".".concat(this.inputNameCls)).addClass(r).removeClass(i)},getInputName:function(){return this.inputName||(this.inputName=this.el.querySelector(".".concat(this.inputNameCls))),this.inputName},updateOpening:function(){var t=this.opt.opened||{},e=this.model;e.get("open")?(this.$el.addClass("open"),this.getCaret().addClass("fa-chevron-down"),t[e.cid]=e):(this.$el.removeClass("open"),this.getCaret().removeClass("fa-chevron-down"),delete t[e.cid])},toggleOpening:function(t){t.stopPropagation(),this.model.get("components").length&&this.model.set("open",!this.model.get("open"))},handleSelect:function(t){t.stopPropagation();var e=this.em,n=this.config;if(e){var r=this.model;e.setSelected(r,{fromLayers:1});var i=n.scrollCanvas;i&&e.get("Canvas").scrollTo(r,i)}},handleHover:function(t){t.stopPropagation();var e=this.em,n=this.config,r=this.model;e&&n.showHover&&e.setHovered(r,{fromLayers:1})},startSort:function(t){t.stopPropagation();var e=this.sorter;t.button&&0!==t.button||e&&e.startSort(t.target)},freeze:function(){this.$el.addClass(this.pfx+"opac50"),this.model.set("open",0)},unfreeze:function(){this.$el.removeClass(this.pfx+"opac50")},updateStatus:function(t){l.default.prototype.updateStatus.apply(this,[{avoidHover:!this.config.highlightHover}])},isVisible:function(){var t=this.model.get("style").display;if(!t||"none"!=t)return 1},checkChildren:function(){var t=this.model,e=this.countChildren(t),n=(this.pfx,this.clsNoChild),r=this.$el.children(".".concat(this.clsTitleC)).children(".".concat(this.clsTitle));this.cnt||(this.cnt=this.$el.children(".".concat(this.clsCount))),e?(r.removeClass(n),this.cnt.html(e)):(r.addClass(n),this.cnt.empty(),t.set("open",0))},countChildren:function(t){var e=0;return t.get("components").each((function(t){var n=this.opt.isCountable,r=this.config.hideTextnode;n&&!n(t,r)||e++}),this),e},getCaret:function(){if(!this.caret||!this.caret.length){this.pfx;this.caret=this.$el.children(".".concat(this.clsTitleC)).find(".".concat(this.clsCaret))}return this.caret},setRoot:function(t){t=Object(i.isString)(t)?this.em.getWrapper().find(t)[0]:t;var e=Object(o.f)(t,c);e&&(this.stopListening(),this.model=e,this.initialize(this.opt),this.render())},render:function(){var t=this.model,e=this.config,o=this.pfx,a=this.ppfx,s=this.opt.isCountable,l=s&&!s(t,e.hideTextnode),c=this.isVisible(),u=this.$el.empty(),h=this.level+1;Object(i.isUndefined)(r)&&(r=n(82).default);var d=new r({collection:t.get("components"),config:this.config,sorter:this.sorter,opened:this.opt.opened,parent:t,level:h}).render().$el;return this.config.showWrapper||1!==h?(u.html(this.template(t)),u.find(".".concat(this.clsChildren)).append(d)):u.append(d),t.get("draggable")&&this.config.sortable||u.children(".".concat(this.clsMove)).remove(),!c&&(this.className+=" ".concat(o,"hide")),l&&(this.className+=" ".concat(a,"hidden")),u.attr("class",this.className),this.updateOpening(),this.updateStatus(),this.updateVisibility(),this}})},function(t,e,n){"use strict";var r=n(2),i=n.n(r),o=n(1),a=n.n(o),s=n(0),l=n(6),c=n.n(l),u=n(15);function h(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}var d=a.a.$;!function(t,e){var n={beforeShow:h,move:h,change:h,show:h,hide:h,color:!1,flat:!1,showInput:!1,allowEmpty:!1,showButtons:!0,clickoutFiresChange:!0,showInitial:!1,showPalette:!1,showPaletteOnly:!1,hideAfterPaletteSelect:!1,togglePaletteOnly:!1,showSelectionPalette:!0,localStorageKey:!1,appendTo:"body",maxSelectionSize:7,cancelText:"cancel",chooseText:"choose",togglePaletteMoreText:"more",togglePaletteLessText:"less",clearText:"Clear Color Selection",noColorSelectedText:"No Color Selected",preferredFormat:!1,className:"",containerClassName:"",replacerClassName:"",showAlpha:!1,theme:"sp-light",palette:[["#ffffff","#000000","#ff0000","#ff8000","#ffff00","#008000","#0000ff","#4b0082","#9400d3"]],selectionPalette:[],disabled:!1,offset:null},r=[],i=!!/msie/i.exec(window.navigator.userAgent),o=function(){function t(t,e){return!!~(""+t).indexOf(e)}var e=document.createElement("div").style;return e.cssText="background-color:rgba(0,0,0,.5)",t(e.backgroundColor,"rgba")||t(e.backgroundColor,"hsla")}(),a=["
","
","
","
"].join(""),s=function(){var t="";if(i)for(var e=1;e<=6;e++)t+="
";return["
","
","
","
","","
","
","
","
","
","
","
","
","
","
","
","
","
","
","
","
","
",t,"
","
","
","
","
","","
","
","
","","","
","
","
"].join("")}();function l(e,n,r,i){for(var a=[],s=0;s')}else{a.push(t("
").append(t('').attr("title",i.noColorSelectedText)).html())}}return"
"+a.join("")+"
"}function u(c,u){var h,v,m,y,b=function(e,r){var i=t.extend({},n,e);return i.callbacks={move:f(i.move,r),change:f(i.change,r),show:f(i.show,r),hide:f(i.hide,r),beforeShow:f(i.beforeShow,r)},i}(u,c),w=b.flat,x=b.showSelectionPalette,C=b.localStorageKey,O=b.theme,S=b.callbacks,T=(h=Bt,v=10,function(){var t=this,e=arguments,n=function(){y=null,h.apply(t,e)};m&&clearTimeout(y),!m&&y||(y=setTimeout(n,v))}),P=!1,j=!1,E=0,M=0,D=0,A=0,L=0,N=0,I=0,F=0,R=0,_=0,V=1,z=[],H=[],$={},W=b.selectionPalette.slice(0),B=b.maxSelectionSize,U="sp-dragging",q=null,G=c.ownerDocument,K=(G.body,t(c)),Y=!1,X=t(s,G).addClass(O),J=X.find(".sp-picker-container"),Z=X.find(".sp-color"),Q=X.find(".sp-dragger"),tt=X.find(".sp-hue"),et=X.find(".sp-slider"),nt=X.find(".sp-alpha-inner"),rt=X.find(".sp-alpha"),it=X.find(".sp-alpha-handle"),ot=X.find(".sp-input"),at=X.find(".sp-palette"),st=X.find(".sp-initial"),lt=X.find(".sp-cancel"),ct=X.find(".sp-clear"),ut=X.find(".sp-choose"),ht=X.find(".sp-palette-toggle"),dt=K.is("input"),ft=dt&&"color"===K.attr("type")&&g(),pt=dt&&!w,gt=pt?t(a).addClass(O).addClass(b.className).addClass(b.replacerClassName):t([]),vt=pt?gt:K,mt=gt.find(".sp-preview-inner"),yt=b.color||dt&&K.val(),bt=!1,wt=b.preferredFormat,xt=!b.showButtons||b.clickoutFiresChange,Ct=!yt,Ot=b.allowEmpty&&!ft;function St(){if(b.showPaletteOnly&&(b.showPalette=!0),ht.text(b.showPaletteOnly?b.togglePaletteMoreText:b.togglePaletteLessText),b.palette){z=b.palette.slice(0),H=t.isArray(z[0])?z:[z],$={};for(var e=0;e1&&(delete window.localStorage[C],t.each(e,(function(t,e){Tt(e)})))}catch(t){}try{W=window.localStorage[C].split(";")}catch(t){}}}function Tt(e){if(x){var n=k(e).toRgbString();if(!$[n]&&-1===t.inArray(n,W))for(W.push(n);W.length>B;)W.shift();if(C&&window.localStorage)try{window.localStorage[C]=W.join(";")}catch(t){}}}function Pt(){var e=Vt(),n=t.map(H,(function(t,n){return l(t,e,"sp-palette-row sp-palette-row-"+n,b)}));kt(),W&&n.push(l(function(){var t=[];if(b.showPalette)for(var e=0;ed&&d>r?Math.abs(p.left+r-d):0),p.top-=Math.min(p.top,p.top+i>f&&f>i?Math.abs(i+o-0):0),p}(X,vt))),$t(),b.showPalette&&Pt(),K.trigger("reflow.spectrum"))}function Ut(){Ft(),Y=!0,K.attr("disabled",!0),vt.addClass("sp-disabled")}!function(){if(i&&X.find("*:not(input)").attr("unselectable","on"),St(),pt&&K.after(gt).hide(),Ot||ct.hide(),w)K.after(X).hide();else{var e="parent"===b.appendTo?K.parent():t(b.appendTo);1!==e.length&&(e=t("body")),e.append(X)}function n(e){return e.data&&e.data.ignore?(_t(t(e.target).closest(".sp-thumb-el").data("color")),zt()):(_t(t(e.target).closest(".sp-thumb-el").data("color")),zt(),Wt(!0),b.hideAfterPaletteSelect&&Ft()),!1}kt(),vt.bind("click.spectrum touchstart.spectrum",(function(e){Y||At(),e.stopPropagation(),t(e.target).is("input")||e.preventDefault()})),(K.is(":disabled")||!0===b.disabled)&&Ut(),X.click(d),ot.change(Dt),ot.bind("paste",(function(){setTimeout(Dt,1)})),ot.keydown((function(t){13==t.keyCode&&Dt()})),lt.text(b.cancelText),lt.bind("click.spectrum",(function(t){t.stopPropagation(),t.preventDefault(),Rt(),Ft()})),ct.attr("title",b.clearText),ct.bind("click.spectrum",(function(t){t.stopPropagation(),t.preventDefault(),Ct=!0,zt(),w&&Wt(!0)})),ut.text(b.chooseText),ut.bind("click.spectrum",(function(t){t.stopPropagation(),t.preventDefault(),i&&ot.is(":focus")&&ot.trigger("change"),ot.hasClass("sp-validation-error")||(Wt(!0),Ft())})),ht.text(b.showPaletteOnly?b.togglePaletteMoreText:b.togglePaletteLessText),ht.bind("click.spectrum",(function(t){t.stopPropagation(),t.preventDefault(),b.showPaletteOnly=!b.showPaletteOnly,b.showPaletteOnly||w||X.css("left","-="+(J.outerWidth(!0)+5)),St()})),p(rt,(function(t,e,n){V=t/L,Ct=!1,n.shiftKey&&(V=Math.round(10*V)/10),zt()}),Et,Mt),p(tt,(function(t,e){F=parseFloat(e/A),Ct=!1,b.showAlpha||(V=1),zt()}),Et,Mt),p(Z,(function(t,e,n){if(n.shiftKey){if(!q){var r=R*E,i=M-_*M,o=Math.abs(t-r)>Math.abs(e-i);q=o?"x":"y"}}else q=null;var a=!q||"y"===q;(!q||"x"===q)&&(R=parseFloat(t/E)),a&&(_=parseFloat((M-e)/M)),Ct=!1,b.showAlpha||(V=1),zt()}),Et,Mt),yt?(_t(yt),Ht(),wt=b.preferredFormat||k(yt).format,Tt(yt)):Ht(),w&&Lt();var r=i?"mousedown.spectrum":"click.spectrum touchstart.spectrum";at.delegate(".sp-thumb-el",r,n),st.delegate(".sp-thumb-el:nth-child(1)",r,{ignore:!0},n)}();var qt={show:Lt,hide:Ft,toggle:At,reflow:Bt,option:function(n,r){return n===e?t.extend({},b):r===e?b[n]:(b[n]=r,"preferredFormat"===n&&(wt=b.preferredFormat),void St())},enable:function(){Y=!1,K.attr("disabled",!1),vt.removeClass("sp-disabled")},disable:Ut,offset:function(t){b.offset=t,Bt()},set:function(t){_t(t),Wt()},get:Vt,destroy:function(){K.show(),vt.unbind("click.spectrum touchstart.spectrum"),X.remove(),gt.remove(),r[qt.id]=null},container:X};return qt.id=r.push(qt)-1,qt}function h(){}function d(t){t.stopPropagation()}function f(t,e){var n=Array.prototype.slice,r=n.call(arguments,2);return function(){return t.apply(e,r.concat(n.call(arguments)))}}function p(e,n,r,o){n=n||function(){},r=r||function(){},o=o||function(){};var a=document,s=!1,l={},c=0,u=0,h="ontouchstart"in window,d={};function f(t){t.stopPropagation&&t.stopPropagation(),t.preventDefault&&t.preventDefault(),t.returnValue=!1}function p(t){if(s){if(i&&a.documentMode<9&&!t.button)return g();var r=t&&t.touches&&t.touches[0],o=r&&r.pageX||t.pageX,d=r&&r.pageY||t.pageY,p=Math.max(0,Math.min(o-l.left,u)),v=Math.max(0,Math.min(d-l.top,c));h&&f(t),n.apply(e,[p,v,t])}}function g(){s&&(t(a).unbind(d),t(a.body).removeClass("sp-dragging"),setTimeout((function(){o.apply(e,arguments)}),0)),s=!1}d.selectstart=f,d.dragstart=f,d["touchmove mousemove"]=p,d["touchend mouseup"]=g,t(e).bind("touchstart mousedown",(function(n){(n.which?3==n.which:2==n.button)||s||!1!==r.apply(e,arguments)&&(s=!0,c=t(e).height(),u=t(e).width(),l=t(e).offset(),t(a).bind(d),t(a.body).addClass("sp-dragging"),p(n),f(n))}))}function g(){return t.fn.spectrum.inputTypeColorSupport()}var v="spectrum.id";t.fn.spectrum=function(e,n){if("string"==typeof e){var i=this,o=Array.prototype.slice.call(arguments,1);return this.each((function(){var n=r[t(this).data(v)];if(n){var a=n[e];if(!a)throw new Error("Spectrum: no such method: '"+e+"'");"get"==e?i=n.get():"container"==e?i=n.container:"option"==e?i=n.option.apply(n,o):"destroy"==e?(n.destroy(),t(this).removeData(v)):a.apply(n,o)}})),i}return this.spectrum("destroy").each((function(){var n=u(this,t.extend({},e,t(this).data()));t(this).data(v,n.id)}))},t.fn.spectrum.load=!0,t.fn.spectrum.loadOpts={},t.fn.spectrum.draggable=p,t.fn.spectrum.defaults=n,t.fn.spectrum.inputTypeColorSupport=function e(){if(void 0===e._cachedResult){var n=t("")[0];e._cachedResult="color"===n.type&&""!==n.value}return e._cachedResult},t.spectrum={},t.spectrum.localization={},t.spectrum.palettes={},t.fn.spectrum.processNativeColorInputs=function(){var e=t("input[type=color]");e.length&&!g()&&e.spectrum({preferredFormat:"hex6"})};var m=/^[\s,#]+/,y=/\s+$/,b=0,w=Math,x=w.round,C=w.min,O=w.max,S=w.random,k=function t(e,n){if(n=n||{},(e=e||"")instanceof t)return e;if(!(this instanceof t))return new t(e,n);var r=function(t){var e={r:0,g:0,b:0},n=1,r=!1,i=!1;"string"==typeof t&&(t=function(t){t=t.replace(m,"").replace(y,"").toLowerCase();var e,n=!1;if(W[t])t=W[t],n=!0;else if("transparent"==t)return{r:0,g:0,b:0,a:0,format:"name"};if(e=tt.rgb.exec(t))return{r:e[1],g:e[2],b:e[3]};if(e=tt.rgba.exec(t))return{r:e[1],g:e[2],b:e[3],a:e[4]};if(e=tt.hsl.exec(t))return{h:e[1],s:e[2],l:e[3]};if(e=tt.hsla.exec(t))return{h:e[1],s:e[2],l:e[3],a:e[4]};if(e=tt.hsv.exec(t))return{h:e[1],s:e[2],v:e[3]};if(e=tt.hsva.exec(t))return{h:e[1],s:e[2],v:e[3],a:e[4]};if(e=tt.hex8.exec(t))return{a:(r=e[1],K(r)/255),r:K(e[2]),g:K(e[3]),b:K(e[4]),format:n?"name":"hex8"};var r;if(e=tt.hex6.exec(t))return{r:K(e[1]),g:K(e[2]),b:K(e[3]),format:n?"name":"hex"};if(e=tt.hex3.exec(t))return{r:K(e[1]+""+e[1]),g:K(e[2]+""+e[2]),b:K(e[3]+""+e[3]),format:n?"name":"hex"};return!1}(t));"object"==c()(t)&&(t.hasOwnProperty("r")&&t.hasOwnProperty("g")&&t.hasOwnProperty("b")?(o=t.r,a=t.g,s=t.b,e={r:255*q(o,255),g:255*q(a,255),b:255*q(s,255)},r=!0,i="%"===String(t.r).substr(-1)?"prgb":"rgb"):t.hasOwnProperty("h")&&t.hasOwnProperty("s")&&t.hasOwnProperty("v")?(t.s=X(t.s),t.v=X(t.v),e=function(t,e,n){t=6*q(t,360),e=q(e,100),n=q(n,100);var r=w.floor(t),i=t-r,o=n*(1-e),a=n*(1-i*e),s=n*(1-(1-i)*e),l=r%6;return{r:255*[n,a,o,o,s,n][l],g:255*[s,n,n,a,o,o][l],b:255*[o,o,s,n,n,a][l]}}(t.h,t.s,t.v),r=!0,i="hsv"):t.hasOwnProperty("h")&&t.hasOwnProperty("s")&&t.hasOwnProperty("l")&&(t.s=X(t.s),t.l=X(t.l),e=function(t,e,n){var r,i,o;function a(t,e,n){return n<0&&(n+=1),n>1&&(n-=1),n<1/6?t+6*(e-t)*n:n<.5?e:n<2/3?t+(e-t)*(2/3-n)*6:t}if(t=q(t,360),e=q(e,100),n=q(n,100),0===e)r=i=o=n;else{var s=n<.5?n*(1+e):n+e-n*e,l=2*n-s;r=a(l,s,t+1/3),i=a(l,s,t),o=a(l,s,t-1/3)}return{r:255*r,g:255*i,b:255*o}}(t.h,t.s,t.l),r=!0,i="hsl"),t.hasOwnProperty("a")&&(n=t.a));var o,a,s;return n=U(n),{ok:r,format:t.format||i,r:C(255,O(e.r,0)),g:C(255,O(e.g,0)),b:C(255,O(e.b,0)),a:n}}(e);this._originalInput=e,this._r=r.r,this._g=r.g,this._b=r.b,this._a=r.a,this._roundA=x(100*this._a)/100,this._format=n.format||r.format,this._gradientType=n.gradientType,this._r<1&&(this._r=x(this._r)),this._g<1&&(this._g=x(this._g)),this._b<1&&(this._b=x(this._b)),this._ok=r.ok,this._tc_id=b++};function T(t,e,n){t=q(t,255),e=q(e,255),n=q(n,255);var r,i,o=O(t,e,n),a=C(t,e,n),s=(o+a)/2;if(o==a)r=i=0;else{var l=o-a;switch(i=s>.5?l/(2-o-a):l/(o+a),o){case t:r=(e-n)/l+(e>1)+720)%360;--e;)r.h=(r.h+i)%360,o.push(k(r));return o}function $(t,e){e=e||6;for(var n=k(t).toHsv(),r=n.h,i=n.s,o=n.v,a=[],s=1/e;e--;)a.push(k({h:r,s:i,v:o})),o=(o+s)%1;return a}k.prototype={isDark:function(){return this.getBrightness()<128},isLight:function(){return!this.isDark()},isValid:function(){return this._ok},getOriginalInput:function(){return this._originalInput},getFormat:function(){return this._format},getAlpha:function(){return this._a},getBrightness:function(){var t=this.toRgb();return(299*t.r+587*t.g+114*t.b)/1e3},setAlpha:function(t){return this._a=U(t),this._roundA=x(100*this._a)/100,this},toHsv:function(){var t=P(this._r,this._g,this._b);return{h:360*t.h,s:t.s,v:t.v,a:this._a}},toHsvString:function(){var t=P(this._r,this._g,this._b),e=x(360*t.h),n=x(100*t.s),r=x(100*t.v);return 1==this._a?"hsv("+e+", "+n+"%, "+r+"%)":"hsva("+e+", "+n+"%, "+r+"%, "+this._roundA+")"},toHsl:function(){var t=T(this._r,this._g,this._b);return{h:360*t.h,s:t.s,l:t.l,a:this._a}},toHslString:function(){var t=T(this._r,this._g,this._b),e=x(360*t.h),n=x(100*t.s),r=x(100*t.l);return 1==this._a?"hsl("+e+", "+n+"%, "+r+"%)":"hsla("+e+", "+n+"%, "+r+"%, "+this._roundA+")"},toHex:function(t){return j(this._r,this._g,this._b,t)},toHexString:function(t){return"#"+this.toHex(t)},toHex8:function(){return E(this._r,this._g,this._b,this._a)},toHex8String:function(){return"#"+this.toHex8()},toRgb:function(){return{r:x(this._r),g:x(this._g),b:x(this._b),a:this._a}},toRgbString:function(){return 1==this._a?"rgb("+x(this._r)+", "+x(this._g)+", "+x(this._b)+")":"rgba("+x(this._r)+", "+x(this._g)+", "+x(this._b)+", "+this._roundA+")"},toPercentageRgb:function(){return{r:x(100*q(this._r,255))+"%",g:x(100*q(this._g,255))+"%",b:x(100*q(this._b,255))+"%",a:this._a}},toPercentageRgbString:function(){return 1==this._a?"rgb("+x(100*q(this._r,255))+"%, "+x(100*q(this._g,255))+"%, "+x(100*q(this._b,255))+"%)":"rgba("+x(100*q(this._r,255))+"%, "+x(100*q(this._g,255))+"%, "+x(100*q(this._b,255))+"%, "+this._roundA+")"},toName:function(){return 0===this._a?"transparent":!(this._a<1)&&(B[j(this._r,this._g,this._b,!0)]||!1)},toFilter:function(t){var e="#"+E(this._r,this._g,this._b,this._a),n=e,r=this._gradientType?"GradientType = 1, ":"";t&&(n=k(t).toHex8String());return"progid:DXImageTransform.Microsoft.gradient("+r+"startColorstr="+e+",endColorstr="+n+")"},toString:function(t){var e=!!t;t=t||this._format;var n=!1,r=this._a<1&&this._a>=0;return e||!r||"hex"!==t&&"hex6"!==t&&"hex3"!==t&&"name"!==t?("rgb"===t&&(n=this.toRgbString()),"prgb"===t&&(n=this.toPercentageRgbString()),"hex"!==t&&"hex6"!==t||(n=this.toHexString()),"hex3"===t&&(n=this.toHexString(!0)),"hex8"===t&&(n=this.toHex8String()),"name"===t&&(n=this.toName()),"hsl"===t&&(n=this.toHslString()),"hsv"===t&&(n=this.toHsvString()),n||this.toHexString()):"name"===t&&0===this._a?this.toName():this.toRgbString()},_applyModification:function(t,e){var n=t.apply(null,[this].concat([].slice.call(e)));return this._r=n._r,this._g=n._g,this._b=n._b,this.setAlpha(n._a),this},lighten:function(){return this._applyModification(L,arguments)},brighten:function(){return this._applyModification(N,arguments)},darken:function(){return this._applyModification(I,arguments)},desaturate:function(){return this._applyModification(M,arguments)},saturate:function(){return this._applyModification(D,arguments)},greyscale:function(){return this._applyModification(A,arguments)},spin:function(){return this._applyModification(F,arguments)},_applyCombination:function(t,e){return t.apply(null,[this].concat([].slice.call(e)))},analogous:function(){return this._applyCombination(H,arguments)},complement:function(){return this._applyCombination(R,arguments)},monochromatic:function(){return this._applyCombination($,arguments)},splitcomplement:function(){return this._applyCombination(z,arguments)},triad:function(){return this._applyCombination(_,arguments)},tetrad:function(){return this._applyCombination(V,arguments)}},k.fromRatio=function(t,e){if("object"==c()(t)){var n={};for(var r in t)t.hasOwnProperty(r)&&(n[r]="a"===r?t[r]:X(t[r]));t=n}return k(t,e)},k.equals=function(t,e){return!(!t||!e)&&k(t).toRgbString()==k(e).toRgbString()},k.random=function(){return k.fromRatio({r:S(),g:S(),b:S()})},k.mix=function(t,e,n){n=0===n?0:n||50;var r,i=k(t).toRgb(),o=k(e).toRgb(),a=n/100,s=2*a-1,l=o.a-i.a,c=1-(r=((r=s*l==-1?s:(s+l)/(1+s*l))+1)/2),u={r:o.r*r+i.r*c,g:o.g*r+i.g*c,b:o.b*r+i.b*c,a:o.a*a+i.a*(1-a)};return k(u)},k.readability=function(t,e){var n=k(t),r=k(e),i=n.toRgb(),o=r.toRgb(),a=n.getBrightness(),s=r.getBrightness(),l=Math.max(i.r,o.r)-Math.min(i.r,o.r)+Math.max(i.g,o.g)-Math.min(i.g,o.g)+Math.max(i.b,o.b)-Math.min(i.b,o.b);return{brightness:Math.abs(a-s),color:l}},k.isReadable=function(t,e){var n=k.readability(t,e);return n.brightness>125&&n.color>500},k.mostReadable=function(t,e){for(var n=null,r=0,i=!1,o=0;o125&&a.color>500,l=a.brightness/125*3+a.color/500;(s&&!i||s&&i&&l>r||!s&&!i&&l>r)&&(i=s,r=l,n=k(e[o]))}return n};var W=k.names={aliceblue:"f0f8ff",antiquewhite:"faebd7",aqua:"0ff",aquamarine:"7fffd4",azure:"f0ffff",beige:"f5f5dc",bisque:"ffe4c4",black:"000",blanchedalmond:"ffebcd",blue:"00f",blueviolet:"8a2be2",brown:"a52a2a",burlywood:"deb887",burntsienna:"ea7e5d",cadetblue:"5f9ea0",chartreuse:"7fff00",chocolate:"d2691e",coral:"ff7f50",cornflowerblue:"6495ed",cornsilk:"fff8dc",crimson:"dc143c",cyan:"0ff",darkblue:"00008b",darkcyan:"008b8b",darkgoldenrod:"b8860b",darkgray:"a9a9a9",darkgreen:"006400",darkgrey:"a9a9a9",darkkhaki:"bdb76b",darkmagenta:"8b008b",darkolivegreen:"556b2f",darkorange:"ff8c00",darkorchid:"9932cc",darkred:"8b0000",darksalmon:"e9967a",darkseagreen:"8fbc8f",darkslateblue:"483d8b",darkslategray:"2f4f4f",darkslategrey:"2f4f4f",darkturquoise:"00ced1",darkviolet:"9400d3",deeppink:"ff1493",deepskyblue:"00bfff",dimgray:"696969",dimgrey:"696969",dodgerblue:"1e90ff",firebrick:"b22222",floralwhite:"fffaf0",forestgreen:"228b22",fuchsia:"f0f",gainsboro:"dcdcdc",ghostwhite:"f8f8ff",gold:"ffd700",goldenrod:"daa520",gray:"808080",green:"008000",greenyellow:"adff2f",grey:"808080",honeydew:"f0fff0",hotpink:"ff69b4",indianred:"cd5c5c",indigo:"4b0082",ivory:"fffff0",khaki:"f0e68c",lavender:"e6e6fa",lavenderblush:"fff0f5",lawngreen:"7cfc00",lemonchiffon:"fffacd",lightblue:"add8e6",lightcoral:"f08080",lightcyan:"e0ffff",lightgoldenrodyellow:"fafad2",lightgray:"d3d3d3",lightgreen:"90ee90",lightgrey:"d3d3d3",lightpink:"ffb6c1",lightsalmon:"ffa07a",lightseagreen:"20b2aa",lightskyblue:"87cefa",lightslategray:"789",lightslategrey:"789",lightsteelblue:"b0c4de",lightyellow:"ffffe0",lime:"0f0",limegreen:"32cd32",linen:"faf0e6",magenta:"f0f",maroon:"800000",mediumaquamarine:"66cdaa",mediumblue:"0000cd",mediumorchid:"ba55d3",mediumpurple:"9370db",mediumseagreen:"3cb371",mediumslateblue:"7b68ee",mediumspringgreen:"00fa9a",mediumturquoise:"48d1cc",mediumvioletred:"c71585",midnightblue:"191970",mintcream:"f5fffa",mistyrose:"ffe4e1",moccasin:"ffe4b5",navajowhite:"ffdead",navy:"000080",oldlace:"fdf5e6",olive:"808000",olivedrab:"6b8e23",orange:"ffa500",orangered:"ff4500",orchid:"da70d6",palegoldenrod:"eee8aa",palegreen:"98fb98",paleturquoise:"afeeee",palevioletred:"db7093",papayawhip:"ffefd5",peachpuff:"ffdab9",peru:"cd853f",pink:"ffc0cb",plum:"dda0dd",powderblue:"b0e0e6",purple:"800080",rebeccapurple:"663399",red:"f00",rosybrown:"bc8f8f",royalblue:"4169e1",saddlebrown:"8b4513",salmon:"fa8072",sandybrown:"f4a460",seagreen:"2e8b57",seashell:"fff5ee",sienna:"a0522d",silver:"c0c0c0",skyblue:"87ceeb",slateblue:"6a5acd",slategray:"708090",slategrey:"708090",snow:"fffafa",springgreen:"00ff7f",steelblue:"4682b4",tan:"d2b48c",teal:"008080",thistle:"d8bfd8",tomato:"ff6347",turquoise:"40e0d0",violet:"ee82ee",wheat:"f5deb3",white:"fff",whitesmoke:"f5f5f5",yellow:"ff0",yellowgreen:"9acd32"},B=k.hexNames=function(t){var e={};for(var n in t)t.hasOwnProperty(n)&&(e[t[n]]=n);return e}(W);function U(t){return t=parseFloat(t),(isNaN(t)||t<0||t>1)&&(t=1),t}function q(t,e){(function(t){return"string"==typeof t&&-1!=t.indexOf(".")&&1===parseFloat(t)})(t)&&(t="100%");var n=function(t){return"string"==typeof t&&-1!=t.indexOf("%")}(t);return t=C(e,O(0,parseFloat(t))),n&&(t=parseInt(t*e,10)/100),w.abs(t-e)<1e-6?1:t%e/parseFloat(e)}function G(t){return C(1,O(0,t))}function K(t){return parseInt(t,16)}function Y(t){return 1==t.length?"0"+t:""+t}function X(t){return t<=1&&(t=100*t+"%"),t}var J,Z,Q,tt=(Z="[\\s|\\(]+("+(J="(?:[-\\+]?\\d*\\.\\d+%?)|(?:[-\\+]?\\d+%?)")+")[,|\\s]+("+J+")[,|\\s]+("+J+")\\s*\\)?",Q="[\\s|\\(]+("+J+")[,|\\s]+("+J+")[,|\\s]+("+J+")[,|\\s]+("+J+")\\s*\\)?",{rgb:new RegExp("rgb"+Z),rgba:new RegExp("rgba"+Q),hsl:new RegExp("hsl"+Z),hsla:new RegExp("hsla"+Q),hsv:new RegExp("hsv"+Z),hsva:new RegExp("hsva"+Q),hex3:/^([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,hex6:/^([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/,hex8:/^([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/});window.tinycolor=k,t((function(){t.fn.spectrum.load&&t.fn.spectrum.processNativeColorInputs()}))}(d);e.a=u.a.extend({template:function(){var t=this.ppfx;return'\n
\n
\n
\n
\n
\n
\n ')},inputClass:function(){var t=this.ppfx;return"".concat(t,"field ").concat(t,"field-color")},holderClass:function(){return"".concat(this.ppfx,"input-holder")},setValue:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=this.model,r=n.get("defaults"),i=Object(s.isUndefined)(t)?Object(s.isUndefined)(r)?"":r:t,o=this.getInputEl(),a=this.getColorEl(),l="none"!=i?i:"";o.value=i,a.get(0).style.backgroundColor=l,e.fromTarget&&(a.spectrum("set",l),this.noneColor="none"==i)},getColorEl:function(){if(!this.colorEl){var t,e=this,n=this.ppfx,r=this.model,o=d('
')),a=o.get(0).style,s=this.em&&this.em.config?this.em.config.el:"",l=this.em&&this.em.getConfig&&this.em.getConfig("colorPicker")||{},c=function(t){return(1==t.getAlpha()?t.toHexString():t.toRgbString()).replace(/ /g,"")},u=0;this.$el.find("[data-colorp-c]").append(o),o.spectrum(function(t){for(var e=1;e1&&(o=m(t),t=[t[t.length-1]]),t=t[0],(t=l(t))in r||(r[t]=[]),r[t].push({shortcut:i[a],scope:e,method:n,key:i[a],mods:o})}for(n in a)p[n]=!1;function g(){return o||"all"}function v(t){var e;return""==(e=(t=t.replace(/\s/g,"")).split(","))[e.length-1]&&(e[e.length-2]+=","),e}function m(t){for(var e=t.slice(0,t.length-1),n=0;n0,i)(!i[o]&&u(n.mods,+o)>-1||i[o]&&-1==u(n.mods,+o))&&(l=!1);(0!=n.mods.length||i[16]||i[18]||i[17]||i[91])&&!l||!1===n.method(t,n)&&(t.preventDefault?t.preventDefault():t.returnValue=!1,t.stopPropagation&&t.stopPropagation(),t.cancelBubble&&(t.cancelBubble=!0))}}(t)})),y(document,"keyup",(function(t){var e,n=t.keyCode,r=u(c,n);if(r>=0&&c.splice(r,1),93!=n&&224!=n||(n=91),n in i)for(e in i[n]=!1,a)a[e]==n&&(p[e]=!1)})),y(window,"focus",(function(){for(n in i)i[n]=!1;for(n in a)p[n]=!1}));var b=e.key;e.key=p,e.key.setScope=function(t){o=t||"all"},e.key.getScope=g,e.key.deleteScope=function(t){var e,n,i;for(e in r)for(n=r[e],i=0;i1&&(c=m(i),t=i[i.length-1]),t=l(t),void 0===e&&(e=g()),!r[t])return;for(o=0;o*\/]/.test(n)?x(null,"select-op"):"."==n&&t.match(/^-?[_a-z][_a-z0-9-]*/i)?x("qualifier","qualifier"):/[:;{}\[\]\(\)]/.test(n)?x(null,n):t.match(/[\w-.]+(?=\()/)?(/^(url(-prefix)?|domain|regexp)$/.test(t.current().toLowerCase())&&(e.tokenize=S),x("variable callee","variable")):/[\w\\\-]/.test(n)?(t.eatWhile(/[\w\\\-]/),x("property","word")):x(null,null):/[\d.]/.test(t.peek())?(t.eatWhile(/[\w.%]/),x("number","unit")):t.match(/^-[\w\\\-]*/)?(t.eatWhile(/[\w\\\-]/),t.match(/^\s*:/,!1)?x("variable-2","variable-definition"):x("variable-2","variable")):t.match(/^\w+-/)?x("meta","meta"):void 0}function O(t){return function(e,n){for(var r,i=!1;null!=(r=e.next());){if(r==t&&!i){")"==t&&e.backUp(1);break}i=!i&&"\\"==r}return(r==t||!i&&")"!=t)&&(n.tokenize=null),x("string","string")}}function S(t,e){return t.next(),t.match(/\s*[\"\')]/,!1)?e.tokenize=null:e.tokenize=O(")"),x(null,"(")}function k(t,e,n){this.type=t,this.indent=e,this.prev=n}function T(t,e,n,r){return t.context=new k(n,e.indentation()+(!1===r?0:a),t.context),n}function P(t){return t.context.prev&&(t.context=t.context.prev),t.context.type}function j(t,e,n){return D[n.context.type](t,e,n)}function E(t,e,n,r){for(var i=r||1;i>0;i--)n.context=n.context.prev;return j(t,e,n)}function M(t){var e=t.current().toLowerCase();o=m.hasOwnProperty(e)?"atom":v.hasOwnProperty(e)?"keyword":"variable"}var D={top:function(t,e,n){if("{"==t)return T(n,e,"block");if("}"==t&&n.context.prev)return P(n);if(w&&/@component/i.test(t))return T(n,e,"atComponentBlock");if(/^@(-moz-)?document$/i.test(t))return T(n,e,"documentTypes");if(/^@(media|supports|(-moz-)?document|import)$/i.test(t))return T(n,e,"atBlock");if(/^@(font-face|counter-style)/i.test(t))return n.stateArg=t,"restricted_atBlock_before";if(/^@(-(moz|ms|o|webkit)-)?keyframes$/i.test(t))return"keyframes";if(t&&"@"==t.charAt(0))return T(n,e,"at");if("hash"==t)o="builtin";else if("word"==t)o="tag";else{if("variable-definition"==t)return"maybeprop";if("interpolation"==t)return T(n,e,"interpolation");if(":"==t)return"pseudo";if(y&&"("==t)return T(n,e,"parens")}return n.context.type},block:function(t,e,n){if("word"==t){var r=e.current().toLowerCase();return d.hasOwnProperty(r)?(o="property","maybeprop"):f.hasOwnProperty(r)?(o="string-2","maybeprop"):y?(o=e.match(/^\s*:(?:\s|$)/,!1)?"property":"tag","block"):(o+=" error","maybeprop")}return"meta"==t?"block":y||"hash"!=t&&"qualifier"!=t?D.top(t,e,n):(o="error","block")},maybeprop:function(t,e,n){return":"==t?T(n,e,"prop"):j(t,e,n)},prop:function(t,e,n){if(";"==t)return P(n);if("{"==t&&y)return T(n,e,"propBlock");if("}"==t||"{"==t)return E(t,e,n);if("("==t)return T(n,e,"parens");if("hash"!=t||/^#([0-9a-fA-f]{3,4}|[0-9a-fA-f]{6}|[0-9a-fA-f]{8})$/.test(e.current())){if("word"==t)M(e);else if("interpolation"==t)return T(n,e,"interpolation")}else o+=" error";return"prop"},propBlock:function(t,e,n){return"}"==t?P(n):"word"==t?(o="property","maybeprop"):n.context.type},parens:function(t,e,n){return"{"==t||"}"==t?E(t,e,n):")"==t?P(n):"("==t?T(n,e,"parens"):"interpolation"==t?T(n,e,"interpolation"):("word"==t&&M(e),"parens")},pseudo:function(t,e,n){return"meta"==t?"pseudo":"word"==t?(o="variable-3",n.context.type):j(t,e,n)},documentTypes:function(t,e,n){return"word"==t&&l.hasOwnProperty(e.current())?(o="tag",n.context.type):D.atBlock(t,e,n)},atBlock:function(t,e,n){if("("==t)return T(n,e,"atBlock_parens");if("}"==t||";"==t)return E(t,e,n);if("{"==t)return P(n)&&T(n,e,y?"block":"top");if("interpolation"==t)return T(n,e,"interpolation");if("word"==t){var r=e.current().toLowerCase();o="only"==r||"not"==r||"and"==r||"or"==r?"keyword":c.hasOwnProperty(r)?"attribute":u.hasOwnProperty(r)?"property":h.hasOwnProperty(r)?"keyword":d.hasOwnProperty(r)?"property":f.hasOwnProperty(r)?"string-2":m.hasOwnProperty(r)?"atom":v.hasOwnProperty(r)?"keyword":"error"}return n.context.type},atComponentBlock:function(t,e,n){return"}"==t?E(t,e,n):"{"==t?P(n)&&T(n,e,y?"block":"top",!1):("word"==t&&(o="error"),n.context.type)},atBlock_parens:function(t,e,n){return")"==t?P(n):"{"==t||"}"==t?E(t,e,n,2):D.atBlock(t,e,n)},restricted_atBlock_before:function(t,e,n){return"{"==t?T(n,e,"restricted_atBlock"):"word"==t&&"@counter-style"==n.stateArg?(o="variable","restricted_atBlock_before"):j(t,e,n)},restricted_atBlock:function(t,e,n){return"}"==t?(n.stateArg=null,P(n)):"word"==t?(o="@font-face"==n.stateArg&&!p.hasOwnProperty(e.current().toLowerCase())||"@counter-style"==n.stateArg&&!g.hasOwnProperty(e.current().toLowerCase())?"error":"property","maybeprop"):"restricted_atBlock"},keyframes:function(t,e,n){return"word"==t?(o="variable","keyframes"):"{"==t?T(n,e,"top"):j(t,e,n)},at:function(t,e,n){return";"==t?P(n):"{"==t||"}"==t?E(t,e,n):("word"==t?o="tag":"hash"==t&&(o="builtin"),"at")},interpolation:function(t,e,n){return"}"==t?P(n):"{"==t||";"==t?E(t,e,n):("word"==t?o="variable":"variable"!=t&&"("!=t&&")"!=t&&(o="error"),"interpolation")}};return{startState:function(t){return{tokenize:null,state:r?"block":"top",stateArg:null,context:new k(r?"block":"top",t||0,null)}},token:function(t,e){if(!e.tokenize&&t.eatSpace())return null;var n=(e.tokenize||C)(t,e);return n&&"object"==typeof n&&(i=n[1],n=n[0]),o=n,"comment"!=i&&(e.state=D[e.state](i,t,e)),o},indent:function(t,e){var n=t.context,r=e&&e.charAt(0),i=n.indent;return"prop"!=n.type||"}"!=r&&")"!=r||(n=n.prev),n.prev&&("}"!=r||"block"!=n.type&&"top"!=n.type&&"interpolation"!=n.type&&"restricted_atBlock"!=n.type?(")"!=r||"parens"!=n.type&&"atBlock_parens"!=n.type)&&("{"!=r||"at"!=n.type&&"atBlock"!=n.type)||(i=Math.max(0,n.indent-a)):i=(n=n.prev).indent),i},electricChars:"}",blockCommentStart:"/*",blockCommentEnd:"*/",blockCommentContinue:" * ",lineComment:b,fold:"brace"}}));var n=["domain","regexp","url","url-prefix"],r=e(n),i=["all","aural","braille","handheld","print","projection","screen","tty","tv","embossed"],o=e(i),a=["width","min-width","max-width","height","min-height","max-height","device-width","min-device-width","max-device-width","device-height","min-device-height","max-device-height","aspect-ratio","min-aspect-ratio","max-aspect-ratio","device-aspect-ratio","min-device-aspect-ratio","max-device-aspect-ratio","color","min-color","max-color","color-index","min-color-index","max-color-index","monochrome","min-monochrome","max-monochrome","resolution","min-resolution","max-resolution","scan","grid","orientation","device-pixel-ratio","min-device-pixel-ratio","max-device-pixel-ratio","pointer","any-pointer","hover","any-hover"],s=e(a),l=["landscape","portrait","none","coarse","fine","on-demand","hover","interlace","progressive"],c=e(l),u=["align-content","align-items","align-self","alignment-adjust","alignment-baseline","anchor-point","animation","animation-delay","animation-direction","animation-duration","animation-fill-mode","animation-iteration-count","animation-name","animation-play-state","animation-timing-function","appearance","azimuth","backface-visibility","background","background-attachment","background-blend-mode","background-clip","background-color","background-image","background-origin","background-position","background-repeat","background-size","baseline-shift","binding","bleed","bookmark-label","bookmark-level","bookmark-state","bookmark-target","border","border-bottom","border-bottom-color","border-bottom-left-radius","border-bottom-right-radius","border-bottom-style","border-bottom-width","border-collapse","border-color","border-image","border-image-outset","border-image-repeat","border-image-slice","border-image-source","border-image-width","border-left","border-left-color","border-left-style","border-left-width","border-radius","border-right","border-right-color","border-right-style","border-right-width","border-spacing","border-style","border-top","border-top-color","border-top-left-radius","border-top-right-radius","border-top-style","border-top-width","border-width","bottom","box-decoration-break","box-shadow","box-sizing","break-after","break-before","break-inside","caption-side","caret-color","clear","clip","color","color-profile","column-count","column-fill","column-gap","column-rule","column-rule-color","column-rule-style","column-rule-width","column-span","column-width","columns","content","counter-increment","counter-reset","crop","cue","cue-after","cue-before","cursor","direction","display","dominant-baseline","drop-initial-after-adjust","drop-initial-after-align","drop-initial-before-adjust","drop-initial-before-align","drop-initial-size","drop-initial-value","elevation","empty-cells","fit","fit-position","flex","flex-basis","flex-direction","flex-flow","flex-grow","flex-shrink","flex-wrap","float","float-offset","flow-from","flow-into","font","font-feature-settings","font-family","font-kerning","font-language-override","font-size","font-size-adjust","font-stretch","font-style","font-synthesis","font-variant","font-variant-alternates","font-variant-caps","font-variant-east-asian","font-variant-ligatures","font-variant-numeric","font-variant-position","font-weight","grid","grid-area","grid-auto-columns","grid-auto-flow","grid-auto-rows","grid-column","grid-column-end","grid-column-gap","grid-column-start","grid-gap","grid-row","grid-row-end","grid-row-gap","grid-row-start","grid-template","grid-template-areas","grid-template-columns","grid-template-rows","hanging-punctuation","height","hyphens","icon","image-orientation","image-rendering","image-resolution","inline-box-align","justify-content","justify-items","justify-self","left","letter-spacing","line-break","line-height","line-stacking","line-stacking-ruby","line-stacking-shift","line-stacking-strategy","list-style","list-style-image","list-style-position","list-style-type","margin","margin-bottom","margin-left","margin-right","margin-top","marks","marquee-direction","marquee-loop","marquee-play-count","marquee-speed","marquee-style","max-height","max-width","min-height","min-width","mix-blend-mode","move-to","nav-down","nav-index","nav-left","nav-right","nav-up","object-fit","object-position","opacity","order","orphans","outline","outline-color","outline-offset","outline-style","outline-width","overflow","overflow-style","overflow-wrap","overflow-x","overflow-y","padding","padding-bottom","padding-left","padding-right","padding-top","page","page-break-after","page-break-before","page-break-inside","page-policy","pause","pause-after","pause-before","perspective","perspective-origin","pitch","pitch-range","place-content","place-items","place-self","play-during","position","presentation-level","punctuation-trim","quotes","region-break-after","region-break-before","region-break-inside","region-fragment","rendering-intent","resize","rest","rest-after","rest-before","richness","right","rotation","rotation-point","ruby-align","ruby-overhang","ruby-position","ruby-span","shape-image-threshold","shape-inside","shape-margin","shape-outside","size","speak","speak-as","speak-header","speak-numeral","speak-punctuation","speech-rate","stress","string-set","tab-size","table-layout","target","target-name","target-new","target-position","text-align","text-align-last","text-decoration","text-decoration-color","text-decoration-line","text-decoration-skip","text-decoration-style","text-emphasis","text-emphasis-color","text-emphasis-position","text-emphasis-style","text-height","text-indent","text-justify","text-outline","text-overflow","text-shadow","text-size-adjust","text-space-collapse","text-transform","text-underline-position","text-wrap","top","transform","transform-origin","transform-style","transition","transition-delay","transition-duration","transition-property","transition-timing-function","unicode-bidi","user-select","vertical-align","visibility","voice-balance","voice-duration","voice-family","voice-pitch","voice-range","voice-rate","voice-stress","voice-volume","volume","white-space","widows","width","will-change","word-break","word-spacing","word-wrap","z-index","clip-path","clip-rule","mask","enable-background","filter","flood-color","flood-opacity","lighting-color","stop-color","stop-opacity","pointer-events","color-interpolation","color-interpolation-filters","color-rendering","fill","fill-opacity","fill-rule","image-rendering","marker","marker-end","marker-mid","marker-start","shape-rendering","stroke","stroke-dasharray","stroke-dashoffset","stroke-linecap","stroke-linejoin","stroke-miterlimit","stroke-opacity","stroke-width","text-rendering","baseline-shift","dominant-baseline","glyph-orientation-horizontal","glyph-orientation-vertical","text-anchor","writing-mode"],h=e(u),d=["scrollbar-arrow-color","scrollbar-base-color","scrollbar-dark-shadow-color","scrollbar-face-color","scrollbar-highlight-color","scrollbar-shadow-color","scrollbar-3d-light-color","scrollbar-track-color","shape-inside","searchfield-cancel-button","searchfield-decoration","searchfield-results-button","searchfield-results-decoration","zoom"],f=e(d),p=e(["font-family","src","unicode-range","font-variant","font-feature-settings","font-stretch","font-weight","font-style"]),g=e(["additive-symbols","fallback","negative","pad","prefix","range","speak-as","suffix","symbols","system"]),v=["aliceblue","antiquewhite","aqua","aquamarine","azure","beige","bisque","black","blanchedalmond","blue","blueviolet","brown","burlywood","cadetblue","chartreuse","chocolate","coral","cornflowerblue","cornsilk","crimson","cyan","darkblue","darkcyan","darkgoldenrod","darkgray","darkgreen","darkkhaki","darkmagenta","darkolivegreen","darkorange","darkorchid","darkred","darksalmon","darkseagreen","darkslateblue","darkslategray","darkturquoise","darkviolet","deeppink","deepskyblue","dimgray","dodgerblue","firebrick","floralwhite","forestgreen","fuchsia","gainsboro","ghostwhite","gold","goldenrod","gray","grey","green","greenyellow","honeydew","hotpink","indianred","indigo","ivory","khaki","lavender","lavenderblush","lawngreen","lemonchiffon","lightblue","lightcoral","lightcyan","lightgoldenrodyellow","lightgray","lightgreen","lightpink","lightsalmon","lightseagreen","lightskyblue","lightslategray","lightsteelblue","lightyellow","lime","limegreen","linen","magenta","maroon","mediumaquamarine","mediumblue","mediumorchid","mediumpurple","mediumseagreen","mediumslateblue","mediumspringgreen","mediumturquoise","mediumvioletred","midnightblue","mintcream","mistyrose","moccasin","navajowhite","navy","oldlace","olive","olivedrab","orange","orangered","orchid","palegoldenrod","palegreen","paleturquoise","palevioletred","papayawhip","peachpuff","peru","pink","plum","powderblue","purple","rebeccapurple","red","rosybrown","royalblue","saddlebrown","salmon","sandybrown","seagreen","seashell","sienna","silver","skyblue","slateblue","slategray","snow","springgreen","steelblue","tan","teal","thistle","tomato","turquoise","violet","wheat","white","whitesmoke","yellow","yellowgreen"],m=e(v),y=["above","absolute","activeborder","additive","activecaption","afar","after-white-space","ahead","alias","all","all-scroll","alphabetic","alternate","always","amharic","amharic-abegede","antialiased","appworkspace","arabic-indic","armenian","asterisks","attr","auto","auto-flow","avoid","avoid-column","avoid-page","avoid-region","background","backwards","baseline","below","bidi-override","binary","bengali","blink","block","block-axis","bold","bolder","border","border-box","both","bottom","break","break-all","break-word","bullets","button","button-bevel","buttonface","buttonhighlight","buttonshadow","buttontext","calc","cambodian","capitalize","caps-lock-indicator","caption","captiontext","caret","cell","center","checkbox","circle","cjk-decimal","cjk-earthly-branch","cjk-heavenly-stem","cjk-ideographic","clear","clip","close-quote","col-resize","collapse","color","color-burn","color-dodge","column","column-reverse","compact","condensed","contain","content","contents","content-box","context-menu","continuous","copy","counter","counters","cover","crop","cross","crosshair","currentcolor","cursive","cyclic","darken","dashed","decimal","decimal-leading-zero","default","default-button","dense","destination-atop","destination-in","destination-out","destination-over","devanagari","difference","disc","discard","disclosure-closed","disclosure-open","document","dot-dash","dot-dot-dash","dotted","double","down","e-resize","ease","ease-in","ease-in-out","ease-out","element","ellipse","ellipsis","embed","end","ethiopic","ethiopic-abegede","ethiopic-abegede-am-et","ethiopic-abegede-gez","ethiopic-abegede-ti-er","ethiopic-abegede-ti-et","ethiopic-halehame-aa-er","ethiopic-halehame-aa-et","ethiopic-halehame-am-et","ethiopic-halehame-gez","ethiopic-halehame-om-et","ethiopic-halehame-sid-et","ethiopic-halehame-so-et","ethiopic-halehame-ti-er","ethiopic-halehame-ti-et","ethiopic-halehame-tig","ethiopic-numeric","ew-resize","exclusion","expanded","extends","extra-condensed","extra-expanded","fantasy","fast","fill","fixed","flat","flex","flex-end","flex-start","footnotes","forwards","from","geometricPrecision","georgian","graytext","grid","groove","gujarati","gurmukhi","hand","hangul","hangul-consonant","hard-light","hebrew","help","hidden","hide","higher","highlight","highlighttext","hiragana","hiragana-iroha","horizontal","hsl","hsla","hue","icon","ignore","inactiveborder","inactivecaption","inactivecaptiontext","infinite","infobackground","infotext","inherit","initial","inline","inline-axis","inline-block","inline-flex","inline-grid","inline-table","inset","inside","intrinsic","invert","italic","japanese-formal","japanese-informal","justify","kannada","katakana","katakana-iroha","keep-all","khmer","korean-hangul-formal","korean-hanja-formal","korean-hanja-informal","landscape","lao","large","larger","left","level","lighter","lighten","line-through","linear","linear-gradient","lines","list-item","listbox","listitem","local","logical","loud","lower","lower-alpha","lower-armenian","lower-greek","lower-hexadecimal","lower-latin","lower-norwegian","lower-roman","lowercase","ltr","luminosity","malayalam","match","matrix","matrix3d","media-controls-background","media-current-time-display","media-fullscreen-button","media-mute-button","media-play-button","media-return-to-realtime-button","media-rewind-button","media-seek-back-button","media-seek-forward-button","media-slider","media-sliderthumb","media-time-remaining-display","media-volume-slider","media-volume-slider-container","media-volume-sliderthumb","medium","menu","menulist","menulist-button","menulist-text","menulist-textfield","menutext","message-box","middle","min-intrinsic","mix","mongolian","monospace","move","multiple","multiply","myanmar","n-resize","narrower","ne-resize","nesw-resize","no-close-quote","no-drop","no-open-quote","no-repeat","none","normal","not-allowed","nowrap","ns-resize","numbers","numeric","nw-resize","nwse-resize","oblique","octal","opacity","open-quote","optimizeLegibility","optimizeSpeed","oriya","oromo","outset","outside","outside-shape","overlay","overline","padding","padding-box","painted","page","paused","persian","perspective","plus-darker","plus-lighter","pointer","polygon","portrait","pre","pre-line","pre-wrap","preserve-3d","progress","push-button","radial-gradient","radio","read-only","read-write","read-write-plaintext-only","rectangle","region","relative","repeat","repeating-linear-gradient","repeating-radial-gradient","repeat-x","repeat-y","reset","reverse","rgb","rgba","ridge","right","rotate","rotate3d","rotateX","rotateY","rotateZ","round","row","row-resize","row-reverse","rtl","run-in","running","s-resize","sans-serif","saturation","scale","scale3d","scaleX","scaleY","scaleZ","screen","scroll","scrollbar","scroll-position","se-resize","searchfield","searchfield-cancel-button","searchfield-decoration","searchfield-results-button","searchfield-results-decoration","self-start","self-end","semi-condensed","semi-expanded","separate","serif","show","sidama","simp-chinese-formal","simp-chinese-informal","single","skew","skewX","skewY","skip-white-space","slide","slider-horizontal","slider-vertical","sliderthumb-horizontal","sliderthumb-vertical","slow","small","small-caps","small-caption","smaller","soft-light","solid","somali","source-atop","source-in","source-out","source-over","space","space-around","space-between","space-evenly","spell-out","square","square-button","start","static","status-bar","stretch","stroke","sub","subpixel-antialiased","super","sw-resize","symbolic","symbols","system-ui","table","table-caption","table-cell","table-column","table-column-group","table-footer-group","table-header-group","table-row","table-row-group","tamil","telugu","text","text-bottom","text-top","textarea","textfield","thai","thick","thin","threeddarkshadow","threedface","threedhighlight","threedlightshadow","threedshadow","tibetan","tigre","tigrinya-er","tigrinya-er-abegede","tigrinya-et","tigrinya-et-abegede","to","top","trad-chinese-formal","trad-chinese-informal","transform","translate","translate3d","translateX","translateY","translateZ","transparent","ultra-condensed","ultra-expanded","underline","unset","up","upper-alpha","upper-armenian","upper-greek","upper-hexadecimal","upper-latin","upper-norwegian","upper-roman","uppercase","urdu","url","var","vertical","vertical-text","visible","visibleFill","visiblePainted","visibleStroke","visual","w-resize","wait","wave","wider","window","windowframe","windowtext","words","wrap","wrap-reverse","x-large","x-small","xor","xx-large","xx-small"],b=e(y),w=n.concat(i).concat(a).concat(l).concat(u).concat(d).concat(v).concat(y);function x(t,e){for(var n,r=!1;null!=(n=t.next());){if(r&&"/"==n){e.tokenize=null;break}r="*"==n}return["comment","comment"]}t.registerHelper("hintWords","css",w),t.defineMIME("text/css",{documentTypes:r,mediaTypes:o,mediaFeatures:s,mediaValueKeywords:c,propertyKeywords:h,nonStandardPropertyKeywords:f,fontProperties:p,counterDescriptors:g,colorKeywords:m,valueKeywords:b,tokenHooks:{"/":function(t,e){return!!t.eat("*")&&(e.tokenize=x,x(t,e))}},name:"css"}),t.defineMIME("text/x-scss",{mediaTypes:o,mediaFeatures:s,mediaValueKeywords:c,propertyKeywords:h,nonStandardPropertyKeywords:f,colorKeywords:m,valueKeywords:b,fontProperties:p,allowNested:!0,lineComment:"//",tokenHooks:{"/":function(t,e){return t.eat("/")?(t.skipToEnd(),["comment","comment"]):t.eat("*")?(e.tokenize=x,x(t,e)):["operator","operator"]},":":function(t){return!!t.match(/\s*\{/,!1)&&[null,null]},$:function(t){return t.match(/^[\w-]+/),t.match(/^\s*:/,!1)?["variable-2","variable-definition"]:["variable-2","variable"]},"#":function(t){return!!t.eat("{")&&[null,"interpolation"]}},name:"css",helperType:"scss"}),t.defineMIME("text/x-less",{mediaTypes:o,mediaFeatures:s,mediaValueKeywords:c,propertyKeywords:h,nonStandardPropertyKeywords:f,colorKeywords:m,valueKeywords:b,fontProperties:p,allowNested:!0,lineComment:"//",tokenHooks:{"/":function(t,e){return t.eat("/")?(t.skipToEnd(),["comment","comment"]):t.eat("*")?(e.tokenize=x,x(t,e)):["operator","operator"]},"@":function(t){return t.eat("{")?[null,"interpolation"]:!t.match(/^(charset|document|font-face|import|(-(moz|ms|o|webkit)-)?keyframes|media|namespace|page|supports)\b/i,!1)&&(t.eatWhile(/[\w\\\-]/),t.match(/^\s*:/,!1)?["variable-2","variable-definition"]:["variable-2","variable"])},"&":function(){return["atom","atom"]}},name:"css",helperType:"less"}),t.defineMIME("text/x-gss",{documentTypes:r,mediaTypes:o,mediaFeatures:s,propertyKeywords:h,nonStandardPropertyKeywords:f,fontProperties:p,counterDescriptors:g,colorKeywords:m,valueKeywords:b,supportsAtComponent:!0,tokenHooks:{"/":function(t,e){return!!t.eat("*")&&(e.tokenize=x,x(t,e))}},name:"css",helperType:"gss"})}(n(10))},function(t,e,n){"use strict";n.r(e),e.default={run:function(t){t.DomComponents.clear(),t.CssComposer.clear()}}},function(t,e,n){"use strict";n.r(e);var r=n(0),i=n(3),o=n(17);e.default={run:function(t){Object(r.bindAll)(this,"onKeyUp","enableDragger","disableDragger"),this.editor=t,this.canvasModel=this.canvas.getCanvasView().model,this.toggleMove(1)},stop:function(t){this.toggleMove(),this.disableDragger()},onKeyUp:function(t){" "===Object(i.e)(t)&&this.editor.stopCommand(this.id)},enableDragger:function(t){this.toggleDragger(1,t)},disableDragger:function(t){this.toggleDragger(0,t)},toggleDragger:function(t,e){var n=this.canvasModel,r=this.em,i=this.dragger,a=t?"add":"remove";this.getCanvas().classList[a]("".concat(this.ppfx,"is__grabbing")),i||(i=new o.a({getPosition:function(){return{x:n.get("x"),y:n.get("y")}},setPosition:function(t){var e=t.x,r=t.y;n.set({x:e,y:r})},onStart:function(t,e){r.trigger("canvas:move:start",e)},onDrag:function(t,e){r.trigger("canvas:move",e)},onEnd:function(t,e){r.trigger("canvas:move:end",e)}}),this.dragger=i),t?i.start(e):i.stop()},toggleMove:function(t){var e=this.ppfx,n=t?"add":"remove",r=t?"on":"off",o={on:i.p,off:i.o},a=this.getCanvas(),s=["".concat(e,"is__grab")];!t&&s.push("".concat(e,"is__grabbing")),s.forEach((function(t){return a.classList[n](t)})),o[r](document,"keyup",this.onKeyUp),o[r](a,"mousedown",this.enableDragger),o[r](document,"mouseup",this.disableDragger)}}},function(t,e,n){"use strict";n.r(e);var r=n(8),i=n.n(r),o=n(0);e.default={run:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},r=n.component||t.getSelectedAll();return r=Object(o.isArray)(r)?i()(r):[r],t.select(null),r.forEach((function(t){if(t&&t.get("removable")){if(t){var e=t.collection;t.trigger("component:destroy"),e&&e.remove(t)}}else console.warn("The element is not removable",t)})),r}}},function(t,e,n){"use strict";n.r(e);var r=n(2),i=n.n(r),o=n(0),a=n(17);function s(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function l(t){for(var e=1;e2&&void 0!==arguments[2]?arguments[2]:{};Object(o.bindAll)(this,"setPosition","onStart","onDrag","onEnd","getPosition","getGuidesStatic","renderGuide","getGuidesTarget");var i=r.target,s=r.event,c=r.mode,u=r.dragger,h=void 0===u?{}:u,d=i.getEl(),f=l({doc:d.ownerDocument,onStart:this.onStart,onEnd:this.onEnd,onDrag:this.onDrag,getPosition:this.getPosition,setPosition:this.setPosition,guidesStatic:function(){return n.guidesStatic},guidesTarget:function(){return n.guidesTarget}},h);this.setupGuides(),this.opts=r,this.editor=t,this.em=t.getModel(),this.target=i,this.isTran="translate"==c,this.guidesContainer=this.getGuidesContainer(),this.guidesTarget=this.getGuidesTarget(),this.guidesStatic=this.getGuidesStatic(),window.guidesTarget=this.guidesTarget;var p=this.dragger;return p?p.setOptions(f):(p=new a.a(f),this.dragger=p),s&&p.start(s),this.toggleDrag(1),p},stop:function(){this.toggleDrag()},setupGuides:function(){(this.guides||[]).forEach((function(t){var e=t.guide;e&&e.parentNode.removeChild(e)})),this.guides=[]},getGuidesContainer:function(){var t=this,e=this.guidesEl;if(!e){var n=this.editor,r=this.em,i=this.opts,o=n.getConfig("stylePrefix"),a=document.createElement("div"),s=document.createElement("div"),l='
\n
\n
');(e=document.createElement("div")).className="".concat(o,"guides"),a.className="".concat(o,"guide-info ").concat(o,"guide-info__x"),s.className="".concat(o,"guide-info ").concat(o,"guide-info__y"),a.innerHTML=l,s.innerHTML=l,e.appendChild(a),e.appendChild(s),n.Canvas.getToolsEl().appendChild(e),this.guidesEl=e,this.elGuideInfoX=a,this.elGuideInfoY=s,this.elGuideInfoContentX=a.querySelector(".".concat(o,"guide-info__content")),this.elGuideInfoContentY=s.querySelector(".".concat(o,"guide-info__content")),r.on("canvas:update",(function(){t.updateGuides(),i.debug&&t.guides.forEach((function(e){return t.renderGuide(e)}))}))}return e},getGuidesStatic:function(){var t=this,e=[],n=this.target.getEl(),r=n.parentNode,i=void 0===r?{}:r;return Object(o.each)(i.children,(function(r){return e=e.concat(n!==r?t.getElementGuides(r):[])})),e.concat(this.getElementGuides(i))},getGuidesTarget:function(){return this.getElementGuides(this.target.getEl())},updateGuides:function(t){(t||this.guides).forEach((function(t){var e=t.origin,n=editor.Canvas.getElementPos(e),r=n.top,i=n.height,o=n.left,a=n.width;switch(t.type){case"t":return t.y=r;case"b":return t.y=r+i;case"l":return t.x=o;case"r":return t.x=o+a;case"x":return t.x=o+a/2;case"y":return t.y=r+i/2}}))},getGuidePosUpdate:function(t,e){var n={},r=e.top,i=e.height,o=e.left,a=e.width;switch(t.type){case"t":n.y=r;break;case"b":n.y=r+i;break;case"l":n.x=o;break;case"r":n.x=o+a;break;case"x":n.x=o+a/2;break;case"y":n.y=r+i/2}return n},renderGuide:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=t.guide||document.createElement("div"),n=this.editor.Canvas,r=n.getRect(),i=r.topScroll,o=r.top,a=n.getCanvasView().getFrameOffset().top,s="px",l=t.active?2:1,c=e.children[0];return e.style="position: absolute; background-color: ".concat(t.active?"green":"red",";"),e.children.length||((c=document.createElement("div")).style="position: absolute; color: red; padding: 5px; top: 0; left: 0;",e.appendChild(c)),t.y?(e.style.width="100%",e.style.height="".concat(l).concat(s),e.style.top="".concat(t.y).concat(s),e.style.left=0):(e.style.width="".concat(l).concat(s),e.style.height="100%",e.style.left="".concat(t.x).concat(s),e.style.top="".concat(i-a+o).concat(s)),!t.guide&&this.guidesContainer.appendChild(e),e},getElementGuides:function(t){var e=this,n=this.editor,r=this.opts,i=n.Canvas.getElementPos(t),o=i.top,a=i.height,s=i.left,c=i.width,u=[{type:"t",y:o},{type:"b",y:o+a},{type:"l",x:s},{type:"r",x:s+c},{type:"x",x:s+c/2},{type:"y",y:o+a/2}].map((function(i){return l({},i,{origin:t,originRect:n.Canvas.getElementPos(t),guide:r.debug&&e.renderGuide(i)})}));return u.forEach((function(t){return e.guides.push(t)})),u},getTranslate:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:"x",n=0;return(t||"").split(" ").forEach((function(t){var r=t.trim(),i="translate".concat(e.toUpperCase(),"(");0===r.indexOf(i)&&(n=parseFloat(r.replace(i,"")))})),n},setTranslate:function(t,e,n){var r="translate".concat(e.toUpperCase(),"("),i="".concat(r).concat(n,")"),o=(t||"").split(" ").map((function(t){return 0===t.trim().indexOf(r)&&(t=i),t})).join(" ");return o.indexOf(r)<0&&(o+=" ".concat(i)),o},getPosition:function(){var t=this.target,e=this.isTran,n=t.getStyle(),r=n.left,i=n.top,o=n.transform,a=0,s=0;return e?(a=this.getTranslate(o),s=this.getTranslate(o,"y")):(a=parseFloat(r),s=parseFloat(i)),{x:a,y:s}},setPosition:function(t){var e=t.x,n=t.y,r=t.end,i=t.position,a=t.width,s=t.height,l=this.target,c=this.isTran,u=r?"":1,h="".concat(e).concat("px"),d="".concat(n).concat("px");if(c){var f=l.getStyle().transform||"";return f=this.setTranslate(f,"x",h),f=this.setTranslate(f,"y",d),l.addStyle({transform:f,en:u},{avoidStore:!r})}var p={position:i,width:a,height:s},g={left:h,top:d,en:u};Object(o.keys)(p).forEach((function(t){var e=p[t];e&&(g[t]=e)})),l.addStyle(g,{avoidStore:!r})},onStart:function(){var t=this.target,e=this.editor,n=this.isTran,r=this.opts.center,i=e.Canvas,o=t.getStyle();if(!n&&"absolute"!==o.position){var a=i.offset(t.getEl()),s=a.left,l=a.top,c=a.width,u=a.height;if(r){var h=i.getMouseRelativeCanvas(event);s=h.x,l=h.y}this.setPosition({x:s,y:l,width:"".concat(c,"px"),height:"".concat(u,"px"),position:"absolute"})}},onDrag:function(){var t=this,e=this.guidesTarget,n=this.opts,r=n.onDrag;this.updateGuides(e),n.debug&&e.forEach((function(e){return t.renderGuide(e)})),n.guidesInfo&&this.renderGuideInfo(e.filter((function(t){return t.active}))),r&&r.apply(void 0,arguments)},onEnd:function(){var t=this.editor,e=this.opts,n=this.id,r=e.onEnd;r&&r.apply(void 0,arguments),t.stopCommand(n),this.hideGuidesInfo()},hideGuidesInfo:function(){var t=this;["X","Y"].forEach((function(e){var n=t["elGuideInfo".concat(e)];n&&(n.style.display="none")}))},renderGuideInfo:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:[],n=this.guidesStatic,r=this.editor;this.hideGuidesInfo(),e.forEach((function(e){var i=e.origin,a=e.x,s=r.Canvas.getElementPos(i),l=Object(o.isUndefined)(a)?"y":"x",c="y"===l,u=s[c?"left":"top"],h=s.rect[c?"left":"top"],d=c?u+s.width:u+s.height,f=c?h+s.rect.width:h+s.rect.height,p=t["elGuideInfo".concat(l.toUpperCase())],g=t["elGuideInfoContent".concat(l.toUpperCase())],v=p.style,m=n.filter((function(t){return t[l]===e[l]})).map((function(t){var e=t.originRect,n=e.left,r=e.width,i=e.top,o=e.height,a=c?n+r:i+o;return{gap:a0})).sort((function(t,e){return t.gap-e.gap})).map((function(t){return t.guide}))[0];if(m){var y=m.originRect,b=y.left,w=y.width,x=y.top,C=y.height,O=y.rect,S=c?b2&&void 0!==arguments[2]?arguments[2]:{};if(t.Canvas.hasFocus()||n.force){var r=[];t.getSelectedAll().forEach((function(t){for(var e=t.parent();e&&!e.get("selectable");)e=e.parent();e&&r.push(e)})),r.length&&t.select(r)}}}},function(t,e,n){"use strict";n.r(e),e.default={run:function(t){if(t.Canvas.hasFocus()){var e=[];t.getSelectedAll().forEach((function(t){var n=t.collection,r=n.indexOf(t),i=n.at(r+1);e.push(i||t)})),e.length&&t.select(e)}}}},function(t,e,n){"use strict";n.r(e),e.default={run:function(t){if(t.Canvas.hasFocus()){var e=[];t.getSelectedAll().forEach((function(t){var n=t.collection,r=n.indexOf(t),i=n.at(r-1);e.push(i&&r-1>=0?i:t)})),e.length&&t.select(e)}}}},function(t,e,n){"use strict";n.r(e);var r=n(0);e.default={run:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},i=n.target,o=t.DomComponents,a=i.get("type"),s=o.getWrapper().find('[data-gjs-type="'.concat(a,'"]')).length,l=[];if(!s){var c=t.CssComposer.getAll(),u=i.get("style-signature");u=Object(r.isArray)(u)?u:[u],c.forEach((function(t){var e=t.selectorsToString();u.forEach((function(n){n&&e.indexOf(n)>=0&&l.push(t)}))})),c.remove(l)}return l}}},function(t,e,n){"use strict";n.r(e);var r=n(8),i=n.n(r);e.default={run:function(t){var e=t.getModel(),n=i()(t.getSelectedAll());n.length&&e.set("clipboard",n)}}},function(t,e,n){"use strict";n.r(e);var r=n(0),i=n(1),o=n.n(i),a=n(12),s=o.a.$;e.default=Object(r.extend)({},a.default,{init:function(t){Object(r.bindAll)(this,"startDelete","stopDelete","onDelete"),this.hoverClass=this.pfx+"hover-delete",this.badgeClass=this.pfx+"badge-red"},enable:function(){this.$el.find("*").mouseover(this.startDelete).mouseout(this.stopDelete).click(this.onDelete)},startDelete:function(t){t.stopPropagation();var e=s(t.target);e.data("model").get("removable")&&(e.addClass(this.hoverClass),this.attachBadge(e.get(0)))},stopDelete:function(t){t.stopPropagation(),s(t.target).removeClass(this.hoverClass),this.badge&&this.badge.css({left:-1e3,top:-1e3})},onDelete:function(t){t.stopPropagation();var e=s(t.target);e.data("model").get("removable")&&(e.data("model").destroy(),this.removeBadge(),this.clean())},updateBadgeLabel:function(t){this.badge.html("Remove "+t.getName())}})},function(t,e,n){"use strict";n.r(e);var r=n(1),i=n.n(r).a.$;e.default={run:function(t,e){var n=this;arguments.length>2&&void 0!==arguments[2]&&arguments[2];e&&e.set&&e.set("active",0);var r=t.getConfig(),o=t.Modal,a=r.stylePrefix;if(this.cm=t.CodeManager||null,!this.$editors){var s=this.buildEditor("htmlmixed","hopscotch","HTML"),l=this.buildEditor("css","hopscotch","CSS");this.htmlEditor=s.el,this.cssEditor=l.el;var c=i('
'));c.append(s.$el).append(l.$el),this.$editors=c}o.open({title:r.textViewCode,content:this.$editors}).getModel().once("change:open",(function(){return t.stopCommand(n.id)})),this.htmlEditor.setContent(t.getHtml()),this.cssEditor.setContent(t.getCss())},stop:function(t){var e=t.Modal;e&&e.close()},buildEditor:function(t,e,n){var r=document.createElement("textarea");!this.codeMirror&&(this.codeMirror=this.cm.getViewer("CodeMirror"));var i=this.codeMirror.clone().set({label:n,codeName:t,theme:e,input:r}),o=new this.cm.EditorView({model:i,config:this.cm.getConfig()}).render().$el;return i.init(r),{el:i,$el:o}}}},function(t,e,n){"use strict";n.r(e);var r=n(0);e.default={isEnabled:function(){var t=document;return t.fullscreenElement||t.webkitFullscreenElement||t.mozFullScreenElement?1:0},enable:function(t){var e="";return t.requestFullscreen?t.requestFullscreen():t.webkitRequestFullscreen?(e="webkit",t.webkitRequestFullscreen()):t.mozRequestFullScreen?(e="moz",t.mozRequestFullScreen()):t.msRequestFullscreen?t.msRequestFullscreen():console.warn("Fullscreen not supported"),e},disable:function(){var t=document;this.isEnabled()&&(t.exitFullscreen?t.exitFullscreen():t.webkitExitFullscreen?t.webkitExitFullscreen():t.mozCancelFullScreen?t.mozCancelFullScreen():t.msExitFullscreen&&t.msExitFullscreen())},fsChanged:function(t,e){var n=(t||"")+"fullscreenchange";this.isEnabled()||(this.stop(null,this.sender),document.removeEventListener(n,this.fsChanged))},run:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};this.sender=e;var i=n.target,o=Object(r.isElement)(i)?i:document.querySelector(i),a=this.enable(o||t.getContainer());this.fsChanged=this.fsChanged.bind(this,a),document.addEventListener(a+"fullscreenchange",this.fsChanged),t.trigger("change:canvasOffset")},stop:function(t,e){e&&e.set&&e.set("active",!1),this.disable(),t&&t.trigger("change:canvasOffset")}}},function(t,e,n){"use strict";n.r(e);var r=n(0),i=n(1),o=n.n(i),a=n(3),s=n(12),l=n(24),c=o.a.$;e.default=Object(r.extend)({},l.default,s.default,{init:function(t){s.default.init.apply(this,arguments),Object(r.bindAll)(this,"initSorter","rollback","onEndMove"),this.opt=t,this.hoverClass=this.ppfx+"highlighter-warning",this.badgeClass=this.ppfx+"badge-warning",this.noSelClass=this.ppfx+"no-select"},enable:function(){for(var t=arguments.length,e=new Array(t),n=0;n2&&void 0!==arguments[2]?arguments[2]:{},i=t.Modal,o=t.AssetManager,a=o.getConfig(),s=o.getContainer(),l=r.modalTitle||a.modalTitle||"",c=r.types,u=r.accept;if(o.setTarget(r.target),o.onClick(r.onClick),o.onDblClick(r.onDblClick),o.onSelect(r.onSelect),!this.rendered||c){var h=o.getAll().filter((function(t){return 1}));c&&c.length&&(h=h.filter((function(t){return-1!==c.indexOf(t.get("type"))}))),o.render(h),this.rendered=1}if(u){var d=s.querySelector("input#".concat(a.stylePrefix,"uploadFile"));d&&d.setAttribute("accept",u)}return i.open({title:l,content:s}).getModel().once("change:open",(function(){return t.stopCommand(n.id)})),this},stop:function(t){return t.Modal.close(),this}}},function(t,e,n){"use strict";n.r(e),e.default={run:function(t,e){var n=t.BlockManager,r=t.Panels;if(!this.blocks){n.render();var i="views-container",o=document.createElement("div"),a=r.getPanel(i)||r.addPanel({id:i});o.appendChild(n.getContainer()),a.set("appendContent",o).trigger("change:appendContent"),this.blocks=o}this.blocks.style.display="block"},stop:function(){var t=this.blocks;t&&(t.style.display="none")}}},function(t,e,n){"use strict";n.r(e);var r=n(1);n.n(r).a.$;e.default={run:function(t){var e=t.LayerManager,n=t.Panels;if(!this.layers){var r="views-container",i=document.createElement("div"),o=n.getPanel(r)||n.addPanel({id:r});i.appendChild(e.render()),o.set("appendContent",i).trigger("change:appendContent"),this.layers=i}this.layers.style.display="block"},stop:function(){var t=this.layers;t&&(t.style.display="none")}}},function(t,e,n){"use strict";n.r(e);var r=n(1),i=n.n(r).a.$;e.default={run:function(t,e){if(this.sender=e,!this.$cn){var n=t.getConfig(),r=t.Panels;this.$cn=i("
"),this.$cn2=i("
"),this.$cn.append(this.$cn2);var o=t.DeviceManager;if(o&&n.showDevices)r.addPanel({id:"devices-c"}).set("appendContent",o.render()).trigger("change:appendContent");var a=t.SelectorManager;a&&this.$cn2.append(a.render([])),this.$cn2.append(t.StyleManager.render());var s=t.StyleManager.getConfig(),l=s.stylePrefix;this.$header=i('
').concat(s.textNoElement,"
")),this.$cn.append(this.$header),r.getPanel("views-container")?this.panel=r.getPanel("views-container"):this.panel=r.addPanel({id:"views-container"}),this.panel.set("appendContent",this.$cn).trigger("change:appendContent"),this.target=t.editor,this.listenTo(this.target,"component:toggled",this.toggleSm)}this.toggleSm()},toggleSm:function(){var t=this.target,e=this.sender;e&&e.get&&!e.get("active")||(1===t.getSelectedAll().length?(this.$cn2.show(),this.$header.hide()):(this.$cn2.hide(),this.$header.show()))},stop:function(){this.$cn2&&this.$cn2.hide(),this.$header&&this.$header.hide()}}},function(t,e,n){"use strict";n.r(e);var r=n(1),i=n.n(r).a.$;e.default={run:function(t,e){this.sender=e;var n=t.Config.stylePrefix,r=t.TraitManager;if(!this.$cn){var o=r.getTraitsViewer(),a=r.getConfig();this.$cn=i("
"),this.$cn2=i("
"),this.$cn.append(this.$cn2),this.$header=i("
").append('
').concat(a.textNoElement,"
")),this.$cn.append(this.$header),this.$cn2.append('
').concat(a.labelContainer,"
")),this.$cn2.append(o.render().el);var s=t.Panels;(s.getPanel("views-container")?s.getPanel("views-container"):s.addPanel({id:"views-container"})).set("appendContent",this.$cn.get(0)).trigger("change:appendContent"),this.target=t.getModel(),this.listenTo(this.target,"component:toggled",this.toggleTm)}this.toggleTm()},toggleTm:function(){var t=this.sender;t&&t.get&&!t.get("active")||(1===this.target.getSelectedAll().length?(this.$cn2.show(),this.$header.hide()):(this.$cn2.hide(),this.$header.show()))},stop:function(){this.$cn2&&this.$cn2.hide(),this.$header&&this.$header.hide()}}},function(t,e,n){"use strict";n.r(e);var r=n(0);e.default={run:function(t){var e=t.getModel().get("clipboard"),n=t.getSelected();e&&n&&(t.getSelectedAll().forEach((function(n){if(n){var i,o=n.collection,a=o.indexOf(n)+1,s=e.filter((function(t){return t.get("copyable")}));i=Object(r.contains)(e,n)&&n.get("copyable")?o.add(n.clone(),{at:a}):o.add(s.map((function(t){return t.clone()})),{at:a}),(i=Object(r.isArray)(i)?i:[i]).forEach((function(e){return t.trigger("component:paste",e)}))}})),n.emitUpdate())}}},function(t,e,n){"use strict";n.r(e);var r=n(0);e.default={getPanels:function(t){return this.panels||(this.panels=t.Panels.getPanelsEl()),this.panels},tglPointers:function(t,e){var n=t.Canvas.getBody().querySelectorAll(".".concat(this.ppfx,"no-pointer"));Object(r.each)(n,(function(t){return t.style.pointerEvents=e?"":"all"}))},run:function(t,e){var n=this;this.sender=e,t.stopCommand("sw-visibility"),t.getModel().stopDefault();var r=this.getPanels(t),i=t.Canvas.getElement(),o=t.getEl(),a=t.Config.stylePrefix;if(!this.helper){var s=document.createElement("span");s.className="".concat(a,"off-prv fa fa-eye-slash"),o.appendChild(s),s.onclick=function(){return n.stopCommand()},this.helper=s}this.helper.style.display="inline-block",this.tglPointers(t),r.style.display="none";var l=i.style;l.width="100%",l.height="100%",l.top="0",l.left="0",l.padding="0",l.margin="0",t.refresh()},stop:function(t){var e=this.sender,n=void 0===e?{}:e;n.set&&n.set("active",0);var r=this.getPanels(t);t.runCommand("sw-visibility"),t.getModel().runDefault(),r.style.display="",t.Canvas.getElement().setAttribute("style",""),this.helper&&(this.helper.style.display="none"),t.refresh(),this.tglPointers(t,1)}}},function(t,e,n){"use strict";n.r(e),e.default={run:function(t,e,n){var r=n||{},i=r.el||"",o=t.Canvas,a=this.canvasResizer,s=r.options||{},l=o.getCanvasView();return s.appendTo=o.getResizerEl(),s.prefix=t.getConfig().stylePrefix,s.posFetcher=l.getElementPos.bind(l),s.mousePosFetcher=o.getMouseRelativePos,a&&!r.forceNew||(this.canvasResizer=t.Utils.Resizer.init(s),a=this.canvasResizer),a.setOptions(s),a.blur(),a.focus(i),a},stop:function(){var t=this.canvasResizer;t&&t.blur()}}},function(t,e,n){"use strict";n.r(e);var r=n(1),i=n.n(r),o=n(3),a=i.a.$;e.default={getOffsetMethod:function(t){return"get"+(t||"")+"OffsetViewerEl"},run:function(t,e,n){var r=n||{},i=r.state||"",s=t.getConfig(),l=this.em.getZoomDecimal(),c=r.el||"";if(!s.showOffsets||Object(o.l)(c)||!s.showOffsetsSelected&&"Fixed"==i)t.stopCommand(this.id,n);else{var u=t.Canvas,h=r.elPos||u.getElementPos(c),d=window.getComputedStyle(c),f=this.ppfx,p=i+"State",g=u[this.getOffsetMethod(i)]();g.style.display="block";var v=this["marginT"+i],m=this["marginB"+i],y=this["marginL"+i],b=this["marginR"+i],w=this["padT"+i],x=this["padB"+i],C=this["padL"+i],O=this["padR"+i];if(!this[p]){var S=i.toLowerCase(),k=S+"margin-v",T=S+"padding-v",P=a('
')).get(0),j=a('
')).get(0),E=f+T+"-el",M="".concat(f+k+"-el"," ").concat(f+k),D="".concat(E," ").concat(f+T);v=a('
')).get(0),m=a('
')).get(0),y=a('
')).get(0),b=a('
')).get(0),w=a('
')).get(0),x=a('
')).get(0),C=a('
')).get(0),O=a('
')).get(0),this["marginT"+i]=v,this["marginB"+i]=m,this["marginL"+i]=y,this["marginR"+i]=b,this["padT"+i]=w,this["padB"+i]=x,this["padL"+i]=C,this["padR"+i]=O,P.appendChild(v),P.appendChild(m),P.appendChild(y),P.appendChild(b),j.appendChild(w),j.appendChild(x),j.appendChild(C),j.appendChild(O),g.appendChild(P),g.appendChild(j),this[p]="1"}var A=parseFloat(d.marginLeft.replace("px",""))*l,L=parseFloat(d.marginRight.replace("px",""))*l,N=parseFloat(d.marginTop.replace("px",""))*l,I=parseFloat(d.marginBottom.replace("px",""))*l,F=v.style,R=m.style,_=y.style,V=b.style,z=w.style,H=x.style,$=C.style,W=O.style,B=parseFloat(h.left),U=parseFloat(d.width)*l+"px";F.height=N+"px",F.width=U,F.top=h.top-N+"px",F.left=B+"px",R.height=I+"px",R.width=U,R.top=h.top+h.height+"px",R.left=B+"px";var q=h.height+N+I+"px",G=h.top-N+"px";_.height=q,_.width=A+"px",_.top=G,_.left=B-A+"px",V.height=q,V.width=L+"px",V.top=G,V.left=B+h.width+"px";var K=parseFloat(d.paddingTop)*l;z.height=K+"px",z.width=U,z.top=h.top+"px",z.left=B+"px";var Y=parseFloat(d.paddingBottom)*l;H.height=Y+"px",H.width=U,H.top=h.top+h.height-Y+"px",H.left=B+"px";var X=h.height-Y-K+"px",J=h.top+K+"px";$.height=X,$.width=parseFloat(d.paddingLeft)*l+"px",$.top=J,$.left=h.left+"px";var Z=parseFloat(d.paddingRight)*l;W.height=X,W.width=Z+"px",W.top=J,W.left=h.left+h.width-Z+"px"}},stop:function(t,e,n){var r=(n||{}).state||"",i=this.getOffsetMethod(r);t.Canvas[i]().style.display="none"}}},function(t,e,n){"use strict";n.r(e),e.default={run:function(t){t.Canvas.getBody().className=this.ppfx+"dashed"},stop:function(t){t.Canvas.getBody().className=""}}},function(t,e,n){"use strict";n.r(e);var r=n(2),i=n.n(r),o=n(0),a={stylePrefix:"sm-",sectors:[],appendTo:"",textNoElement:"Select an element before using Style Manager",textLayer:"Layer",hideNotStylable:!0,highlightChanged:!0,highlightComputed:!0,showComputed:!0,clearProperties:0,avoidComputed:["width","height"]},s=n(1),l=n.n(s),c=n(22),u=function(){return{build:function(t){var e=[];"string"==typeof t&&(t=[t]);for(var n=0,r=t.length;n\n \n <%= label %>\n
'),events:{"click [data-sector-title]":"toggle"},initialize:function(t){this.config=t.config||{},this.pfx=this.config.stylePrefix||"",this.target=t.target||{},this.propTarget=t.propTarget||{},this.caretR="fa-caret-right",this.caretD="fa-caret-down";var e=this.model;this.listenTo(e,"change:open",this.updateOpen),this.listenTo(e,"updateVisibility",this.updateVisibility),this.listenTo(e,"destroy remove",this.remove)},updateVisibility:function(){var t;this.model.get("properties").each((function(e){e.get("visible")&&(t=1)})),this.el.style.display=t?"block":"none"},updateOpen:function(){this.model.get("open")?this.show():this.hide()},show:function(){this.$el.addClass(this.pfx+"open"),this.getPropertiesEl().style.display="",this.$caret.removeClass(this.caretR).addClass(this.caretD)},hide:function(){this.$el.removeClass(this.pfx+"open"),this.getPropertiesEl().style.display="none",this.$caret.removeClass(this.caretD).addClass(this.caretR)},getPropertiesEl:function(){return this.$el.find(".".concat(this.pfx,"properties")).get(0)},toggle:function(t){var e=this.model.get("open")?0:1;this.model.set("open",e)},render:function(){var t=this.pfx,e=this.model,n=e.attributes.id;return this.$el.html(this.template({pfx:t,label:e.get("name")})),this.$caret=this.$el.find("#".concat(t,"caret")),this.renderProperties(),this.$el.attr("class","".concat(t,"sector ").concat(t,"sector__").concat(n," no-select")),this.updateOpen(),this},renderProperties:function(){var t=this.model.get("properties");if(t){var e=new g.default({collection:t,target:this.target,propTarget:this.propTarget,config:this.config});this.$el.append(e.render().el)}}});function m(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function y(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{},e=t.config||{};this.pfx=e.stylePrefix||"",this.ppfx=e.pStylePrefix||"",this.target=t.target||{},this.config=e;var n={};Object(o.extend)(n,l.a.Events);var r=document.body,i=document.createElement("el-".concat((new Date).getTime()));r.appendChild(i),n.computedDefault=y({},window.getComputedStyle(i)),r.removeChild(i),this.propTarget=n;var a=this.collection,s="component:toggled component:update:classes component:update:state change:device";this.listenTo(a,"add",this.addTo),this.listenTo(a,"reset",this.render),this.listenTo(this.target,s,this.targetUpdated)},addTo:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};this.addToCollection(t,null,n)},targetUpdated:function(){var t=this.target,e=this.propTarget,n=t.getSelected();if(n){var r=t.get("Config").devicePreviewMode?"":n.get("state"),i=n.getEl();if(e.helper=null,i&&Object(f.k)(i)){var o=r?":".concat(r):null;e.computed=window.getComputedStyle(i,o)}n=t.get("StyleManager").getModelToStyle(n),r&&function(){var n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},r=t.get("CssComposer"),i="hc-state",o=r.getAll(),a=r.getClassRule(i);a?(o.remove(a),o.add(a)):a=r.setClassRule(i),a.set("important",1),a.setStyle(n),e.helper=a}(n.getStyle()),e.model=n,e.trigger("update")}},setTarget:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=this.target,r=n.get("Config"),i=e.targetIsClass,a=e.stylable,s=t;if(Object(o.isString)(t)){var l,c=n.get("CssComposer").getAll();i&&(l=c.filter((function(e){return e.get("selectors").getFullString()===t}))[0]),l||(l=c.filter((function(e){return e.get("selectorsAdd")===t}))[0]),l||(l=c.add({selectors:[],selectorsAdd:t})),a&&l.set({stylable:a}),s=l}r.devicePreviewMode||s.get("state");var u=this.propTarget;return u.model=s,u.trigger("styleManager:update",s),s},addToCollection:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},r=this.pfx,i=this.target,o=this.propTarget,a=this.config,s=this.el,l=e||s,c=new v({model:t,id:"".concat(r).concat(t.get("id")),name:t.get("name"),properties:t.get("properties"),target:i,propTarget:o,config:a}).render().el;return Object(p.a)(l,c,n.at),c},render:function(){var t=this,e=document.createDocumentFragment(),n=this.$el,r=this.pfx,i=this.ppfx;return n.empty(),this.collection.each((function(n){return t.addToCollection(n,e)})),n.append(e),n.addClass("".concat(r,"sectors ").concat(i,"one-bg ").concat(i,"two-color")),this}});function w(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function x(t){for(var e=1;e2&&void 0!==arguments[2]?arguments[2]:{},i=this.getSector(t);return i||(n.id=t,i=e.add(n,r)),i},getSector:function(t){var n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},r=e.where({id:t})[0];return!r&&n.warn&&this._logNoSector(t),r},removeSector:function(t){return this.getSectors().remove(this.getSector(t,{warn:1}))},getSectors:function(){return e},addProperty:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},r=this.getSector(t,{warn:1}),i=null;return r&&(i=r.get("properties").add(e,n)),i},getProperty:function(t,e){var n=this.getSector(t,{warn:1}),r=null;return n&&(r=1==(r=n.get("properties").where({property:e})).length?r[0]:r),r},removeProperty:function(t,e){var n=this.getProperties(t);return n&&n.remove(this.getProperty(t,e))},getProperties:function(t){var e=null,n=this.getSector(t,{warn:1});return n&&(e=n.get("properties")),e},getModelToStyle:function(t){var e=r.em,n=t.get("classes"),i=t.getId();if(e){var o,a=e.getConfig(),s=e.get("UndoManager"),l=e.get("CssComposer"),c=a.devicePreviewMode?"":t.get("state"),u=n.getStyleable(),h=u.length,d={state:c};if(s.stop(),h){var f=e.getCurrentMedia();(o=l.get(u,c,f))||(o=l.add(u,c,f))}else a.avoidInlineStyle&&(!(o=l.getIdRule(i,d))&&(o=l.setIdRule(i,{},d)),t.is("wrapper")&&o.set("wrapper",1));o&&(t=o),s.start()}return t},addType:function(e,n){t.addType(e,n)},getType:function(e){return t.getType(e)},getTypes:function(){return t.getTypes()},createType:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=e.model,i=void 0===n?{}:n,o=e.view,a=void 0===o?{}:o,s=this.getType(t);if(s)return new s.view(x({model:new s.model(i),config:r},a))},setTarget:function(t,e){return n.setTarget(t,e)},getEmitter:function(){return n.propTarget},render:function(){return n.render().el},_logNoSector:function(t){var e=this.em;e&&e.logWarning("'".concat(t,"' sector not found"))}}}},function(t,e,n){"use strict";n.r(e);var r=n(2),i=n.n(r),o={stylePrefix:"",appendTo:"",sortable:1,hidable:1,hideTextnode:1,root:"",showWrapper:1,showHover:1,scrollCanvas:{behavior:"smooth",block:"nearest"},scrollLayers:{behavior:"auto",block:"nearest"},highlightHover:1},a=n(31),s=n(0);function l(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function c(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{};return(n=c({},o,{},e)).stylePrefix=e.pStylePrefix,t=n.em,this},getConfig:function(){return n},onLoad:function(){e=new a.a({level:0,config:n,opened:n.opened||{},model:t.get("DomComponents").getWrapper()}),t&&t.on("component:selected",this.componentChanged),this.componentChanged()},postRender:function(){var t=n.appendTo,e=n.root;(e&&this.setRoot(e),t)&&(Object(s.isElement)(t)?t:document.querySelector(t)).appendChild(this.render())},setRoot:function(t){return e.setRoot(t),this},getRoot:function(){return e.model},getAll:function(){return e},componentChanged:function(e){var r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};if(!r.fromLayers){var i=t.get("opened"),o=t.getSelected(),a=n.scrollLayers,s=o&&o.collection?o.collection.parent:null;for(var l in i)i[l].set("open",0);for(;s;)s.set("open",1),i[s.cid]=s,s=s.collection?s.collection.parent:null;if(o&&a){var c=o.viewLayer&&o.viewLayer.el;c&&c.scrollIntoView(a)}}},render:function(){return e.render().el}}}},function(t,e,n){var r,i,o; +/*! * Backbone.Undo.js v0.2 * * Copyright (c)2013 Oliver Sartun @@ -7,5 +9,5 @@ * * Documentation and full license available at * https://github.com/osartun/Backbone.Undo.js - */ -!function(s){r=[n(1),n(72)],i=s,void 0!==(o="function"==typeof i?i.apply(e,r):i)&&(t.exports=o)}(function(t,e){function n(t,e,n){return n.length<=4?t.call(e,n[0],n[1],n[2],n[3]):t.apply(e,n)}function i(t,e){return f.call(t,e)}function r(e,n){return null!=e&&(t.isArray(n)||(n=i(arguments,1)),t.all(n,function(t){return t in e}))}function o(){this.registeredObjects=[],this.cidIndexes=[]}function s(e,n,i,r){for(var o,s=0,a=n.length;st.maximumStackLength&&(t.shift(),t.pointer--)}}}function h(){}function d(e,n,i,o){if("object"==typeof n)return t.each(n,function(t,n){2===e?d(e,t,i,o):d(e,n,t,i)});switch(e){case 0:r(i,"undo","redo","on")&&t.all(t.pick(i,"undo","redo","on"),t.isFunction)&&(o[n]=i);break;case 1:o[n]&&t.isObject(i)&&(o[n]=t.extend({},o[n],i));break;case 2:delete o[n]}return this}var f=Array.prototype.slice,p=function(){function e(){i++,n=!0,t.defer(function(){n=!1})}var n=!1,i=-1;return function(){return n||e(),i}}();o.prototype={isRegistered:function(e){return e&&e.cid?this.registeredObjects[e.cid]:t.contains(this.registeredObjects,e)},register:function(t){return!this.isRegistered(t)&&(t&&t.cid?(this.registeredObjects[t.cid]=t,this.cidIndexes.push(t.cid)):this.registeredObjects.push(t),!0)},unregister:function(e){if(this.isRegistered(e)){if(e&&e.cid)delete this.registeredObjects[e.cid],this.cidIndexes.splice(t.indexOf(this.cidIndexes,e.cid),1);else{var n=t.indexOf(this.registeredObjects,e);this.registeredObjects.splice(n,1)}return!0}return!1},get:function(){return t.map(this.cidIndexes,function(t){return this.registeredObjects[t]},this).concat(this.registeredObjects)}};var g={add:{undo:function(t,e,n,i){t.remove(n,i)},redo:function(t,e,n,i){i.index&&(i.at=i.index),t.add(n,i)},on:function(e,n,i){return{object:n,before:void 0,after:e,options:t.clone(i)}}},remove:{undo:function(t,e,n,i){"index"in i&&(i.at=i.index),t.add(e,i)},redo:function(t,e,n,i){t.remove(e,i)},on:function(e,n,i){return{object:n,before:e,after:void 0,options:t.clone(i)}}},change:{undo:function(e,n,i,r){t.isEmpty(n)?t.each(t.keys(i),e.unset,e):(e.set(n),r&&r.unsetData&&r.unsetData.before&&r.unsetData.before.length&&t.each(r.unsetData.before,e.unset,e))},redo:function(e,n,i,r){t.isEmpty(i)?t.each(t.keys(n),e.unset,e):(e.set(i),r&&r.unsetData&&r.unsetData.after&&r.unsetData.after.length&&t.each(r.unsetData.after,e.unset,e))},on:function(e,n){var i=e.changedAttributes(),r=t.keys(i),o=t.pick(e.previousAttributes(),r),s=t.keys(o),a=(n||(n={})).unsetData={after:[],before:[]};return r.length!=s.length&&(r.length>s.length?t.each(r,function(t){t in o||a.before.push(t)},this):t.each(s,function(t){t in i||a.after.push(t)})),{object:e,before:o,after:i,options:t.clone(n)}}},reset:{undo:function(t,e,n){t.reset(e)},redo:function(t,e,n){t.reset(n)},on:function(e,n){return{object:e,before:n.previousModels,after:t.clone(e.models)}}}};h.prototype=g;var v=e.Model.extend({defaults:{type:null,object:null,before:null,after:null,magicFusionIndex:null},undo:function(t){a("undo",this.attributes)},redo:function(t){a("redo",this.attributes)}}),m=e.Collection.extend({model:v,pointer:-1,track:!1,isCurrentlyUndoRedoing:!1,maximumStackLength:1/0,setMaxLength:function(t){this.maximumStackLength=t}}),y=e.Model.extend({defaults:{maximumStackLength:1/0,track:!1},initialize:function(e){this.stack=new m,this.objectRegistry=new o,this.undoTypes=new h,this.stack.setMaxLength(this.get("maximumStackLength")),this.on("change:maximumStackLength",function(t,e){this.stack.setMaxLength(e)},this),e&&e.track&&this.startTracking(),e&&e.register&&(t.isArray(e.register)||t.isArguments(e.register)?n(this.register,this,e.register):this.register(e.register))},startTracking:function(){this.set("track",!0),this.stack.track=!0},stopTracking:function(){this.set("track",!1),this.stack.track=!1},isTracking:function(){return this.get("track")},_addToStack:function(t){u(this.stack,t,i(arguments,1),this.undoTypes)},register:function(){s("on",arguments,this._addToStack,this)},unregister:function(){s("off",arguments,this._addToStack,this)},unregisterAll:function(){n(this.unregister,this,this.objectRegistry.get())},undo:function(t){l("undo",this,this.stack,t)},undoAll:function(){l("undo",this,this.stack,!1,!0)},redo:function(t){l("redo",this,this.stack,t)},redoAll:function(){l("redo",this,this.stack,!1,!0)},isAvailable:function(t){var e=this.stack,n=e.length;switch(t){case"undo":return n>0&&e.pointer>-1;case"redo":return n>0&&e.pointer1&&void 0!==arguments[1]?arguments[1]:{},i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:null,r=this.get("contentTypeJson"),s=this.get("headers")||{},a=this.get("params"),l=n.body||{},c=void 0,u=void 0;for(var h in a)l[h]=a[h];if((0,o.isUndefined)(s["X-Requested-With"])&&(s["X-Requested-With"]="XMLHttpRequest"),(0,o.isUndefined)(s["Content-Type"])&&r&&(s["Content-Type"]="application/json; charset=utf-8"),r)u=JSON.stringify(l);else{u=new FormData;for(var d in l)u.append(d,l[d])}c={method:n.method||"post",credentials:"include",headers:s},"post"===c.method&&(c.body=u),this.onStart(),this.fetch(t,c).then(function(t){return 1==(t.status/200|0)?t.text():t.text().then(function(t){return Promise.reject(t)})}).then(function(t){return e.onResponse(t,i)}).catch(function(t){return e.onError(t)})}})},function(t,e,n){(function(e){!function(n){function i(){}function r(t,e){return function(){t.apply(e,arguments)}}function o(t){if("object"!=typeof this)throw new TypeError("Promises must be constructed via new");if("function"!=typeof t)throw new TypeError("not a function");this._state=0,this._handled=!1,this._value=void 0,this._deferreds=[],h(t,this)}function s(t,e){for(;3===t._state;)t=t._value;if(0===t._state)return void t._deferreds.push(e);t._handled=!0,o._immediateFn(function(){var n=1===t._state?e.onFulfilled:e.onRejected;if(null===n)return void(1===t._state?a:l)(e.promise,t._value);var i;try{i=n(t._value)}catch(t){return void l(e.promise,t)}a(e.promise,i)})}function a(t,e){try{if(e===t)throw new TypeError("A promise cannot be resolved with itself.");if(e&&("object"==typeof e||"function"==typeof e)){var n=e.then;if(e instanceof o)return t._state=3,t._value=e,void c(t);if("function"==typeof n)return void h(r(n,e),t)}t._state=1,t._value=e,c(t)}catch(e){l(t,e)}}function l(t,e){t._state=2,t._value=e,c(t)}function c(t){2===t._state&&0===t._deferreds.length&&o._immediateFn(function(){t._handled||o._unhandledRejectionFn(t._value)});for(var e=0,n=t._deferreds.length;e=0&&(t._idleTimeoutId=setTimeout(function(){t._onTimeout&&t._onTimeout()},e))},n(79),e.setImmediate=setImmediate,e.clearImmediate=clearImmediate},function(t,e,n){(function(t,e){!function(t,n){"use strict";function i(t){"function"!=typeof t&&(t=new Function(""+t));for(var e=new Array(arguments.length-1),n=0;n1)for(var n=1;n<%= deviceLabel %>
\n
\n \n \n \n
\n
\n
\n
\n '),events:{change:"updateDevice"},initialize:function(t){this.config=t.config||{},this.em=this.config.em,this.ppfx=this.config.pStylePrefix||"",this.events["click ."+this.ppfx+"add-trasp"]=this.startAdd,this.listenTo(this.em,"change:device",this.updateSelect),this.delegateEvents()},startAdd:function(){},updateDevice:function(){var t=this.em;if(t){var e=this.devicesEl,n=e?e.val():"";t.set("device",n)}},updateSelect:function(){var t=this.em,e=this.devicesEl;if(t&&t.getDeviceModel&&e){var n=t.getDeviceModel(),i=n?n.get("name"):"";e.val(i)}},getOptions:function(){var t="";return this.collection.each(function(e){var n=e.get("name");t+='"}),t},render:function(){var t=this.ppfx;return this.$el.html(this.template({ppfx:t,deviceLabel:this.config.deviceLabel})),this.devicesEl=this.$el.find("."+t+"devices"),this.devicesEl.append(this.getOptions()),this.el.className=t+"devices-c",this}})}).call(e,n(1))},function(t,e,n){"use strict";t.exports=function(){var t,e,i={},r=n(87),o=n(88),s=n(25);return{compTypes:"",name:"Parser",init:function(n){i=n||{};for(var a in r)a in i||(i[a]=r[a]);return t=new s(i),e=new o(i),this},parseHtml:function(n){return t.compTypes=this.compTypes,t.parse(n,e)},parseCss:function(t){return e.parse(t)}}}},function(t,e,n){"use strict";t.exports={textTags:["br","b","i","u","a","ul","ol"]}},function(t,e,n){"use strict";t.exports=function(t){return{parseSelector:function(t){for(var e=[],n=[],i=t.split(","),r=0,o=i.length;r1&&void 0!==arguments[1]?arguments[1]:{};"object"==(void 0===t?"undefined":i(t))?n=t:n.name=t,n.label&&!n.name&&(n.name=l.escapeName(n.label));var r=n.name,o=r?this.get(r,n.type):e.where(n)[0];return o||e.add(n)},addClass:function(t){var n=[];return(0,r.isString)(t)&&(t=t.trim().split(" ")),t.forEach(function(t){return n.push(e.add({name:t}))}),n},get:function(t){var n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:l.TYPE_CLASS;return e.where({name:t,type:n})[0]},getAll:function(){return e},render:function(t){if(t){return new u({collection:new c(t),config:s}).render().el}return o.render().el}}}},function(t,e,n){"use strict";t.exports={stylePrefix:"clm-",selectors:[],label:"Classes",statesLabel:"- State -",selectedLabel:"Selected",states:[{name:"hover",label:"Hover"},{name:"active",label:"Click"},{name:"nth-of-type(2n)",label:"Even/Odd"}]}},function(t,e,n){"use strict";(function(e){var i=n(0),r=n(92);t.exports=i.View.extend({template:e.template('\n
\n
<%= label %>
\n
\n \n
\n \n \n \n
\n
\n
\n
\n
\n
\n
\n
\n
\n \n \n
\n
\n
<%= selectedLabel %>
\n
\n
\n
'),events:{},initialize:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};this.config=t.config||{},this.pfx=this.config.stylePrefix||"",this.ppfx=this.config.pStylePrefix||"",this.className=this.pfx+"tags",this.addBtnId=this.pfx+"add-tag",this.newInputId=this.pfx+"new",this.stateInputId=this.pfx+"states",this.stateInputC=this.pfx+"input-c",this.states=this.config.states||[],this.events["click #"+this.addBtnId]="startNewTag",this.events["blur #"+this.newInputId]="endNewTag",this.events["keyup #"+this.newInputId]="onInputKeyUp",this.events["change #"+this.stateInputId]="stateChanged",this.target=this.config.em,this.em=this.target,this.listenTo(this.target,"change:selectedComponent",this.componentChanged),this.listenTo(this.target,"component:update:classes",this.updateSelector),this.listenTo(this.collection,"add",this.addNew),this.listenTo(this.collection,"reset",this.renderClasses),this.listenTo(this.collection,"remove",this.tagRemoved),this.delegateEvents()},tagRemoved:function(t){this.updateStateVis()},getStateOptions:function(){for(var t="",e=0;e'+this.states[e].label+"";return t},addNew:function(t){this.addToClasses(t)},startNewTag:function(t){this.$addBtn.get(0).style.display="none",this.$input.show().focus()},endNewTag:function(t){this.$addBtn.get(0).style.display="",this.$input.hide().val("")},onInputKeyUp:function(t){13===t.keyCode?this.addNewTag(this.$input.val()):27===t.keyCode&&this.endNewTag()},componentChanged:function(t){this.compTarget=this.target.get("selectedComponent");var e=this.compTarget,n=[];e&&(this.getStates().val(e.get("state")),n=e.get("classes").getValid()),this.collection.reset(n),this.updateStateVis()},updateStateVis:function(){var t=this.em,e=t&&t.getConfig("avoidInlineStyle");this.collection.length||e?this.getStatesC().css("display","block"):this.getStatesC().css("display","none"),this.updateSelector()},updateSelector:function(){var t=this.target.getSelected();if(this.compTarget=t,t&&t.get){var e=t.get("state"),n=this.collection,i=n.getFullString(n.getStyleable());i=i||"#"+t.getId(),i+=e?":"+e:"";var r=this.el.querySelector("#"+this.pfx+"sel");r&&(r.innerHTML=i)}},stateChanged:function(t){this.compTarget&&(this.compTarget.set("state",this.$states.val()),this.updateSelector())},addNewTag:function(t){var e=this.target,n=this.compTarget;if(t.trim()){if(e){var i=e.get("SelectorManager"),r=i.add({label:t});if(n){var o=n.get("classes");o.length;o.add(r);o.length;this.collection.add(r),this.updateStateVis()}}this.endNewTag()}},addToClasses:function(t,e){var n=e||null,i=new r({model:t,config:this.config,coll:this.collection}),o=i.render().el;return n?n.appendChild(o):this.getClasses().append(o),o},renderClasses:function(){var t=document.createDocumentFragment();return this.collection.each(function(e){this.addToClasses(e,t)},this),this.getClasses()&&this.getClasses().empty().append(t),this},getClasses:function(){return this.$classes||(this.$classes=this.$el.find("#"+this.pfx+"tags-c")),this.$classes},getStates:function(){return this.$states||(this.$states=this.$el.find("#"+this.stateInputId)),this.$states},getStatesC:function(){return this.$statesC||(this.$statesC=this.$el.find("#"+this.stateInputC)),this.$statesC},render:function(){var t=this.config;return this.$el.html(this.template({selectedLabel:t.selectedLabel,statesLabel:t.statesLabel,label:t.label,pfx:this.pfx,ppfx:this.ppfx})),this.$input=this.$el.find("input#"+this.newInputId),this.$addBtn=this.$el.find("#"+this.addBtnId),this.$classes=this.$el.find("#"+this.pfx+"tags-c"),this.$states=this.$el.find("#"+this.stateInputId),this.$statesC=this.$el.find("#"+this.stateInputC),this.$states.append(this.getStateOptions()),this.renderClasses(),this.$el.attr("class",this.className),this}})}).call(e,n(1))},function(t,e,n){"use strict";var i=n(7);t.exports=n(0).View.extend({template:function(){var t=this.pfx;this.ppfx;return'\n \n '+(this.model.get("label")||"")+'\n \n ⨯\n \n '},events:{"click [data-tag-remove]":"removeTag","click [data-tag-status]":"changeStatus","dblclick [data-tag-name]":"startEditTag","focusout [data-tag-name]":"endEditTag"},initialize:function(t){this.config=t.config||{},this.coll=t.coll||null,this.pfx=this.config.stylePrefix||"",this.ppfx=this.config.pStylePrefix||"",this.target=this.config.em,this.listenTo(this.model,"change:active",this.updateStatus)},getInputEl:function(){return this.inputEl||(this.inputEl=this.el.querySelector("[data-tag-name]")),this.inputEl},startEditTag:function(){var t=this.getInputEl();t.contentEditable=!0,t.focus()},endEditTag:function(){var t=this.model,e=this.getInputEl(),n=e.textContent,r=i.escapeName(n),o=this.target,s=o&&o.get("SelectorManager");e.contentEditable=!1,s&&(s.get(r)?e.innerText=t.get("label"):t.set({name:r,label:n}))},changeStatus:function(){this.model.set("active",!this.model.get("active"))},removeTag:function(t){var e=this,n=this.target,i=this.model,r=this.coll,o=(this.el,n&&n.get("selectedComponent"));o&&(o.get,o.get("classes").remove(i)),r&&r.remove(i),setTimeout(function(){return e.remove()},0)},updateStatus:function(){var t="fa-check-square-o";this.$chk||(this.$chk=this.$el.find("#"+this.pfx+"checkbox")),this.model.get("active")?(this.$chk.removeClass("fa-square-o").addClass(t),this.$el.removeClass("opac50")):(this.$chk.removeClass(t).addClass("fa-square-o"),this.$el.addClass("opac50"))},render:function(){var t=this.pfx,e=this.ppfx;return this.$el.html(this.template()),this.$el.attr("class",t+"tag "+e+"three-bg"),this.updateStatus(),this}})},function(t,e,n){"use strict";t.exports=function(){var t,e,i={},r=n(94),o=n(95),s=n(96);return{name:"Modal",init:function(n){i=n||{};for(var a in r)a in i||(i[a]=r[a]);var l=i.pStylePrefix;return l&&(i.stylePrefix=l+i.stylePrefix),t=new o(i),e=new s({model:t,config:i}),this},postRender:function(t){this.render().appendTo(t.el)},open:function(){return e.show(),this},close:function(){return e.hide(),this},isOpen:function(){return!!t.get("open")},setTitle:function(e){return t.set("title",e),this},getTitle:function(){return t.get("title")},setContent:function(e){return t.set("content"," "),t.set("content",e),this},getContent:function(){return t.get("content")},getContentEl:function(){return e.getContent().get(0)},getModel:function(){return t},render:function(){return e.render().$el}}}},function(t,e,n){"use strict";t.exports={stylePrefix:"mdl-",title:"",content:"",backdrop:!0}},function(t,e,n){"use strict";var i=n(0);t.exports=i.Model.extend({defaults:{title:"",content:"",open:!1}})},function(t,e,n){"use strict";t.exports=n(0).View.extend({template:function(t){var e=t.pfx,n=t.ppfx,i=t.content;return'
\n
\n
'+t.title+'
\n
\n
\n
\n
'+i+'
\n
\n
\n
\n
\n '},events:{},initialize:function(t){var e=this.model,n=t.config||{},i=n.stylePrefix||"",r=n.backdrop;this.config=n,this.pfx=i,this.ppfx=n.pStylePrefix||"",this.listenTo(e,"change:open",this.updateOpen),this.listenTo(e,"change:title",this.updateTitle),this.listenTo(e,"change:content",this.updateContent),this.events["click ."+i+"btn-close"]="hide",r&&(this.events["click ."+i+"backlayer"]="hide"),this.delegateEvents()},getCollector:function(){return this.$collector||(this.$collector=this.$el.find("."+this.pfx+"collector")),this.$collector},getContent:function(){var t=this.pfx;return this.$content||(this.$content=this.$el.find("."+t+"content #"+t+"c")),this.$content},getTitle:function(){return this.$title||(this.$title=this.$el.find("."+this.pfx+"title")),this.$title.get(0)},updateContent:function(){var t=this.getContent(),e=t.children(),n=this.getCollector(),i=this.model.get("content");e.length&&n.append(e),t.empty().append(i)},updateTitle:function(){var t=this.getTitle();t&&(t.innerHTML=this.model.get("title"))},updateOpen:function(){this.el.style.display=this.model.get("open")?"":"none"},hide:function(){this.model.set("open",0)},show:function(){this.model.set("open",1)},render:function(){var t=this.$el,e=this.pfx,n=(this.ppfx,this.model.toJSON());return n.pfx=this.pfx,n.ppfx=this.ppfx,t.html(this.template(n)),t.attr("class",e+"container"),this.updateOpen(),this}})},function(t,e,n){"use strict";t.exports=function(){var t={},e=n(98),i=n(99),r=n(100),o=n(101),s=n(102),a=n(103),l=n(108),c={},u={},h={},d={};return{getConfig:function(){return t},config:t,EditorView:l,name:"CodeManager",init:function(n){t=n||{};for(var l in e)l in t||(t[l]=e[l]);var c=t.pStylePrefix;return c&&(t.stylePrefix=c+t.stylePrefix),u.html=new i,u.css=new r,u.json=new o,u.js=new s,d.CodeMirror=new a,this.loadDefaultGenerators().loadDefaultViewers(),this},addGenerator:function(t,e){return c[t]=e,this},getGenerator:function(t){return c[t]||null},getGenerators:function(){return c},addViewer:function(t,e){return h[t]=e,this},getViewer:function(t){return h[t]||null},getViewers:function(){return h},updateViewer:function(t,e){t.setContent(e)},getCode:function(e,n){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};i.em=t.em;var r=this.getGenerator(n);return r?r.build(e,i):""},loadDefaultGenerators:function(){for(var t in u)this.addGenerator(t,u[t]);return this},loadDefaultViewers:function(){for(var t in d)this.addViewer(t,d[t]);return this}}}},function(t,e,n){"use strict";t.exports={stylePrefix:"cm-",inlineCss:!1}},function(t,e,n){"use strict";var i=n(0);t.exports=i.Model.extend({build:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=t.get("components");return e.exportWrapper?e.wrappesIsBody?""+this.buildModels(n)+"":t.toHTML():this.buildModels(n)},buildModels:function(t){var e="";return t.each(function(t){e+=t.toHTML()}),e}})},function(t,e,n){"use strict";t.exports=n(0).Model.extend({initialize:function(){this.compCls=[],this.ids=[]},buildFromModel:function(t){var e=this,n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},i="",r=this.em,o=r&&r.getConfig("avoidInlineStyle"),s=t.styleToString(),a=t.get("classes"),l=n.wrappesIsBody,c=t.get("wrapper");if(this.ids.push("#"+t.getId()),a.each(function(t){return e.compCls.push(t.getFullName())}),(!o||c)&&s){var u="#"+t.getId();u=l&&c?"body":u,i=u+"{"+s+"}"}return t.components().each(function(t){return i+=e.buildFromModel(t,n)}),i},build:function(t){var e=this,n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},i=n.cssc;this.em=n.em||"",this.compCls=[],this.ids=[];var r=this.buildFromModel(t,n);if(i){var o=i.getAll(),s={};o.each(function(t){var n=t.get("mediaText");if(n){var i=s[n];return void(i?i.push(t):s[n]=[t])}r+=e.buildFromRule(t)});for(var a in s){var l="";s[a].forEach(function(t){return l+=e.buildFromRule(t)}),l&&(r+="@media "+a+"{"+l+"}")}}return r},buildFromRule:function(t){var e=this,n="",i=t.selectorsToString(),r=t.selectorsToString({skipAdd:1}),o=void 0;if(t.get("selectors").each(function(t){var n=t.getFullName();(e.compCls.indexOf(n)>=0||e.ids.indexOf(n)>=0)&&(o=1)}),r&&o||t.get("selectorsAdd")){var s=t.styleToString();s&&(n+=i+"{"+s+"}")}return n}})},function(t,e,n){"use strict";(function(e){var i=n(0);t.exports=i.Model.extend({build:function(t){var n=t.toJSON();return this.beforeEach(n),e.each(n,function(t,e){var r=n[e];if(r instanceof i.Model)n[e]=this.build(r);else if(r instanceof i.Collection){var o=r;n[e]=[],o.length&&o.each(function(t,i){n[e][i]=this.build(t)},this)}},this),n},beforeEach:function(t){delete t.status}})}).call(e,n(1))},function(t,e,n){"use strict";(function(e){var i=n(0);t.exports=i.Model.extend({mapModel:function(t){var n="",i=t.get("script"),r=t.get("type"),o=t.get("components"),s=t.getId();if(i){var a=t.get("attributes");a=e.extend({},a,{id:s}),t.set("attributes",a);var l=t.getScriptString();if(t.get("scriptUpdated"))this.mapJs[r+"-"+s]={ids:[s],code:l};else{var c=this.mapJs[r];c?c.ids.push(s):this.mapJs[r]={ids:[s],code:l}}}return o.each(function(t){n+=this.mapModel(t)},this),n},build:function(t){this.mapJs={},this.mapModel(t);var e="";for(var n in this.mapJs){var i=this.mapJs[n];e+="\n var items = document.querySelectorAll('"+("#"+i.ids.join(", #"))+"');\n for (var i = 0, len = items.length; i < len; i++) {\n (function(){"+i.code+"}.bind(items[i]))();\n }"}return e}})}).call(e,n(1))},function(t,e,n){"use strict";var i=Object.assign||function(t){for(var e=1;e-1?t.backUp(i.length-r):i.match(/<\/?$/)&&(t.backUp(i.length),t.match(e,!1)||t.match(i)),n}function n(t){var e=l[t];return e||(l[t]=new RegExp("\\s+"+t+"\\s*=\\s*('|\")?([^'\"]+)('|\")?\\s*"))}function i(t,e){var i=t.match(n(e));return i?/^\s*(.*?)\s*$/.exec(i[2])[1]:""}function r(t,e){return new RegExp((e?"^":"")+"","i")}function o(t,e){for(var n in t)for(var i=e[n]||(e[n]=[]),r=t[n],o=r.length-1;o>=0;o--)i.unshift(r[o])}function s(t,e){for(var n=0;n\s\/]/.test(i.current())&&(a=o.htmlState.tagName&&o.htmlState.tagName.toLowerCase())&&u.hasOwnProperty(a))o.inTag=a+" ";else if(o.inTag&&d&&/>$/.test(i.current())){var f=/^([\S]+) (.*)/.exec(o.inTag);o.inTag=null;var p=">"==i.current()&&s(u[f[1]],f[2]),g=t.getMode(n,p),v=r(f[1],!0),m=r(f[1],!1);o.token=function(t,n){return t.match(v,!1)?(n.token=l,n.localState=n.localMode=null,null):e(t,m,n.localMode.token(t,n.localState))},o.localMode=g,o.localState=t.startState(g,c.indent(o.htmlState,""))}else o.inTag&&(o.inTag+=i.current(),i.eol()&&(o.inTag+=" "));return h}var c=t.getMode(n,{name:"xml",htmlMode:!0,multilineTagIndentFactor:i.multilineTagIndentFactor,multilineTagIndentPastTag:i.multilineTagIndentPastTag}),u={},h=i&&i.tags,d=i&&i.scriptTypes;if(o(a,u),h&&o(h,u),d)for(var f=d.length-1;f>=0;f--)u.script.unshift(["type",d[f].matches,d[f].mode]);return{startState:function(){return{token:l,inTag:null,localMode:null,localState:null,htmlState:t.startState(c)}},copyState:function(e){var n;return e.localState&&(n=t.copyState(e.localMode,e.localState)),{token:e.token,inTag:e.inTag,localMode:e.localMode,localState:n,htmlState:t.copyState(c,e.htmlState)}},token:function(t,e){return e.token(t,e)},indent:function(e,n,i){return!e.localMode||/^\s*<\//.test(n)?c.indent(e.htmlState,n):e.localMode.indent?e.localMode.indent(e.localState,n,i):t.Pass},innerMode:function(t){return{state:t.localState||t.htmlState,mode:t.localMode||c}}}},"xml","javascript","css"),t.defineMIME("text/html","htmlmixed")})},function(t,e,n){!function(t){t(n(6))}(function(t){"use strict";var e={autoSelfClosers:{area:!0,base:!0,br:!0,col:!0,command:!0,embed:!0,frame:!0,hr:!0,img:!0,input:!0,keygen:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0,menuitem:!0},implicitlyClosed:{dd:!0,li:!0,optgroup:!0,option:!0,p:!0,rp:!0,rt:!0,tbody:!0,td:!0,tfoot:!0,th:!0,tr:!0},contextGrabbers:{dd:{dd:!0,dt:!0},dt:{dd:!0,dt:!0},li:{li:!0},option:{option:!0,optgroup:!0},optgroup:{optgroup:!0},p:{address:!0,article:!0,aside:!0,blockquote:!0,dir:!0,div:!0,dl:!0,fieldset:!0,footer:!0,form:!0,h1:!0,h2:!0,h3:!0,h4:!0,h5:!0,h6:!0,header:!0,hgroup:!0,hr:!0,menu:!0,nav:!0,ol:!0,p:!0,pre:!0,section:!0,table:!0,ul:!0},rp:{rp:!0,rt:!0},rt:{rp:!0,rt:!0},tbody:{tbody:!0,tfoot:!0},td:{td:!0,th:!0},tfoot:{tbody:!0},th:{td:!0,th:!0},thead:{tbody:!0,tfoot:!0},tr:{tr:!0}},doNotIndent:{pre:!0},allowUnquoted:!0,allowMissing:!0,caseFold:!0},n={autoSelfClosers:{},implicitlyClosed:{},contextGrabbers:{},doNotIndent:{},allowUnquoted:!1,allowMissing:!1,caseFold:!1};t.defineMode("xml",function(i,r){function o(t,e){function n(n){return e.tokenize=n,n(t,e)}var i=t.next();if("<"==i)return t.eat("!")?t.eat("[")?t.match("CDATA[")?n(l("atom","]]>")):null:t.match("--")?n(l("comment","--\x3e")):t.match("DOCTYPE",!0,!0)?(t.eatWhile(/[\w\._\-]/),n(c(1))):null:t.eat("?")?(t.eatWhile(/[\w\._\-]/),e.tokenize=l("meta","?>"),"meta"):(E=t.eat("/")?"closeTag":"openTag",e.tokenize=s,"tag bracket");if("&"==i){var r;return r=t.eat("#")?t.eat("x")?t.eatWhile(/[a-fA-F\d]/)&&t.eat(";"):t.eatWhile(/[\d]/)&&t.eat(";"):t.eatWhile(/[\w\.\-:]/)&&t.eat(";"),r?"atom":"error"}return t.eatWhile(/[^&<]/),null}function s(t,e){var n=t.next();if(">"==n||"/"==n&&t.eat(">"))return e.tokenize=o,E=">"==n?"endTag":"selfcloseTag","tag bracket";if("="==n)return E="equals",null;if("<"==n){e.tokenize=o,e.state=f,e.tagName=e.tagStart=null;var i=e.tokenize(t,e);return i?i+" tag error":"tag error"}return/[\'\"]/.test(n)?(e.tokenize=a(n),e.stringStartCol=t.column(),e.tokenize(t,e)):(t.match(/^[^\s\u00a0=<>\"\']*[^\s\u00a0=<>\"\'\/]/),"word")}function a(t){var e=function(e,n){for(;!e.eol();)if(e.next()==t){n.tokenize=s;break}return"string"};return e.isInAttribute=!0,e}function l(t,e){return function(n,i){for(;!n.eol();){if(n.match(e)){i.tokenize=o;break}n.next()}return t}}function c(t){return function(e,n){for(var i;null!=(i=e.next());){if("<"==i)return n.tokenize=c(t+1),n.tokenize(e,n);if(">"==i){if(1==t){n.tokenize=o;break}return n.tokenize=c(t-1),n.tokenize(e,n)}}return"meta"}}function u(t,e,n){this.prev=t.context,this.tagName=e,this.indent=t.indented,this.startOfLine=n,(k.doNotIndent.hasOwnProperty(e)||t.context&&t.context.noIndent)&&(this.noIndent=!0)}function h(t){t.context&&(t.context=t.context.prev)}function d(t,e){for(var n;;){if(!t.context)return;if(n=t.context.tagName,!k.contextGrabbers.hasOwnProperty(n)||!k.contextGrabbers[n].hasOwnProperty(e))return;h(t)}}function f(t,e,n){return"openTag"==t?(n.tagStart=e.column(),p):"closeTag"==t?g:f}function p(t,e,n){return"word"==t?(n.tagName=e.current(),M="tag",y):(M="error",p)}function g(t,e,n){if("word"==t){var i=e.current();return n.context&&n.context.tagName!=i&&k.implicitlyClosed.hasOwnProperty(n.context.tagName)&&h(n),n.context&&n.context.tagName==i||!1===k.matchClosing?(M="tag",v):(M="tag error",m)}return M="error",m}function v(t,e,n){return"endTag"!=t?(M="error",v):(h(n),f)}function m(t,e,n){return M="error",v(t,e,n)}function y(t,e,n){if("word"==t)return M="attribute",b;if("endTag"==t||"selfcloseTag"==t){var i=n.tagName,r=n.tagStart;return n.tagName=n.tagStart=null,"selfcloseTag"==t||k.autoSelfClosers.hasOwnProperty(i)?d(n,i):(d(n,i),n.context=new u(n,i,r==n.indented)),f}return M="error",y}function b(t,e,n){return"equals"==t?x:(k.allowMissing||(M="error"),y(t,e,n))}function x(t,e,n){return"string"==t?w:"word"==t&&k.allowUnquoted?(M="string",y):(M="error",y(t,e,n))}function w(t,e,n){return"string"==t?w:y(t,e,n)}var C=i.indentUnit,k={},S=r.htmlMode?e:n;for(var T in S)k[T]=S[T];for(var T in r)k[T]=r[T];var E,M;return o.isInText=!0,{startState:function(t){var e={tokenize:o,state:f,indented:t||0,tagName:null,tagStart:null,context:null};return null!=t&&(e.baseIndent=t),e},token:function(t,e){if(!e.tagName&&t.sol()&&(e.indented=t.indentation()),t.eatSpace())return null;E=null;var n=e.tokenize(t,e);return(n||E)&&"comment"!=n&&(M=null,e.state=e.state(E||n,t,e),M&&(n="error"==M?n+" error":M)),n},indent:function(e,n,i){var r=e.context;if(e.tokenize.isInAttribute)return e.tagStart==e.indented?e.stringStartCol+1:e.indented+C;if(r&&r.noIndent)return t.Pass;if(e.tokenize!=s&&e.tokenize!=o)return i?i.match(/^(\s*)/)[0].length:0;if(e.tagName)return!1!==k.multilineTagIndentPastTag?e.tagStart+e.tagName.length+2:e.tagStart+C*(k.multilineTagIndentFactor||1);if(k.alignCDATA&&/$/,blockCommentStart:"\x3c!--",blockCommentEnd:"--\x3e",configuration:k.htmlMode?"html":"xml",helperType:k.htmlMode?"html":"xml",skipAttribute:function(t){t.state==x&&(t.state=y)}}}),t.defineMIME("text/xml","xml"),t.defineMIME("application/xml","xml"),t.mimeModes.hasOwnProperty("text/html")||t.defineMIME("text/html",{name:"xml",htmlMode:!0})})},function(t,e,n){!function(t){t(n(6))}(function(t){"use strict";t.defineMode("javascript",function(e,n){function i(t){for(var e,n=!1,i=!1;null!=(e=t.next());){if(!n){if("/"==e&&!i)return;"["==e?i=!0:i&&"]"==e&&(i=!1)}n=!n&&"\\"==e}}function r(t,e,n){return Tt=t,Et=n,e}function o(t,e){var n=t.next();if('"'==n||"'"==n)return e.tokenize=s(n),e.tokenize(t,e);if("."==n&&t.match(/^\d+(?:[eE][+\-]?\d+)?/))return r("number","number");if("."==n&&t.match(".."))return r("spread","meta");if(/[\[\]{}\(\),;\:\.]/.test(n))return r(n);if("="==n&&t.eat(">"))return r("=>","operator");if("0"==n&&t.eat(/x/i))return t.eatWhile(/[\da-f]/i),r("number","number");if("0"==n&&t.eat(/o/i))return t.eatWhile(/[0-7]/i),r("number","number");if("0"==n&&t.eat(/b/i))return t.eatWhile(/[01]/i),r("number","number");if(/\d/.test(n))return t.match(/^\d*(?:\.\d*)?(?:[eE][+\-]?\d+)?/),r("number","number");if("/"==n)return t.eat("*")?(e.tokenize=a,a(t,e)):t.eat("/")?(t.skipToEnd(),r("comment","comment")):St(t,e,1)?(i(t),t.match(/^\b(([gimyu])(?![gimyu]*\2))+\b/),r("regexp","string-2")):(t.eat("="),r("operator","operator",t.current()));if("`"==n)return e.tokenize=l,l(t,e);if("#"==n)return t.skipToEnd(),r("error","error");if(Dt.test(n))return">"==n&&e.lexical&&">"==e.lexical.type||(t.eat("=")?"!"!=n&&"="!=n||t.eat("="):/[<>*+\-]/.test(n)&&(t.eat(n),">"==n&&t.eat(n))),r("operator","operator",t.current());if(Nt.test(n)){t.eatWhile(Nt);var o=t.current();if("."!=e.lastType){if(It.propertyIsEnumerable(o)){var c=It[o];return r(c.type,c.style,o)}if("async"==o&&t.match(/^\s*[\(\w]/,!1))return r("async","keyword",o)}return r("variable","variable",o)}}function s(t){return function(e,n){var i,s=!1;if(At&&"@"==e.peek()&&e.match(_t))return n.tokenize=o,r("jsonld-keyword","meta");for(;null!=(i=e.next())&&(i!=t||s);)s=!s&&"\\"==i;return s||(n.tokenize=o),r("string","string")}}function a(t,e){for(var n,i=!1;n=t.next();){if("/"==n&&i){e.tokenize=o;break}i="*"==n}return r("comment","comment")}function l(t,e){for(var n,i=!1;null!=(n=t.next());){if(!i&&("`"==n||"$"==n&&t.eat("{"))){e.tokenize=o;break}i=!i&&"\\"==n}return r("quasi","string-2",t.current())}function c(t,e){e.fatArrowAt&&(e.fatArrowAt=null);var n=t.string.indexOf("=>",t.start);if(!(n<0)){if(Lt){var i=/:\s*(?:\w+(?:<[^>]*>|\[\])?|\{[^}]*\})\s*$/.exec(t.string.slice(t.start,n));i&&(n=i.index)}for(var r=0,o=!1,s=n-1;s>=0;--s){var a=t.string.charAt(s),l=Ft.indexOf(a);if(l>=0&&l<3){if(!r){++s;break}if(0==--r){"("==a&&(o=!0);break}}else if(l>=3&&l<6)++r;else if(Nt.test(a))o=!0;else{if(/["'\/]/.test(a))return;if(o&&!r){++s;break}}}o&&!r&&(e.fatArrowAt=s)}}function u(t,e,n,i,r,o){this.indented=t,this.column=e,this.type=n,this.prev=r,this.info=o,null!=i&&(this.align=i)}function h(t,e){for(var n=t.localVars;n;n=n.next)if(n.name==e)return!0;for(var i=t.context;i;i=i.prev)for(var n=i.vars;n;n=n.next)if(n.name==e)return!0}function d(t,e,n,i,r){var o=t.cc;for($t.state=t,$t.stream=r,$t.marked=null,$t.cc=o,$t.style=e,t.lexical.hasOwnProperty("align")||(t.lexical.align=!0);;){if((o.length?o.pop():Ot?C:w)(n,i)){for(;o.length&&o[o.length-1].lex;)o.pop()();return $t.marked?$t.marked:"variable"==n&&h(t,i)?"variable-2":e}}}function f(){for(var t=arguments.length-1;t>=0;t--)$t.cc.push(arguments[t])}function p(){return f.apply(null,arguments),!0}function g(t){function e(e){for(var n=e;n;n=n.next)if(n.name==t)return!0;return!1}var i=$t.state;if($t.marked="def",i.context){if(e(i.localVars))return;i.localVars={name:t,next:i.localVars}}else{if(e(i.globalVars))return;n.globalVars&&(i.globalVars={name:t,next:i.globalVars})}}function v(){$t.state.context={prev:$t.state.context,vars:$t.state.localVars},$t.state.localVars=Rt}function m(){$t.state.localVars=$t.state.context.vars,$t.state.context=$t.state.context.prev}function y(t,e){var n=function(){var n=$t.state,i=n.indented;if("stat"==n.lexical.type)i=n.lexical.indented;else for(var r=n.lexical;r&&")"==r.type&&r.align;r=r.prev)i=r.indented;n.lexical=new u(i,$t.stream.column(),t,null,n.lexical,e)};return n.lex=!0,n}function b(){var t=$t.state;t.lexical.prev&&(")"==t.lexical.type&&(t.indented=t.lexical.indented),t.lexical=t.lexical.prev)}function x(t){function e(n){return n==t?p():";"==t?f():p(e)}return e}function w(t,e){return"var"==t?p(y("vardef",e.length),J,x(";"),b):"keyword a"==t?p(y("form"),S,w,b):"keyword b"==t?p(y("form"),w,b):"keyword d"==t?$t.stream.match(/^\s*$/,!1)?p():p(y("stat"),E,x(";"),b):"debugger"==t?p(x(";")):"{"==t?p(y("}"),B,b):";"==t?p():"if"==t?("else"==$t.state.lexical.info&&$t.state.cc[$t.state.cc.length-1]==b&&$t.state.cc.pop()(),p(y("form"),S,w,b,nt)):"function"==t?p(lt):"for"==t?p(y("form"),it,w,b):"variable"==t?Lt&&"type"==e?($t.marked="keyword",p(U,x("operator"),U,x(";"))):Lt&&"declare"==e?($t.marked="keyword",p(w)):p(y("stat"),F):"switch"==t?p(y("form"),S,x("{"),y("}","switch"),B,b,b):"case"==t?p(C,x(":")):"default"==t?p(x(":")):"catch"==t?p(y("form"),v,x("("),ct,x(")"),w,b,m):"class"==t?p(y("form"),ht,b):"export"==t?p(y("stat"),gt,b):"import"==t?p(y("stat"),mt,b):"module"==t?p(y("form"),Z,x("{"),y("}"),B,b,b):"async"==t?p(w):"@"==e?p(C,w):f(y("stat"),C,x(";"),b)}function C(t){return T(t,!1)}function k(t){return T(t,!0)}function S(t){return"("!=t?f():p(y(")"),C,x(")"),b)}function T(t,e){if($t.state.fatArrowAt==$t.stream.start){var n=e?N:L;if("("==t)return p(v,y(")"),H(ct,")"),b,x("=>"),n,m);if("variable"==t)return f(v,Z,x("=>"),n,m)}var i=e?P:M;return zt.hasOwnProperty(t)?p(i):"function"==t?p(lt,i):"class"==t?p(y("form"),ut,b):"keyword c"==t||"async"==t?p(e?k:C):"("==t?p(y(")"),E,x(")"),b,i):"operator"==t||"spread"==t?p(e?k:C):"["==t?p(y("]"),Ct,b,i):"{"==t?j($,"}",null,i):"quasi"==t?f(A,i):"new"==t?p(I(e)):p()}function E(t){return t.match(/[;\}\)\],]/)?f():f(C)}function M(t,e){return","==t?p(C):P(t,e,!1)}function P(t,e,n){var i=0==n?M:P,r=0==n?C:k;return"=>"==t?p(v,n?N:L,m):"operator"==t?/\+\+|--/.test(e)||Lt&&"!"==e?p(i):"?"==e?p(C,x(":"),r):p(r):"quasi"==t?f(A,i):";"!=t?"("==t?j(k,")","call",i):"."==t?p(z,i):"["==t?p(y("]"),E,x("]"),b,i):Lt&&"as"==e?($t.marked="keyword",p(U,i)):"regexp"==t?($t.state.lastType=$t.marked="operator",$t.stream.backUp($t.stream.pos-$t.stream.start-1),p(r)):void 0:void 0}function A(t,e){return"quasi"!=t?f():"${"!=e.slice(e.length-2)?p(A):p(C,O)}function O(t){if("}"==t)return $t.marked="string-2",$t.state.tokenize=l,p(A)}function L(t){return c($t.stream,$t.state),f("{"==t?w:C)}function N(t){return c($t.stream,$t.state),f("{"==t?w:k)}function I(t){return function(e){return"."==e?p(t?_:D):"variable"==e&&Lt?p(X,t?P:M):f(t?k:C)}}function D(t,e){if("target"==e)return $t.marked="keyword",p(M)}function _(t,e){if("target"==e)return $t.marked="keyword",p(P)}function F(t){return":"==t?p(b,w):f(M,x(";"),b)}function z(t){if("variable"==t)return $t.marked="property",p()}function $(t,e){if("async"==t)return $t.marked="property",p($);if("variable"==t||"keyword"==$t.style){if($t.marked="property","get"==e||"set"==e)return p(R);var n;return Lt&&$t.state.fatArrowAt==$t.stream.start&&(n=$t.stream.match(/^\s*:\s*/,!1))&&($t.state.fatArrowAt=$t.stream.pos+n[0].length),p(V)}return"number"==t||"string"==t?($t.marked=At?"property":$t.style+" property",p(V)):"jsonld-keyword"==t?p(V):"modifier"==t?p($):"["==t?p(C,x("]"),V):"spread"==t?p(k,V):"*"==e?($t.marked="keyword",p($)):":"==t?f(V):void 0}function R(t){return"variable"!=t?f(V):($t.marked="property",p(lt))}function V(t){return":"==t?p(k):"("==t?f(lt):void 0}function H(t,e,n){function i(r,o){if(n?n.indexOf(r)>-1:","==r){var s=$t.state.lexical;return"call"==s.info&&(s.pos=(s.pos||0)+1),p(function(n,i){return n==e||i==e?f():f(t)},i)}return r==e||o==e?p():p(x(e))}return function(n,r){return n==e||r==e?p():f(t,i)}}function j(t,e,n){for(var i=3;i"==t)return p(U)}function K(t,e){return"variable"==t||"keyword"==$t.style?($t.marked="property",p(K)):"?"==e?p(K):":"==t?p(U):"["==t?p(C,W,x("]"),K):void 0}function G(t){return"variable"==t?p(G):":"==t?p(U):void 0}function Y(t,e){return"<"==e?p(y(">"),H(U,">"),b,Y):"|"==e||"."==t?p(U):"["==t?p(x("]"),Y):"extends"==e?p(U):void 0}function X(t,e){if("<"==e)return p(y(">"),H(U,">"),b,Y)}function J(){return f(Z,W,tt,et)}function Z(t,e){return"modifier"==t?p(Z):"variable"==t?(g(e),p()):"spread"==t?p(Z):"["==t?j(Z,"]"):"{"==t?j(Q,"}"):void 0}function Q(t,e){return"variable"!=t||$t.stream.match(/^\s*:/,!1)?("variable"==t&&($t.marked="property"),"spread"==t?p(Z):"}"==t?f():p(x(":"),Z,tt)):(g(e),p(tt))}function tt(t,e){if("="==e)return p(k)}function et(t){if(","==t)return p(J)}function nt(t,e){if("keyword b"==t&&"else"==e)return p(y("form","else"),w,b)}function it(t){if("("==t)return p(y(")"),rt,x(")"),b)}function rt(t){return"var"==t?p(J,x(";"),st):";"==t?p(st):"variable"==t?p(ot):f(C,x(";"),st)}function ot(t,e){return"in"==e||"of"==e?($t.marked="keyword",p(C)):p(M,st)}function st(t,e){return";"==t?p(at):"in"==e||"of"==e?($t.marked="keyword",p(C)):f(C,x(";"),at)}function at(t){")"!=t&&p(C)}function lt(t,e){return"*"==e?($t.marked="keyword",p(lt)):"variable"==t?(g(e),p(lt)):"("==t?p(v,y(")"),H(ct,")"),b,W,w,m):Lt&&"<"==e?p(y(">"),H(U,">"),b,lt):void 0}function ct(t,e){return"@"==e&&p(C,ct),"spread"==t||"modifier"==t?p(ct):f(Z,W,tt)}function ut(t,e){return"variable"==t?ht(t,e):dt(t,e)}function ht(t,e){if("variable"==t)return g(e),p(dt)}function dt(t,e){return"<"==e?p(y(">"),H(U,">"),b,dt):"extends"==e||"implements"==e||Lt&&","==t?p(Lt?U:C,dt):"{"==t?p(y("}"),ft,b):void 0}function ft(t,e){return"modifier"==t||"async"==t||"variable"==t&&("static"==e||"get"==e||"set"==e)&&$t.stream.match(/^\s+[\w$\xa1-\uffff]/,!1)?($t.marked="keyword",p(ft)):"variable"==t||"keyword"==$t.style?($t.marked="property",p(Lt?pt:lt,ft)):"["==t?p(C,x("]"),Lt?pt:lt,ft):"*"==e?($t.marked="keyword",p(ft)):";"==t?p(ft):"}"==t?p():"@"==e?p(C,ft):void 0}function pt(t,e){return"?"==e?p(pt):":"==t?p(U,tt):"="==e?p(k):f(lt)}function gt(t,e){return"*"==e?($t.marked="keyword",p(wt,x(";"))):"default"==e?($t.marked="keyword",p(C,x(";"))):"{"==t?p(H(vt,"}"),wt,x(";")):f(w)}function vt(t,e){return"as"==e?($t.marked="keyword",p(x("variable"))):"variable"==t?f(k,vt):void 0}function mt(t){return"string"==t?p():f(yt,bt,wt)}function yt(t,e){return"{"==t?j(yt,"}"):("variable"==t&&g(e),"*"==e&&($t.marked="keyword"),p(xt))}function bt(t){if(","==t)return p(yt,bt)}function xt(t,e){if("as"==e)return $t.marked="keyword",p(yt)}function wt(t,e){if("from"==e)return $t.marked="keyword",p(C)}function Ct(t){return"]"==t?p():f(H(k,"]"))}function kt(t,e){return"operator"==t.lastType||","==t.lastType||Dt.test(e.charAt(0))||/[,.]/.test(e.charAt(0))}function St(t,e,n){return e.tokenize==o&&/^(?:operator|sof|keyword [bcd]|case|new|export|default|spread|[\[{}\(,;:]|=>)$/.test(e.lastType)||"quasi"==e.lastType&&/\{\s*$/.test(t.string.slice(0,t.pos-(n||0)))}var Tt,Et,Mt=e.indentUnit,Pt=n.statementIndent,At=n.jsonld,Ot=n.json||At,Lt=n.typescript,Nt=n.wordCharacters||/[\w$\xa1-\uffff]/,It=function(){function t(t){return{type:t,style:"keyword"}}var e=t("keyword a"),n=t("keyword b"),i=t("keyword c"),r=t("keyword d"),o=t("operator"),s={type:"atom",style:"atom"},a={if:t("if"),while:e,with:e,else:n,do:n,try:n,finally:n,return:r,break:r,continue:r,new:t("new"),delete:i,void:i,throw:i,debugger:t("debugger"),var:t("var"),const:t("var"),let:t("var"),function:t("function"),catch:t("catch"),for:t("for"),switch:t("switch"),case:t("case"),default:t("default"),in:o,typeof:o,instanceof:o,true:s,false:s,null:s,undefined:s,NaN:s,Infinity:s,this:t("this"),class:t("class"),super:t("atom"),yield:i,export:t("export"),import:t("import"),extends:i,await:i};if(Lt){var l={type:"variable",style:"type"},c={interface:t("class"),implements:i,namespace:i,module:t("module"),enum:t("module"),public:t("modifier"),private:t("modifier"),protected:t("modifier"),abstract:t("modifier"),readonly:t("modifier"),string:l,number:l,boolean:l,any:l};for(var u in c)a[u]=c[u]}return a}(),Dt=/[+\-*&%=<>!?|~^@]/,_t=/^@(context|id|value|language|type|container|list|set|reverse|index|base|vocab|graph)"/,Ft="([{}])",zt={atom:!0,number:!0,variable:!0,string:!0,regexp:!0,this:!0,"jsonld-keyword":!0},$t={state:null,column:null,marked:null,cc:null},Rt={name:"this",next:{name:"arguments"}};return b.lex=!0,{startState:function(t){var e={tokenize:o,lastType:"sof",cc:[],lexical:new u((t||0)-Mt,0,"block",!1),localVars:n.localVars,context:n.localVars&&{vars:n.localVars},indented:t||0};return n.globalVars&&"object"==typeof n.globalVars&&(e.globalVars=n.globalVars),e},token:function(t,e){if(t.sol()&&(e.lexical.hasOwnProperty("align")||(e.lexical.align=!1),e.indented=t.indentation(),c(t,e)),e.tokenize!=a&&t.eatSpace())return null;var n=e.tokenize(t,e);return"comment"==Tt?n:(e.lastType="operator"!=Tt||"++"!=Et&&"--"!=Et?Tt:"incdec",d(e,n,Tt,Et,t))},indent:function(e,i){if(e.tokenize==a)return t.Pass;if(e.tokenize!=o)return 0;var r,s=i&&i.charAt(0),l=e.lexical;if(!/^\s*else\b/.test(i))for(var c=e.cc.length-1;c>=0;--c){var u=e.cc[c];if(u==b)l=l.prev;else if(u!=nt)break}for(;("stat"==l.type||"form"==l.type)&&("}"==s||(r=e.cc[e.cc.length-1])&&(r==M||r==P)&&!/^[,\.=+\-*:?[\(]/.test(i));)l=l.prev;Pt&&")"==l.type&&"stat"==l.prev.type&&(l=l.prev);var h=l.type,d=s==h;return"vardef"==h?l.indented+("operator"==e.lastType||","==e.lastType?l.info+1:0):"form"==h&&"{"==s?l.indented:"form"==h?l.indented+Mt:"stat"==h?l.indented+(kt(e,i)?Pt||Mt:0):"switch"!=l.info||d||0==n.doubleIndentSwitch?l.align?l.column+(d?0:1):l.indented+(d?0:Mt):l.indented+(/^(?:case|default)\b/.test(i)?Mt:2*Mt)},electricInput:/^\s*(?:case .*?:|default:|\{|\})$/,blockCommentStart:Ot?null:"/*",blockCommentEnd:Ot?null:"*/",blockCommentContinue:Ot?null:" * ",lineComment:Ot?null:"//",fold:"brace",closeBrackets:"()[]{}''\"\"``",helperType:Ot?"json":"javascript",jsonldMode:At,jsonMode:Ot,expressionAllowed:St,skipExpression:function(t){var e=t.cc[t.cc.length-1];e!=C&&e!=k||t.cc.pop()}}}),t.registerHelper("wordChars","javascript",/[\w$]/),t.defineMIME("text/javascript","javascript"),t.defineMIME("text/ecmascript","javascript"),t.defineMIME("application/javascript","javascript"),t.defineMIME("application/x-javascript","javascript"),t.defineMIME("application/ecmascript","javascript"),t.defineMIME("application/json",{name:"javascript",json:!0}),t.defineMIME("application/x-json",{name:"javascript",json:!0}),t.defineMIME("application/ld+json",{name:"javascript",jsonld:!0}),t.defineMIME("text/typescript",{name:"javascript",typescript:!0}),t.defineMIME("application/typescript",{name:"javascript",typescript:!0})})},function(t,e,n){!function(t){t(n(6))}(function(t){t.extendMode("css",{commentStart:"/*",commentEnd:"*/",newlineAfterToken:function(t,e){return/^[;{}]$/.test(e)}}),t.extendMode("javascript",{commentStart:"/*",commentEnd:"*/",newlineAfterToken:function(t,e,n,i){return this.jsonMode?/^[\[,{]$/.test(e)||/^}/.test(n):(";"!=e||!i.lexical||")"!=i.lexical.type)&&(/^[;{}]$/.test(e)&&!/^;/.test(n))}});var e=/^(a|abbr|acronym|area|base|bdo|big|br|button|caption|cite|code|col|colgroup|dd|del|dfn|em|frame|hr|iframe|img|input|ins|kbd|label|legend|link|map|object|optgroup|option|param|q|samp|script|select|small|span|strong|sub|sup|textarea|tt|var)$/;t.extendMode("xml",{commentStart:"\x3c!--",commentEnd:"--\x3e",newlineAfterToken:function(t,n,i,r){var o=!1;return"html"==this.configuration&&(o=!!r.context&&e.test(r.context.tagName)),!o&&("tag"==t&&/>$/.test(n)&&r.context||/^-1&&a>-1&&a>s&&(t=t.substr(0,s)+t.substring(s+o.commentStart.length,a)+t.substr(a+o.commentEnd.length)),r.replaceRange(t,n,i)}})}),t.defineExtension("autoIndentRange",function(t,e){var n=this;this.operation(function(){for(var i=t.line;i<=e.line;i++)n.indentLine(i,"smart")})}),t.defineExtension("autoFormatRange",function(e,n){function i(){c+="\n",h=!0,++u}for(var r=this,o=r.getMode(),s=r.getRange(e,n).split("\n"),a=t.copyState(o,r.getTokenAt(e).state),l=r.getOption("tabSize"),c="",u=0,h=0===e.ch,d=0;d\n \t
<%= label %>
\n \t
\n
'),initialize:function(t){this.config=t.config||{},this.pfx=this.config.stylePrefix},render:function(){var t=this.model.toJSON();return t.pfx=this.pfx,this.$el.html(this.template(t)),this.$el.attr("class",this.pfx+"editor-c"),this.$el.find("#"+this.pfx+"code").append(this.model.get("input")),this}})}).call(e,n(1))},function(t,e,n){"use strict";t.exports=function(){var t,e,i={},r=n(110),o=n(27),s=n(112),a=(n(29),n(114));return{name:"Panels",init:function(n){i=n||{};for(var o in r)o in i||(i[o]=r[o]);var l=i.pStylePrefix;return l&&(i.stylePrefix=l+i.stylePrefix),t=new s(i.defaults),e=new a({collection:t,config:i}),this},getPanels:function(){return t},getPanelsEl:function(){return e.el},addPanel:function(e){return t.add(e)},removePanel:function(e){return t.remove(e)},getPanel:function(e){var n=t.where({id:e});return n.length?n[0]:null},addButton:function(t,e){var n=this.getPanel(t);return n?n.get("buttons").add(e):null},removeButton:function(t,e){var n=this.getPanel(t);return n&&n.get("buttons").remove(e)},getButton:function(t,e){var n=this.getPanel(t);if(n){var i=n.get("buttons").where({id:e});return i.length?i[0]:null}return null},render:function(){return e.render().el},active:function(){this.getPanels().each(function(t){t.get("buttons").each(function(t){t.get("active")&&t.trigger("updateActive")})})},disableButtons:function(){this.getPanels().each(function(t){t.get("buttons").each(function(t){t.get("disable")&&t.trigger("change:disable")})})},Panel:o}}},function(t,e,n){"use strict";var i="sw-visibility",r="export-template",o="open-layers",s="open-blocks",a="fullscreen",l="preview";t.exports={stylePrefix:"pn-",defaults:[{id:"commands",buttons:[{}]},{id:"options",buttons:[{active:!0,id:i,className:"fa fa-square-o",command:i,context:i,attributes:{title:"View components"}},{id:l,className:"fa fa-eye",command:l,context:l,attributes:{title:"Preview"}},{id:a,className:"fa fa-arrows-alt",command:a,context:a,attributes:{title:"Fullscreen"}},{id:r,className:"fa fa-code",command:r,attributes:{title:"View code"}}]},{id:"views",buttons:[{id:"open-sm",className:"fa fa-paint-brush",command:"open-sm",active:!0,attributes:{title:"Open Style Manager"}},{id:"open-tm",className:"fa fa-cog",command:"open-tm",attributes:{title:"Settings"}},{id:o,className:"fa fa-bars",command:o,attributes:{title:"Open Layer Manager"}},{id:s,className:"fa fa-th-large",command:s,attributes:{title:"Open Blocks"}}]}],em:null,delayBtnsShow:300}},function(t,e,n){"use strict";var i=n(0);t.exports=i.Model.extend({defaults:{id:"",className:"",command:"",context:"",buttons:[],attributes:{},options:{},active:!1,dragDrop:!1,runDefaultCommand:!0,stopDefaultCommand:!1,disable:!1},initialize:function(t){if(this.get("buttons").length){var e=n(28);this.set("buttons",new e(this.get("buttons")))}}})},function(t,e,n){"use strict";var i=n(0),r=n(27);t.exports=i.Collection.extend({model:r})},function(t,e,n){"use strict";(function(e,i){var r=n(1),o=e.$;t.exports=e.View.extend({tagName:"span",initialize:function(t){i.bindAll(this,"startTimer","stopTimer","showButtons","hideButtons","closeOnKeyPress","onDrop","initSorter","stopDrag");var e=this.model.get("className");this.config=t.config||{},this.em=this.config.em||{};var n=this.config.stylePrefix||"",r=this.config.pStylePrefix||"";this.pfx=n,this.ppfx=this.config.pStylePrefix||"",this.id=n+this.model.get("id"),this.activeCls=n+"active "+r+"four-color",this.disableCls=n+"active",this.btnsVisCls=n+"visible",this.parentM=t.parentM||null,this.className=n+"btn"+(e?" "+e:""),this.listenTo(this.model,"change:active updateActive",this.updateActive),this.listenTo(this.model,"checkActive",this.checkActive),this.listenTo(this.model,"change:bntsVis",this.updateBtnsVis),this.listenTo(this.model,"change:attributes",this.updateAttributes),this.listenTo(this.model,"change:className",this.updateClassName),this.listenTo(this.model,"change:disable",this.updateDisable),this.model.get("buttons").length&&(this.$el.on("mousedown",this.startTimer),this.$el.append(o("
",{class:n+"arrow-rd"}))),this.em&&this.em.get&&(this.commands=this.em.get("Commands")),this.events={},this.model.get("dragDrop")?(this.events.mousedown="initDrag",this.em.on("loaded",this.initSorter)):this.events.click="clicked",this.delegateEvents()},initSorter:function(){if(this.em.Canvas){var t=this.em.Canvas;this.canvasEl=t.getBody(),this.sorter=new this.em.Utils.Sorter({container:this.canvasEl,placer:t.getPlacerEl(),containerSel:"*",itemSel:"*",pfx:this.ppfx,onMove:this.onDrag,onEndMove:this.onDrop,document:t.getFrameEl().contentDocument,direction:"a",wmargin:1,nested:1});var e=t.getOffset();this.sorter.offTop=e.top,this.sorter.offLeft=e.left}},initDrag:function(){this.model.collection.deactivateAll(this.model.get("context")),this.sorter.startSort(this.el),this.sorter.setDropContent(this.model.get("options").content),this.canvasEl.style.cursor="grabbing",o(document).on("mouseup",this.stopDrag)},stopDrag:function(){o(document).off("mouseup",this.stopDrag),this.sorter.endMove()},onDrag:function(t){},onDrop:function(t){this.canvasEl.style.cursor="default"},updateClassName:function(){var t=this.model.get("className");this.$el.attr("class",this.pfx+"btn"+(t?" "+t:""))},updateAttributes:function(){this.$el.attr(this.model.get("attributes"))},updateBtnsVis:function(){this.$buttons&&(this.model.get("bntsVis")?this.$buttons.addClass(this.btnsVisCls):this.$buttons.removeClass(this.btnsVisCls))},startTimer:function(){this.timeout=setTimeout(this.showButtons,this.config.delayBtnsShow),o(document).on("mouseup",this.stopTimer)},stopTimer:function(){o(document).off("mouseup",this.stopTimer),this.timeout&&clearTimeout(this.timeout)},showButtons:function(){clearTimeout(this.timeout),this.model.set("bntsVis",!0),o(document).on("mousedown",this.hideButtons),o(document).on("keypress",this.closeOnKeyPress)},hideButtons:function(t){t&&o(t.target).trigger("click"),this.model.set("bntsVis",!1),o(document).off("mousedown",this.hideButtons),o(document).off("keypress",this.closeOnKeyPress)},closeOnKeyPress:function(t){27==(t.which||t.keyCode)&&this.hideButtons()},updateActive:function(){var t=this.model,e=t.get("context"),n=this.parentM,i={},o=this.em&&this.em.get?this.em.get("Editor"):null,s=t.get("command");this.commands&&(0,r.isString)(s)?i=this.commands.get(s)||{}:(0,r.isFunction)(s)?i={run:s}:null!==s&&(0,r.isObject)(s)&&(i=s),t.get("active")?(t.collection.deactivateAll(e),t.set("active",!0,{silent:!0}).trigger("checkActive"),n&&n.set("active",!0,{silent:!0}).trigger("checkActive"),i.run&&(i.run(o,t,t.get("options")),o.trigger("run:"+s)),!i.stop&&t.set("active",!1)):(this.$el.removeClass(this.activeCls),t.collection.deactivateAll(e),n&&n.set("active",!1,{silent:!0}).trigger("checkActive"),i.stop&&(i.stop(o,t,t.get("options")),o.trigger("stop:"+s)))},updateDisable:function(){this.model.get("disable")?this.$el.addClass(this.disableCls):this.$el.removeClass(this.disableCls)},checkActive:function(){this.model.get("active")?this.$el.addClass(this.activeCls):this.$el.removeClass(this.activeCls)},clicked:function(t){this.model.get("bntsVis")||this.model.get("disable")||this.toogleActive()},toogleActive:function(){this.parentM&&this.swapParent();var t=this.model.get("active");this.model.set("active",!t);this.em.get("Commands").get("select-comp");t?this.model.get("runDefaultCommand")&&this.em.runDefault():this.model.get("stopDefaultCommand")&&this.em.stopDefault()},swapParent:function(){this.parentM.collection.deactivateAll(this.model.get("context")),this.parentM.set("attributes",this.model.get("attributes")),this.parentM.set("options",this.model.get("options")),this.parentM.set("command",this.model.get("command")),this.parentM.set("className",this.model.get("className")),this.parentM.set("active",!0,{silent:!0}).trigger("checkActive")},render:function(){if(this.updateAttributes(),this.$el.attr("class",this.className),this.model.get("buttons").length){var t=n(30),e=new t({collection:this.model.get("buttons"),config:this.config,parentM:this.model});this.$buttons=e.render().$el,this.$buttons.append(o("
",{class:this.pfx+"arrow-l"})),this.$el.append(this.$buttons)}return this}})}).call(e,n(0),n(1))},function(t,e,n){"use strict";var i=n(0),r=n(29);t.exports=i.View.extend({initialize:function(t){this.opt=t||{},this.config=this.opt.config||{},this.pfx=this.config.stylePrefix||"",this.listenTo(this.collection,"add",this.addTo),this.listenTo(this.collection,"reset",this.render),this.className=this.pfx+"panels"},addTo:function(t){this.addToCollection(t)},addToCollection:function(t,e){var n=e||null,i=new r({model:t,config:this.config}),o=i.render().el,s=t.get("appendTo");if(s){document.querySelector(s).appendChild(o)}else n?n.appendChild(o):this.$el.append(o);return i.initResize(),o},render:function(){var t=document.createDocumentFragment();return this.$el.empty(),this.collection.each(function(e){this.addToCollection(e,t)},this),this.$el.append(t),this.$el.attr("class",this.className),this}})},function(t,e,n){"use strict";var i=n(116),r=function(t){return t&&t.__esModule?t:{default:t}}(i),o=n(2);t.exports=function(){var t={},e=n(117),i=void 0,s=void 0,a=void 0,l=void 0,c=function(){var t=i.style;t.top="-100px",t.left="-100px",t.display="none"};return{customRte:null,name:"RichTextEditor",init:function(){var n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};t=n;for(var r in e)r in t||(t[r]=e[r]);var a=t.pStylePrefix;return a&&(t.stylePrefix=a+t.stylePrefix),this.pfx=t.stylePrefix,s=t.actions||[],i=document.createElement("div"),i.className=a+"rte-toolbar "+a+"one-bg",l=this.initRte(document.createElement("div")),(0,o.on)(i,"mousedown",function(t){return t.stopPropagation()}),this},postRender:function(t){var e=t.model.get("Canvas");i.style.pointerEvents="all",c(),e.getToolsEl().appendChild(i)},initRte:function(e){var n=this.pfx,o=i,s=this.actionbar,a=this.actions||t.actions,c={actionbar:n+"actionbar",button:n+"action",active:n+"active"},u=new r.default({el:e,classes:c,actions:a,actionbar:s,actionbarContainer:o});return l&&l.setEl(e),u.actionbar&&(this.actionbar=u.actionbar),u.actions&&(this.actions=u.actions),u},add:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};e.name=t,l.addAction(e,{sync:1})},get:function(t){var e=void 0;return l.getActions().forEach(function(n){n.name==t&&(e=n)}),e},getAll:function(){return l.getActions()},remove:function(t){var e=this.getAll(),n=this.get(t);if(n){var i=n.btn,r=e.indexOf(n);i.parentNode.removeChild(i),e.splice(r,1)}return n},getToolbarEl:function(){return i},udpatePosition:function(){var e=t.em.get("Canvas"),n=e.getTargetToElementDim(i,a,{event:"rteToolbarPosUpdate"});t.adjustToolbar&&n.top<=n.canvasTop&&(n.top=n.elementTop+n.elementHeight);var r=i.style;r.top=n.top+"px",r.left=n.left+"px"},enable:function(e,n){a=e.el;var r=t.em,o=e.getChildrenContainer(),s=this.customRte;if(i.style.display="",n=s?s.enable(o,n):this.initRte(o).enable(),r){setTimeout(this.udpatePosition.bind(this),0);var l="change:canvasOffset canvasScroll";r.off(l,this.udpatePosition,this),r.on(l,this.udpatePosition,this),r.trigger("rte:enable",e,n)}return n},disable:function(e,n){var i=t.em,r=this.customRte,o=e.getChildrenContainer();r?r.disable(o,n):n&&n.disable(),c(),i&&i.trigger("rte:disable",e,n)}}}},function(t,e,n){"use strict";function i(t,e){if(!(t instanceof e))throw new TypeError("Cannot call a class as a function")}Object.defineProperty(e,"__esModule",{value:!0});var r=Object.assign||function(t){for(var e=1;eB",attributes:{title:"Bold"},result:function(t){return t.exec("bold")}},italic:{name:"italic",icon:"I",attributes:{title:"Italic"},result:function(t){return t.exec("italic")}},underline:{name:"underline",icon:"U",attributes:{title:"Underline"},result:function(t){return t.exec("underline")}},strikethrough:{name:"strikethrough",icon:"S",attributes:{title:"Strike-through"},result:function(t){return t.exec("strikeThrough")}},link:{icon:'',name:"link",attributes:{style:"font-size:1.4rem;padding:0 4px 2px;",title:"Link"},result:function(t){return t.insertHTML(''+t.selection()+"")}}},c=function(){function t(){var e=this,n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};i(this,t);var o=n.el;if(o[a])return o[a];o[a]=this,this.setEl(o),this.updateActiveActions=this.updateActiveActions.bind(this);var s=n.actions||[];s.forEach(function(t,e){"string"==typeof t?t=l[t]:l[t.name]&&(t=r({},l[t.name],t)),s[e]=t});var c=s.length?s:Object.keys(l).map(function(t){return l[t]});n.classes=r({actionbar:"actionbar",button:"action",active:"active"},n.classes);var u=n.classes,h=n.actionbar;if(this.actionbar=h,this.settings=n,this.classes=u,this.actions=c,!h){var d=n.actionbarContainer;h=document.createElement("div"),h.className=u.actionbar,d.appendChild(h),this.actionbar=h,c.forEach(function(t){return e.addAction(t)})}return n.styleWithCSS&&this.exec("styleWithCSS"),this.syncActions(),this}return o(t,[{key:"setEl",value:function(t){this.el=t,this.doc=t.ownerDocument}},{key:"updateActiveActions",value:function(){var t=this;this.getActions().forEach(function(e){var n=e.btn,i=e.update,r=t.classes.active,o=e.name,s=t.doc;n.className=n.className.replace(r,"").trim(),s.queryCommandState(o)&&(n.className+=" "+r),i&&i(t,e)})}},{key:"enable",value:function(){return this.enabled?this:(this.actionbarEl().style.display="",this.el.contentEditable=!0,(0,s.on)(this.el,"mouseup keyup",this.updateActiveActions),this.syncActions(),this.updateActiveActions(),this.el.focus(),this.enabled=1,this)}},{key:"disable",value:function(){return this.actionbarEl().style.display="none",this.el.contentEditable=!1,(0,s.off)(this.el,"mouseup keyup",this.updateActiveActions),this.enabled=0,this}},{key:"syncActions",value:function(){var t=this;this.getActions().forEach(function(e){var n=e.event||"click";e.btn["on"+n]=function(n){e.result(t,e),t.updateActiveActions()}})}},{key:"addAction",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=e.sync,i=document.createElement("span"),r=t.icon,o=t.attributes||{};i.className=this.classes.button,t.btn=i;for(var s in o)i.setAttribute(s,o[s]);"string"==typeof r?i.innerHTML=r:i.appendChild(r),this.actionbarEl().appendChild(i),n&&(this.actions.push(t),this.syncActions())}},{key:"getActions",value:function(){return this.actions}},{key:"selection",value:function(){return this.doc.getSelection()}},{key:"exec",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null;this.doc.execCommand(t,!1,e)}},{key:"actionbarEl",value:function(){return this.actionbar}},{key:"insertHTML",value:function(t){var e=void 0,n=this.doc,i=n.getSelection();if(i&&i.rangeCount){var r=n.createElement("div"),o=i.getRangeAt(0);o.deleteContents(),r.innerHTML=t,Array.prototype.slice.call(r.childNodes).forEach(function(t){o.insertNode(t),e=t}),i.removeAllRanges(),i.addRange(o),this.el.focus()}}}]),t}();e.default=c},function(t,e,n){"use strict";t.exports={stylePrefix:"rte-",adjustToolbar:1,actions:["bold","italic","underline","strikethrough","link"]}},function(t,e,n){"use strict";t.exports={stylePrefix:"sm-",sectors:[],textNoElement:"Select an element before using Style Manager",hideNotStylable:!0,highlightChanged:!0,highlightComputed:!0,showComputed:!0,clearProperties:0,avoidComputed:["width","height"]}},function(t,e,n){"use strict";var i=n(120);t.exports=n(0).Collection.extend({model:i})},function(t,e,n){"use strict";var i=n(1),r=n(0),o=n(11),s=n(129);t.exports=r.Model.extend({defaults:{id:"",name:"",open:!0,buildProps:"",extendBuilded:1,properties:[]},initialize:function(t){var e=t||{},n=[],i=this.buildProperties(e.buildProps);!this.get("id")&&this.set("id",this.get("name")),n=i?this.extendProperties(i):this.get("properties");var r=new o(n);r.sector=this,this.set("properties",r)},extendProperties:function(t,e,n){for(var r=t.length,o=e||this.get("properties"),s=this.get("extendBuilded"),a=[],l=0,c=o.length;l')}else{o.push(t("
").append(t('').attr("title",r.noColorSelectedText)).html())}}return"
"+o.join("")+"
"}function r(){for(var t=0;t1&&(delete window.localStorage[B],t.each(e,function(t,e){p(e)}))}catch(t){}try{vt=window.localStorage[B].split(";")}catch(t){}}}function p(e){if(j){var n=st(e).toRgbString();if(!gt[n]&&-1===t.inArray(n,vt))for(vt.push(n);vt.length>mt;)vt.shift();if(B&&window.localStorage)try{window.localStorage[B]=vt.join(";")}catch(t){}}}function g(){var t=[];if(V.showPalette)for(var e=0;eMath.abs(e-r);bt=o?"x":"y"}}else bt=null;var s=!bt||"x"===bt,a=!bt||"y"===bt;s&&(ut=parseFloat(t/tt)),a&&(ht=parseFloat((et-e)/et)),Yt=!1,V.showAlpha||(dt=1),O()},y,b),Ut?(M(Ut),L(),Kt=V.preferredFormat||st(Ut).format,p(Ut)):L(),H&&C();var i=G?"mousedown.spectrum":"click.spectrum touchstart.spectrum";It.delegate(".sp-thumb-el",i,e),Dt.delegate(".sp-thumb-el:nth-child(1)",i,{ignore:!0},e)}();var Jt={show:C,hide:T,toggle:w,reflow:D,option:F,enable:z,disable:$,offset:R,set:function(t){M(t),I()},get:P,destroy:_,container:kt};return Jt.id=K.push(Jt)-1,Jt}function a(e,n){var i=e.outerWidth(),r=e.outerHeight(),o=n.outerHeight(),s=e[0].ownerDocument,a=s.documentElement,l=a.clientWidth,c=a.clientHeight,u=t(s).scrollLeft(),h=t(s).scrollTop(),d=l+u,f=c+h,p=n.offset();return p.top+=o,p.left-=Math.min(p.left,p.left+i>d&&d>i?Math.abs(p.left+i-d):0),p.top-=Math.min(p.top,p.top+r>f&&f>r?Math.abs(r+o-0):0),p}function l(){}function c(t){t.stopPropagation()}function u(t,e){var n=Array.prototype.slice,i=n.call(arguments,2);return function(){return t.apply(e,i.concat(n.call(arguments)))}}function h(e,n,i,r){function o(t){t.stopPropagation&&t.stopPropagation(),t.preventDefault&&t.preventDefault(),t.returnValue=!1}function s(t){if(u){if(G&&c.documentMode<9&&!t.button)return l();var i=t.originalEvent&&t.originalEvent.touches&&t.originalEvent.touches[0],r=i&&i.pageX||t.pageX,s=i&&i.pageY||t.pageY,a=Math.max(0,Math.min(r-h.left,f)),g=Math.max(0,Math.min(s-h.top,d));p&&o(t),n.apply(e,[a,g,t])}}function a(n){(n.which?3==n.which:2==n.button)||u||!1!==i.apply(e,arguments)&&(u=!0,d=t(e).height(),f=t(e).width(),h=t(e).offset(),t(c).bind(g),t(c.body).addClass("sp-dragging"),s(n),o(n))}function l(){u&&(t(c).unbind(g),t(c.body).removeClass("sp-dragging"),setTimeout(function(){r.apply(e,arguments)},0)),u=!1}n=n||function(){},i=i||function(){},r=r||function(){};var c=document,u=!1,h={},d=0,f=0,p="ontouchstart"in window,g={};g.selectstart=o,g.dragstart=o,g["touchmove mousemove"]=s,g["touchend mouseup"]=l,t(e).bind("touchstart mousedown",a)}function d(t,e,n){var i;return function(){var r=this,o=arguments,s=function(){i=null,t.apply(r,o)};n&&clearTimeout(i),!n&&i||(i=setTimeout(s,e))}}function f(){return t.fn.spectrum.inputTypeColorSupport()}function p(t){var n={r:0,g:0,b:0},i=1,r=!1,o=!1;return"string"==typeof t&&(t=U(t)),"object"==(void 0===t?"undefined":e(t))&&(t.hasOwnProperty("r")&&t.hasOwnProperty("g")&&t.hasOwnProperty("b")?(n=g(t.r,t.g,t.b),r=!0,o="%"===String(t.r).substr(-1)?"prgb":"rgb"):t.hasOwnProperty("h")&&t.hasOwnProperty("s")&&t.hasOwnProperty("v")?(t.s=j(t.s),t.v=j(t.v),n=b(t.h,t.s,t.v),r=!0,o="hsv"):t.hasOwnProperty("h")&&t.hasOwnProperty("s")&&t.hasOwnProperty("l")&&(t.s=j(t.s),t.l=j(t.l),n=m(t.h,t.s,t.l),r=!0,o="hsl"),t.hasOwnProperty("a")&&(i=t.a)),i=_(i),{ok:r,format:t.format||o,r:it(255,rt(n.r,0)),g:it(255,rt(n.g,0)),b:it(255,rt(n.b,0)),a:i}}function g(t,e,n){return{r:255*F(t,255),g:255*F(e,255),b:255*F(n,255)}}function v(t,e,n){t=F(t,255),e=F(e,255),n=F(n,255);var i,r,o=rt(t,e,n),s=it(t,e,n),a=(o+s)/2;if(o==s)i=r=0;else{var l=o-s;switch(r=a>.5?l/(2-o-s):l/(o+s),o){case t:i=(e-n)/l+(e1&&(n-=1),n<1/6?t+6*(e-t)*n:n<.5?e:n<2/3?t+(e-t)*(2/3-n)*6:t}var r,o,s;if(t=F(t,360),e=F(e,100),n=F(n,100),0===e)r=o=s=n;else{var a=n<.5?n*(1+e):n+e-n*e,l=2*n-a;r=i(l,a,t+1/3),o=i(l,a,t),s=i(l,a,t-1/3)}return{r:255*r,g:255*o,b:255*s}}function y(t,e,n){t=F(t,255),e=F(e,255),n=F(n,255);var i,r,o=rt(t,e,n),s=it(t,e,n),a=o,l=o-s;if(r=0===o?0:l/o,o==s)i=0;else{switch(o){case t:i=(e-n)/l+(e>1)+720)%360;--e;)i.h=(i.h+r)%360,o.push(st(i));return o}function D(t,e){e=e||6;for(var n=st(t).toHsv(),i=n.h,r=n.s,o=n.v,s=[],a=1/e;e--;)s.push(st({h:i,s:r,v:o})),o=(o+a)%1;return s}function _(t){return t=parseFloat(t),(isNaN(t)||t<0||t>1)&&(t=1),t}function F(t,e){R(t)&&(t="100%");var n=V(t);return t=it(e,rt(0,parseFloat(t))),n&&(t=parseInt(t*e,10)/100),et.abs(t-e)<1e-6?1:t%e/parseFloat(e)}function z(t){return it(1,rt(0,t))}function $(t){return parseInt(t,16)}function R(t){return"string"==typeof t&&-1!=t.indexOf(".")&&1===parseFloat(t)}function V(t){return"string"==typeof t&&-1!=t.indexOf("%")}function H(t){return 1==t.length?"0"+t:""+t}function j(t){return t<=1&&(t=100*t+"%"),t}function B(t){return Math.round(255*parseFloat(t)).toString(16)}function W(t){return $(t)/255}function U(t){t=t.replace(Z,"").replace(Q,"").toLowerCase();var e=!1;if(at[t])t=at[t],e=!0;else if("transparent"==t)return{r:0,g:0,b:0,a:0,format:"name"};var n;return(n=ct.rgb.exec(t))?{r:n[1],g:n[2],b:n[3]}:(n=ct.rgba.exec(t))?{r:n[1],g:n[2],b:n[3],a:n[4]}:(n=ct.hsl.exec(t))?{h:n[1],s:n[2],l:n[3]}:(n=ct.hsla.exec(t))?{h:n[1],s:n[2],l:n[3],a:n[4]}:(n=ct.hsv.exec(t))?{h:n[1],s:n[2],v:n[3]}:(n=ct.hsva.exec(t))?{h:n[1],s:n[2],v:n[3],a:n[4]}:(n=ct.hex8.exec(t))?{a:W(n[1]),r:$(n[2]),g:$(n[3]),b:$(n[4]),format:e?"name":"hex8"}:(n=ct.hex6.exec(t))?{r:$(n[1]),g:$(n[2]),b:$(n[3]),format:e?"name":"hex"}:!!(n=ct.hex3.exec(t))&&{r:$(n[1]+""+n[1]),g:$(n[2]+""+n[2]),b:$(n[3]+""+n[3]),format:e?"name":"hex"}}var q={beforeShow:l,move:l,change:l,show:l,hide:l,color:!1,flat:!1,showInput:!1,allowEmpty:!1,showButtons:!0,clickoutFiresChange:!0,showInitial:!1,showPalette:!1,showPaletteOnly:!1,hideAfterPaletteSelect:!1,togglePaletteOnly:!1,showSelectionPalette:!0,localStorageKey:!1,appendTo:"body",maxSelectionSize:7,cancelText:"cancel",chooseText:"choose",togglePaletteMoreText:"more",togglePaletteLessText:"less",clearText:"Clear Color Selection",noColorSelectedText:"No Color Selected",preferredFormat:!1,className:"",containerClassName:"",replacerClassName:"",showAlpha:!1,theme:"sp-light",palette:[["#ffffff","#000000","#ff0000","#ff8000","#ffff00","#008000","#0000ff","#4b0082","#9400d3"]],selectionPalette:[],disabled:!1,offset:null},K=[],G=!!/msie/i.exec(window.navigator.userAgent),Y=function(){function t(t,e){return!!~(""+t).indexOf(e)}var e=document.createElement("div"),n=e.style;return n.cssText="background-color:rgba(0,0,0,.5)",t(n.backgroundColor,"rgba")||t(n.backgroundColor,"hsla")}(),X=["
","
","
","
"].join(""),J=function(){var t="";if(G)for(var e=1;e<=6;e++)t+="
";return["
","
","
","
","","
","
","
","
","
","
","
","
","
","
","
","
","
","
","
","
","
",t,"
","
","
","
","
","","
","
","
","","","
","
","
"].join("")}();t.fn.spectrum=function(e,n){if("string"==typeof e){var i=this,r=Array.prototype.slice.call(arguments,1);return this.each(function(){var n=K[t(this).data("spectrum.id")];if(n){var o=n[e];if(!o)throw new Error("Spectrum: no such method: '"+e+"'");"get"==e?i=n.get():"container"==e?i=n.container:"option"==e?i=n.option.apply(n,r):"destroy"==e?(n.destroy(),t(this).removeData("spectrum.id")):o.apply(n,r)}}),i}return this.spectrum("destroy").each(function(){var n=t.extend({},e,t(this).data()),i=s(this,n);t(this).data("spectrum.id",i.id)})},t.fn.spectrum.load=!0,t.fn.spectrum.loadOpts={},t.fn.spectrum.draggable=h,t.fn.spectrum.defaults=q,t.fn.spectrum.inputTypeColorSupport=function e(){if(void 0===e._cachedResult){var n=t("")[0];e._cachedResult="color"===n.type&&""!==n.value}return e._cachedResult},t.spectrum={},t.spectrum.localization={},t.spectrum.palettes={},t.fn.spectrum.processNativeColorInputs=function(){var e=t("input[type=color]");e.length&&!f()&&e.spectrum({preferredFormat:"hex6"})};var Z=/^[\s,#]+/,Q=/\s+$/,tt=0,et=Math,nt=et.round,it=et.min,rt=et.max,ot=et.random,st=function t(e,n){if(e=e||"",n=n||{},e instanceof t)return e;if(!(this instanceof t))return new t(e,n);var i=p(e);this._originalInput=e,this._r=i.r,this._g=i.g,this._b=i.b,this._a=i.a,this._roundA=nt(100*this._a)/100,this._format=n.format||i.format,this._gradientType=n.gradientType,this._r<1&&(this._r=nt(this._r)),this._g<1&&(this._g=nt(this._g)),this._b<1&&(this._b=nt(this._b)),this._ok=i.ok,this._tc_id=tt++};st.prototype={isDark:function(){return this.getBrightness()<128},isLight:function(){return!this.isDark()},isValid:function(){return this._ok},getOriginalInput:function(){return this._originalInput},getFormat:function(){return this._format},getAlpha:function(){return this._a},getBrightness:function(){var t=this.toRgb();return(299*t.r+587*t.g+114*t.b)/1e3},setAlpha:function(t){return this._a=_(t),this._roundA=nt(100*this._a)/100,this},toHsv:function(){var t=y(this._r,this._g,this._b);return{h:360*t.h,s:t.s,v:t.v,a:this._a}},toHsvString:function(){var t=y(this._r,this._g,this._b),e=nt(360*t.h),n=nt(100*t.s),i=nt(100*t.v);return 1==this._a?"hsv("+e+", "+n+"%, "+i+"%)":"hsva("+e+", "+n+"%, "+i+"%, "+this._roundA+")"},toHsl:function(){var t=v(this._r,this._g,this._b);return{h:360*t.h,s:t.s,l:t.l,a:this._a}},toHslString:function(){var t=v(this._r,this._g,this._b),e=nt(360*t.h),n=nt(100*t.s),i=nt(100*t.l);return 1==this._a?"hsl("+e+", "+n+"%, "+i+"%)":"hsla("+e+", "+n+"%, "+i+"%, "+this._roundA+")"},toHex:function(t){return x(this._r,this._g,this._b,t)},toHexString:function(t){return"#"+this.toHex(t)},toHex8:function(){return w(this._r,this._g,this._b,this._a)},toHex8String:function(){return"#"+this.toHex8()},toRgb:function(){return{r:nt(this._r),g:nt(this._g),b:nt(this._b),a:this._a}},toRgbString:function(){return 1==this._a?"rgb("+nt(this._r)+", "+nt(this._g)+", "+nt(this._b)+")":"rgba("+nt(this._r)+", "+nt(this._g)+", "+nt(this._b)+", "+this._roundA+")"},toPercentageRgb:function(){return{r:nt(100*F(this._r,255))+"%",g:nt(100*F(this._g,255))+"%",b:nt(100*F(this._b,255))+"%",a:this._a}},toPercentageRgbString:function(){return 1==this._a?"rgb("+nt(100*F(this._r,255))+"%, "+nt(100*F(this._g,255))+"%, "+nt(100*F(this._b,255))+"%)":"rgba("+nt(100*F(this._r,255))+"%, "+nt(100*F(this._g,255))+"%, "+nt(100*F(this._b,255))+"%, "+this._roundA+")"},toName:function(){return 0===this._a?"transparent":!(this._a<1)&&(lt[x(this._r,this._g,this._b,!0)]||!1)},toFilter:function(t){var e="#"+w(this._r,this._g,this._b,this._a),n=e,i=this._gradientType?"GradientType = 1, ":"";if(t){n=st(t).toHex8String()}return"progid:DXImageTransform.Microsoft.gradient("+i+"startColorstr="+e+",endColorstr="+n+")"},toString:function(t){var e=!!t;t=t||this._format;var n=!1,i=this._a<1&&this._a>=0;return e||!i||"hex"!==t&&"hex6"!==t&&"hex3"!==t&&"name"!==t?("rgb"===t&&(n=this.toRgbString()),"prgb"===t&&(n=this.toPercentageRgbString()),"hex"!==t&&"hex6"!==t||(n=this.toHexString()),"hex3"===t&&(n=this.toHexString(!0)),"hex8"===t&&(n=this.toHex8String()),"name"===t&&(n=this.toName()),"hsl"===t&&(n=this.toHslString()),"hsv"===t&&(n=this.toHsvString()),n||this.toHexString()):"name"===t&&0===this._a?this.toName():this.toRgbString()},_applyModification:function(t,e){var n=t.apply(null,[this].concat([].slice.call(e)));return this._r=n._r,this._g=n._g,this._b=n._b,this.setAlpha(n._a),this},lighten:function(){return this._applyModification(T,arguments)},brighten:function(){return this._applyModification(E,arguments)},darken:function(){return this._applyModification(M,arguments)},desaturate:function(){return this._applyModification(C,arguments)},saturate:function(){return this._applyModification(k,arguments)},greyscale:function(){return this._applyModification(S,arguments)},spin:function(){return this._applyModification(P,arguments)},_applyCombination:function(t,e){return t.apply(null,[this].concat([].slice.call(e)))},analogous:function(){return this._applyCombination(I,arguments)},complement:function(){return this._applyCombination(A,arguments)},monochromatic:function(){return this._applyCombination(D,arguments)},splitcomplement:function(){return this._applyCombination(N,arguments)},triad:function(){return this._applyCombination(O,arguments)},tetrad:function(){return this._applyCombination(L,arguments)}},st.fromRatio=function(t,n){if("object"==(void 0===t?"undefined":e(t))){var i={};for(var r in t)t.hasOwnProperty(r)&&(i[r]="a"===r?t[r]:j(t[r]));t=i}return st(t,n)},st.equals=function(t,e){return!(!t||!e)&&st(t).toRgbString()==st(e).toRgbString()},st.random=function(){return st.fromRatio({r:ot(),g:ot(),b:ot()})},st.mix=function(t,e,n){n=0===n?0:n||50;var i,r=st(t).toRgb(),o=st(e).toRgb(),s=n/100,a=2*s-1,l=o.a-r.a;i=a*l==-1?a:(a+l)/(1+a*l),i=(i+1)/2;var c=1-i,u={r:o.r*i+r.r*c,g:o.g*i+r.g*c,b:o.b*i+r.b*c,a:o.a*s+r.a*(1-s)};return st(u)},st.readability=function(t,e){var n=st(t),i=st(e),r=n.toRgb(),o=i.toRgb(),s=n.getBrightness(),a=i.getBrightness(),l=Math.max(r.r,o.r)-Math.min(r.r,o.r)+Math.max(r.g,o.g)-Math.min(r.g,o.g)+Math.max(r.b,o.b)-Math.min(r.b,o.b);return{brightness:Math.abs(s-a),color:l}},st.isReadable=function(t,e){var n=st.readability(t,e);return n.brightness>125&&n.color>500},st.mostReadable=function(t,e){for(var n=null,i=0,r=!1,o=0;o125&&s.color>500,l=s.brightness/125*3+s.color/500;(a&&!r||a&&r&&l>i||!a&&!r&&l>i)&&(r=a,i=l,n=st(e[o]))}return n};var at=st.names={aliceblue:"f0f8ff",antiquewhite:"faebd7",aqua:"0ff",aquamarine:"7fffd4",azure:"f0ffff",beige:"f5f5dc",bisque:"ffe4c4",black:"000",blanchedalmond:"ffebcd",blue:"00f",blueviolet:"8a2be2",brown:"a52a2a",burlywood:"deb887",burntsienna:"ea7e5d",cadetblue:"5f9ea0",chartreuse:"7fff00",chocolate:"d2691e",coral:"ff7f50",cornflowerblue:"6495ed",cornsilk:"fff8dc",crimson:"dc143c",cyan:"0ff",darkblue:"00008b",darkcyan:"008b8b",darkgoldenrod:"b8860b",darkgray:"a9a9a9",darkgreen:"006400",darkgrey:"a9a9a9",darkkhaki:"bdb76b",darkmagenta:"8b008b",darkolivegreen:"556b2f",darkorange:"ff8c00",darkorchid:"9932cc",darkred:"8b0000",darksalmon:"e9967a",darkseagreen:"8fbc8f",darkslateblue:"483d8b",darkslategray:"2f4f4f",darkslategrey:"2f4f4f",darkturquoise:"00ced1",darkviolet:"9400d3",deeppink:"ff1493",deepskyblue:"00bfff",dimgray:"696969",dimgrey:"696969",dodgerblue:"1e90ff",firebrick:"b22222",floralwhite:"fffaf0",forestgreen:"228b22",fuchsia:"f0f",gainsboro:"dcdcdc",ghostwhite:"f8f8ff",gold:"ffd700",goldenrod:"daa520",gray:"808080",green:"008000",greenyellow:"adff2f",grey:"808080",honeydew:"f0fff0",hotpink:"ff69b4",indianred:"cd5c5c",indigo:"4b0082",ivory:"fffff0",khaki:"f0e68c",lavender:"e6e6fa",lavenderblush:"fff0f5",lawngreen:"7cfc00",lemonchiffon:"fffacd",lightblue:"add8e6",lightcoral:"f08080",lightcyan:"e0ffff",lightgoldenrodyellow:"fafad2",lightgray:"d3d3d3",lightgreen:"90ee90",lightgrey:"d3d3d3",lightpink:"ffb6c1",lightsalmon:"ffa07a",lightseagreen:"20b2aa",lightskyblue:"87cefa",lightslategray:"789",lightslategrey:"789",lightsteelblue:"b0c4de",lightyellow:"ffffe0",lime:"0f0",limegreen:"32cd32",linen:"faf0e6",magenta:"f0f",maroon:"800000",mediumaquamarine:"66cdaa",mediumblue:"0000cd",mediumorchid:"ba55d3",mediumpurple:"9370db",mediumseagreen:"3cb371",mediumslateblue:"7b68ee",mediumspringgreen:"00fa9a",mediumturquoise:"48d1cc",mediumvioletred:"c71585",midnightblue:"191970",mintcream:"f5fffa",mistyrose:"ffe4e1",moccasin:"ffe4b5",navajowhite:"ffdead",navy:"000080",oldlace:"fdf5e6",olive:"808000",olivedrab:"6b8e23",orange:"ffa500",orangered:"ff4500",orchid:"da70d6",palegoldenrod:"eee8aa",palegreen:"98fb98",paleturquoise:"afeeee",palevioletred:"db7093",papayawhip:"ffefd5",peachpuff:"ffdab9",peru:"cd853f",pink:"ffc0cb",plum:"dda0dd",powderblue:"b0e0e6",purple:"800080",rebeccapurple:"663399",red:"f00",rosybrown:"bc8f8f",royalblue:"4169e1",saddlebrown:"8b4513",salmon:"fa8072",sandybrown:"f4a460",seagreen:"2e8b57",seashell:"fff5ee",sienna:"a0522d",silver:"c0c0c0",skyblue:"87ceeb",slateblue:"6a5acd",slategray:"708090",slategrey:"708090",snow:"fffafa",springgreen:"00ff7f",steelblue:"4682b4",tan:"d2b48c",teal:"008080",thistle:"d8bfd8",tomato:"ff6347",turquoise:"40e0d0",violet:"ee82ee",wheat:"f5deb3",white:"fff",whitesmoke:"f5f5f5",yellow:"ff0",yellowgreen:"9acd32"},lt=st.hexNames=function(t){var e={};for(var n in t)t.hasOwnProperty(n)&&(e[t[n]]=n);return e}(at),ct=function(){var t="(?:[-\\+]?\\d*\\.\\d+%?)|(?:[-\\+]?\\d+%?)",e="[\\s|\\(]+("+t+")[,|\\s]+("+t+")[,|\\s]+("+t+")\\s*\\)?",n="[\\s|\\(]+("+t+")[,|\\s]+("+t+")[,|\\s]+("+t+")[,|\\s]+("+t+")\\s*\\)?";return{rgb:new RegExp("rgb"+e),rgba:new RegExp("rgba"+n),hsl:new RegExp("hsl"+e),hsla:new RegExp("hsla"+n),hsv:new RegExp("hsv"+e),hsva:new RegExp("hsva"+n),hex3:/^([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,hex6:/^([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/,hex8:/^([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/}}();window.tinycolor=st,t(function(){t.fn.spectrum.load&&t.fn.spectrum.processNativeColorInputs()})}(t.$)}()}).call(e,n(0))},function(t,e,n){"use strict";var i=n(0),r=n(126);t.exports=i.View.extend({initialize:function(t){this.config=t.config||{},this.stackModel=t.stackModel,this.preview=t.preview,this.pfx=this.config.stylePrefix||"",this.ppfx=this.config.pStylePrefix||"",this.propsConfig=t.propsConfig;var e=this.pfx,n=this.ppfx,i=this.collection;this.className=e+"layers "+n+"field",this.listenTo(i,"add",this.addTo),this.listenTo(i,"deselectAll",this.deselectAll),this.listenTo(i,"reset",this.render);var r=this.config.em||"",o=r?r.get("Utils"):"";this.sorter=o?new o.Sorter({container:this.el,ignoreViewChildren:1,containerSel:"."+e+"layers",itemSel:"."+e+"layer",pfx:this.config.pStylePrefix}):"",i.view=this,this.$el.data("model",i),this.$el.data("collection",i)},addTo:function(t){var e=this.collection.indexOf(t);this.addToCollection(t,null,e)},addToCollection:function(t,e,n){var i=e||null,o=this.stackModel,s=this.config,a=this.sorter,l=this.propsConfig;void 0!==this.preview&&t.set("preview",this.preview);var c=new r({model:t,config:s,sorter:a,stackModel:o,propsConfig:l}),u=c.render().el;if(i)i.appendChild(u);else if(void 0!==n){var h="before";this.$el.children().length==n&&(n--,h="after"),n<0?this.$el.append(u):this.$el.children().eq(n)[h](u)}else this.$el.append(u);return u},deselectAll:function(){this.$el.find("."+this.pfx+"layer").removeClass(this.pfx+"active")},render:function(){var t=document.createDocumentFragment();return this.$el.empty(),this.collection.each(function(e){this.addToCollection(e,t)},this),this.$el.append(t),this.$el.attr("class",this.className),this.sorter&&(this.sorter.plh=null),this}})},function(t,e,n){"use strict";(function(e){t.exports=e.View.extend({events:{click:"active","click [data-close-layer]":"remove","mousedown [data-move-layer]":"initSorter"},template:function(t){var e=this.pfx;return'\n
\n \n
\n
Layer '+t.get("index")+'
\n
\n \t
\n
\n
\n ⨯\n
\n
\n
\n '},initialize:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=this.model;this.stackModel=t.stackModel||{},this.config=t.config||{},this.pfx=this.config.stylePrefix||"",this.sorter=t.sorter||null,this.propsConfig=t.propsConfig||{},this.customPreview=t.onPreview,this.listenTo(e,"destroy remove",this.remove),this.listenTo(e,"change:active",this.updateVisibility),this.listenTo(e.get("properties"),"change",this.updatePreview),e.get("preview")||this.$el.addClass(this.pfx+"no-preview"),e.view=this,e.set({droppable:0,draggable:1}),this.$el.data("model",e)},initSorter:function(t){this.sorter&&this.sorter.startSort(this.el)},remove:function(t){t&&t.stopPropagation&&t.stopPropagation();var n=this.model,i=n.collection,r=this.stackModel;e.View.prototype.remove.apply(this,arguments),i.contains(n)&&i.remove(n),r&&r.set&&(r.set({stackIndex:null},{silent:!0}),r.trigger("updateValue"))},onPreview:function(t){var e=t.split(" "),n=[];return this.model.get("properties").each(function(t,i){var r=e[i]||"";if(r&&"integer"==t.get("type")){var o=parseInt(r,10),s=r.replace(o,"");o=isNaN(o)?0:o,o=o>3?3:o,o=o<-3?-3:o,r=o+s}n.push(r)}),n.join(" ")},updatePreview:function(){var t=this.stackModel,e=this.customPreview,n=this.getPreviewEl(),i=this.model.getFullValue(),r=e?e(i):this.onPreview(i);r&&t&&n&&(n.style[t.get("property")]=r)},getPropertiesWrapper:function(){return this.propsWrapEl||(this.propsWrapEl=this.el.querySelector("[data-properties]")),this.propsWrapEl},getPreviewEl:function(){return this.previewEl||(this.previewEl=this.el.querySelector("[data-preview]")),this.previewEl},active:function(){var t=this.model,e=t.collection;e.active(e.indexOf(t))},updateVisibility:function(){var t=this.pfx,e=this.getPropertiesWrapper(),n=this.model.get("active");e.style.display=n?"":"none",this.$el[n?"addClass":"removeClass"](t+"active")},render:function(){var t=n(13),e=this.propsConfig,i=this.pfx+"layer",r=this.model,o=this.el,s=new t({collection:r.get("properties"),config:this.config,target:e.target,customValue:e.customValue,propTarget:e.propTarget,onChange:e.onChange}).render().el;return o.innerHTML=this.template(r),o.className=i,this.getPropertiesWrapper().appendChild(s),this.updateVisibility(),this.updatePreview(),this}})}).call(e,n(0))},function(t,e,n){"use strict";var i=Object.assign||function(t){for(var e=1;e\n \n
\n '},getSliderEl:function(){return this.slider||(this.slider=this.el.querySelector("input[type=range]")),this.slider},inputValueChanged:function(){var t=this.model,e=t.get("step");this.getInputEl().value=this.getSliderEl().value;var n=this.getInputValue()-e;t.set("value",n,{avoidStore:1}).set("value",n+e),this.elementUpdated()},inputValueChangedSoft:function(){this.getInputEl().value=this.getSliderEl().value,this.model.set("value",this.getInputValue(),{avoidStore:1}),this.elementUpdated()},setValue:function(t){this.getSliderEl().value=t,this.inputInst.setValue(t,{silent:1})},onRender:function(){i.prototype.onRender.apply(this,arguments),this.model.get("showInput")||(this.inputInst.el.style.display="none")}})},function(t,e,n){"use strict";n(0);t.exports=function(){return{build:function(t){var e=[];"string"==typeof t&&(t=[t]);for(var n=0,i=t.length;n0&&void 0!==arguments[0]?arguments[0]:{},n=t.get("SelectorManager"),r=n.add("hc-state"),o=i.get([r]);if(o){var s=i.getAll();s.remove(o),s.add(o)}else o=i.add([r]);o.set("important",1),o.setStyle(e),l.helper=o};if(r){var p=i.getIdRule(o,u);e=p||i.setIdRule(o,{},u)}if(a.length){var g=a.getStyleable(),v=i.get(g,c,d);return!v&&g.length&&(n.stop(),v=i.add(g,c,d),v.setStyle(e.getStyle()),e.setStyle({}),n.start()),v?(c&&f(v.getStyle()),l.model=v,void l.trigger("update")):(l.model=e,void l.trigger("update"))}if(c){var m=i.getIdRule(o,u);c&&f(m&&m.getStyle())}l.model=e,l.trigger("update")}},addToCollection:function(t,e){var n=e||null,i=new o({model:t,id:this.pfx+t.get("name").replace(" ","_").toLowerCase(),name:t.get("name"),properties:t.get("properties"),target:this.target,propTarget:this.propTarget,config:this.config}),r=i.render().el;return n?n.appendChild(r):this.$el.append(r),r},render:function(){var t=document.createDocumentFragment();return this.$el.empty(),this.collection.each(function(e){this.addToCollection(e,t)},this),this.$el.attr("id",this.pfx+"sectors"),this.$el.append(t),this}})}).call(e,n(0))},function(t,e,n){"use strict";(function(e){var i=n(0),r=n(13);t.exports=i.View.extend({template:e.template('\n
\n \n <%= label %>\n
'),events:{"click [data-sector-title]":"toggle"},initialize:function(t){this.config=t.config||{},this.pfx=this.config.stylePrefix||"",this.target=t.target||{},this.propTarget=t.propTarget||{},this.caretR="fa-caret-right",this.caretD="fa-caret-down";var e=this.model;this.listenTo(e,"change:open",this.updateOpen),this.listenTo(e,"updateVisibility",this.updateVisibility),this.listenTo(e,"destroy remove",this.remove)},updateVisibility:function(){var t;this.model.get("properties").each(function(e){e.get("visible")&&(t=1)}),this.el.style.display=t?"block":"none"},updateOpen:function(){this.model.get("open")?this.show():this.hide()},show:function(){this.$el.addClass(this.pfx+"open"),this.getPropertiesEl().style.display="",this.$caret.removeClass(this.caretR).addClass(this.caretD)},hide:function(){this.$el.removeClass(this.pfx+"open"),this.getPropertiesEl().style.display="none",this.$caret.removeClass(this.caretD).addClass(this.caretR)},getPropertiesEl:function(){return this.$el.find("."+this.pfx+"properties").get(0)},toggle:function(t){var e=this.model.get("open")?0:1;this.model.set("open",e)},render:function(){return this.$el.html(this.template({pfx:this.pfx,label:this.model.get("name")})),this.$caret=this.$el.find("#"+this.pfx+"caret"),this.renderProperties(),this.$el.attr("class",this.pfx+"sector no-select"),this.updateOpen(),this},renderProperties:function(){var t=this.model.get("properties");if(t){var e=new r({collection:t,target:this.target,propTarget:this.propTarget,config:this.config});this.$el.append(e.render().el)}}})}).call(e,n(1))},function(t,e,n){"use strict";t.exports=function(){var t={},e=n(133),i=n(134),r=n(137),o=n(45),s=void 0,a=void 0,l=void 0;return{name:"AssetManager",storageKey:"assets",getConfig:function(){return t},init:function(n){var c=this;t=n||{};for(var u in e)u in t||(t[u]=e[u]);var h=t.pStylePrefix,d=t.em;h&&(t.stylePrefix=h+t.stylePrefix),s=new i([]);var f={collection:new i([]),globalCollection:s,config:t};return l=new o(f),f.fu=l,a=new r(f),s.listenTo(s,"add",function(t){c.getAllVisible().add(t),d&&d.trigger("asset:add",t)}),s.listenTo(s,"remove",function(t){c.getAllVisible().remove(t),d&&d.trigger("asset:remove",t)}),this},add:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return void 0===e.at&&(e.at=0),s.add(t,e)},get:function(t){return s.where({src:t})[0]},getAll:function(){return s},getAllVisible:function(){return a.collection},remove:function(t){var e=this.get(t);return this.getAll().remove(e),this},store:function(e){var n={},i=JSON.stringify(this.getAll().toJSON());return n[this.storageKey]=i,!e&&t.stm&&t.stm.store(n),n},load:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=this.storageKey,n=t[e]||[];if("string"==typeof n)try{n=JSON.parse(t[e])}catch(t){}return n&&n.length&&this.getAll().reset(n),n},getContainer:function(){return a.el},getAssetsEl:function(){return a.el.querySelector("[data-el=assets]")},render:function(t){var e=t||this.getAll().models;return a.rendered||a.render(),a.collection.reset(e),this.getContainer()},addType:function(t,e){this.getAll().addType(t,e)},getType:function(t){return this.getAll().getType(t)},getTypes:function(){return this.getAll().getTypes()},AssetsView:function(){return a},FileUploader:function(){return l},onLoad:function(){this.getAll().reset(t.assets)},postRender:function(e){t.dropzone&&l.initDropzone(e)},setTarget:function(t){a.collection.target=t},onSelect:function(t){a.collection.onSelect=t},onClick:function(e){t.onClick=e},onDblClick:function(e){t.onDblClick=e}}}},function(t,e,n){"use strict";t.exports={assets:[],noAssets:"",stylePrefix:"am-",upload:0,uploadName:"files",headers:{},params:{},autoAdd:1,uploadText:"Drop files here or click to upload",addBtnText:"Add image",uploadFile:"",handleAdd:"",dropzone:0,openAssetsOnDrop:1,dropzoneContent:"",modalTitle:"Select Image",inputPlaceholder:"http://path/to/the/image.jpg"}},function(t,e,n){"use strict";var i=n(32),r=function(t){return t&&t.__esModule?t:{default:t}}(i);t.exports=n(0).Collection.extend(r.default).extend({types:[{id:"image",model:n(135),view:n(43),isType:function(t){return"string"==typeof t?{type:"image",src:t}:t}}]})},function(t,e,n){"use strict";var i=Object.assign||function(t){for(var e=1;e\n
\n
\n
\n \n
\n \n
\n
\n \n
\n
\n
\n
\n '},initialize:function(t){this.options=t,this.config=t.config,this.pfx=this.config.stylePrefix||"",this.ppfx=this.config.pStylePrefix||"";var e=this.collection;this.listenTo(e,"reset",this.renderAssets),this.listenTo(e,"add",this.addToAsset),this.listenTo(e,"remove",this.removedAsset),this.listenTo(e,"deselectAll",this.deselectAll)},handleSubmit:function(t){t.preventDefault();var e=this.getAddInput(),n=e.value.trim(),i=this.config.handleAdd;n&&(e.value="",this.getAssetsEl().scrollTop=0,i?i(n):this.options.globalCollection.add(n,{at:0}))},getAssetsEl:function(){return this.el.querySelector("."+this.pfx+"assets")},getAddInput:function(){return this.inputUrl&&this.inputUrl.value||(this.inputUrl=this.el.querySelector("."+this.pfx+"add-asset input")),this.inputUrl},removedAsset:function(t){this.collection.length||this.toggleNoAssets()},addToAsset:function(t){1==this.collection.length&&this.toggleNoAssets(1),this.addAsset(t)},addAsset:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null,n=e,i=this.collection,r=this.config,o=new t.typeView({model:t,collection:i,config:r}).render().el;if(n)n.appendChild(o);else{var s=this.getAssetsEl();s&&s.insertBefore(o,s.firstChild)}return o},toggleNoAssets:function(t){var e=this.$el.find("."+this.pfx+"assets");if(t)e.empty();else{var n=this.config.noAssets;n&&e.append(n)}},deselectAll:function(){var t=this.pfx;this.$el.find("."+t+"highlight").removeClass(t+"highlight")},renderAssets:function(){var t=this,e=document.createDocumentFragment(),n=this.$el.find("."+this.pfx+"assets");n.empty(),this.toggleNoAssets(this.collection.length),this.collection.each(function(n){return t.addAsset(n,e)}),n.append(e)},render:function(){var t=this.options.fu.render().el;return this.$el.empty(),this.$el.append(t).append(this.template(this)),this.el.className=this.ppfx+"asset-manager",this.renderAssets(),this.rendered=1,this}})}).call(e,n(0))},function(t,e,n){"use strict";var i=Object.assign||function(t){for(var e=1;e=0&&(n.css=o.em.getCss()),i.indexOf("styles")>=0&&(n.styles=JSON.stringify(t)),e||o.stm.store(n),n}},add:function(e,n,i,r){var s=n||"",l=i||"",c=r||{},u=this.get(e,s,l,c);return u||(c.state=s,c.mediaText=l,c.selectors="",u=new a(c,o),u.get("selectors").add(e),t.add(u),u)},get:function(e,n,i,r){var o=null;return t.each(function(t){o||t.compare(e,n,i,r)&&(o=t)}),o},getAll:function(){return t},clear:function(){return this.getAll().reset(),this},addCollection:function(t){for(var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=[],r=t instanceof Array?t:[t],s=0,a=r.length;s1&&void 0!==arguments[1]?arguments[1]:{},n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},i=n.state||"",o=n.mediaText||r.getCurrentMedia(),s=r.get("SelectorManager"),a=s.add({name:t,type:h.TYPE_ID}),l=this.add(a,i,o);return l.setStyle(e,n),l},getIdRule:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=e.state||"",i=e.mediaText||r.getCurrentMedia(),o=r.get("SelectorManager").get(t,h.TYPE_ID);return o&&this.get(o,n,i)},setClassRule:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},i=n.state||"",o=n.mediaText||r.getCurrentMedia(),s=r.get("SelectorManager"),a=s.add({name:t,type:h.TYPE_CLASS}),l=this.add(a,i,o);return l.setStyle(e,n),l},getClassRule:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=e.state||"",i=e.mediaText||r.getCurrentMedia(),o=r.get("SelectorManager").get(t,h.TYPE_CLASS);return o&&this.get(o,n,i)},render:function(){return e.render().el}}}},function(t,e,n){"use strict";t.exports={stylePrefix:"css-",staticRules:"",rules:[]}},function(t,e,n){"use strict";var i=n(0),r=n(46);t.exports=i.Collection.extend({initialize:function(t,e){e&&e.sm&&(this.editor=e.sm),this.model=function(t,n){return!n.sm&&e&&e.sm&&(n.sm=e.sm),new r(t,n)}},add:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return"string"==typeof t&&(t=this.editor.get("Parser").parseCss(t)),e.em=this.editor,i.Collection.prototype.add.apply(this,[t,e])}})},function(t,e,n){"use strict";var i=n(0),r=n(142);t.exports=i.View.extend({initialize:function(t){var e=t.config||{};this.config=e,this.em=e.em,this.pfx=e.stylePrefix||"",this.className=this.pfx+"rules";var n=this.collection;this.listenTo(n,"add",this.addTo),this.listenTo(n,"reset",this.render)},addTo:function(t){this.addToCollection(t)},addToCollection:function(t,e){var n=e||null,i=r,o=new i({model:t,config:this.config}),s=o.render().el;return n?n.appendChild(s):this.$el.append(s),s},render:function(){var t=this,e=this.$el,n=document.createDocumentFragment();return e.empty(),this.collection.each(function(e){return t.addToCollection(e,n)}),e.append(n),e.attr("class",this.className),this}})},function(t,e,n){"use strict";t.exports=n(0).View.extend({tagName:"style",initialize:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};this.config=t.config||{};var e=this.model;this.listenTo(e,"change:style change:state change:mediaText",this.render),this.listenTo(e,"destroy remove",this.remove),this.listenTo(e.get("selectors"),"change",this.render)},render:function(){var t=this.model,e=t.get("important");return this.el.innerHTML=this.model.toCSS({important:e}),this}})},function(t,e,n){"use strict";var i=n(1);t.exports=function(){var t={},e=n(144),r=n(145),o=void 0;return{TraitsView:r,name:"TraitManager",getConfig:function(){return t},init:function(){var n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};t=n,(0,i.defaults)(t,e);var s=t.pStylePrefix;return s&&(t.stylePrefix=""+s+t.stylePrefix),o=new r({collection:[],editor:t.em,config:t}),this},getTraitsViewer:function(){return o},addType:function(t,e){var n=o.itemView;o.itemsView[t]=n.extend(e)},getType:function(t){return o.itemsView[t]}}}},function(t,e,n){"use strict";t.exports={stylePrefix:"trt-",labelContainer:"Component settings",labelPlhText:"eg. Text here",labelPlhHref:"eg. https://google.com",optionsTarget:[{value:"",name:"This window"},{value:"_blank",name:"New window"}]}},function(t,e,n){"use strict";var i=n(48),r=n(8),o=n(146),s=n(147),a=n(148),l=n(149);t.exports=i.extend({itemView:r,itemsView:{text:r,number:a,select:o,checkbox:s,color:l},initialize:function(t){this.config=t.config||{},this.em=t.editor,this.pfx=this.config.stylePrefix||"",this.className=this.pfx+"traits",this.listenTo(this.em,"change:selectedComponent",this.updatedCollection),this.updatedCollection()},updatedCollection:function(){this.el.className=this.className;var t=this.em.get("selectedComponent");t&&(this.collection=t.get("traits"),this.render())}})},function(t,e,n){"use strict";(function(e,i){var r=n(8),o=e.$;t.exports=r.extend({initialize:function(t){r.prototype.initialize.apply(this,arguments);var e=this.ppfx;this.tmpl='
'},getInputEl:function(){if(!this.$input){var t=this.model,e=t.get("options")||[],n="",this.input=n,this.$input=o(this.input);var r=this.target,s=t.get("name"),a=t.get("value");if(t.get("changeProp"))a=a||r.get(s);else{a=r.get("attributes")[s]}a&&this.$input.val(a)}return this.$input.get(0)}})}).call(e,n(0),n(1))},function(t,e,n){"use strict";var i=n(8);t.exports=i.extend({initialize:function(t){i.prototype.initialize.apply(this,arguments);var e=this.ppfx+"chk-icon";this.tmpl='
'},onChange:function(){this.model.set("value",this.getInputEl().checked)},getInputEl:function(){var t;this.$input||(t=1);for(var e=arguments.length,n=Array(e),r=0;r2&&void 0!==arguments[2]?arguments[2]:{},r=t.components(),s=o.get("UndoManager"),a=o.handleUpdates.bind(o),l=this.handleChanges.bind(this),c=this.handleRemoves.bind(this);s&&s.add(t),s&&r&&s.add(r);[[t,"change:style change:content change:attributes change:src",a],[r,"add",l],[r,"remove",c],[t.get("classes"),"add remove",a]].forEach(function(t){o.stopListening(t[0],t[1],t[2]),o.listenTo(t[0],t[1],t[2])}),!i.avoidStore&&a("","",i),r.each(function(t){return n.handleChanges(t,e,i)})},handleRemoves:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};!n.avoidStore&&o.handleUpdates(t,e,n)},load:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"",e="";if(!t&&r.stm&&(t=r.em.getCacheLoad()),t.components)try{e=JSON.parse(t.components)}catch(t){}else t.html&&(e=t.html);var n=e&&e.constructor===Object;return(e&&e.length||n)&&(this.clear(),this.getComponents().reset(),n?this.getWrapper().set(e).initComponents().initClasses().loadTraits():this.getComponents().add(e)),e},store:function(t){if(r.stm){var e={},n=this.storageKey();if(n.indexOf("html")>=0&&(e.html=r.em.getHtml()),n.indexOf("components")>=0){var i=r.storeWrapper?this.getWrapper():this.getComponents();e.components=JSON.stringify(i)}return t||r.stm.store(e),e}},getComponent:function(){return t},getWrapper:function(){return this.getComponent()},getComponents:function(){return this.getWrapper().get("components")},addComponent:function(t){return this.getComponents().add(t)},render:function(){return e.render().el},clear:function(){for(var t=this.getComponents(),e=0,n=t.length;e1&&void 0!==arguments[1]?arguments[1]:{};this.em=e.em||""},setTarget:function(t){this.target=t},add:function(t,e){var n=this.em;if((0,i.isString)(t)||(0,i.isArray)(t)){var o=n&&n.get&&n.get("TraitManager"),a=o&&o.getConfig(),l=s(a);(0,i.isString)(t)&&(t=[t]);for(var c=0,u=t.length;c0&&void 0!==arguments[0]?arguments[0]:{};return{build:function(e){var n=[];"string"==typeof e&&(e=[e]);for(var i=0;is.top+s.height?s.top+s.height:g;var v={top:g,left:p,elementTop:s.top,elementLeft:s.left,elementWidth:s.width,elementHeight:s.height,targetWidth:t.offsetWidth,targetHeight:t.offsetHeight,canvasTop:o.top,canvasLeft:o.left};return h&&r.em&&r.em.trigger(h,v),v},getMouseRelativePos:function(t,e){var n=e||{},i=0,r=0,o=n.subWinOffset,s=t.target.ownerDocument,a=s.defaultView||s.parentWindow,l=a.frameElement,c=o?a.pageYOffset:0,u=o?a.pageXOffset:0;if(l){var h=l.getBoundingClientRect();i=h.top||0,r=h.left||0}return{y:t.clientY+i-c,x:t.clientX+r-u}},getMouseRelativeCanvas:function(t,e){var n=this.getFrameEl(),i=this.getBody(),r=n.offsetTop||0,o=n.offsetLeft||0,s=i.scrollTop||0,a=i.scrollLeft||0;return{y:t.clientY+r+s,x:t.clientX+o+a}},isInputFocused:function(){return"BODY"!==this.getFrameEl().contentDocument.activeElement.tagName},startAutoscroll:function(){var t=this;this.dragging=1;var n=this.getScrollListeners();e=a.getFrameOffset(1),setTimeout(function(){(0,i.on)(n,"mousemove",t.autoscroll),(0,i.on)(n,"mouseup",t.stopAutoscroll)},0)},autoscroll:function(t){if(t.preventDefault(),this.dragging){var n=this.getFrameEl().contentWindow,i=n.document.body.scrollTop,r=i,o=t.clientY,s=e.height-50;o<50&&(r-=50-o),o>s&&(r+=o-s),n.scrollTo(0,r)}},stopAutoscroll:function(){this.dragging=0;var t=this.getScrollListeners();(0,i.off)(t,"mousemove",this.autoscroll),(0,i.off)(t,"mouseup",this.stopAutoscroll)},getScrollListeners:function(){return[this.getFrameEl().contentWindow,this.getElement()]},getFrameWrapperEl:function(){return a.frame.getWrapper()}}}},function(t,e,n){"use strict";t.exports={stylePrefix:"cv-",rulers:!1,scripts:[],styles:[],customBadgeLabel:""}},function(t,e,n){"use strict";var i=n(0),r=n(181);t.exports=i.Model.extend({defaults:{frame:"",wrapper:"",rulers:!1},initialize:function(t){var e=this.conf||{};this.set("frame",new r(e.frame))}})},function(t,e,n){"use strict";var i=n(0);t.exports=i.Model.extend({defaults:{wrapper:"",width:"",height:"",attributes:{}}})},function(t,e,n){"use strict";(function(e,i){var r=n(183),o=e.$;t.exports=e.View.extend({initialize:function(t){i.bindAll(this,"renderBody","onFrameScroll","clearOff"),window.onscroll=this.clearOff,this.config=t.config||{},this.em=this.config.em||{},this.ppfx=this.config.pStylePrefix||"",this.className=this.config.stylePrefix+"canvas",this.listenTo(this.em,"change:canvasOffset",this.clearOff),this.frame=new r({model:this.model.get("frame"),config:this.config})},isElInViewport:function(t){var e=t.getBoundingClientRect(),n=this.getFrameOffset(1),i=e.top,r=e.left;return i>=0&&r>=0&&i<=n.height&&r<=n.width},onFrameScroll:function(){var t=this.frame.el.contentDocument.body;this.toolsEl.style.top="-"+t.scrollTop+"px",this.toolsEl.style.left="-"+t.scrollLeft+"px",this.em.trigger("canvasScroll")},renderScripts:function(){var t=this.frame,e=this;t.el.onload=function(){function n(i){if(i.length>0){var r=document.createElement("script");r.type="text/javascript",r.src=i.shift(),r.onerror=r.onload=n.bind(null,i),t.el.contentDocument.head.appendChild(r)}else e.renderBody()}var i=e.config.scripts.slice(0);n(i)}},renderBody:function(){var t=this.model.get("frame").get("wrapper"),e=this.config.em;if(t){var n=this.ppfx,i=o(this.frame.el.contentWindow.document.body),r=e.get("CssComposer"),s=e.get("Config"),a=this.config,l=s.protectedCss,c="";a.styles.forEach(function(t){c+=''});var u="\n \n * {\n box-sizing: border-box;\n }\n html, body, #wrapper {\n min-height: 100%;\n }\n body {\n margin: 0;\n height: 100%;\n background-color: #fff\n }\n #wrapper {\n overflow: auto\n }\n \n\n ."+n+"dashed *[data-highlightable] {\n outline: 1px dashed rgba(170,170,170,0.7);\n outline-offset: -3px\n }\n\n ."+n+"comp-selected {\n outline: 3px solid #3b97e3 !important;\n }\n\n ."+n+"comp-selected-parent {\n outline: 2px solid #ffca6f !important\n }\n\n ."+n+"no-select {\n user-select: none;\n -webkit-user-select:none;\n -moz-user-select: none;\n }\n\n ."+n+"freezed {\n opacity: 0.5;\n pointer-events: none;\n }\n\n ."+n+"no-pointer {\n pointer-events: none;\n }\n\n ."+n+"plh-image {\n background: #f5f5f5;\n border: none;\n height: 50px;\n width: 50px;\n display: block;\n outline: 3px solid #ffca6f;\n cursor: pointer;\n outline-offset: -2px\n }\n\n ."+n+"grabbing {\n cursor: grabbing;\n cursor: -webkit-grabbing;\n }\n\n * ::-webkit-scrollbar-track {\n background: rgba(0, 0, 0, 0.1)\n }\n\n * ::-webkit-scrollbar-thumb {\n background: rgba(255, 255, 255, 0.2)\n }\n\n * ::-webkit-scrollbar {\n width: 10px\n }\n\n "+(s.canvasCss||"")+"\n "+(l||"")+"\n ";c&&i.append(c),i.append(""),i.append(t.render()).append(r.render()),i.append(this.getJsContainer()),e.trigger("loaded"),this.frame.el.contentWindow.onscroll=this.onFrameScroll,this.frame.udpateOffset();var h=document,d=this.frame.el.contentDocument,f=function(t){var e=new KeyboardEvent(t.type,t);return e.keyCodeVal=t.keyCode,["keyCode","which"].forEach(function(t){Object.defineProperty(e,t,{get:function(){return this.keyCodeVal}})}),e};d.addEventListener("keydown",function(t){h.dispatchEvent(f(t))}),d.addEventListener("keyup",function(t){h.dispatchEvent(f(t))})}},offset:function(t){var e=t.getBoundingClientRect(),n=t.ownerDocument.body;return{top:e.top+n.scrollTop,left:e.left+n.scrollLeft,width:e.width,height:e.height}},clearOff:function(){this.frmOff=null,this.cvsOff=null},getFrameOffset:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0;return this.frmOff&&!t||(this.frmOff=this.offset(this.frame.el)),this.frmOff},getCanvasOffset:function(){return this.cvsOff||(this.cvsOff=this.offset(this.el)),this.cvsOff},getElementPos:function(t,e){var n=e||{},i=this.getFrameOffset(),r=this.getCanvasOffset(),o=this.offset(t),s=n.avoidFrameOffset?0:i.top,a=n.avoidFrameOffset?0:i.left;return{top:o.top+s-r.top,left:o.left+a-r.left,height:t.offsetHeight||t.clientHeight,width:t.offsetWidth||t.clientWidth}},getPosition:function(){var t=this.frame.el.contentDocument.body,e=this.getFrameOffset(),n=this.getCanvasOffset();return{top:e.top+t.scrollTop-n.top,left:e.left+t.scrollLeft-n.left}},updateScript:function(t){t.scriptContainer||(t.scriptContainer=o("
"),this.getJsContainer().append(t.scriptContainer.get(0)));var e=t.model,n=e.getId();t.el.id=n,t.scriptContainer.html("");var i=document.createElement("script");i.innerText="\n setTimeout(function() {\n var item = document.getElementById('"+n+"');\n if (!item) return;\n (function(){\n "+e.getScriptString()+";\n }.bind(item))()\n }, 1);",t.scriptContainer.get(0).appendChild(i)},getJsContainer:function(){return this.jsContainer||(this.jsContainer=o('
').get(0)),this.jsContainer},render:function(){if(this.wrapper=this.model.get("wrapper"),this.wrapper&&"function"==typeof this.wrapper.render){this.model.get("frame").set("wrapper",this.wrapper),this.$el.append(this.frame.render().el);var t=this.frame;0===this.config.scripts.length?t.el.onload=this.renderBody:this.renderScripts()}var e=this.ppfx;this.$el.append('\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n ');var n=this.el,i=n.querySelector("#"+e+"tools");return this.hlEl=n.querySelector("."+e+"highlighter"),this.badgeEl=n.querySelector("."+e+"badge"),this.placerEl=n.querySelector("."+e+"placeholder"),this.ghostEl=n.querySelector("."+e+"ghost"),this.toolbarEl=n.querySelector("."+e+"toolbar"),this.resizerEl=n.querySelector("."+e+"resizer"),this.offsetEl=n.querySelector("."+e+"offset-v"),this.fixedOffsetEl=n.querySelector("."+e+"offset-fixed-v"),this.toolsEl=i,this.el.className=this.className,this}})}).call(e,n(0),n(1))},function(t,e,n){"use strict";var i=n(1),r="transitionend oTransitionEnd transitionend webkitTransitionEnd";t.exports=n(0).View.extend({tagName:"iframe",attributes:{src:"about:blank",allowfullscreen:"allowfullscreen"},initialize:function(t){(0,i.bindAll)(this,"udpateOffset"),this.config=t.config||{},this.ppfx=this.config.pStylePrefix||"",this.em=this.config.em,this.listenTo(this.em,"change:device",this.updateDim)},updateDim:function(t){var e=this.em,n=e.getDeviceModel(),i=this.el.style;i.width=n?n.get("width"):"",i.height=n?n.get("height"):"",this.udpateOffset(),e.stopDefault({preserveSelected:1}),this.$el.on(r,this.udpateOffset)},udpateOffset:function(){var t=this.em,e=t.get("Canvas").getOffset();t.set("canvasOffset",e),t.runDefault({preserveSelected:1}),this.$el.off(r,this.udpateOffset)},getBody:function(){this.$el.contents().find("body")},getWrapper:function(){return this.$el.contents().find("body > div")},render:function(){return this.$el.attr({class:this.ppfx+"frame"}),this}})},function(t,e,n){"use strict";var i=n(1);t.exports=function(){var t=void 0,e={},r={},o={},s=n(185),a=n(186),l=function(t,e){return(0,i.isFunction)(e)&&(e={run:e}),delete e.initialize,r[t]=a.extend(e),this};return{name:"Commands",init:function(i){e=i||{};for(var r in s)r in e||(e[r]=s[r]);t=e.em;var a=e.pStylePrefix;a&&(e.stylePrefix=a+e.stylePrefix);for(var l in e.defaults){var c=e.defaults[l];c.id&&this.add(c.id,c)}var u=n(187);return o["select-comp"]=n(21),o["create-comp"]=n(22),o["delete-comp"]=n(192),o["image-comp"]=n(193),o["move-comp"]=n(194),o["text-comp"]=n(195),o["insert-custom"]=n(54),o["export-template"]=u,o["sw-visibility"]=n(196),o["open-layers"]=n(197),o["open-sm"]=n(200),o["open-tm"]=n(201),o["open-blocks"]=n(202),o["open-assets"]=n(203),o["show-offset"]=n(204),o["select-parent"]=n(205),o.fullscreen=n(206),o.preview=n(207),o.resize=n(208),o.drag=n(209),o["tlb-delete"]={run:function(t){var e=t.getSelected();if(!e||!e.get("removable"))return void console.warn("The element is not removable");t.select(null),e.destroy()}},o["tlb-clone"]={run:function(t){var e=t.getSelected();if(!e||!e.get("copyable"))return void console.warn("The element is not clonable");var n=e.collection,i=n.indexOf(e);n.add(e.clone(),{at:i+1}),e.emitUpdate()}},o["tlb-move"]={run:function(t,e,n){var i,r=t.getSelected();if(!r||!r.get("draggable"))return void console.warn("The element is not draggable");var o=function(t,e){console.log("start mouse pos ",e.start),console.log("el rect ",e.elRect);var n=e.el;n.style.position="absolute",n.style.margin=0},s=function(t,e){l.runDefault(),l.set("selectedComponent",r),r.emitUpdate(),i&&i.blur()},a=function(t,e){console.log("Delta ",e.delta),console.log("Current ",e.current)};t.Canvas.getToolbarEl().style.display="none";var l=t.getModel();if(l.stopDefault(),l.get("designerMode"))i=editor.runCommand("drag",{el:r.view.el,options:{event:n&&n.event,onStart:o,onDrag:a,onEnd:s}});else{var c=t.Commands.get("move-comp");c.onEndMoveFromModel=s,c.initSorterFromModel(r)}r.set("status","selected")}},o["core:undo"]=function(t){return t.UndoManager.undo()},o["core:redo"]=function(t){return t.UndoManager.redo()},o["core:canvas-clear"]=function(t){t.DomComponents.clear(),t.CssComposer.clear()},o["core:copy"]=function(t){var e=t.getModel(),n=t.getSelected();n&&n.get("copyable")&&!t.Canvas.isInputFocused()&&e.set("clipboard",n)},o["core:paste"]=function(t){var e=t.getModel(),n=e.get("clipboard"),i=t.getSelected(),r=i&&i.collection;if(r&&n&&!t.Canvas.isInputFocused()){var o=r.indexOf(i)+1;r.add(n.clone(),{at:o})}},e.em&&(e.model=e.em.get("Canvas")),this.loadDefaultCommands(),this},add:l,get:function(t){var n=r[t];return"function"==typeof n&&(n=new n(e),r[t]=n),n},has:function(t){return!!r[t]},loadDefaultCommands:function(){for(var t in o)this.add(t,o[t]);return this}}}},function(t,e,n){"use strict";t.exports={ESCAPE_KEY:27,stylePrefix:"com-",defaults:[],em:null,firstCentered:!0,newFixedH:!1,minComponentH:50,minComponentW:50}},function(t,e,n){"use strict";(function(e){var n=e.$;t.exports=e.View.extend({initialize:function(t){this.config=t||{},this.editorModel=this.em=this.config.em||{},this.pfx=this.config.stylePrefix,this.ppfx=this.config.pStylePrefix,this.hoverClass=this.pfx+"hover",this.badgeClass=this.pfx+"badge",this.plhClass=this.pfx+"placeholder",this.freezClass=this.ppfx+"freezed",this.canvas=this.em.get&&this.em.get("Canvas"),this.em.get&&this.setElement(this.getCanvas()),this.canvas&&(this.$canvas=this.$el,this.$wrapper=n(this.getCanvasWrapper()),this.frameEl=this.canvas.getFrameEl(),this.canvasTool=this.getCanvasTools(),this.bodyEl=this.getCanvasBody()),this.init(this.config)},onFrameScroll:function(t){},getCanvas:function(){return this.canvas.getElement()},getCanvasBody:function(){return this.canvas.getBody()},getCanvasWrapper:function(){return this.canvas.getWrapperEl()},getCanvasTools:function(){return this.canvas.getToolsEl()},offset:function(t){var e=t.getBoundingClientRect();return{top:e.top+t.ownerDocument.body.scrollTop,left:e.left+t.ownerDocument.body.scrollLeft}},init:function(t){},run:function(t,e){},stop:function(t,e){}})}).call(e,n(0))},function(t,e,n){"use strict";(function(e){var n=e.$;t.exports={run:function(t,e){arguments.length>2&&void 0!==arguments[2]&&arguments[2];e&&e.set&&e.set("active",0);var i=t.getConfig(),r=t.Modal,o=i.stylePrefix;if(this.cm=t.CodeManager||null,!this.$editors){var s=this.buildEditor("htmlmixed","hopscotch","HTML"),a=this.buildEditor("css","hopscotch","CSS");this.htmlEditor=s.el,this.cssEditor=a.el;var l=n('
');l.append(s.$el).append(a.$el),this.$editors=l}r.setTitle(i.textViewCode),r.setContent(this.$editors),r.open(),this.htmlEditor.setContent(t.getHtml()),this.cssEditor.setContent(t.getCss())},stop:function(t){var e=t.Modal;e&&e.close()},buildEditor:function(t,e,n){var i=document.createElement("textarea");!this.codeMirror&&(this.codeMirror=this.cm.getViewer("CodeMirror"));var r=this.codeMirror.clone().set({label:n,codeName:t,theme:e,input:i}),o=new this.cm.EditorView({model:r,config:this.cm.getConfig()}).render().$el;return r.init(i),{el:r,$el:o}}}}).call(e,n(0))},function(t,e,n){"use strict";var i=(n(0),n(48)),r=n(189);t.exports=i.extend({itemView:r,initialize:function(t){this.config={editor:t.editor||""},this.listenTo(this.collection,"reset",this.render)}})},function(t,e,n){"use strict";var i=n(0);t.exports=i.View.extend({events:{mousedown:"handleClick"},attributes:function(){return this.model.get("attributes")},initialize:function(t){this.editor=t.config.editor},handleClick:function(t){t.preventDefault(),t.stopPropagation();var e={event:t},n=this.model.get("command"),i=this.editor;"function"==typeof n&&n(i,null,e),"string"==typeof n&&i.runCommand(n,e)},render:function(){var t=this.editor.getConfig();return this.el.className+=" "+t.stylePrefix+"toolbar-item",this}})},function(t,e,n){"use strict";var i=n(0),r=n(191);t.exports=i.Collection.extend({model:r})},function(t,e,n){"use strict";var i=n(0);t.exports=i.Model.extend({defaults:{command:"",attributes:{}}})},function(t,e,n){"use strict";(function(e,i){var r=n(21),o=e.$;t.exports=i.extend({},r,{init:function(t){i.bindAll(this,"startDelete","stopDelete","onDelete"),this.hoverClass=this.pfx+"hover-delete",this.badgeClass=this.pfx+"badge-red"},enable:function(){this.$el.find("*").mouseover(this.startDelete).mouseout(this.stopDelete).click(this.onDelete)},startDelete:function(t){t.stopPropagation();var e=o(t.target);e.data("model").get("removable")&&(e.addClass(this.hoverClass),this.attachBadge(e.get(0)))},stopDelete:function(t){t.stopPropagation(),o(t.target).removeClass(this.hoverClass),this.badge&&this.badge.css({left:-1e3,top:-1e3})},onDelete:function(t){t.stopPropagation();var e=o(t.target);e.data("model").get("removable")&&(e.data("model").destroy(),this.removeBadge(),this.clean())},updateBadgeLabel:function(t){this.badge.html("Remove "+t.getName())}})}).call(e,n(0),n(1))},function(t,e,n){"use strict";(function(e){var i=(n(0),n(54));t.exports=e.extend({},i,{beforeInsert:function(t){t.type="image",t.style={},t.attributes={},t.attributes.onmousedown="return false",this.config.firstCentered&&this.getCanvasWrapper()==this.sorter.target&&(t.style.margin="0 auto")},afterInsert:function(t){t.trigger("dblclick"),this.sender&&this.sender.set("active",!1)}})}).call(e,n(1))},function(t,e,n){"use strict";(function(e,i){var r=n(2),o=n(21),s=n(53),a=e.$;t.exports=i.extend({},s,o,{init:function(t){o.init.apply(this,arguments),i.bindAll(this,"initSorter","rollback","onEndMove"),this.opt=t,this.hoverClass=this.ppfx+"highlighter-warning",this.badgeClass=this.ppfx+"badge-warning",this.noSelClass=this.ppfx+"no-select"},enable:function(){for(var t=arguments.length,e=Array(t),n=0;n
');this.panel.set("appendContent",c).trigger("change:appendContent"),o.layers.sortContainer=c.get(0);var u=(new i).init(n,o.layers);this.$layers=u.render(),c.append(this.$layers),this.toAppend=c}this.toAppend.show()},stop:function(){this.toAppend&&this.toAppend.hide()}}}).call(e,n(0))},function(t,e,n){"use strict";t.exports=function(){var t=void 0,e={},i=n(199),r=n(55),o=n(56);return{init:function(n,s){e=s||e;var a=e.em;for(var l in i)l in e||(e[l]=i[l]);var c=o,u=s.opened||{},h={level:0,config:e,opened:u};return e.showWrapper&&n.parent?(c=r,h.model=n.parent):h.collection=n,t=new c(h),a&&a.on("change:selectedComponent",this.componentChanged),this.componentChanged(),this},componentChanged:function(t,n){if(!(arguments.length>2&&void 0!==arguments[2]?arguments[2]:{}).fromLayers){var i=e.em,r=i.get("opened"),o=i.get("selectedComponent"),s=o&&o.collection?o.collection.parent:null;for(var a in r)r[a].set("open",0);for(;s;)s.set("open",1),r[s.cid]=s,s=s.collection?s.collection.parent:null}},render:function(){return t.render().$el}}}},function(t,e,n){"use strict";t.exports={stylePrefix:"nv-",sortable:1,hidable:1,hideTextnode:1,showWrapper:1}},function(t,e,n){"use strict";var i=(n(31),n(0)),r=i.$;t.exports={run:function(t,e){if(this.sender=e,!this.$cn){var n=t.getConfig(),i=t.Panels;this.$cn=r("
"),this.$cn2=r("
"),this.$cn.append(this.$cn2);var o=t.DeviceManager;if(o&&n.showDevices){i.addPanel({id:"devices-c"}).set("appendContent",o.render()).trigger("change:appendContent")}var s=t.SelectorManager;s&&this.$cn2.append(s.render([])),this.$cn2.append(t.StyleManager.render());var a=t.StyleManager.getConfig(),l=a.stylePrefix;this.$header=r('
'+a.textNoElement+"
"),this.$cn.append(this.$header),i.getPanel("views-container")?this.panel=i.getPanel("views-container"):this.panel=i.addPanel({id:"views-container"}),this.panel.set("appendContent",this.$cn).trigger("change:appendContent"),this.target=t.editor,this.listenTo(this.target,"change:selectedComponent",this.toggleSm)}this.toggleSm()},toggleSm:function(){var t=this.sender;t&&t.get&&!t.get("active")||(this.target.get("selectedComponent")?(this.$cn2.show(),this.$header.hide()):(this.$cn2.hide(),this.$header.show()))},stop:function(){this.$cn2&&this.$cn2.hide(),this.$header&&this.$header.hide()}}},function(t,e,n){"use strict";(function(e){var n=e.$;t.exports={run:function(t,e){var i,r=t.Config,o=r.stylePrefix,s=t.TraitManager;if(!this.obj){var a=s.getTraitsViewer(),l=s.getConfig();this.obj=n("
").append('
'+l.labelContainer+"
").get(0),this.obj.appendChild(a.render().el);var c=t.Panels;i=c.getPanel("views-container")?c.getPanel("views-container"):c.addPanel({id:"views-container"}),i.set("appendContent",this.obj).trigger("change:appendContent")}this.obj.style.display="block"},stop:function(){this.obj&&(this.obj.style.display="none")}}}).call(e,n(0))},function(t,e,n){"use strict";t.exports={run:function(t,e){var n=t.BlockManager,i=t.Panels;if(!this.blocks){n.render();var r="views-container",o=document.createElement("div"),s=i.getPanel(r)||i.addPanel({id:r});o.appendChild(n.getContainer()),s.set("appendContent",o).trigger("change:appendContent"),this.blocks=o}this.blocks.style.display="block"},stop:function(){var t=this.blocks;t&&(t.style.display="none")}}},function(t,e,n){"use strict";t.exports={run:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},i=t.Modal,r=t.AssetManager,o=r.getConfig(),s=n.modalTitle||o.modalTitle||"";r.setTarget(n.target),r.onClick(n.onClick),r.onDblClick(n.onDblClick),r.onSelect(n.onSelect),this.rendered||(r.render(r.getAll().filter(function(t){return"image"==t.get("type")})),this.rendered=1),i.setTitle(s),i.setContent(r.getContainer()),i.open()}}},function(t,e,n){"use strict";(function(e){var n=e.$;t.exports={getOffsetMethod:function(t){return"get"+(t||"")+"OffsetViewerEl"},run:function(t,e,i){var r=i||{},o=r.state||"",s=t.getConfig();if(s.showOffsets&&(s.showOffsetsSelected||"Fixed"!=o)){var a=t.Canvas,l=r.el||"",c=r.elPos||a.getElementPos(l),u=window.getComputedStyle(l),h=this.ppfx,d=o+"State",f=this.getOffsetMethod(o),p=a[f]();p.style.display="block";var g=this["marginT"+o],v=this["marginB"+o],m=this["marginL"+o],y=this["marginR"+o],b=this["padT"+o],x=this["padB"+o],w=this["padL"+o],C=this["padR"+o];if(!this[d]){var k=o.toLowerCase(),S=k+"margin-v",T=k+"padding-v",E=n('
').get(0),M=n('
').get(0),P=h+S+"-el",A=h+T+"-el",O=P+" "+(h+S),L=A+" "+(h+T);g=n('
').get(0),v=n('
').get(0),m=n('
').get(0),y=n('
').get(0),b=n('
').get(0),x=n('
').get(0),w=n('
').get(0),C=n('
').get(0),this["marginT"+o]=g,this["marginB"+o]=v,this["marginL"+o]=m,this["marginR"+o]=y,this["padT"+o]=b,this["padB"+o]=x,this["padL"+o]=w,this["padR"+o]=C,E.appendChild(g),E.appendChild(v),E.appendChild(m),E.appendChild(y),M.appendChild(b),M.appendChild(x),M.appendChild(w),M.appendChild(C),p.appendChild(E),p.appendChild(M),this[d]="1"}var N=u.marginLeft.replace("px",""),I=parseInt(u.marginTop.replace("px","")),D=parseInt(u.marginBottom.replace("px","")),_=g.style,F=v.style,z=m.style,$=y.style,R=b.style,V=x.style,H=w.style,j=C.style,B=parseInt(c.left);_.height=u.marginTop,_.width=u.width,_.top=c.top-u.marginTop.replace("px","")+"px",_.left=B+"px",F.height=u.marginBottom,F.width=u.width,F.top=c.top+c.height+"px",F.left=B+"px";var W=c.height+I+D+"px",U=c.top-I+"px";z.height=W,z.width=u.marginLeft,z.top=U,z.left=B-N+"px",$.height=W,$.width=u.marginRight,$.top=U,$.left=B+c.width+"px";var q=parseInt(u.paddingTop.replace("px",""));R.height=u.paddingTop,R.width=u.width,R.top=c.top+"px",R.left=B+"px";var K=parseInt(u.paddingBottom.replace("px",""));V.height=u.paddingBottom,V.width=u.width,V.top=c.top+c.height-K+"px",V.left=B+"px";var G=c.height-K-q+"px",Y=c.top+q+"px";H.height=G,H.width=u.paddingLeft,H.top=Y,H.left=c.left+"px";var X=parseInt(u.paddingRight.replace("px",""));j.height=G,j.width=u.paddingRight,j.top=Y,j.left=c.left+c.width-X+"px"}},stop:function(t,e,n){var i=n||{},r=i.state||"",o=this.getOffsetMethod(r);t.Canvas[o]().style.display="none"}}}).call(e,n(0))},function(t,e,n){"use strict";t.exports={run:function(t){for(var e=t.getSelected(),n=e&&e.parent();n&&!n.get("selectable");)n=n.parent();n&&t.select(n)}}},function(t,e,n){"use strict";t.exports={isEnabled:function(){var t=document;return t.fullscreenElement||t.webkitFullscreenElement||t.mozFullScreenElement?1:0},enable:function(t){var e="";return t.requestFullscreen?t.requestFullscreen():t.webkitRequestFullscreen?(e="webkit",t.webkitRequestFullscreen()):t.mozRequestFullScreen?(e="moz",t.mozRequestFullScreen()):t.msRequestFullscreen?t.msRequestFullscreen():console.warn("Fullscreen not supported"),e},disable:function(){var t=document;t.exitFullscreen?t.exitFullscreen():t.webkitExitFullscreen?t.webkitExitFullscreen():t.mozCancelFullScreen?t.mozCancelFullScreen():t.msExitFullscreen&&t.msExitFullscreen()},fsChanged:function(t,e){var n=(document,(t||"")+"fullscreenchange");this.isEnabled()||(this.stop(null,this.sender),document.removeEventListener(n,this.fsChanged))},run:function(t,e){this.sender=e;var n=this.enable(t.getContainer());this.fsChanged=this.fsChanged.bind(this,n),document.addEventListener(n+"fullscreenchange",this.fsChanged),t&&t.trigger("change:canvasOffset")},stop:function(t,e){e&&e.set&&e.set("active",!1),this.disable(),t&&t.trigger("change:canvasOffset")}}},function(t,e,n){"use strict";(function(e){t.exports={getPanels:function(t){return this.panels||(this.panels=t.Panels.getPanelsEl()),this.panels},tglPointers:function(t,n){var i=t.Canvas.getBody().querySelectorAll("."+this.ppfx+"no-pointer");e.each(i,function(t){t.style.pointerEvents=n?"":"all"})},run:function(t,e){e&&e.set&&e.set("active",!1),t.stopCommand("sw-visibility"),t.getModel().stopDefault();var n=this.getPanels(t),i=t.Canvas.getElement(),r=t.getEl(),o=t.Config.stylePrefix;this.helper||(this.helper=document.createElement("span"),this.helper.className=o+"off-prv fa fa-eye-slash",r.appendChild(this.helper),this.helper.onclick=function(){t.stopCommand("preview")}),this.helper.style.display="inline-block",this.tglPointers(t),n.style.display="none";var s=i.style;s.width="100%",s.height="100%",s.top="0",s.left="0",s.padding="0",s.margin="0",t.trigger("change:canvasOffset")},stop:function(t,e){var n=this.getPanels(t);t.runCommand("sw-visibility"),t.getModel().runDefault(),n.style.display="block",t.Canvas.getElement().setAttribute("style",""),this.helper&&(this.helper.style.display="none"),t.trigger("change:canvasOffset"),this.tglPointers(t,1)}}}).call(e,n(1))},function(t,e,n){"use strict";t.exports={run:function(t,e,n){var i=n||{},r=i.el||"",o=t.Canvas,s=this.canvasResizer,a=i.options||{},l=o.getCanvasView();return a.ratioDefault=1,a.appendTo=o.getResizerEl(),a.prefix=t.getConfig().stylePrefix,a.posFetcher=l.getElementPos.bind(l),a.mousePosFetcher=o.getMouseRelativePos,s&&!i.forceNew||(this.canvasResizer=t.Utils.Resizer.init(a),s=this.canvasResizer),s.setOptions(a),s.focus(r),s},stop:function(){var t=this.canvasResizer;t&&t.blur()}}},function(t,e,n){"use strict";t.exports={run:function(t,e,n){var i=n&&n.el||"",r=t.Canvas,o=this.dragger,s=n.options||{},a=r.getCanvasView();return s.prefix=t.getConfig().stylePrefix,s.mousePosFetcher=r.getMouseRelativePos,s.posFetcher=a.getElementPos.bind(a),o||(o=t.Utils.Dragger.init(s),this.dragger=o),o.setOptions(s),o.focus(i),s.event&&o.start(s.event),o},stop:function(){this.canvasResizer&&this.canvasResizer.blur()}}},function(t,e,n){"use strict";t.exports=function(){var t,e,i,r={},o=n(211),s=n(212),a=n(214),l=n(215),c=[];return{name:"BlockManager",init:function(n){r=n||{};var u=r.em;for(var h in o)h in r||(r[h]=o[h]);return t=new s([]),e=new s([]),c=new a,i=new l({collection:e,categories:c},r),t.listenTo(t,"add",function(t){e.add(t),u&&u.trigger("block:add",t)}),t.listenTo(t,"remove",function(t){e.remove(t),u&&u.trigger("block:remove",t)}),t.listenTo(t,"reset",function(t){e.reset(t.models)}),this},getConfig:function(){return r},onLoad:function(){var t=this.getAll();!t.length&&t.reset(r.blocks)},add:function(e,n){var i=n||{};return i.id=e,t.add(i)},get:function(e){return t.get(e)},getAll:function(){return t},getAllVisible:function(){return e},remove:function(e){return t.remove(e)},getCategories:function(){return c},getContainer:function(){return i.el},render:function(t){var e=t||this.getAll().models;i.rendered||(i.render(),i.rendered=1),i.collection.reset(e)}}}},function(t,e,n){"use strict";t.exports={blocks:[],appendTo:""}},function(t,e,n){"use strict";var i=n(0),r=n(213);t.exports=i.Collection.extend({model:r})},function(t,e,n){"use strict";var i=n(0),r=n(57);t.exports=i.Model.extend({defaults:{label:"",content:"",category:"",attributes:{}},initialize:function(){var t=(arguments.length>0&&void 0!==arguments[0]&&arguments[0],this.get("category"));if(t&&"string"==typeof t){new r({id:t,label:t})}}})},function(t,e,n){"use strict";var i=n(0);t.exports=i.Collection.extend({model:n(57)})},function(t,e,n){"use strict";(function(e){var i=n(0),r=n(216),o=n(217);t.exports=i.View.extend({initialize:function(t,n){e.bindAll(this,"getSorter","onDrag","onDrop"),this.config=n||{},this.categories=t.categories||"",this.renderedCategories=[];var i=this.config.pStylePrefix||"";this.ppfx=i,this.noCatClass=i+"blocks-no-cat",this.blockContClass=i+"blocks-c",this.catsClass=i+"block-categories";var r=this.collection;this.listenTo(r,"add",this.addTo),this.listenTo(r,"reset",this.render),this.em=this.config.em,this.tac="test-tac",this.grabbingCls=this.ppfx+"grabbing",this.em&&(this.config.getSorter=this.getSorter,this.canvas=this.em.get("Canvas"))},getSorter:function(){if(this.em){if(!this.sorter){var t=this.em.get("Utils"),e=this.canvas;this.sorter=new t.Sorter({container:e.getBody(),placer:e.getPlacerEl(),containerSel:"*",itemSel:"*",pfx:this.ppfx,onStart:this.onDrag,onEndMove:this.onDrop,onMove:this.onMove,document:e.getFrameEl().contentDocument,direction:"a",wmargin:1,nested:1,em:this.em,canvasRelative:1})}return this.sorter}},onDrag:function(t){this.em.stopDefault(),this.em.trigger("block:drag:start",t)},onMove:function(t){this.em.trigger("block:drag:move",t)},onDrop:function(t){var e=this.em;e.runDefault(),t&&t.get&&(t.get("activeOnRender")&&(t.trigger("active"),t.set("activeOnRender",0)),e.trigger("block:drag:stop",t))},addTo:function(t){this.add(t)},add:function(t,e){var n=e||null,i=new r({model:t,attributes:t.get("attributes")},this.config),s=i.render().el,a=t.get("category");if(a&&this.categories){"string"==typeof a&&(a={id:a,label:a});var l=this.categories.add(a),c=l.get("id"),u=this.renderedCategories[c],h=this.getCategoriesEl();return t.set("category",l),!u&&h&&(u=new o({model:l},this.config).render(),this.renderedCategories[c]=u,h.appendChild(u.el)),void(u&&u.append(s))}n?n.appendChild(s):this.append(s)},getCategoriesEl:function(){return this.catsEl||(this.catsEl=this.el.querySelector("."+this.catsClass)),this.catsEl},getBlocksEl:function(){return this.blocksEl||(this.blocksEl=this.el.querySelector("."+this.noCatClass+" ."+this.blockContClass)),this.blocksEl},append:function(t){var e=this.getBlocksEl();e&&e.appendChild(t)},render:function(){var t=this,e=document.createDocumentFragment();return this.catsEl=null,this.blocksEl=null,this.renderedCategories=[],this.el.innerHTML='\n
\n
\n
\n
\n ',this.collection.each(function(n){return t.add(n,e)}),this.append(e),this.$el.addClass(this.blockContClass+"s"),this}})}).call(e,n(1))},function(t,e,n){"use strict";(function(e){var i=n(2);t.exports=e.View.extend({events:{mousedown:"startDrag"},initialize:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};this.config=e,this.endDrag=this.endDrag.bind(this),this.ppfx=e.pStylePrefix||"",this.listenTo(this.model,"destroy remove",this.remove)},startDrag:function(t){if(0===t.button&&this.config.getSorter){this.config.em.refreshCanvas();var e=this.config.getSorter();e.setDragHelper(this.el,t),e.setDropContent(this.model.get("content")),e.startSort(this.el),(0,i.on)(document,"mouseup",this.endDrag)}},endDrag:function(t){(0,i.off)(document,"mouseup",this.endDrag);var e=this.config.getSorter();e.moved=0,e.endMove()},render:function(){var t=this.el,e=this.ppfx,n=e+"block";return t.className+=" "+n+" "+e+"one-bg "+e+"four-color-h",t.innerHTML='
'+this.model.get("label")+"
",this}})}).call(e,n(0))},function(t,e,n){"use strict";(function(e){var i=n(0);t.exports=i.View.extend({template:e.template('\n
\n \n <%= label %>\n
\n
\n '),events:{},initialize:function(){var t=(arguments.length>0&&void 0!==arguments[0]&&arguments[0],arguments.length>1&&void 0!==arguments[1]?arguments[1]:{});this.config=t;var e=this.config.pStylePrefix||"";this.pfx=e,this.caretR="fa fa-caret-right",this.caretD="fa fa-caret-down",this.iconClass=e+"caret-icon",this.activeClass=e+"open",this.className=e+"block-category",this.events["click ."+e+"title"]="toggle",this.listenTo(this.model,"change:open",this.updateVisibility),this.delegateEvents()},updateVisibility:function(){this.model.get("open")?this.open():this.close()},open:function(){this.el.className=this.className+" "+this.activeClass,this.getIconEl().className=this.iconClass+" "+this.caretD,this.getBlocksEl().style.display=""},close:function(){this.el.className=this.className,this.getIconEl().className=this.iconClass+" "+this.caretR,this.getBlocksEl().style.display="none"},toggle:function(){var t=this.model;t.set("open",!t.get("open"))},getIconEl:function(){return this.iconEl||(this.iconEl=this.el.querySelector("."+this.iconClass)),this.iconEl},getBlocksEl:function(){return this.blocksEl||(this.blocksEl=this.el.querySelector("."+this.pfx+"blocks-c")),this.blocksEl},append:function(t){this.getBlocksEl().appendChild(t)},render:function(){return this.el.innerHTML=this.template({pfx:this.pfx,label:this.model.get("label")}),this.el.className=this.className,this.updateVisibility(),this}})}).call(e,n(1))},function(t,e,n){"use strict";t.exports=function(t){var e=t.$,n=t.Backbone;if(n){var i=n.View.prototype,r={};i.eventNsMap=r,i.delegate=function(t,e,n){var i=".delegateEvents"+this.cid;this.$el.on(t,e,n);var o=r[i];return o||(o=[],r[i]=o),o.push({eventName:t,selector:e,listener:n}),this},i.undelegateEvents=function(){var t=this,e=".delegateEvents"+this.cid;if(this.$el){var n=r[e];n&&n.forEach(function(e){var n=e.eventName;e.selector,e.listener;t.$el.off(n)})}return this},i.undelegate=function(t,e,n){var i=this,o=".delegateEvents"+this.cid,s=r[o];return s&&s.forEach(function(n){var r=n.eventName,o=n.selector;n.listener;r==t&&o==e&&i.$el.off(r)}),this}}if(e&&"jQuery"!==e.prototype.constructor.name){var o=e.fn,s=e.prototype.on,a=e.prototype.off,l=e.prototype.trigger,c=e.prototype.offset,u=function(t){return t.split(/[,\s]+/g)},h=function(t){return t.split(".")};o.on=function(t,e,n,i){var r=this;if("string"==typeof t){var o=u(t);if(1==o.length){t=o[0];var a=h(t);if(0!==t.indexOf(".")&&(t=a[0]),a=a.slice(1),a.length){this.data("_cashNs");this.data("_cashNs",a)}return s.call(this,t,e,n,i)}return o.forEach(function(t){return r.on(t,e,n,i)}),this}return s.call(this,t,e,n,i)},o.off=function(t,e){var n=this;if("string"==typeof t){var i=u(t);if(1==i.length){t=i[0];var r=h(t);return 0!==t.indexOf(".")&&(t=r[0]),r=r.slice(1),r.length,a.call(this,t,e)}return i.forEach(function(t){return n.off(t,e)}),this}return a.call(this,t,e)},o.trigger=function(t,n){var i=this;if(t instanceof e.Event)return this.trigger(t.type,n);if("string"==typeof t){var r=u(t);if(1==r.length){t=r[0];var o=h(t);return 0!==t.indexOf(".")&&(t=o[0]),o=o.slice(1),o.length,l.call(this,t,n)}return r.forEach(function(t){return i.trigger(t,n)}),this}return l.call(this,t,n)},o.hide=function(){return this.css("display","none")},o.show=function(){return this.css("display","block")},o.focus=function(){var t=this.get(0);return t&&t.focus(),this},o.remove=function(){return this.each(function(t){return t.parentNode&&t.parentNode.removeChild(t)})},o.bind=function(t,e){return this.on(t,e)},o.unbind=function(t,e){return this.off(t,e)},o.click=function(t){return t?this.on("click",t):this.trigger("click")},o.change=function(t){return t?this.on("change",t):this.trigger("change")},o.keydown=function(t){return t?this.on("keydown",t):this.trigger("keydown")},o.delegate=function(t,e,n,i){return i||(i=n),this.on(e,t,function(t){t.data=n,i(t)})},o.scrollLeft=function(){var t=this.get(0);t=9==t.nodeType?t.defaultView:t;var e=t instanceof Window?t:null;return e?e.pageXOffset:t.scrollLeft||0},o.scrollTop=function(){var t=this.get(0);t=9==t.nodeType?t.defaultView:t;var e=t instanceof Window?t:null;return e?e.pageYOffset:t.scrollTop||0},o.offset=function(t){var e=void 0,n=void 0;return t&&(e=t.top,n=t.left),void 0!==e&&this.css("top",e+"px"),void 0!==n&&this.css("left",n+"px"),c.call(this)},e.map=function(t,e){for(var n=[],i=0;it.maximumStackLength&&(t.shift(),t.pointer--)}}}c.prototype={isRegistered:function(e){return e&&e.cid?this.registeredObjects[e.cid]:t.contains(this.registeredObjects,e)},register:function(t){return!this.isRegistered(t)&&(t&&t.cid?(this.registeredObjects[t.cid]=t,this.cidIndexes.push(t.cid)):this.registeredObjects.push(t),!0)},unregister:function(e){if(this.isRegistered(e)){if(e&&e.cid)delete this.registeredObjects[e.cid],this.cidIndexes.splice(t.indexOf(this.cidIndexes,e.cid),1);else{var n=t.indexOf(this.registeredObjects,e);this.registeredObjects.splice(n,1)}return!0}return!1},get:function(){return t.map(this.cidIndexes,(function(t){return this.registeredObjects[t]}),this).concat(this.registeredObjects)}};var p={add:{undo:function(t,e,n,r){t.remove(n,r)},redo:function(t,e,n,r){r.index&&(r.at=r.index),t.add(n,r)},on:function(e,n,r){return{object:n,before:void 0,after:e,options:t.clone(r)}}},remove:{undo:function(t,e,n,r){"index"in r&&(r.at=r.index),t.add(e,r)},redo:function(t,e,n,r){t.remove(e,r)},on:function(e,n,r){return{object:n,before:e,after:void 0,options:t.clone(r)}}},change:{undo:function(e,n,r,i){t.isEmpty(n)?t.each(t.keys(r),e.unset,e):(e.set(n),i&&i.unsetData&&i.unsetData.before&&i.unsetData.before.length&&t.each(i.unsetData.before,e.unset,e))},redo:function(e,n,r,i){t.isEmpty(r)?t.each(t.keys(n),e.unset,e):(e.set(r),i&&i.unsetData&&i.unsetData.after&&i.unsetData.after.length&&t.each(i.unsetData.after,e.unset,e))},on:function(e,n){var r=e.changedAttributes(),i=t.keys(r),o=t.pick(e.previousAttributes(),i),a=t.keys(o),s=(n||(n={})).unsetData={after:[],before:[]};return i.length!=a.length&&(i.length>a.length?t.each(i,(function(t){t in o||s.before.push(t)}),this):t.each(a,(function(t){t in r||s.after.push(t)}))),{object:e,before:o,after:r,options:t.clone(n)}}},reset:{undo:function(t,e,n){t.reset(e)},redo:function(t,e,n){t.reset(n)},on:function(e,n){return{object:e,before:n.previousModels,after:t.clone(e.models)}}}};function g(){}function v(e,n,r,i){if("object"==typeof n)return t.each(n,(function(t,n){2===e?v(e,t,r,i):v(e,n,t,r)}));switch(e){case 0:o(r,"undo","redo","on")&&t.all(t.pick(r,"undo","redo","on"),t.isFunction)&&(i[n]=r);break;case 1:i[n]&&t.isObject(r)&&(i[n]=t.extend({},i[n],r));break;case 2:delete i[n]}return this}g.prototype=p;var m=e.Model.extend({defaults:{type:null,object:null,before:null,after:null,magicFusionIndex:null},undo:function(t){h("undo",this.attributes)},redo:function(t){h("redo",this.attributes)}}),y=e.Collection.extend({model:m,pointer:-1,track:!1,isCurrentlyUndoRedoing:!1,maximumStackLength:1/0,setMaxLength:function(t){this.maximumStackLength=t}}),b=e.Model.extend({defaults:{maximumStackLength:1/0,track:!1},initialize:function(e){this.stack=new y,this.objectRegistry=new c,this.undoTypes=new g,this.stack.setMaxLength(this.get("maximumStackLength")),this.on("change:maximumStackLength",(function(t,e){this.stack.setMaxLength(e)}),this),e&&e.track&&this.startTracking(),e&&e.register&&(t.isArray(e.register)||t.isArguments(e.register)?r(this.register,this,e.register):this.register(e.register))},startTracking:function(){this.set("track",!0),this.stack.track=!0},stopTracking:function(){this.set("track",!1),this.stack.track=!1},isTracking:function(){return this.get("track")},_addToStack:function(t){f(this.stack,t,i(arguments,1),this.undoTypes)},register:function(){u("on",arguments,this._addToStack,this)},unregister:function(){u("off",arguments,this._addToStack,this)},unregisterAll:function(){r(this.unregister,this,this.objectRegistry.get())},undo:function(t){d("undo",this,this.stack,t)},undoAll:function(){d("undo",this,this.stack,!1,!0)},redo:function(t){d("redo",this,this.stack,t)},redoAll:function(){d("redo",this,this.stack,!1,!0)},isAvailable:function(t){var e=this.stack,n=e.length;switch(t){case"undo":return n>0&&e.pointer>-1;case"redo":return n>0&&e.pointer0&&void 0!==arguments[0]?arguments[0]:{};return e=h({},r,{},n),t=e.em,this.em=t,this},onLoad:function(){var t=e.defaults;for(var n in t){var r=t[n];this.add(n,r.keys,r.handler)}},add:function(t,e,r){var o=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{},a=this.em,l=a.get("Commands"),u=a.getEditor(),h=a.get("Canvas"),d={id:t,keys:e,handler:r},f=n[t];return f&&this.remove(t),n[t]=d,c()(e,(function(e,n){var c={event:e,h:n};if(r=Object(s.isString)(r)?l.get(r):r,o.prevent&&h.getCanvasView().preventDefault(e),!a.isEditing()&&!u.Canvas.isInputFocused()||o.force){"object"==i()(r)?r.run(u,0,c):r(u,0,c);var d=[t,n.shortcut,e];a.trigger.apply(a,["keymap:emit"].concat(d)),a.trigger.apply(a,["keymap:emit:".concat(t)].concat(d))}})),a.trigger("keymap:add",d),d},get:function(t){return n[t]},getAll:function(){return n},remove:function(t){var e=this.em,r=this.get(t);if(r)return delete n[t],c.a.unbind(r.keys),e&&e.trigger("keymap:remove",r),r},removeAll:function(){var t=this;return Object.keys(n).forEach((function(e){return t.remove(e)})),this}}}},function(t,e,n){"use strict";n.r(e);var r=n(2),i=n.n(r),o=n(63),a=n.n(o);function s(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function l(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{};n=l({},o,{},i),t=n.em,this.em=t,(e=new a.a({track:!0,register:[]})).changeUndoType("change",{condition:!1}),e.changeUndoType("add",{on:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};if(!n.avoidStore)return{object:e,before:void 0,after:t,options:l({},n)}}}),e.changeUndoType("remove",{on:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};if(!n.avoidStore)return{object:e,before:t,after:void 0,options:l({},n)}}});var s={on:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};if(!r&&(r=t.previousAttributes()),!n.avoidStore){var i={object:t,before:r,after:t.toJSON()};return r=null,i}},undo:function(t,e,n,r){t.set(e)},redo:function(t,e,n,r){t.set(n)}},c=["style","attributes","content","src"];return c.forEach((function(t){return e.addUndoType("change:".concat(t),s)})),e.on("undo redo",(function(){return t.trigger("component:toggled change:canvasOffset")})),["undo","redo"].forEach((function(n){return e.on(n,(function(){return t.trigger(n)}))})),this},getConfig:function(){return n},add:function(t){return e.register(t),this},remove:function(t){return e.unregister(t),this},removeAll:function(){return e.unregisterAll(),this},start:function(){return e.startTracking(),this},stop:function(){return e.stopTracking(),this},undo:function(){return!t.isEditing()&&e.undo(1),this},undoAll:function(){return e.undoAll(),this},redo:function(){return!t.isEditing()&&e.redo(1),this},redoAll:function(){return e.redoAll(),this},hasUndo:function(){return e.isAvailable("undo")},hasRedo:function(){return e.isAvailable("redo")},getStack:function(){return e.stack},clear:function(){return e.clear(),this},getInstance:function(){return e}}}},function(t,e,n){(function(t){var r=void 0!==t&&t||"undefined"!=typeof self&&self||window,i=Function.prototype.apply;function o(t,e){this._id=t,this._clearFn=e}e.setTimeout=function(){return new o(i.call(setTimeout,r,arguments),clearTimeout)},e.setInterval=function(){return new o(i.call(setInterval,r,arguments),clearInterval)},e.clearTimeout=e.clearInterval=function(t){t&&t.close()},o.prototype.unref=o.prototype.ref=function(){},o.prototype.close=function(){this._clearFn.call(r,this._id)},e.enroll=function(t,e){clearTimeout(t._idleTimeoutId),t._idleTimeout=e},e.unenroll=function(t){clearTimeout(t._idleTimeoutId),t._idleTimeout=-1},e._unrefActive=e.active=function(t){clearTimeout(t._idleTimeoutId);var e=t._idleTimeout;e>=0&&(t._idleTimeoutId=setTimeout((function(){t._onTimeout&&t._onTimeout()}),e))},n(70),e.setImmediate="undefined"!=typeof self&&self.setImmediate||void 0!==t&&t.setImmediate||this&&this.setImmediate,e.clearImmediate="undefined"!=typeof self&&self.clearImmediate||void 0!==t&&t.clearImmediate||this&&this.clearImmediate}).call(this,n(23))},function(t,e,n){(function(t,e){!function(t,n){"use strict";if(!t.setImmediate){var r,i,o,a,s,l=1,c={},u=!1,h=t.document,d=Object.getPrototypeOf&&Object.getPrototypeOf(t);d=d&&d.setTimeout?d:t,"[object process]"==={}.toString.call(t.process)?r=function(t){e.nextTick((function(){p(t)}))}:!function(){if(t.postMessage&&!t.importScripts){var e=!0,n=t.onmessage;return t.onmessage=function(){e=!1},t.postMessage("","*"),t.onmessage=n,e}}()?t.MessageChannel?((o=new MessageChannel).port1.onmessage=function(t){p(t.data)},r=function(t){o.port2.postMessage(t)}):h&&"onreadystatechange"in h.createElement("script")?(i=h.documentElement,r=function(t){var e=h.createElement("script");e.onreadystatechange=function(){p(t),e.onreadystatechange=null,i.removeChild(e),e=null},i.appendChild(e)}):r=function(t){setTimeout(p,0,t)}:(a="setImmediate$"+Math.random()+"$",s=function(e){e.source===t&&"string"==typeof e.data&&0===e.data.indexOf(a)&&p(+e.data.slice(a.length))},t.addEventListener?t.addEventListener("message",s,!1):t.attachEvent("onmessage",s),r=function(e){t.postMessage(a+e,"*")}),d.setImmediate=function(t){"function"!=typeof t&&(t=new Function(""+t));for(var e=new Array(arguments.length-1),n=0;n1)for(var n=1;n","i")}function o(t,e){for(var n in t)for(var r=e[n]||(e[n]=[]),i=t[n],o=i.length-1;o>=0;o--)r.unshift(i[o])}t.defineMode("htmlmixed",(function(n,a){var s=t.getMode(n,{name:"xml",htmlMode:!0,multilineTagIndentFactor:a.multilineTagIndentFactor,multilineTagIndentPastTag:a.multilineTagIndentPastTag}),l={},c=a&&a.tags,u=a&&a.scriptTypes;if(o(e,l),c&&o(c,l),u)for(var h=u.length-1;h>=0;h--)l.script.unshift(["type",u[h].matches,u[h].mode]);function d(e,o){var a,c=s.token(e,o.htmlState),u=/\btag\b/.test(c);if(u&&!/[<>\s\/]/.test(e.current())&&(a=o.htmlState.tagName&&o.htmlState.tagName.toLowerCase())&&l.hasOwnProperty(a))o.inTag=a+" ";else if(o.inTag&&u&&/>$/.test(e.current())){var h=/^([\S]+) (.*)/.exec(o.inTag);o.inTag=null;var f=">"==e.current()&&function(t,e){for(var n=0;n-1?t.backUp(r.length-i):r.match(/<\/?$/)&&(t.backUp(r.length),t.match(e,!1)||t.match(r)),n}(t,v,e.localMode.token(t,e.localState))},o.localMode=p,o.localState=t.startState(p,s.indent(o.htmlState,"",""))}else o.inTag&&(o.inTag+=e.current(),e.eol()&&(o.inTag+=" "));return c}return{startState:function(){return{token:d,inTag:null,localMode:null,localState:null,htmlState:t.startState(s)}},copyState:function(e){var n;return e.localState&&(n=t.copyState(e.localMode,e.localState)),{token:e.token,inTag:e.inTag,localMode:e.localMode,localState:n,htmlState:t.copyState(s,e.htmlState)}},token:function(t,e){return e.token(t,e)},indent:function(e,n,r){return!e.localMode||/^\s*<\//.test(n)?s.indent(e.htmlState,n,r):e.localMode.indent?e.localMode.indent(e.localState,n,r):t.Pass},innerMode:function(t){return{state:t.localState||t.htmlState,mode:t.localMode||s}}}}),"xml","javascript","css"),t.defineMIME("text/html","htmlmixed")}(n(10),n(76),n(77),n(36))},function(t,e,n){!function(t){"use strict";var e={autoSelfClosers:{area:!0,base:!0,br:!0,col:!0,command:!0,embed:!0,frame:!0,hr:!0,img:!0,input:!0,keygen:!0,link:!0,meta:!0,param:!0,source:!0,track:!0,wbr:!0,menuitem:!0},implicitlyClosed:{dd:!0,li:!0,optgroup:!0,option:!0,p:!0,rp:!0,rt:!0,tbody:!0,td:!0,tfoot:!0,th:!0,tr:!0},contextGrabbers:{dd:{dd:!0,dt:!0},dt:{dd:!0,dt:!0},li:{li:!0},option:{option:!0,optgroup:!0},optgroup:{optgroup:!0},p:{address:!0,article:!0,aside:!0,blockquote:!0,dir:!0,div:!0,dl:!0,fieldset:!0,footer:!0,form:!0,h1:!0,h2:!0,h3:!0,h4:!0,h5:!0,h6:!0,header:!0,hgroup:!0,hr:!0,menu:!0,nav:!0,ol:!0,p:!0,pre:!0,section:!0,table:!0,ul:!0},rp:{rp:!0,rt:!0},rt:{rp:!0,rt:!0},tbody:{tbody:!0,tfoot:!0},td:{td:!0,th:!0},tfoot:{tbody:!0},th:{td:!0,th:!0},thead:{tbody:!0,tfoot:!0},tr:{tr:!0}},doNotIndent:{pre:!0},allowUnquoted:!0,allowMissing:!0,caseFold:!0},n={autoSelfClosers:{},implicitlyClosed:{},contextGrabbers:{},doNotIndent:{},allowUnquoted:!1,allowMissing:!1,allowMissingTagName:!1,caseFold:!1};t.defineMode("xml",(function(r,i){var o,a,s=r.indentUnit,l={},c=i.htmlMode?e:n;for(var u in c)l[u]=c[u];for(var u in i)l[u]=i[u];function h(t,e){function n(n){return e.tokenize=n,n(t,e)}var r=t.next();return"<"==r?t.eat("!")?t.eat("[")?t.match("CDATA[")?n(f("atom","]]>")):null:t.match("--")?n(f("comment","--\x3e")):t.match("DOCTYPE",!0,!0)?(t.eatWhile(/[\w\._\-]/),n(function t(e){return function(n,r){for(var i;null!=(i=n.next());){if("<"==i)return r.tokenize=t(e+1),r.tokenize(n,r);if(">"==i){if(1==e){r.tokenize=h;break}return r.tokenize=t(e-1),r.tokenize(n,r)}}return"meta"}}(1))):null:t.eat("?")?(t.eatWhile(/[\w\._\-]/),e.tokenize=f("meta","?>"),"meta"):(o=t.eat("/")?"closeTag":"openTag",e.tokenize=d,"tag bracket"):"&"==r?(t.eat("#")?t.eat("x")?t.eatWhile(/[a-fA-F\d]/)&&t.eat(";"):t.eatWhile(/[\d]/)&&t.eat(";"):t.eatWhile(/[\w\.\-:]/)&&t.eat(";"))?"atom":"error":(t.eatWhile(/[^&<]/),null)}function d(t,e){var n,r,i=t.next();if(">"==i||"/"==i&&t.eat(">"))return e.tokenize=h,o=">"==i?"endTag":"selfcloseTag","tag bracket";if("="==i)return o="equals",null;if("<"==i){e.tokenize=h,e.state=m,e.tagName=e.tagStart=null;var a=e.tokenize(t,e);return a?a+" tag error":"tag error"}return/[\'\"]/.test(i)?(e.tokenize=(n=i,(r=function(t,e){for(;!t.eol();)if(t.next()==n){e.tokenize=d;break}return"string"}).isInAttribute=!0,r),e.stringStartCol=t.column(),e.tokenize(t,e)):(t.match(/^[^\s\u00a0=<>\"\']*[^\s\u00a0=<>\"\'\/]/),"word")}function f(t,e){return function(n,r){for(;!n.eol();){if(n.match(e)){r.tokenize=h;break}n.next()}return t}}function p(t,e,n){this.prev=t.context,this.tagName=e,this.indent=t.indented,this.startOfLine=n,(l.doNotIndent.hasOwnProperty(e)||t.context&&t.context.noIndent)&&(this.noIndent=!0)}function g(t){t.context&&(t.context=t.context.prev)}function v(t,e){for(var n;;){if(!t.context)return;if(n=t.context.tagName,!l.contextGrabbers.hasOwnProperty(n)||!l.contextGrabbers[n].hasOwnProperty(e))return;g(t)}}function m(t,e,n){return"openTag"==t?(n.tagStart=e.column(),y):"closeTag"==t?b:m}function y(t,e,n){return"word"==t?(n.tagName=e.current(),a="tag",C):l.allowMissingTagName&&"endTag"==t?(a="tag bracket",C(t,0,n)):(a="error",y)}function b(t,e,n){if("word"==t){var r=e.current();return n.context&&n.context.tagName!=r&&l.implicitlyClosed.hasOwnProperty(n.context.tagName)&&g(n),n.context&&n.context.tagName==r||!1===l.matchClosing?(a="tag",w):(a="tag error",x)}return l.allowMissingTagName&&"endTag"==t?(a="tag bracket",w(t,0,n)):(a="error",x)}function w(t,e,n){return"endTag"!=t?(a="error",w):(g(n),m)}function x(t,e,n){return a="error",w(t,0,n)}function C(t,e,n){if("word"==t)return a="attribute",O;if("endTag"==t||"selfcloseTag"==t){var r=n.tagName,i=n.tagStart;return n.tagName=n.tagStart=null,"selfcloseTag"==t||l.autoSelfClosers.hasOwnProperty(r)?v(n,r):(v(n,r),n.context=new p(n,r,i==n.indented)),m}return a="error",C}function O(t,e,n){return"equals"==t?S:(l.allowMissing||(a="error"),C(t,0,n))}function S(t,e,n){return"string"==t?k:"word"==t&&l.allowUnquoted?(a="string",C):(a="error",C(t,0,n))}function k(t,e,n){return"string"==t?k:C(t,0,n)}return h.isInText=!0,{startState:function(t){var e={tokenize:h,state:m,indented:t||0,tagName:null,tagStart:null,context:null};return null!=t&&(e.baseIndent=t),e},token:function(t,e){if(!e.tagName&&t.sol()&&(e.indented=t.indentation()),t.eatSpace())return null;o=null;var n=e.tokenize(t,e);return(n||o)&&"comment"!=n&&(a=null,e.state=e.state(o||n,t,e),a&&(n="error"==a?n+" error":a)),n},indent:function(e,n,r){var i=e.context;if(e.tokenize.isInAttribute)return e.tagStart==e.indented?e.stringStartCol+1:e.indented+s;if(i&&i.noIndent)return t.Pass;if(e.tokenize!=d&&e.tokenize!=h)return r?r.match(/^(\s*)/)[0].length:0;if(e.tagName)return!1!==l.multilineTagIndentPastTag?e.tagStart+e.tagName.length+2:e.tagStart+s*(l.multilineTagIndentFactor||1);if(l.alignCDATA&&/$/,blockCommentStart:"\x3c!--",blockCommentEnd:"--\x3e",configuration:l.htmlMode?"html":"xml",helperType:l.htmlMode?"html":"xml",skipAttribute:function(t){t.state==S&&(t.state=C)}}})),t.defineMIME("text/xml","xml"),t.defineMIME("application/xml","xml"),t.mimeModes.hasOwnProperty("text/html")||t.defineMIME("text/html",{name:"xml",htmlMode:!0})}(n(10))},function(t,e,n){!function(t){"use strict";t.defineMode("javascript",(function(e,n){var r,i,o=e.indentUnit,a=n.statementIndent,s=n.jsonld,l=n.json||s,c=n.typescript,u=n.wordCharacters||/[\w$\xa1-\uffff]/,h=function(){function t(t){return{type:t,style:"keyword"}}var e=t("keyword a"),n=t("keyword b"),r=t("keyword c"),i=t("keyword d"),o=t("operator"),a={type:"atom",style:"atom"};return{if:t("if"),while:e,with:e,else:n,do:n,try:n,finally:n,return:i,break:i,continue:i,new:t("new"),delete:r,void:r,throw:r,debugger:t("debugger"),var:t("var"),const:t("var"),let:t("var"),function:t("function"),catch:t("catch"),for:t("for"),switch:t("switch"),case:t("case"),default:t("default"),in:o,typeof:o,instanceof:o,true:a,false:a,null:a,undefined:a,NaN:a,Infinity:a,this:t("this"),class:t("class"),super:t("atom"),yield:r,export:t("export"),import:t("import"),extends:r,await:r}}(),d=/[+\-*&%=<>!?|~^@]/,f=/^@(context|id|value|language|type|container|list|set|reverse|index|base|vocab|graph)"/;function p(t,e,n){return r=t,i=n,e}function g(t,e){var n,r=t.next();if('"'==r||"'"==r)return e.tokenize=(n=r,function(t,e){var r,i=!1;if(s&&"@"==t.peek()&&t.match(f))return e.tokenize=g,p("jsonld-keyword","meta");for(;null!=(r=t.next())&&(r!=n||i);)i=!i&&"\\"==r;return i||(e.tokenize=g),p("string","string")}),e.tokenize(t,e);if("."==r&&t.match(/^\d[\d_]*(?:[eE][+\-]?[\d_]+)?/))return p("number","number");if("."==r&&t.match(".."))return p("spread","meta");if(/[\[\]{}\(\),;\:\.]/.test(r))return p(r);if("="==r&&t.eat(">"))return p("=>","operator");if("0"==r&&t.match(/^(?:x[\dA-Fa-f_]+|o[0-7_]+|b[01_]+)n?/))return p("number","number");if(/\d/.test(r))return t.match(/^[\d_]*(?:n|(?:\.[\d_]*)?(?:[eE][+\-]?[\d_]+)?)?/),p("number","number");if("/"==r)return t.eat("*")?(e.tokenize=v,v(t,e)):t.eat("/")?(t.skipToEnd(),p("comment","comment")):Kt(t,e,1)?(function(t){for(var e,n=!1,r=!1;null!=(e=t.next());){if(!n){if("/"==e&&!r)return;"["==e?r=!0:r&&"]"==e&&(r=!1)}n=!n&&"\\"==e}}(t),t.match(/^\b(([gimyus])(?![gimyus]*\2))+\b/),p("regexp","string-2")):(t.eat("="),p("operator","operator",t.current()));if("`"==r)return e.tokenize=m,m(t,e);if("#"==r)return t.skipToEnd(),p("error","error");if(d.test(r))return">"==r&&e.lexical&&">"==e.lexical.type||(t.eat("=")?"!"!=r&&"="!=r||t.eat("="):/[<>*+\-]/.test(r)&&(t.eat(r),">"==r&&t.eat(r))),p("operator","operator",t.current());if(u.test(r)){t.eatWhile(u);var i=t.current();if("."!=e.lastType){if(h.propertyIsEnumerable(i)){var o=h[i];return p(o.type,o.style,i)}if("async"==i&&t.match(/^(\s|\/\*.*?\*\/)*[\[\(\w]/,!1))return p("async","keyword",i)}return p("variable","variable",i)}}function v(t,e){for(var n,r=!1;n=t.next();){if("/"==n&&r){e.tokenize=g;break}r="*"==n}return p("comment","comment")}function m(t,e){for(var n,r=!1;null!=(n=t.next());){if(!r&&("`"==n||"$"==n&&t.eat("{"))){e.tokenize=g;break}r=!r&&"\\"==n}return p("quasi","string-2",t.current())}var y="([{}])";function b(t,e){e.fatArrowAt&&(e.fatArrowAt=null);var n=t.string.indexOf("=>",t.start);if(!(n<0)){if(c){var r=/:\s*(?:\w+(?:<[^>]*>|\[\])?|\{[^}]*\})\s*$/.exec(t.string.slice(t.start,n));r&&(n=r.index)}for(var i=0,o=!1,a=n-1;a>=0;--a){var s=t.string.charAt(a),l=y.indexOf(s);if(l>=0&&l<3){if(!i){++a;break}if(0==--i){"("==s&&(o=!0);break}}else if(l>=3&&l<6)++i;else if(u.test(s))o=!0;else if(/["'\/`]/.test(s))for(;;--a){if(0==a)return;if(t.string.charAt(a-1)==s&&"\\"!=t.string.charAt(a-2)){a--;break}}else if(o&&!i){++a;break}}o&&!i&&(e.fatArrowAt=a)}}var w={atom:!0,number:!0,variable:!0,string:!0,regexp:!0,this:!0,"jsonld-keyword":!0};function x(t,e,n,r,i,o){this.indented=t,this.column=e,this.type=n,this.prev=i,this.info=o,null!=r&&(this.align=r)}function C(t,e){for(var n=t.localVars;n;n=n.next)if(n.name==e)return!0;for(var r=t.context;r;r=r.prev)for(n=r.vars;n;n=n.next)if(n.name==e)return!0}var O={state:null,column:null,marked:null,cc:null};function S(){for(var t=arguments.length-1;t>=0;t--)O.cc.push(arguments[t])}function k(){return S.apply(null,arguments),!0}function T(t,e){for(var n=e;n;n=n.next)if(n.name==t)return!0;return!1}function P(t){var e=O.state;if(O.marked="def",e.context)if("var"==e.lexical.info&&e.context&&e.context.block){var r=function t(e,n){if(n){if(n.block){var r=t(e,n.prev);return r?r==n.prev?n:new E(r,n.vars,!0):null}return T(e,n.vars)?n:new E(n.prev,new M(e,n.vars),!1)}return null}(t,e.context);if(null!=r)return void(e.context=r)}else if(!T(t,e.localVars))return void(e.localVars=new M(t,e.localVars));n.globalVars&&!T(t,e.globalVars)&&(e.globalVars=new M(t,e.globalVars))}function j(t){return"public"==t||"private"==t||"protected"==t||"abstract"==t||"readonly"==t}function E(t,e,n){this.prev=t,this.vars=e,this.block=n}function M(t,e){this.name=t,this.next=e}var D=new M("this",new M("arguments",null));function A(){O.state.context=new E(O.state.context,O.state.localVars,!1),O.state.localVars=D}function L(){O.state.context=new E(O.state.context,O.state.localVars,!0),O.state.localVars=null}function N(){O.state.localVars=O.state.context.vars,O.state.context=O.state.context.prev}function I(t,e){var n=function(){var n=O.state,r=n.indented;if("stat"==n.lexical.type)r=n.lexical.indented;else for(var i=n.lexical;i&&")"==i.type&&i.align;i=i.prev)r=i.indented;n.lexical=new x(r,O.stream.column(),t,null,n.lexical,e)};return n.lex=!0,n}function F(){var t=O.state;t.lexical.prev&&(")"==t.lexical.type&&(t.indented=t.lexical.indented),t.lexical=t.lexical.prev)}function R(t){return function e(n){return n==t?k():";"==t||"}"==n||")"==n||"]"==n?S():k(e)}}function _(t,e){return"var"==t?k(I("vardef",e),bt,R(";"),F):"keyword a"==t?k(I("form"),$,_,F):"keyword b"==t?k(I("form"),_,F):"keyword d"==t?O.stream.match(/^\s*$/,!1)?k():k(I("stat"),B,R(";"),F):"debugger"==t?k(R(";")):"{"==t?k(I("}"),L,at,F,N):";"==t?k():"if"==t?("else"==O.state.lexical.info&&O.state.cc[O.state.cc.length-1]==F&&O.state.cc.pop()(),k(I("form"),$,_,F,kt)):"function"==t?k(Et):"for"==t?k(I("form"),Tt,_,F):"class"==t||c&&"interface"==e?(O.marked="keyword",k(I("form","class"==t?t:e),Nt,F)):"variable"==t?c&&"declare"==e?(O.marked="keyword",k(_)):c&&("module"==e||"enum"==e||"type"==e)&&O.stream.match(/^\s*\w/,!1)?(O.marked="keyword","enum"==e?k(qt):"type"==e?k(Dt,R("operator"),ht,R(";")):k(I("form"),wt,R("{"),I("}"),at,F,F)):c&&"namespace"==e?(O.marked="keyword",k(I("form"),z,_,F)):c&&"abstract"==e?(O.marked="keyword",k(_)):k(I("stat"),Q):"switch"==t?k(I("form"),$,R("{"),I("}","switch"),L,at,F,F,N):"case"==t?k(z,R(":")):"default"==t?k(R(":")):"catch"==t?k(I("form"),A,V,_,F,N):"export"==t?k(I("stat"),_t,F):"import"==t?k(I("stat"),zt,F):"async"==t?k(_):"@"==e?k(z,_):S(I("stat"),z,R(";"),F)}function V(t){if("("==t)return k(At,R(")"))}function z(t,e){return W(t,e,!1)}function H(t,e){return W(t,e,!0)}function $(t){return"("!=t?S():k(I(")"),z,R(")"),F)}function W(t,e,n){if(O.state.fatArrowAt==O.stream.start){var r=n?X:Y;if("("==t)return k(A,I(")"),it(At,")"),F,R("=>"),r,N);if("variable"==t)return S(A,wt,R("=>"),r,N)}var i=n?q:U;return w.hasOwnProperty(t)?k(i):"function"==t?k(Et,i):"class"==t||c&&"interface"==e?(O.marked="keyword",k(I("form"),Lt,F)):"keyword c"==t||"async"==t?k(n?H:z):"("==t?k(I(")"),B,R(")"),F,i):"operator"==t||"spread"==t?k(n?H:z):"["==t?k(I("]"),Ut,F,i):"{"==t?ot(et,"}",null,i):"quasi"==t?S(G,i):"new"==t?k(function(t){return function(e){return"."==e?k(t?Z:J):"variable"==e&&c?k(vt,t?q:U):S(t?H:z)}}(n)):"import"==t?k(z):k()}function B(t){return t.match(/[;\}\)\],]/)?S():S(z)}function U(t,e){return","==t?k(z):q(t,e,!1)}function q(t,e,n){var r=0==n?U:q,i=0==n?z:H;return"=>"==t?k(A,n?X:Y,N):"operator"==t?/\+\+|--/.test(e)||c&&"!"==e?k(r):c&&"<"==e&&O.stream.match(/^([^>]|<.*?>)*>\s*\(/,!1)?k(I(">"),it(ht,">"),F,r):"?"==e?k(z,R(":"),i):k(i):"quasi"==t?S(G,r):";"!=t?"("==t?ot(H,")","call",r):"."==t?k(tt,r):"["==t?k(I("]"),B,R("]"),F,r):c&&"as"==e?(O.marked="keyword",k(ht,r)):"regexp"==t?(O.state.lastType=O.marked="operator",O.stream.backUp(O.stream.pos-O.stream.start-1),k(i)):void 0:void 0}function G(t,e){return"quasi"!=t?S():"${"!=e.slice(e.length-2)?k(G):k(z,K)}function K(t){if("}"==t)return O.marked="string-2",O.state.tokenize=m,k(G)}function Y(t){return b(O.stream,O.state),S("{"==t?_:z)}function X(t){return b(O.stream,O.state),S("{"==t?_:H)}function J(t,e){if("target"==e)return O.marked="keyword",k(U)}function Z(t,e){if("target"==e)return O.marked="keyword",k(q)}function Q(t){return":"==t?k(F,_):S(U,R(";"),F)}function tt(t){if("variable"==t)return O.marked="property",k()}function et(t,e){return"async"==t?(O.marked="property",k(et)):"variable"==t||"keyword"==O.style?(O.marked="property","get"==e||"set"==e?k(nt):(c&&O.state.fatArrowAt==O.stream.start&&(n=O.stream.match(/^\s*:\s*/,!1))&&(O.state.fatArrowAt=O.stream.pos+n[0].length),k(rt))):"number"==t||"string"==t?(O.marked=s?"property":O.style+" property",k(rt)):"jsonld-keyword"==t?k(rt):c&&j(e)?(O.marked="keyword",k(et)):"["==t?k(z,st,R("]"),rt):"spread"==t?k(H,rt):"*"==e?(O.marked="keyword",k(et)):":"==t?S(rt):void 0;var n}function nt(t){return"variable"!=t?S(rt):(O.marked="property",k(Et))}function rt(t){return":"==t?k(H):"("==t?S(Et):void 0}function it(t,e,n){function r(i,o){if(n?n.indexOf(i)>-1:","==i){var a=O.state.lexical;return"call"==a.info&&(a.pos=(a.pos||0)+1),k((function(n,r){return n==e||r==e?S():S(t)}),r)}return i==e||o==e?k():n&&n.indexOf(";")>-1?S(t):k(R(e))}return function(n,i){return n==e||i==e?k():S(t,r)}}function ot(t,e,n){for(var r=3;r"),ht):void 0}function dt(t){if("=>"==t)return k(ht)}function ft(t,e){return"variable"==t||"keyword"==O.style?(O.marked="property",k(ft)):"?"==e||"number"==t||"string"==t?k(ft):":"==t?k(ht):"["==t?k(R("variable"),lt,R("]"),ft):"("==t?S(Mt,ft):void 0}function pt(t,e){return"variable"==t&&O.stream.match(/^\s*[?:]/,!1)||"?"==e?k(pt):":"==t?k(ht):"spread"==t?k(pt):S(ht)}function gt(t,e){return"<"==e?k(I(">"),it(ht,">"),F,gt):"|"==e||"."==t||"&"==e?k(ht):"["==t?k(ht,R("]"),gt):"extends"==e||"implements"==e?(O.marked="keyword",k(ht)):"?"==e?k(ht,R(":"),ht):void 0}function vt(t,e){if("<"==e)return k(I(">"),it(ht,">"),F,gt)}function mt(){return S(ht,yt)}function yt(t,e){if("="==e)return k(ht)}function bt(t,e){return"enum"==e?(O.marked="keyword",k(qt)):S(wt,st,Ot,St)}function wt(t,e){return c&&j(e)?(O.marked="keyword",k(wt)):"variable"==t?(P(e),k()):"spread"==t?k(wt):"["==t?ot(Ct,"]"):"{"==t?ot(xt,"}"):void 0}function xt(t,e){return"variable"!=t||O.stream.match(/^\s*:/,!1)?("variable"==t&&(O.marked="property"),"spread"==t?k(wt):"}"==t?S():"["==t?k(z,R("]"),R(":"),xt):k(R(":"),wt,Ot)):(P(e),k(Ot))}function Ct(){return S(wt,Ot)}function Ot(t,e){if("="==e)return k(H)}function St(t){if(","==t)return k(bt)}function kt(t,e){if("keyword b"==t&&"else"==e)return k(I("form","else"),_,F)}function Tt(t,e){return"await"==e?k(Tt):"("==t?k(I(")"),Pt,F):void 0}function Pt(t){return"var"==t?k(bt,jt):"variable"==t?k(jt):S(jt)}function jt(t,e){return")"==t?k():";"==t?k(jt):"in"==e||"of"==e?(O.marked="keyword",k(z,jt)):S(z,jt)}function Et(t,e){return"*"==e?(O.marked="keyword",k(Et)):"variable"==t?(P(e),k(Et)):"("==t?k(A,I(")"),it(At,")"),F,ct,_,N):c&&"<"==e?k(I(">"),it(mt,">"),F,Et):void 0}function Mt(t,e){return"*"==e?(O.marked="keyword",k(Mt)):"variable"==t?(P(e),k(Mt)):"("==t?k(A,I(")"),it(At,")"),F,ct,N):c&&"<"==e?k(I(">"),it(mt,">"),F,Mt):void 0}function Dt(t,e){return"keyword"==t||"variable"==t?(O.marked="type",k(Dt)):"<"==e?k(I(">"),it(mt,">"),F):void 0}function At(t,e){return"@"==e&&k(z,At),"spread"==t?k(At):c&&j(e)?(O.marked="keyword",k(At)):c&&"this"==t?k(st,Ot):S(wt,st,Ot)}function Lt(t,e){return"variable"==t?Nt(t,e):It(t,e)}function Nt(t,e){if("variable"==t)return P(e),k(It)}function It(t,e){return"<"==e?k(I(">"),it(mt,">"),F,It):"extends"==e||"implements"==e||c&&","==t?("implements"==e&&(O.marked="keyword"),k(c?ht:z,It)):"{"==t?k(I("}"),Ft,F):void 0}function Ft(t,e){return"async"==t||"variable"==t&&("static"==e||"get"==e||"set"==e||c&&j(e))&&O.stream.match(/^\s+[\w$\xa1-\uffff]/,!1)?(O.marked="keyword",k(Ft)):"variable"==t||"keyword"==O.style?(O.marked="property",k(c?Rt:Et,Ft)):"number"==t||"string"==t?k(c?Rt:Et,Ft):"["==t?k(z,st,R("]"),c?Rt:Et,Ft):"*"==e?(O.marked="keyword",k(Ft)):c&&"("==t?S(Mt,Ft):";"==t||","==t?k(Ft):"}"==t?k():"@"==e?k(z,Ft):void 0}function Rt(t,e){if("?"==e)return k(Rt);if(":"==t)return k(ht,Ot);if("="==e)return k(H);var n=O.state.lexical.prev;return S(n&&"interface"==n.info?Mt:Et)}function _t(t,e){return"*"==e?(O.marked="keyword",k(Bt,R(";"))):"default"==e?(O.marked="keyword",k(z,R(";"))):"{"==t?k(it(Vt,"}"),Bt,R(";")):S(_)}function Vt(t,e){return"as"==e?(O.marked="keyword",k(R("variable"))):"variable"==t?S(H,Vt):void 0}function zt(t){return"string"==t?k():"("==t?S(z):S(Ht,$t,Bt)}function Ht(t,e){return"{"==t?ot(Ht,"}"):("variable"==t&&P(e),"*"==e&&(O.marked="keyword"),k(Wt))}function $t(t){if(","==t)return k(Ht,$t)}function Wt(t,e){if("as"==e)return O.marked="keyword",k(Ht)}function Bt(t,e){if("from"==e)return O.marked="keyword",k(z)}function Ut(t){return"]"==t?k():S(it(H,"]"))}function qt(){return S(I("form"),wt,R("{"),I("}"),it(Gt,"}"),F,F)}function Gt(){return S(wt,Ot)}function Kt(t,e,n){return e.tokenize==g&&/^(?:operator|sof|keyword [bcd]|case|new|export|default|spread|[\[{}\(,;:]|=>)$/.test(e.lastType)||"quasi"==e.lastType&&/\{\s*$/.test(t.string.slice(0,t.pos-(n||0)))}return N.lex=!0,F.lex=!0,{startState:function(t){var e={tokenize:g,lastType:"sof",cc:[],lexical:new x((t||0)-o,0,"block",!1),localVars:n.localVars,context:n.localVars&&new E(null,null,!1),indented:t||0};return n.globalVars&&"object"==typeof n.globalVars&&(e.globalVars=n.globalVars),e},token:function(t,e){if(t.sol()&&(e.lexical.hasOwnProperty("align")||(e.lexical.align=!1),e.indented=t.indentation(),b(t,e)),e.tokenize!=v&&t.eatSpace())return null;var n=e.tokenize(t,e);return"comment"==r?n:(e.lastType="operator"!=r||"++"!=i&&"--"!=i?r:"incdec",function(t,e,n,r,i){var o=t.cc;for(O.state=t,O.stream=i,O.marked=null,O.cc=o,O.style=e,t.lexical.hasOwnProperty("align")||(t.lexical.align=!0);;)if((o.length?o.pop():l?z:_)(n,r)){for(;o.length&&o[o.length-1].lex;)o.pop()();return O.marked?O.marked:"variable"==n&&C(t,r)?"variable-2":e}}(e,n,r,i,t))},indent:function(e,r){if(e.tokenize==v)return t.Pass;if(e.tokenize!=g)return 0;var i,s=r&&r.charAt(0),l=e.lexical;if(!/^\s*else\b/.test(r))for(var c=e.cc.length-1;c>=0;--c){var u=e.cc[c];if(u==F)l=l.prev;else if(u!=kt)break}for(;("stat"==l.type||"form"==l.type)&&("}"==s||(i=e.cc[e.cc.length-1])&&(i==U||i==q)&&!/^[,\.=+\-*:?[\(]/.test(r));)l=l.prev;a&&")"==l.type&&"stat"==l.prev.type&&(l=l.prev);var h=l.type,f=s==h;return"vardef"==h?l.indented+("operator"==e.lastType||","==e.lastType?l.info.length+1:0):"form"==h&&"{"==s?l.indented:"form"==h?l.indented+o:"stat"==h?l.indented+(function(t,e){return"operator"==t.lastType||","==t.lastType||d.test(e.charAt(0))||/[,.]/.test(e.charAt(0))}(e,r)?a||o:0):"switch"!=l.info||f||0==n.doubleIndentSwitch?l.align?l.column+(f?0:1):l.indented+(f?0:o):l.indented+(/^(?:case|default)\b/.test(r)?o:2*o)},electricInput:/^\s*(?:case .*?:|default:|\{|\})$/,blockCommentStart:l?null:"/*",blockCommentEnd:l?null:"*/",blockCommentContinue:l?null:" * ",lineComment:l?null:"//",fold:"brace",closeBrackets:"()[]{}''\"\"``",helperType:l?"json":"javascript",jsonldMode:s,jsonMode:l,expressionAllowed:Kt,skipExpression:function(t){var e=t.cc[t.cc.length-1];e!=z&&e!=H||t.cc.pop()}}})),t.registerHelper("wordChars","javascript",/[\w$]/),t.defineMIME("text/javascript","javascript"),t.defineMIME("text/ecmascript","javascript"),t.defineMIME("application/javascript","javascript"),t.defineMIME("application/x-javascript","javascript"),t.defineMIME("application/ecmascript","javascript"),t.defineMIME("application/json",{name:"javascript",json:!0}),t.defineMIME("application/x-json",{name:"javascript",json:!0}),t.defineMIME("application/ld+json",{name:"javascript",jsonld:!0}),t.defineMIME("text/typescript",{name:"javascript",typescript:!0}),t.defineMIME("application/typescript",{name:"javascript",typescript:!0})}(n(10))},function(t,e,n){!function(t){t.extendMode("css",{commentStart:"/*",commentEnd:"*/",newlineAfterToken:function(t,e){return/^[;{}]$/.test(e)}}),t.extendMode("javascript",{commentStart:"/*",commentEnd:"*/",newlineAfterToken:function(t,e,n,r){return this.jsonMode?/^[\[,{]$/.test(e)||/^}/.test(n):(";"!=e||!r.lexical||")"!=r.lexical.type)&&/^[;{}]$/.test(e)&&!/^;/.test(n)}});var e=/^(a|abbr|acronym|area|base|bdo|big|br|button|caption|cite|code|col|colgroup|dd|del|dfn|em|frame|hr|iframe|img|input|ins|kbd|label|legend|link|map|object|optgroup|option|param|q|samp|script|select|small|span|strong|sub|sup|textarea|tt|var)$/;t.extendMode("xml",{commentStart:"\x3c!--",commentEnd:"--\x3e",newlineAfterToken:function(t,n,r,i){var o=!1;return"html"==this.configuration&&(o=!!i.context&&e.test(i.context.tagName)),!o&&("tag"==t&&/>$/.test(n)&&i.context||/^-1&&s>-1&&s>a&&(t=t.substr(0,a)+t.substring(a+o.commentStart.length,s)+t.substr(s+o.commentEnd.length)),i.replaceRange(t,n,r)}}))})),t.defineExtension("autoIndentRange",(function(t,e){var n=this;this.operation((function(){for(var r=t.line;r<=e.line;r++)n.indentLine(r,"smart")}))})),t.defineExtension("autoFormatRange",(function(e,n){var r=this,i=r.getMode(),o=r.getRange(e,n).split("\n"),a=t.copyState(i,r.getTokenAt(e).state),s=r.getOption("tabSize"),l="",c=0,u=0===e.ch;function h(){l+="\n",u=!0,++c}for(var d=0;d0&&void 0!==arguments[0]?arguments[0]:{};this.opt=t;var e=t.config||{};this.level=t.level,this.config=e,this.preview=t.preview,this.ppfx=e.pStylePrefix||"",this.pfx=e.stylePrefix||"",this.parent=t.parent;var n=this.pfx,r=this.ppfx,i=this.parent,o=this.collection;this.listenTo(o,"add",this.addTo),this.listenTo(o,"reset resetNavigator",this.render),this.listenTo(o,"remove",this.removeChildren),this.className="".concat(n,"layers");var a=e.em;if(e.sortable&&!this.opt.sorter){var s=a.get("Utils");this.opt.sorter=new s.Sorter({container:e.sortContainer||this.el,containerSel:".".concat(this.className),itemSel:".".concat(n,"layer"),ignoreViewChildren:1,onEndMove:function(t,e){var n=e.getSourceModel();a.setSelected(n,{forceChange:1})},avoidSelectOnEnd:1,nested:1,ppfx:r,pfx:n})}this.sorter=this.opt.sorter||"",this.$el.data("collection",o),i&&this.$el.data("model",i)},removeChildren:function(t){var e=t.viewLayer;e&&e.remove.apply(e)},addTo:function(t){var e=this.collection.indexOf(t);this.addToCollection(t,null,e)},addToCollection:function(t,e,n){var r=this.level,i=e||null,a=new(0,o.a)({level:r,model:t,config:this.config,sorter:this.sorter,isCountable:this.isCountable,opened:this.opt.opened}).render().el;if(i)i.appendChild(a);else if(void 0!==n){var s="before";this.$el.children().length==n&&(n--,s="after"),n<0?this.$el.append(a):this.$el.children().eq(n)[s](a)}else this.$el.append(a);return a},isCountable:function(t,e){var n=t.get("type"),r=t.get("tagName");return!(("textnode"==n||"br"==r)&&e||!t.get("layerable"))},render:function(){var t=this,e=document.createDocumentFragment(),n=this.el;return n.innerHTML="",this.collection.each((function(n){return t.addToCollection(n,e)})),n.appendChild(e),n.className=this.className,this}})},function(t,e,n){var r={"./CanvasClear":37,"./CanvasClear.js":37,"./CanvasMove":38,"./CanvasMove.js":38,"./CommandAbstract":19,"./CommandAbstract.js":19,"./ComponentDelete":39,"./ComponentDelete.js":39,"./ComponentDrag":40,"./ComponentDrag.js":40,"./ComponentEnter":41,"./ComponentEnter.js":41,"./ComponentExit":42,"./ComponentExit.js":42,"./ComponentNext":43,"./ComponentNext.js":43,"./ComponentPrev":44,"./ComponentPrev.js":44,"./ComponentStyleClear":45,"./ComponentStyleClear.js":45,"./CopyComponent":46,"./CopyComponent.js":46,"./DeleteComponent":47,"./DeleteComponent.js":47,"./ExportTemplate":48,"./ExportTemplate.js":48,"./Fullscreen":49,"./Fullscreen.js":49,"./MoveComponent":50,"./MoveComponent.js":50,"./OpenAssets":51,"./OpenAssets.js":51,"./OpenBlocks":52,"./OpenBlocks.js":52,"./OpenLayers":53,"./OpenLayers.js":53,"./OpenStyleManager":54,"./OpenStyleManager.js":54,"./OpenTraitManager":55,"./OpenTraitManager.js":55,"./PasteComponent":56,"./PasteComponent.js":56,"./Preview":57,"./Preview.js":57,"./Resize":58,"./Resize.js":58,"./SelectComponent":12,"./SelectComponent.js":12,"./SelectPosition":24,"./SelectPosition.js":24,"./ShowOffset":59,"./ShowOffset.js":59,"./SwitchVisibility":60,"./SwitchVisibility.js":60};function i(t){var e=o(t);return n(e)}function o(t){if(!n.o(r,t)){var e=new Error("Cannot find module '"+t+"'");throw e.code="MODULE_NOT_FOUND",e}return r[t]}i.keys=function(){return Object.keys(r)},i.resolve=o,t.exports=i,i.id=83},function(t,e,n){"use strict";n.r(e);var r=n(6),i=n.n(r),o=n(2),a=n.n(o),s=n(1),l=n.n(s),c=n(0),u={stylePrefix:"comp-",wrapperId:"wrapper",wrapperName:"Body",wrapper:{removable:!1,copyable:!1,draggable:!1,components:[],traits:[],stylable:["background","background-color","background-image","background-repeat","background-attachment","background-position","background-size"]},components:[],draggableComponents:1,storeWrapper:0,processor:0,voidElements:["area","base","br","col","embed","hr","img","input","keygen","link","menuitem","meta","param","source","track","wbr"]},h=n(4),d=n(18),f=n(5),p=n(30);function g(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}var v=h.default.extend({defaults:function(t){for(var e=1;e\n \n '),fallback:"\n \n '),file:""}),initialize:function(t,e){h.default.prototype.initialize.apply(this,arguments);var n=this.get("attributes");n.src&&this.set("src",n.src)},initToolbar:function(){for(var t=arguments.length,e=new Array(t),n=0;n0&&void 0!==arguments[0]?arguments[0]:{},e=this.get(t.fallback?"fallback":"src")||"",n=e;return e&&"2&&void 0!==arguments[2]?arguments[2]:{};!n.fromDisable&&this.disableEditing()},onActive:function(t){if(!this.rteEnabled&&this.model.get("editable")){t&&t.stopPropagation&&t.stopPropagation();var e=this.rte;if(e)try{this.activeRte=e.enable(this,this.activeRte)}catch(t){console.error(t)}this.rteEnabled=1,this.toggleEvents(1)}},disableEditing:function(){var t=this.model,e=this.rte,n=this.activeRte,r=t.get("editable");if(e&&r){try{e.disable(this,n)}catch(t){console.error(t)}this.syncContent()}this.rteEnabled=0,this.toggleEvents()},syncContent:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=this.model,n=this.rte,r=this.rteEnabled;if(r||t.force){var i=this.getChildrenContainer().innerHTML,o=e.components(),a=q({fromDisable:1},t);if(o.length&&o.reset(null,t),e.set("content","",a),n.customRte)e.set("content",i,a);else{var s=function e(n){var r=!!n.get("textable"),i=!["text","default",""].some((function(t){return n.is(t)}))||r;n.set(q({editable:i&&n.get("editable"),selectable:i,hoverable:i,removable:r,draggable:r,highlightable:0,copyable:r},!r&&{toolbar:""}),t),n.get("components").each((function(t){return e(t)}))};!t.silent&&e.trigger("change:content",e,"",a),o.add(i,t),o.each((function(t){return s(t)})),o.trigger("resetNavigator")}}},onInput:function(){var t=this.em;t&&t.trigger("change:canvasOffset")},disablePropagation:function(t){t.stopPropagation()},toggleEvents:function(t){var e=t?"on":"off",n={on:B.p,off:B.o};this.em.setEditing(t);var r=[this.el.ownerDocument,document];if(n.off(r,"mousedown",this.disableEditing),n[e](r,"mousedown",this.disableEditing),this.$el.off("mousedown",this.disablePropagation),this.$el[e]("mousedown",this.disablePropagation),this.config.draggableComponents)for(var i=this.el;i;)i.draggable=!t,"BODY"==(i=i.parentNode).tagName&&(i=0)}}),Y=K.extend({render:function(){for(var t=arguments.length,e=new Array(t),n=0;n2&&void 0!==arguments[2]?arguments[2]:{},o=e.components(),a=t.get("UndoManager"),s=t.handleUpdates.bind(t),l=this.handleChanges.bind(this),c=this.handleChangesColl.bind(this),u=this.handleRemoves.bind(this);a&&a.add(e),a&&o&&a.add(o);var h="change:style change:content change:attributes change:src";[[e,h,s],[e,"change:components",c],[o,"add",l],[o,"remove",u],[e.get("classes"),"add remove",s]].forEach((function(e){t.stopListening(e[0],e[1],e[2]),t.listenTo(e[0],e[1],e[2])})),!i.avoidStore&&s("","",i),o.each((function(t){return r.handleChanges(t,n,i)}))},handleChangesColl:function(e,n){var r=t.get("UndoManager");if(r&&n instanceof l.a.Collection){var i=this.handleChanges.bind(this),o=this.handleRemoves.bind(this);r.add(n),[[n,"add",i],[n,"remove",o]].forEach((function(e){t.stopListening(e[0],e[1],e[2]),t.listenTo(e[0],e[1],e[2])}))}},handleRemoves:function(e,n){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};!r.avoidStore&&t.handleUpdates(e,n,r)},load:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"",e=this.em,n="";!t&&r.stm&&(t=r.em.getCacheLoad());var i=t,o=i.components,a=i.html;if(o)if(Object(c.isObject)(o)||Object(c.isArray)(o))n=o;else try{n=JSON.parse(o)}catch(t){e&&e.logError(t)}else a&&(n=a);var s=n&&n.constructor===Object;return(n&&n.length||s)&&(this.clear(),s?this.getWrapper().set(n):this.getComponents().add(n)),n},store:function(t){if(r.stm){var e={},n=this.storageKey();if(n.indexOf("html")>=0&&(e.html=r.em.getHtml()),n.indexOf("components")>=0){this.em;var i=r.storeWrapper?this.getWrapper():this.getComponents();e.components=JSON.stringify(i)}return t||r.stm.store(e),e}},getComponent:function(){return e},getWrapper:function(){return this.getComponent()},getComponents:function(){return this.getWrapper().get("components")},addComponent:function(t){return this.getComponents().add(t)},render:function(){return n.render().el},clear:function(){return this.getComponents().map((function(t){return t})).forEach((function(t){return t.remove()})),this},setComponents:function(t){this.clear().addComponent(t)},addType:function(t,e){var n=this.em,r=e.model,a=void 0===r?{}:r,s=e.view,l=void 0===s?{}:s,u=e.isComponent,h=e.extend,d=e.extendView,f=e.extendFn,p=void 0===f?[]:f,g=e.extendFnView,v=void 0===g?[]:g,m=this.getType(t),y=this.getType(h),b=this.getType(d),w=y||(m||this.getType("default")),x=w.model,C=b?b.view:w.view,O=function(t,e,n){return t.reduce((function(t,r){var i=e[r],o=n.prototype[r];return i&&o&&(t[r]=function(){o.bind(this).apply(void 0,arguments),i.bind(this).apply(void 0,arguments)}),t}),{})};"object"===i()(a)&&(e.model=x.extend(bt({},a,{},O(p,a,x),{defaults:bt({},x.prototype.defaults,{},Object(c.result)(a,"defaults")||{})}),{isComponent:!m||y||u?u||function(){return 0}:x.isComponent})),"object"===i()(l)&&(e.view=C.extend(bt({},l,{},O(v,l,C)))),m?(m.model=e.model,m.view=e.view):(e.id=t,o.unshift(e));var S="component:type:".concat(m?"update":"add");return n&&n.trigger(S,m||e),this},getType:function(t){for(var e=o,n=0;n1&&void 0!==arguments[1]?arguments[1]:{};t&&(t.set({status:"selected"}),["component:selected","component:toggled"].forEach((function(r){return e.em.trigger(r,t,n)})))},selectRemove:function(t){var e=this,n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};if(t){this.em;t.set({status:"",state:""}),["component:deselected","component:toggled"].forEach((function(r){return e.em.trigger(r,t,n)}))}},componentHovered:function(){var t=r.em,e=t.get("componentHovered"),n=t.previous("componentHovered");n&&"hovered"==n.get("status")&&n.set({status:"",state:""}),e&&Object(c.isEmpty)(e.get("status"))&&e.set("status","hovered")}}}},function(t,e,n){"use strict";n.r(e);var r=n(2),i=n.n(r),o=n(21),a=n.n(o),s={stylePrefix:"gjs-",components:"",style:"",fromElement:0,noticeOnUnload:!0,showOffsets:!1,showOffsetsSelected:!1,forceClass:!0,height:"900px",width:"100%",log:["warning","error"],baseCss:"\n * {\n box-sizing: border-box;\n }\n html, body, #wrapper {\n min-height: 100%;\n }\n body {\n margin: 0;\n height: 100%;\n background-color: #fff\n }\n #wrapper {\n overflow: auto;\n overflow-x: hidden;\n }\n\n * ::-webkit-scrollbar-track {\n background: rgba(0, 0, 0, 0.1)\n }\n\n * ::-webkit-scrollbar-thumb {\n background: rgba(255, 255, 255, 0.2)\n }\n\n * ::-webkit-scrollbar {\n width: 10px\n }\n ",protectedCss:"* { box-sizing: border-box; } body {margin: 0;}",canvasCss:"",defaultCommand:"select-comp",showToolbar:1,allowScripts:0,showDevices:1,devicePreviewMode:0,mediaCondition:"max-width",tagVarStart:"{[ ",tagVarEnd:" ]}",keepEmptyTextNodes:0,jsInHtml:!0,nativeDnD:1,multipleSelection:1,exportWrapper:0,wrapperIsBody:1,avoidInlineStyle:1,avoidDefaults:1,clearStyles:0,dragMode:0,el:"",undoManager:{},assetManager:{},canvas:{},layers:{},storageManager:{},richTextEditor:{},domComponents:{},modal:{},codeManager:{},panels:{},commands:{},cssComposer:{},selectorManager:{},deviceManager:{devices:[{name:"Desktop",width:""},{name:"Tablet",width:"768px",widthMedia:"992px"},{name:"Mobile landscape",width:"568px",widthMedia:"768px"},{name:"Mobile portrait",width:"320px",widthMedia:"480px"}]},styleManager:{sectors:[{name:"General",open:!1,buildProps:["float","display","position","top","right","left","bottom"]},{name:"Flex",open:!1,buildProps:["flex-direction","flex-wrap","justify-content","align-items","align-content","order","flex-basis","flex-grow","flex-shrink","align-self"]},{name:"Dimension",open:!1,buildProps:["width","height","max-width","min-height","margin","padding"]},{name:"Typography",open:!1,buildProps:["font-family","font-size","font-weight","letter-spacing","color","line-height","text-align","text-shadow"],properties:[{property:"text-align",list:[{value:"left",className:"fa fa-align-left"},{value:"center",className:"fa fa-align-center"},{value:"right",className:"fa fa-align-right"},{value:"justify",className:"fa fa-align-justify"}]}]},{name:"Decorations",open:!1,buildProps:["border-radius-c","background-color","border-radius","border","box-shadow","background"]},{name:"Extra",open:!1,buildProps:["transition","perspective","transform"]}]},blockManager:{},traitManager:{},textViewCode:"Code",keepUnusedStyles:0,multiFrames:0},l=n(0),c=n(1),u=n.n(c),h=n(3);function d(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function f(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{};this.config=e,this.set("Config",e),this.set("modules",[]),this.set("toLoad",[]),this.set("storables",[]),this.set("dmode",e.dragMode);var n=e.el,r=e.log,i=!0===r?Object(l.keys)(b):Object(l.isArray)(r)?r:[];n&&e.fromElement&&(this.config.components=n.innerHTML),this.attrsOrig=n?Object(l.toArray)(n.attributes).reduce((function(t,e){return t[e.nodeName]=e.nodeValue,t}),{}):"",v.forEach((function(e){return t.loadModule(e)})),this.on("change:componentHovered",this.componentHovered,this),this.on("change:changesCount",this.updateChanges,this),i.forEach((function(e){return t.listenLog(e)})),[{from:"change:selectedComponent",to:"component:toggled"}].forEach((function(e){var n=e.from,r=e.to;t.listenTo(t,n,(function(){for(var e=arguments.length,i=new Array(e),o=0;o0&&void 0!==arguments[0]?arguments[0]:null,n=this.get("StorageManager");this.get("toLoad").forEach((function(t){t.onLoad()}));var r=function(){t.get("modules").forEach((function(e){return e.postLoad&&e.postLoad(t)})),e&&e()};n&&n.canAutoload()?this.load(r):r()},updateChanges:function(){var t=this,e=this.get("StorageManager"),n=this.get("changesCount");g&&clearTimeout(g),g=setTimeout((function(){return t.trigger("update")})),this.config.noticeOnUnload&&(window.onbeforeunload=n?function(t){return 1}:null),e.isAutosave()&&n>=e.getStepsBeforeSave()&&this.store()},loadModule:function(t){var e=this.config,n=new(t.default||t),r=n.name.charAt(0).toLowerCase()+n.name.slice(1),i=Object(l.isUndefined)(e[r])?e[n.name]:e[r],o=i||{},a=this.get("StorageManager");if(o.pStylePrefix=e.pStylePrefix||"",Object(l.isUndefined)(i)||i||(o._disable=1),n.storageKey&&n.store&&n.load&&a){o.stm=a;var s=this.get("storables");s.push(n),this.set("storables",s)}return o.em=this,n.init(f({},o)),!n.private&&this.set(n.name,n),n.onLoad&&this.get("toLoad").push(n),this.get("modules").push(n),this},init:function(t){this.set("Editor",t)},getEditor:function(){return this.get("Editor")},handleUpdates:function(t,e){var n=this,r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};r.temporary||(p&&clearInterval(p),p=setTimeout((function(){r.avoidStore||n.set("changesCount",n.get("changesCount")+1,r)}),0))},componentHovered:function(t,e,n){var r=this.previous("componentHovered");r&&this.trigger("component:unhovered",r,n),e&&this.trigger("component:hovered",e,n)},getSelected:function(){return this.get("selected").last()},getSelectedAll:function(){return this.get("selected").models},setSelected:function(t){var e,n=this,r=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},i=r.scroll,o=Object(l.isArray)(t),a=o?t:[t],s=this.get("selected");o&&this.removeSelected(s.filter((function(t){return!Object(l.contains)(a,t)}))),a.forEach((function(t){var i=Object(h.f)(t,y);i&&!i.get("selectable")||(!o&&n.removeSelected(s.filter((function(t){return t!==i}))),n.addSelected(i,r),e=i)})),i&&e&&this.get("Canvas").scrollTo(e,i)},addSelected:function(t){var e=this,n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},r=Object(h.f)(t,y),i=Object(l.isArray)(r)?r:[r];i.forEach((function(t){if(!t||t.get("selectable")){var r=e.get("selected");n.forceChange&&r.remove(t,n),r.push(t,n)}}))},removeSelected:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};this.get("selected").remove(Object(h.f)(t,y),e)},toggleSelected:function(t){var e=this,n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},r=Object(h.f)(t,y),i=Object(l.isArray)(r)?r:[r];i.forEach((function(t){e.get("selected").contains(t)?e.removeSelected(t,n):e.addSelected(t,n)}))},setHovered:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=Object(h.f)(t,y);n&&!n.get("hoverable")||(e.forceChange&&this.set("componentHovered",""),this.set("componentHovered",n,e))},setComponents:function(t){return this.get("DomComponents").setComponents(t)},getComponents:function(){var t=this.get("DomComponents"),e=this.get("CodeManager");if(t&&e){var n=t.getComponents();return e.getCode(n,"json")}},setStyle:function(t){for(var e=this.get("CssComposer").getAll(),n=0,r=e.length;n".concat(r,"<\/script>"):""},getCss:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=this.config,n=e.wrapperIsBody,r=t.avoidProtected,i=Object(l.isUndefined)(t.keepUnusedStyles)?e.keepUnusedStyles:t.keepUnusedStyles,o=this.get("CssComposer"),a=this.get("DomComponents").getComponent(),s=r?"":e.protectedCss;return s+this.get("CodeManager").getCode(a,"css",{cssc:o,wrapperIsBody:n,keepUnusedStyles:i})},getJs:function(){var t=this.get("DomComponents").getWrapper();return this.get("CodeManager").getCode(t,"js").trim()},store:function(t){var e=this,n=this.get("StorageManager"),r={};if(n)return this.get("storables").forEach((function(t){var e=t.store(1);for(var n in e)r[n]=e[n]})),n.store(r,(function(n){t&&t(n),e.set("changesCount",0),e.trigger("storage:store",r)})),r},load:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:null;this.getCacheLoad(1,(function(n){t.get("storables").forEach((function(t){return t.load(n)})),e&&e(n)}))},getCacheLoad:function(t,e){var n=this,r=t?1:0;if(this.cacheLoad&&!r)return this.cacheLoad;var i=this.get("StorageManager"),o=[];if(!i)return{};this.get("storables").forEach((function(t){var e=t.storageKey;((e="function"==typeof e?e():e)instanceof Array?e:[e]).forEach((function(t){o.push(t)}))})),i.load(o,(function(t){n.cacheLoad=t,e&&e(t),setTimeout((function(){return n.trigger("storage:load",t)}),0)}))},getDeviceModel:function(){var t=this.get("device");return this.get("DeviceManager").get(t)},runDefault:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=this.get("Commands").get(this.config.defaultCommand);e&&!this.defaultRunning&&(e.stop(this,this,t),e.run(this,this,t),this.defaultRunning=1)},stopDefault:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=this.get("Commands").get(this.config.defaultCommand);e&&(e.stop(this,this,t),this.defaultRunning=0)},refreshCanvas:function(){this.set("canvasOffset",null),this.set("canvasOffset",this.get("Canvas").getOffset())},clearSelection:function(t){(t||window).getSelection().removeAllRanges()},getCurrentMedia:function(){var t=this.config,e=this.getDeviceModel(),n=t.mediaCondition,r=t.devicePreviewMode,i=e&&e.get("widthMedia");return e&&i&&!r?"(".concat(n,": ").concat(i,")"):""},getWrapper:function(){return this.get("DomComponents").getWrapper()},getDirtyCount:function(){return this.get("changesCount")},getZoomDecimal:function(){return this.get("Canvas").getZoomDecimal()},setDragMode:function(t){return this.set("dmode",t)},inAbsoluteMode:function(){return"absolute"===this.get("dmode")},destroyAll:function(){var t=this.attributes,e=t.DomComponents,n=t.CssComposer,r=t.UndoManager,i=t.Panels,o=t.Canvas,a=t.Keymaps;e.clear(),n.clear(),r.clear().removeAll(),i.getPanels().reset(),o.getCanvasView().remove(),a.removeAll(),this.view.remove(),this.stopListening(),y(this.config.el).empty().attr(this.attrsOrig)},setEditing:function(t){return this.set("editing",t),this},isEditing:function(){return!!this.get("editing")},log:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=e.ns,r=e.level,i=void 0===r?"debug":r;if(this.trigger("log",t,e),i&&this.trigger("log:".concat(i),t,e),n){var o="log-".concat(n);this.trigger(o,t,e),i&&this.trigger("".concat(o,":").concat(i),t,e)}},logInfo:function(t,e){this.log(t,f({},e,{level:"info"}))},logWarning:function(t,e){this.log(t,f({},e,{level:"warning"}))},logError:function(t,e){this.log(t,f({},e,{level:"error"}))},data:function(t,e,n){if(t["_gjs-data"]||(t["_gjs-data"]={}),Object(l.isUndefined)(n))return t["_gjs-data"][e];t["_gjs-data"][e]=n}}),x=u.a.$,C=u.a.View.extend({initialize:function(){var t=this,e=this.model;e.view=this,this.conf=e.config,this.pn=e.get("Panels"),e.on("loaded",(function(){t.pn.active(),t.pn.disableButtons(),e.runDefault(),setTimeout((function(){return e.trigger("load",e.get("Editor"))}))}))},render:function(){var t=this.model,e=this.$el,n=this.conf,r=x(n.el||"body ".concat(n.container)),i=n.stylePrefix;return e.empty(),n.width&&r.css("width",n.width),n.height&&r.css("height",n.height),e.append(t.get("Canvas").render()),e.append(this.pn.render()),e.attr("class","".concat(i,"editor ").concat(i,"one-bg ").concat(i,"two-color")),r.addClass("".concat(i,"editor-cont")).empty().append(e),this}});function O(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function S(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{},e=S({},s,{},t);e.pStylePrefix=e.stylePrefix;var n=new w(e),r=new C({model:n,config:e});return{$:a.a,editor:n,DomComponents:n.get("DomComponents"),LayerManager:n.get("LayerManager"),CssComposer:n.get("CssComposer"),StorageManager:n.get("StorageManager"),AssetManager:n.get("AssetManager"),BlockManager:n.get("BlockManager"),TraitManager:n.get("TraitManager"),SelectorManager:n.get("SelectorManager"),CodeManager:n.get("CodeManager"),Commands:n.get("Commands"),Keymaps:n.get("Keymaps"),Modal:n.get("Modal"),Panels:n.get("Panels"),StyleManager:n.get("StyleManager"),Canvas:n.get("Canvas"),UndoManager:n.get("UndoManager"),DeviceManager:n.get("DeviceManager"),RichTextEditor:n.get("RichTextEditor"),Parser:n.get("Parser"),Utils:n.get("Utils"),Config:n.get("Config"),init:function(){return n.init(this),this},getConfig:function(t){return n.getConfig(t)},getHtml:function(t){return n.getHtml(t)},getCss:function(t){return n.getCss(t)},getJs:function(){return n.getJs()},getComponents:function(){return n.get("DomComponents").getComponents()},getWrapper:function(){return n.get("DomComponents").getWrapper()},setComponents:function(t){return n.setComponents(t),this},addComponents:function(t,e){return this.getWrapper().append(t,e)},getStyle:function(){return n.get("CssComposer").getAll()},setStyle:function(t){return n.setStyle(t),this},getSelected:function(){return n.getSelected()},getSelectedAll:function(){return n.getSelectedAll()},getSelectedToStyle:function(){var t=n.getSelected();if(t)return this.StyleManager.getModelToStyle(t)},select:function(t,e){return n.setSelected(t,e),this},selectAdd:function(t){return n.addSelected(t),this},selectRemove:function(t){return n.removeSelected(t),this},selectToggle:function(t){return n.toggleSelected(t),this},setDevice:function(t){return n.set("device",t),this},getDevice:function(){return n.get("device")},runCommand:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return n.get("Commands").run(t,e)},stopCommand:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return n.get("Commands").stop(t,e)},store:function(t){return n.store(t)},load:function(t){return n.load(t)},getContainer:function(){return e.el},getDirtyCount:function(){return n.getDirtyCount()},refresh:function(){n.refreshCanvas()},setCustomRte:function(t){this.RichTextEditor.customRte=t},setCustomParserCss:function(t){return this.Parser.getConfig().parserCss=t,this},setDragMode:function(t){return n.setDragMode(t),this},log:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return n.log(t,e),this},on:function(t,e){return n.on(t,e),this},once:function(t,e){return n.once(t,e),this},off:function(t,e){return n.off(t,e),this},trigger:function(t){return n.trigger.apply(n,arguments),this},destroy:function(){return n.destroyAll()},getEl:function(){return r.el},getModel:function(){return n},render:function(){var t=this;return n.on("loaded",(function(){t.UndoManager.clear(),n.get("modules").forEach((function(t){t.postRender&&t.postRender(r)}))})),r.render(),r.el}}},T={plugins:[]};function P(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function j(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{},e=t.container;if(!e)throw new Error("'container' is required");(t=j({},D,{},t)).el=Object(l.isElement)(e)?e:document.querySelector(e);var n=new k(t).init();return t.plugins.forEach((function(e){var r=E.get(e),i=t.pluginsOpts[e]||{};if(!r){var o=window[e];r=o&&o.default?o.default:o}r?r(n,i):Object(l.isFunction)(e)?e(n,i):console.warn("Plugin ".concat(e," not found"))})),n.getModel().loadOnStart(),t.autorender&&n.render(),M.push(n),n}}},function(t,e,n){"use strict";n.r(e);var r=n(0),i={stylePrefix:"trt-",appendTo:"",labelContainer:"Component settings",labelPlhText:"eg. Text here",labelPlhHref:"eg. https://google.com",optionsTarget:[{value:"",name:"This window"},{value:"_blank",name:"New window"}],textNoElement:"Select an element before using Trait Manager"},o=n(29),a=n(2),s=n.n(a),l=n(65),c=n.n(l),u=n(1),h=n.n(u),d=n(3);function f(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}var p=h.a.$,g=h.a.View.extend({events:{},eventCapture:["change"],appendInput:1,attributes:function(){return this.model.get("attributes")},templateLabel:function(){var t=this.ppfx,e=this.getLabel();return'
').concat(e,"
")},templateInput:function(){var t=this.clsField;return'
')},initialize:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},n=e.config,r=void 0===n?{}:n,i=this.model,o=this.eventCapture,a=i.target,s=i.attributes.type;this.config=r,this.em=r.em,this.pfx=r.stylePrefix||"",this.ppfx=r.pStylePrefix||"",this.target=a;var l=this.ppfx;this.clsField="".concat(l,"field ").concat(l,"field-").concat(s),[["change:value",this.onValueChange],["remove",this.removeView]].forEach((function(e){var n=c()(e,2),r=n[0],o=n[1];i.off(r,o),t.listenTo(i,r,o)})),i.view=this,this.listenTo(i,"change:label",this.render),this.listenTo(i,"change:placeholder",this.rerender),o.forEach((function(e){return t.events[e]="onChange"})),this.delegateEvents(),this.init()},getClbOpts:function(){return{component:this.target,trait:this.model,elInput:this.getInputElem()}},removeView:function(){this.remove(),this.removed()},init:function(){},removed:function(){},onRender:function(){},onUpdate:function(){},onEvent:function(){},onChange:function(t){var e=this.getInputElem();e&&!Object(r.isUndefined)(e.value)&&this.model.set("value",e.value),this.onEvent(function(t){for(var e=1;e2&&void 0!==arguments[2]?arguments[2]:{};if(n.fromTarget)this.setInputValue(t.get("value")),this.postUpdate();else{var r=this.getValueForTarget();t.setTargetValue(r,n)}},renderLabel:function(){var t=this.$el,e=this.target,n=this.getLabel(),r=this.templateLabel(e);this.createLabel&&(r=this.createLabel({label:n,component:e,trait:this})||""),t.find("[data-label]").append(r)},getLabel:function(){var t=this.model.attributes,e=t.label,n=t.name;return Object(d.b)(e||n).replace(/-/g," ")},getComponent:function(){return this.target},getInputEl:function(){if(!this.$input){var t=this.model,e=t.get("placeholder")||t.get("default")||"",n=t.get("type")||"text",i=t.get("min"),o=t.get("max"),a=this.getModelValue(),s=p(''));Object(r.isUndefined)(a)||(t.set({value:a},{silent:!0}),s.prop("value",a)),i&&s.prop("min",i),o&&s.prop("max",o),this.$input=s}return this.$input.get(0)},getInputElem:function(){var t=this.input,e=this.$input;return t||e&&e.get&&e.get(0)||this.getElInput()},getModelValue:function(){var t,e=this.model,n=this.target,i=e.get("name");if(e.get("changeProp"))t=n.get(i);else{var o=n.get("attributes");t=e.get("value")||o[i]}return Object(r.isUndefined)(t)?"":t},getElInput:function(){return this.elInput},renderField:function(){var t=this.$el,e=this.appendInput,n=this.model,i=t.find("[data-input]"),o=i[i.length-1],a=n.el;a||(a=this.createInput?this.createInput(this.getClbOpts()):this.getInputEl()),Object(r.isString)(a)?(o.innerHTML=a,this.elInput=o.firstChild):(e?o.appendChild(a):o.insertBefore(a,o.firstChild),this.elInput=a),n.el=this.elInput},hasLabel:function(){var t=this.model.attributes.label;return!this.noLabel&&!1!==t},rerender:function(){this.model.el=null,this.render()},postUpdate:function(){this.onUpdate(this.getClbOpts())},render:function(){var t=this.$el,e=this.pfx,n=this.ppfx,i=this.model.attributes.type,o=this.hasLabel&&this.hasLabel(),a="".concat(e,"trait");this.$input=null;var s='
\n ').concat(o?'
'):"",'\n
\n ').concat(this.templateInput?Object(r.isFunction)(this.templateInput)?this.templateInput(this.getClbOpts()):this.templateInput:"","\n
\n
");return t.empty().append(s),o&&this.renderLabel(),this.renderField(),this.el.className="".concat(a,"__wrp"),this.postUpdate(),this.onRender(this.getClbOpts()),this}}),v=h.a.$,m=g.extend({init:function(){this.listenTo(this.model,"change:options",this.rerender)},templateInput:function(){var t=this.ppfx,e=this.clsField;return'
\n
\n
\n
\n
\n
')},getInputEl:function(){if(!this.$input){var t=this.model,e=t.get("options")||[],n="",this.$input=v(n);var i=t.getTargetValue()||t.get("value");!Object(r.isUndefined)(i)&&this.$input.val(i)}return this.$input.get(0)}}),y=g.extend({appendInput:0,templateInput:function(){var t=this.ppfx,e=this.clsField;return'')},onChange:function(){var t=this.getInputElem().checked;this.model.set("value",this.getCheckedValue(t))},getCheckedValue:function(t){var e=t,n=this.model.attributes,i=n.valueTrue,o=n.valueFalse;return e&&!Object(r.isUndefined)(i)&&(e=i),e||Object(r.isUndefined)(o)||(e=o),e},getInputEl:function(){for(var t=!this.$input,e=arguments.length,n=new Array(e),i=0;i').concat(a,"")}}),S=o.a.extend({ns:"Traits",itemView:g,reuseView:1,itemsView:{text:g,number:w,select:m,checkbox:y,color:C,button:O},initialize:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=t.config||{};this.config=e,this.em=t.editor,this.pfx=e.stylePrefix||"",this.ppfx=e.pStylePrefix||"",this.className=this.pfx+"traits";var n="component:toggled";this.listenTo(this.em,n,this.updatedCollection),this.updatedCollection()},updatedCollection:function(){var t=this.ppfx,e=this.em.getSelected();this.el.className="".concat(this.className," ").concat(t,"one-bg ").concat(t,"two-color"),this.collection=e?e.get("traits"):[],this.render()}});e.default=function(){var t,e={};return{TraitsView:S,name:"TraitManager",getConfig:function(){return e},init:function(){var n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};e=n,Object(r.defaults)(e,i);var o=e.pStylePrefix;return o&&(e.stylePrefix="".concat(o).concat(e.stylePrefix)),t=new S({collection:[],editor:e.em,config:e}),this},postRender:function(){var t=this.getConfig().appendTo;t&&(Object(r.isElement)(t)?t:document.querySelector(t)).appendChild(this.render())},getTraitsViewer:function(){return t},addType:function(e,n){var r=t.itemView;t.itemsView[e]=r.extend(n)},getType:function(e){return t.itemsView[e]},render:function(){return t.render().el}}}},function(t,e,n){"use strict";n.r(e);var r={assets:[],noAssets:"",stylePrefix:"am-",upload:0,uploadName:"files",headers:{},params:{},credentials:"include",multiUpload:!0,autoAdd:1,uploadText:"Drop files here or click to upload",addBtnText:"Add image",customFetch:"",uploadFile:"",embedAsBase64:1,handleAdd:"",dropzone:0,openAssetsOnDrop:1,dropzoneContent:"",modalTitle:"Select Image",inputPlaceholder:"http://path/to/the/image.jpg",beforeUpload:null},i=n(1),o=n.n(i),a=n(2),s=n.n(a),l=o.a.Model.extend({idAttribute:"src",defaults:{type:"",src:""},getFilename:function(){return this.get("src").split("/").pop()},getExtension:function(){return this.getFilename().split(".").pop()}});function c(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}var u=l.extend({defaults:function(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{};this.options=t,this.collection=t.collection;var e=t.config||{};this.config=e,this.pfx=e.stylePrefix||"",this.ppfx=e.pStylePrefix||"",this.em=e.em,this.className=this.pfx+"asset",this.listenTo(this.model,"destroy remove",this.remove),this.model.view=this;var n=this.init&&this.init.bind(this);n&&n(t)},template:function(){var t=this.pfx;return'\n
\n ').concat(this.getPreview(),'\n
\n
\n ').concat(this.getInfo(),'\n
\n
\n ⨯\n
\n ')},updateTarget:function(t){t&&t.set&&(t.set("attributes",Object(h.clone)(t.get("attributes"))),t.set("src",this.model.get("src")))},getPreview:function(){return""},getInfo:function(){return""},render:function(){var t=this.el;return t.innerHTML=this.template(this,this.model),t.className=this.className,this}}).extend({events:{"click [data-toggle=asset-remove]":"onRemove",click:"onClick",dblclick:"onDblClick"},getPreview:function(){var t=this.pfx,e=this.model.get("src");return'\n
\n
\n ')},getInfo:function(){var t=this.pfx,e=this.model,n=e.get("name"),r=e.get("width"),i=e.get("height"),o=e.get("unitDim"),a=r&&i?"".concat(r,"x").concat(i).concat(o):"";return n=n||e.getFilename(),'\n
').concat(n,'
\n
').concat(a,"
\n ")},init:function(t){var e=this.pfx;this.className+=" ".concat(e,"asset-image")},onClick:function(){var t=this.config.onClick,e=this.model;this.collection.trigger("deselectAll"),this.$el.addClass(this.pfx+"highlight"),Object(h.isFunction)(t)?t(e):this.updateTarget(this.collection.target)},onDblClick:function(){var t=this.em,e=this.model,n=this.config.onDblClick;Object(h.isFunction)(n)?n(e):(this.updateTarget(this.collection.target),t&&t.get("Modal").close());var r=this.collection.onSelect;Object(h.isFunction)(r)&&r(e)},onRemove:function(t){t.stopImmediatePropagation(),this.model.collection.remove(this.model)}}),f=n(27),p=o.a.Collection.extend(f.a).extend({types:[{id:"image",model:u,view:d,isType:function(t){return"string"==typeof t?{type:"image",src:t}:t}}]}),g=o.a.View.extend({events:{submit:"handleSubmit"},template:function(t){var e=t.pfx,n=t.ppfx;return'\n
\n
\n
\n
\n \n
\n \n
\n
\n
\n
\n
\n
\n ')},initialize:function(t){this.options=t,this.config=t.config,this.pfx=this.config.stylePrefix||"",this.ppfx=this.config.pStylePrefix||"";var e=this.collection;this.listenTo(e,"reset",this.renderAssets),this.listenTo(e,"add",this.addToAsset),this.listenTo(e,"remove",this.removedAsset),this.listenTo(e,"deselectAll",this.deselectAll)},handleSubmit:function(t){t.preventDefault();var e=this.getAddInput(),n=e.value.trim(),r=this.config.handleAdd;n&&(e.value="",this.getAssetsEl().scrollTop=0,r?r.bind(this)(n):this.options.globalCollection.add(n,{at:0}))},getAssetsEl:function(){return this.el.querySelector(".".concat(this.pfx,"assets"))},getAddInput:function(){return this.inputUrl&&this.inputUrl.value||(this.inputUrl=this.el.querySelector(".".concat(this.pfx,"add-asset input"))),this.inputUrl},removedAsset:function(t){this.collection.length||this.toggleNoAssets()},addToAsset:function(t){1==this.collection.length&&this.toggleNoAssets(1),this.addAsset(t)},addAsset:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null,n=e,r=this.collection,i=this.config,o=new t.typeView({model:t,collection:r,config:i}).render().el;if(n)n.appendChild(o);else{var a=this.getAssetsEl();a&&a.insertBefore(o,a.firstChild)}return o},toggleNoAssets:function(t){var e=this.$el.find(".".concat(this.pfx,"assets"));if(t)e.empty();else{var n=this.config.noAssets;n&&e.append(n)}},deselectAll:function(){var t=this.pfx;this.$el.find(".".concat(t,"highlight")).removeClass("".concat(t,"highlight"))},renderAssets:function(){var t=this,e=document.createDocumentFragment(),n=this.$el.find(".".concat(this.pfx,"assets"));n.empty(),this.toggleNoAssets(this.collection.length),this.collection.each((function(n){return t.addAsset(n,e)})),n.append(e)},render:function(){var t=this.options.fu.render().el;return this.$el.empty(),this.$el.append(t).append(this.template(this)),this.el.className="".concat(this.ppfx,"asset-manager"),this.renderAssets(),this.rendered=1,this}}),v=n(25),m=o.a.View.extend({template:Object(h.template)('\n
\n
<%= title %>
\n <%= multiUpload ? \'multiple\' : \'\' %>/>\n
\n
\n '),events:{},initialize:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};this.options=t;var e=t.config||{};this.config=e,this.pfx=e.stylePrefix||"",this.ppfx=e.pStylePrefix||"",this.target=this.options.globalCollection||{},this.uploadId=this.pfx+"uploadFile",this.disabled=void 0!==e.disableUpload?e.disableUpload:!e.upload&&!e.embedAsBase64,this.multiUpload=void 0===e.multiUpload||e.multiUpload,this.events["change #"+this.uploadId]="uploadFile";var n=e.uploadFile;n?this.uploadFile=n.bind(this):!e.upload&&e.embedAsBase64&&(this.uploadFile=this.constructor.embedAsBase64),this.delegateEvents()},onUploadStart:function(){var t=this.config.em;t&&t.trigger("asset:upload:start")},onUploadEnd:function(t){var e=this.$el,n=this.config.em;n&&n.trigger("asset:upload:end",t);var r=e.find("input");r&&r.val("")},onUploadError:function(t){var e=this.config.em;console.error(t),this.onUploadEnd(t),e&&e.trigger("asset:upload:error",t)},onUploadResponse:function(t,e){var n,r=this.config.em,i=this.config,o=this.target;try{n="string"==typeof t?JSON.parse(t):t}catch(e){n=t}r&&r.trigger("asset:upload:response",n),i.autoAdd&&o&&o.add(n.data,{at:0}),this.onUploadEnd(t),e&&e(n)},uploadFile:function(t,e){var n=this,r=t.dataTransfer?t.dataTransfer.files:t.target.files,i=this.config,o=i.beforeUpload;if(!1!==(o&&o(r))){var a=new FormData,s=i.params,l=i.customFetch;for(var c in s)a.append(c,s[c]);if(this.multiUpload)for(var u=0;u').concat(r.dropzoneContent,"
")),h(),"draggable"in o&&[o,s].forEach((function(t){t.ondragover=d,t.ondragleave=f,t.ondrop=p}))},render:function(){return this.$el.html(this.template({title:this.config.uploadText,uploadId:this.uploadId,disabled:this.disabled,multiUpload:this.multiUpload,pfx:this.pfx})),this.initDrop(),this.$el.attr("class",this.pfx+"file-uploader"),this}},{embedAsBase64:function(t,e){var n=this,r=t.dataTransfer?t.dataTransfer.files:t.target.files,i={data:[]};if(FileReader){var o=[],a=/^(.+)\/(.+)$/,s=!0,l=!1,c=void 0;try{for(var u,h=function(){var t=u.value,e=new Promise((function(e,n){var r=new FileReader;r.addEventListener("load",(function(i){var o,s=t.name,l=a.exec(t.type);if("image"===(o=l?l[1]:t.type)){var c={src:r.result,name:s,type:o,height:0,width:0},u=new Image;u.addEventListener("error",(function(t){n(t)})),u.addEventListener("load",(function(){c.height=u.height,c.width=u.width,e(c)})),u.src=c.src}else e(o?{src:r.result,name:s,type:o}:r.result)})),r.addEventListener("error",(function(t){n(t)})),r.addEventListener("abort",(function(t){n("Aborted")})),r.readAsDataURL(t)}));o.push(e)},d=r[Symbol.iterator]();!(s=(u=d.next()).done);s=!0)h()}catch(t){l=!0,c=t}finally{try{s||null==d.return||d.return()}finally{if(l)throw c}}Promise.all(o).then((function(t){i.data=t,n.onUploadResponse(i,e)}),(function(t){n.onUploadError(t)}))}else this.onUploadError(new Error("Unsupported platform, FileReader is not defined"))}});e.default=function(){var t,e,n,i={};return{name:"AssetManager",storageKey:"assets",getConfig:function(){return i},init:function(o){var a=this;for(var s in i=o||{},r)s in i||(i[s]=r[s]);var l=i.pStylePrefix,c=i.em;l&&(i.stylePrefix=l+i.stylePrefix),t=new p([]);var u={collection:new p([]),globalCollection:t,config:i};return n=new m(u),u.fu=n,e=new g(u),t.listenTo(t,"add",(function(t){a.getAllVisible().add(t),c&&c.trigger("asset:add",t)})),t.listenTo(t,"remove",(function(t){a.getAllVisible().remove(t),c&&c.trigger("asset:remove",t)})),this},add:function(e){var n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return void 0===n.at&&(n.at=0),t.add(e,n)},get:function(e){return t.where({src:e})[0]},getAll:function(){return t},getAllVisible:function(){return e.collection},remove:function(t){var e=this.get(t);return this.getAll().remove(e),this},store:function(t){var e={},n=JSON.stringify(this.getAll().toJSON());return e[this.storageKey]=n,!t&&i.stm&&i.stm.store(e),e},load:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=this.storageKey,n=t[e]||[];if("string"==typeof n)try{n=JSON.parse(t[e])}catch(t){}return n&&n.length&&this.getAll().reset(n),n},getContainer:function(){return e.el},getAssetsEl:function(){return e.el.querySelector("[data-el=assets]")},render:function(t){var n=t||this.getAll().models;return e.rendered||e.render(),e.collection.reset(n),this.getContainer()},addType:function(t,e){this.getAll().addType(t,e)},getType:function(t){return this.getAll().getType(t)},getTypes:function(){return this.getAll().getTypes()},AssetsView:function(){return e},FileUploader:function(){return n},onLoad:function(){this.getAll().reset(i.assets)},postRender:function(t){i.dropzone&&n.initDropzone(t)},setTarget:function(t){e.collection.target=t},onSelect:function(t){e.collection.onSelect=t},onClick:function(t){i.onClick=t},onDblClick:function(t){i.onDblClick=t}}}},function(t,e,n){"use strict";n.r(e);var r=n(2),i=n.n(r),o=n(0),a={appendTo:"",appendOnClick:0,blocks:[]},s=n(1),l=n.n(s),c=l.a.Model.extend({defaults:{id:"",label:"",open:!0,attributes:{}}}),u=l.a.Model.extend({defaults:{activate:0,select:0,resetId:0,label:"",media:"",content:"",category:"",attributes:{}},initialize:function(){arguments.length>0&&void 0!==arguments[0]&&arguments[0];var t=this.get("category");if(t&&"string"==typeof t)new c({id:t,label:t})}}),h=l.a.Collection.extend({model:u}),d=l.a.Collection.extend({model:c}),f=n(3),p=l.a.View.extend({events:{click:"handleClick",mousedown:"startDrag",dragstart:"handleDragStart",drag:"handleDrag",dragend:"handleDragEnd"},initialize:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=this.model;this.em=e.em,this.config=e,this.endDrag=this.endDrag.bind(this),this.ppfx=e.pStylePrefix||"",this.listenTo(n,"destroy remove",this.remove),this.listenTo(n,"change",this.render)},handleClick:function(){var t=this.config,e=this.model,n=this.em;if(t.appendOnClick){var r,i=t.getSorter(),o=e.get("content"),a=n.getSelected();if(i.setDropContent(o),a)if(i.validTarget(a.getEl(),o).valid)r=a;else{var s=a.parent();i.validTarget(s.getEl(),o).valid&&(r=s)}if(!r){var l=n.getWrapper();i.validTarget(l.getEl(),o).valid&&(r=l)}var c=r&&r.append(o)[0];c&&n.setSelected(c,{scroll:1})}},startDrag:function(t){var e=this.config,n=this.em;if(0===t.button&&e.getSorter&&!this.el.draggable){n.refreshCanvas();var r=e.getSorter();r.setDragHelper(this.el,t),r.setDropContent(this.model.get("content")),r.startSort(this.el),Object(f.p)(document,"mouseup",this.endDrag)}},handleDragStart:function(t){var e=this.em,n=this.model,r=n.get("content"),i=Object(o.isObject)(r)?JSON.stringify(r):r;e.set("dragResult"),t.dataTransfer.setData("text",i),e.set("dragContent",r),e.trigger("block:drag:start",n,t)},handleDrag:function(t){this.em.trigger("block:drag",this.model,t)},handleDragEnd:function(){var t=this.em,e=this.model,n=t.get("dragResult");if(n){var r=n.get&&n.get("activeOnRender");(e.get("activate")||r)&&(n.trigger("active"),n.set("activeOnRender",0)),e.get("select")&&t.setSelected(n),e.get("resetId")&&n.onAll((function(t){return t.resetId()}))}t.set({dragResult:null,dragContent:null}),t.trigger("block:drag:stop",n,e)},endDrag:function(t){Object(f.o)(document,"mouseup",this.endDrag);var e=this.config.getSorter();e.moved=0,e.endMove()},render:function(){var t=this.em,e=this.el,n=this.ppfx,r=this.model,i="".concat(n,"block"),o=r.get("label"),a=r.get("render"),s=r.get("media");e.className+=" ".concat(i," ").concat(n,"one-bg ").concat(n,"four-color-h"),e.innerHTML="\n ".concat(s?'
').concat(s,"
"):"",'\n
').concat(o,"
\n "),e.title=e.textContent.trim(),Object(f.i)(t)&&e.setAttribute("draggable",!0);var l=a&&a({el:e,model:r,className:i,prefix:n});return l&&(e.innerHTML=l),this}}),g=l.a.View.extend({template:Object(o.template)('\n
\n \n <%= label %>\n
\n
\n '),events:{},initialize:function(){arguments.length>0&&void 0!==arguments[0]&&arguments[0];var t=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};this.config=t;var e=this.config.pStylePrefix||"";this.pfx=e,this.caretR="fa fa-caret-right",this.caretD="fa fa-caret-down",this.iconClass="".concat(e,"caret-icon"),this.activeClass="".concat(e,"open"),this.className="".concat(e,"block-category"),this.events["click .".concat(e,"title")]="toggle",this.listenTo(this.model,"change:open",this.updateVisibility),this.delegateEvents()},updateVisibility:function(){this.model.get("open")?this.open():this.close()},open:function(){this.el.className="".concat(this.className," ").concat(this.activeClass),this.getIconEl().className="".concat(this.iconClass," ").concat(this.caretD),this.getBlocksEl().style.display=""},close:function(){this.el.className=this.className,this.getIconEl().className="".concat(this.iconClass," ").concat(this.caretR),this.getBlocksEl().style.display="none"},toggle:function(){var t=this.model;t.set("open",!t.get("open"))},getIconEl:function(){return this.iconEl||(this.iconEl=this.el.querySelector("."+this.iconClass)),this.iconEl},getBlocksEl:function(){return this.blocksEl||(this.blocksEl=this.el.querySelector("."+this.pfx+"blocks-c")),this.blocksEl},append:function(t){this.getBlocksEl().appendChild(t)},render:function(){return this.el.innerHTML=this.template({pfx:this.pfx,label:this.model.get("label")}),this.el.className=this.className,this.$el.css({order:this.model.get("order")}),this.updateVisibility(),this}});function v(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function m(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{};this.config=m({},this.config,{},t)},getSorter:function(){if(this.em){if(!this.sorter){var t=this.em.get("Utils"),e=this.canvas;this.sorter=new t.Sorter({container:e.getBody(),placer:e.getPlacerEl(),containerSel:"*",itemSel:"*",pfx:this.ppfx,onStart:this.onDrag,onEndMove:this.onDrop,onMove:this.onMove,document:e.getFrameEl().contentDocument,direction:"a",wmargin:1,nested:1,em:this.em,canvasRelative:1})}return this.sorter}},onDrag:function(t){this.em.stopDefault(),this.em.trigger("block:drag:start",t)},onMove:function(t){this.em.trigger("block:drag:move",t)},onDrop:function(t){var e=this.em;e.runDefault(),t&&t.get&&(t.get("activeOnRender")&&(t.trigger("active"),t.set("activeOnRender",0)),e.trigger("block:drag:stop",t))},addTo:function(t){this.add(t)},add:function(t,e){var n=this.config,r=e||null,i=new p({model:t,attributes:t.get("attributes")},n).render().el,a=t.get("category");if(a&&this.categories&&!n.ignoreCategories){Object(o.isString)(a)?a={id:a,label:a}:Object(o.isObject)(a)&&!a.id&&(a.id=a.label);var s=this.categories.add(a),l=s.get("id"),c=this.renderedCategories[l],u=this.getCategoriesEl();return t.set("category",s),!c&&u&&(c=new g({model:s},this.config).render(),this.renderedCategories[l]=c,u.appendChild(c.el)),void(c&&c.append(i))}r?r.appendChild(i):this.append(i)},getCategoriesEl:function(){return this.catsEl||(this.catsEl=this.el.querySelector(".".concat(this.catsClass))),this.catsEl},getBlocksEl:function(){return this.blocksEl||(this.blocksEl=this.el.querySelector(".".concat(this.noCatClass," .").concat(this.blockContClass))),this.blocksEl},append:function(t){var e=this.getBlocksEl();e&&e.appendChild(t)},render:function(){var t=this,e=this.ppfx,n=document.createDocumentFragment();this.catsEl=null,this.blocksEl=null,this.renderedCategories=[],this.el.innerHTML='\n
\n
\n
\n
\n '),this.collection.each((function(e){return t.add(e,n)})),this.append(n);var r="".concat(this.blockContClass,"s ").concat(e,"one-bg ").concat(e,"two-color");return this.$el.addClass(r),this}});function b(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function w(t){for(var e=1;e1&&void 0!==arguments[1]?arguments[1]:{},o=t||this.getAll().models;return e.external?new y({collection:new h(o),categories:i},w({},r,{},e)).render().el:(n.rendered||(n.render(),n.rendered=1),n.updateConfig(e),n.collection.reset(o),this.getContainer())}}}},function(t,e,n){"use strict";n.r(e);var r="sw-visibility",i="export-template",o="open-layers",a="open-blocks",s="fullscreen",l="preview",c={stylePrefix:"pn-",defaults:[{id:"commands",buttons:[{}]},{id:"options",buttons:[{active:!0,id:r,className:"fa fa-square-o",command:r,context:r,attributes:{title:"View components"}},{id:l,className:"fa fa-eye",command:l,context:l,attributes:{title:"Preview"}},{id:s,className:"fa fa-arrows-alt",command:s,context:s,attributes:{title:"Fullscreen"}},{id:i,className:"fa fa-code",command:i,attributes:{title:"View code"}}]},{id:"views",buttons:[{id:"open-sm",className:"fa fa-paint-brush",command:"open-sm",active:!0,togglable:0,attributes:{title:"Open Style Manager"}},{id:"open-tm",className:"fa fa-cog",command:"open-tm",togglable:0,attributes:{title:"Settings"}},{id:o,className:"fa fa-bars",command:o,togglable:0,attributes:{title:"Open Layer Manager"}},{id:a,className:"fa fa-th-large",command:a,togglable:0,attributes:{title:"Open Blocks"}}]}],em:null,delayBtnsShow:300},u=n(1),h=n.n(u),d=n(35),f=h.a.Model.extend({defaults:{id:"",content:"",visible:!0,buttons:[],attributes:{}},initialize:function(t){this.btn=this.get("buttons")||[],this.buttons=new d.default(this.btn),this.set("buttons",this.buttons)}}),p=h.a.Collection.extend({model:f}),g=n(2),v=n.n(g),m=n(0);function y(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function b(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{},e=this.model,n=this.commands,r=this.$el,i=this.activeCls,o=t.fromCollection,a=e.get("context"),s=e.get("options"),l=e.get("command"),c={};n&&Object(m.isString)(l)?c=n.get(l)||{}:Object(m.isFunction)(l)?c=n.create({run:l}):null!==l&&Object(m.isObject)(l)&&(c=n.create(l)),e.get("active")?(!o&&e.collection.deactivateAll(a,e),e.set("active",!0,{silent:!0}).trigger("checkActive"),n.runCommand(c,b({},s,{sender:e})),c.noStop&&e.set("active",!1)):(r.removeClass(i),n.stopCommand(c,b({},s,{sender:e,force:1})))},updateDisable:function(){var t=this.disableCls,e=this.model.get("disable");this.$el[e?"addClass":"removeClass"](t)},checkActive:function(){var t=this.model,e=this.$el,n=this.activeCls;t.get("active")?e.addClass(n):e.removeClass(n)},clicked:function(t){this.model.get("bntsVis")||this.model.get("disable")||this.toogleActive()},toogleActive:function(){var t=this.model,e=t.attributes,n=e.active,r=e.togglable;if(!n||r){t.set("active",!n);this.em.get("Commands").get("select-comp");n?t.get("runDefaultCommand")&&this.em.runDefault():t.get("stopDefaultCommand")&&this.em.stopDefault()}},render:function(){var t=this.model.get("label"),e=this.$el;return e.empty(),this.updateAttributes(),t&&e.append(t),this.checkActive(),this.updateDisable(),this}}),x=h.a.View.extend({initialize:function(t){this.opt=t||{},this.config=this.opt.config||{},this.pfx=this.config.stylePrefix||"",this.parentM=this.opt.parentM||null,this.listenTo(this.collection,"add",this.addTo),this.listenTo(this.collection,"reset remove",this.render),this.className=this.pfx+"buttons"},addTo:function(t){this.addToCollection(t)},addToCollection:function(t,e){var n=e||null,r=new w({model:t,config:this.config,parentM:this.parentM}).render().el;return n?n.appendChild(r):this.$el.append(r),r},render:function(){var t=document.createDocumentFragment();return this.$el.empty(),this.collection.each((function(e){this.addToCollection(e,t)}),this),this.$el.append(t),this.$el.attr("class",Object(m.result)(this,"className")),this}});function C(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}var O=h.a.View.extend({initialize:function(t){var e=t.config||{},n=this.model;this.config=e,this.pfx=e.stylePrefix||"",this.ppfx=e.pStylePrefix||"",this.buttons=n.get("buttons"),this.className=this.pfx+"panel",this.id=this.pfx+n.get("id"),this.listenTo(n,"change:appendContent",this.appendContent),this.listenTo(n,"change:content",this.updateContent),this.listenTo(n,"change:visible",this.toggleVisible),n.view=this},appendContent:function(){this.$el.append(this.model.get("appendContent"))},updateContent:function(){this.$el.html(this.model.get("content"))},toggleVisible:function(){this.model.get("visible")?this.$el.removeClass("".concat(this.ppfx,"hidden")):this.$el.addClass("".concat(this.ppfx,"hidden"))},attributes:function(){return this.model.get("attributes")},initResize:function(){var t=this.config.em,e=t?t.get("Editor"):"",n=this.model.get("resizable");if(e&&n){var r,i,o,a=!0===n?[1,1,1,1]:n,s=a.length,l=0;2==s?(r=a[0],o=a[0],i=a[1],l=a[1]):4==s&&(r=a[0],i=a[1],o=a[2],l=a[3]);var c=e.Utils.Resizer.init(function(t){for(var e=1;e1&&void 0!==arguments[1]?arguments[1]:{},n=t.get("components");return e.exportWrapper?e.wrapperIsBody?"".concat(this.buildModels(n),""):t.toHTML():this.buildModels(n)},buildModels:function(t){var e="";return t.each((function(t){e+=t.toHTML()})),e}}),l=Number.MAX_VALUE,c=a.a.Model.extend({initialize:function(){this.compCls=[],this.ids=[]},buildFromModel:function(t){var e=this,n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},r="",i=this.em,o=i&&i.getConfig("avoidInlineStyle"),a=t.styleToString(),s=t.get("classes"),l=n.wrapperIsBody,c=t.get("wrapper");if(this.ids.push("#".concat(t.getId())),s.each((function(t){return e.compCls.push(t.getFullName())})),!o&&a){var u="#".concat(t.getId());r="".concat(u=l&&c?"body":u,"{").concat(a,"}")}var h=t.components();return h.each((function(t){return r+=e.buildFromModel(t,n)})),r},build:function(t){var e=this,n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},i=n.cssc,o=n.em||"";this.em=o,this.compCls=[],this.ids=[];var a=this.buildFromModel(t,n),s=Object(r.isUndefined)(n.clearStyles)&&o?o.getConfig("clearStyles"):n.clearStyles;if(i){var l=i.getAll(),c={},u=[];l.each((function(t){var r=t.getAtRule();if(r){var i=c[r];i?i.push(t):c[r]=[t]}else a+=e.buildFromRule(t,u,n)})),this.sortMediaObject(c).forEach((function(t){var r="",i=t.key;t.value.forEach((function(t){var o=e.buildFromRule(t,u,n);t.get("singleAtRule")?a+="".concat(i,"{").concat(o,"}"):r+=o})),r&&(a+="".concat(i,"{").concat(r,"}"))})),o&&s&&l.remove(u)}return a},buildFromRule:function(t,e){var n,r=this,i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},o="",a=t.selectorsToString({skipAdd:1}),s=t.get("selectorsAdd"),l=t.get("singleAtRule");if(t.get("selectors").each((function(t){var e=t.getFullName();(r.compCls.indexOf(e)>=0||r.ids.indexOf(e)>=0||i.keepUnusedStyles)&&(n=1)})),a&&n||s||l){var c=t.getDeclaration();c&&(o+=c)}else e.push(t);return o},getQueryLength:function(t){var e=/(-?\d*\.?\d+)\w{0,}/.exec(t);return e?parseFloat(e[1]):l},sortMediaObject:function(){var t=this,e=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},n=[];return Object(r.each)(e,(function(t,e){return n.push({key:e,value:t})})),n.sort((function(e,n){var r=[e.key,n.key].every((function(t){return-1!==t.indexOf("min-width")})),i=r?e.key:n.key,o=r?n.key:e.key;return t.getQueryLength(i)-t.getQueryLength(o)}))}}),u=a.a.Model.extend({build:function(t){var e=t.toJSON();return this.beforeEach(e),Object(r.each)(e,(function(t,n){var r=e[n];if(r instanceof a.a.Model)e[n]=this.build(r);else if(r instanceof a.a.Collection){var i=r;e[n]=[],i.length&&i.each((function(t,r){e[n][r]=this.build(t)}),this)}}),this),e},beforeEach:function(t){delete t.status}}),h=a.a.Model.extend({mapModel:function(t){var e="",n=t.get("script-export")||t.get("script"),i=t.get("type"),o=t.get("components"),a=t.getId();if(n){var s=t.get("attributes");s=Object(r.extend)({},s,{id:a}),t.set("attributes",s,{silent:1});var l=t.getScriptString(n);if(t.get("scriptUpdated"))this.mapJs[i+"-"+a]={ids:[a],code:l};else{var c=this.mapJs[i];c?c.ids.push(a):this.mapJs[i]={ids:[a],code:l}}}return o.each((function(t){e+=this.mapModel(t)}),this),e},build:function(t){this.mapJs={},this.mapModel(t);var e="";for(var n in this.mapJs){var r=this.mapJs[n],i="#"+r.ids.join(", #");e+="\n var items = document.querySelectorAll('".concat(i,"');\n for (var i = 0, len = items.length; i < len; i++) {\n (function(){").concat(r.code,"}.bind(items[i]))();\n }")}return e}}),d=n(2),f=n.n(d),p=n(10),g=n.n(p);n(75),n(36),n(78);function v(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}var m=a.a.Model.extend({defaults:{input:"",label:"",codeName:"",theme:"hopscotch",readOnly:!0,lineNumbers:!0},init:function(t){return Object(r.bindAll)(this,"onChange"),this.editor=g.a.fromTextArea(t,function(t){for(var e=1;e1&&void 0!==arguments[1]?arguments[1]:{},r=this.editor;r&&(r.setValue(t),r.autoFormatRange&&(g.a.commands.selectAll(r),r.autoFormatRange(r.getCursor(!0),r.getCursor(!1)),g.a.commands.goDocStart(r)),!n.noRefresh&&setTimeout((function(){return e.refresh()})))}}),y=a.a.View.extend({template:Object(r.template)('\n
\n \t
<%= label %>
\n \t
\n
'),initialize:function(t){this.config=t.config||{},this.pfx=this.config.stylePrefix},render:function(){var t=this.model.toJSON();return t.pfx=this.pfx,this.$el.html(this.template(t)),this.$el.attr("class",this.pfx+"editor-c"),this.$el.find("#"+this.pfx+"code").append(this.model.get("input")),this}});e.default=function(){var t={},e={},n={},o={},a={};return{getConfig:function(){return t},config:t,EditorView:y,name:"CodeManager",init:function(e){for(var r in t=e||{},i)r in t||(t[r]=i[r]);var o=t.pStylePrefix;return o&&(t.stylePrefix=o+t.stylePrefix),n.html=new s,n.css=new c,n.json=new u,n.js=new h,a.CodeMirror=new m,this.loadDefaultGenerators().loadDefaultViewers(),this},addGenerator:function(t,n){return e[t]=n,this},getGenerator:function(t){return e[t]||null},getGenerators:function(){return e},addViewer:function(t,e){return o[t]=e,this},getViewer:function(t){return o[t]||null},getViewers:function(){return o},createViewer:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=Object(r.isUndefined)(t.type)?"CodeMirror":t.type,n=this.getViewer(e)&&this.getViewer(e).clone(),i=document.createElement("div"),o=document.createElement("textarea");return i.appendChild(o),n.set(t),n.init(o),n.setElement(i),n},updateViewer:function(t,e){t.setContent(e)},getCode:function(e,n){var r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{};r.em=t.em;var i=this.getGenerator(n);return i?i.build(e,r):""},loadDefaultGenerators:function(){for(var t in n)this.addGenerator(t,n[t]);return this},loadDefaultViewers:function(){for(var t in a)this.addViewer(t,a[t]);return this}}}},function(t,e,n){"use strict";n.r(e);var r=n(2),i=n.n(r),o=n(0),a={stylePrefix:"css-",staticRules:"",rules:[]},s=n(1),l=n.n(s),c=n(20),u=n(9),h=l.a.Model.extend(c.a).extend({defaults:{selectors:{},selectorsAdd:"",style:{},mediaText:"",state:"",stylable:!0,atRuleType:"",singleAtRule:0,important:0},initialize:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};this.config=t||{};var n=e.em,r=this.config.selectors||[];if(this.em=n,n){var i=n.get("SelectorManager"),o=[];r.forEach((function(t){o.push(i.add(t))})),r=o}this.set("selectors",new u.a(r))},getAtRule:function(){var t=this.get("atRuleType"),e=this.get("mediaText"),n=t?"@".concat(t):e?"@media":"";return n+(e&&n?" ".concat(e):"")},selectorsToString:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=[],n=this.em,r=this.get("state"),i=this.get("wrapper"),o=this.get("selectorsAdd"),a=i&&n&&n.getConfig("wrapperIsBody"),s=a?"body":this.get("selectors").getFullString(),l=r?":".concat(r):"";return s&&e.push("".concat(s).concat(l)),o&&!t.skipAdd&&e.push(o),e.join(", ")},getDeclaration:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e="",n=this.selectorsToString(),r=this.styleToString(t),i=this.get("singleAtRule");return(n||i)&&r&&(e=i?r:"".concat(n,"{").concat(r,"}")),e},toCSS:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e="",n=this.getAtRule(),r=this.getDeclaration(t);return r&&(e=r),n&&e&&(e="".concat(n,"{").concat(e,"}")),e},toJSON:function(){for(var t=arguments.length,e=new Array(t),n=0;n3&&void 0!==arguments[3]?arguments[3]:{},i=e||"",a=n||"",s=r.selectorsAdd||"",l=r.atRuleType||"";t instanceof Array||t.models||(t=[t]);var c=Object(o.map)(t.models||t,(function(t){return t.get("name")})),u=Object(o.map)(this.get("selectors").models,(function(t){return t.get("name")})),h=!1;if(c.length!==u.length)return h;for(var d=0;d1&&void 0!==arguments[1]?arguments[1]:{};return"string"==typeof t&&(t=this.editor.get("Parser").parseCss(t)),e.em=this.editor,l.a.Collection.prototype.add.apply(this,[t,e])}}),f=l.a.View.extend({tagName:"style",initialize:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};this.config=t.config||{};var e=this.model,n="change:style change:state change:mediaText";this.listenTo(e,n,this.render),this.listenTo(e,"destroy remove",this.remove),this.listenTo(e.get("selectors"),"change",this.render)},render:function(){var t=this.model.get("important");return this.el.innerHTML=this.model.toCSS({important:t}),this}}),p=f.extend({_createElement:function(t){return document.createTextNode("")},render:function(){var t=this.model,e=t.get("important");return this.el.textContent=t.getDeclaration({important:e}),this}}),g=l.a.$,v=function(t,e){return"".concat(t).concat(e?"-".concat(parseFloat(e)):"")},m=l.a.View.extend({initialize:function(t){var e=t.config||{};this.atRules={},this.config=e,this.em=e.em,this.pfx=e.stylePrefix||"",this.className=this.pfx+"rules";var n=this.collection;this.listenTo(n,"add",this.addTo),this.listenTo(n,"reset",this.render)},addTo:function(t){this.addToCollection(t)},addToCollection:function(t,e){if(this.renderStarted){var n,r,i=e||null,o={model:t,config:this.config};if("keyframes"===t.get("atRuleType")){var a=t.getAtRule(),s=this.atRules[a];if(!s){var l=document.createElement("style");s=document.createTextNode(""),l.appendChild(document.createTextNode("".concat(a,"{"))),l.appendChild(s),l.appendChild(document.createTextNode("}")),this.atRules[a]=s,n=l}r=new p(o),s.appendData(r.render().el.textContent)}else n=(r=new f(o)).render().el;var c=this.className,u=t.get("mediaText"),h=v(c),d=h;if(u&&(d=v(c,this.getMediaWidth(u))),n){var g,m=i||this.el;try{g=m.querySelector("#".concat(d))}catch(t){}g||(g=m.querySelector("#".concat(h))),g.appendChild(n)}return n}},getMediaWidth:function(t){return t&&t.replace("(".concat(this.em.getConfig("mediaCondition"),": "),"").replace(")","")},render:function(){var t=this;this.renderStarted=1,this.atRules={};var e=this.em,n=this.$el,r=this.className,i=this.collection,o=document.createDocumentFragment();n.empty();var a=e.get("DeviceManager").getAll().pluck("priority");return a.every((function(t){return t}))&&a.unshift(0),a.forEach((function(t){return g('
')).appendTo(o)})),i.each((function(e){return t.addToCollection(e,o)})),n.append(o),n.attr("class",r),this}}),y=n(7);function b(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function w(t){for(var e=1;e1&&void 0!==arguments[1]?arguments[1]:{},r="change:style",i=t.get("UndoManager");i&&i.add(e);var o=t.handleUpdates.bind(t);t.stopListening(e,r,o),t.listenTo(e,r,o),!n.avoidStore&&o("","",n)},load:function(t){var n=t||"";!n&&r.stm&&(n=r.em.getCacheLoad());var i=n.styles||"";if(n.styles)try{i=JSON.parse(n.styles)}catch(t){}else n.css&&(i=r.em.get("Parser").parseCss(n.css));return Object(o.isArray)(i)?i.length&&e.reset(i):i&&e.reset(i),i},store:function(t){if(r.stm){var n={},i=this.storageKey();return i.indexOf("css")>=0&&(n.css=r.em.getCss()),i.indexOf("styles")>=0&&(n.styles=JSON.stringify(e)),t||r.stm.store(n),n}},add:function(t,n,i){var o=arguments.length>3&&void 0!==arguments[3]?arguments[3]:{},a=n||"",s=i||"",l=w({},o),c=this.get(t,a,s,l);return c&&c.config&&!c.config.singleAtRule?c:(l.state=a,l.mediaText=s,l.selectors="",(c=new h(l,r)).get("selectors").add(t),e.add(c),c)},get:function(t,n,r,i){var o=null;return e.each((function(e){o||e.compare(t,n,r,i)&&(o=e)})),o},getAll:function(){return e},clear:function(){return this.getAll().reset(),this},addCollection:function(t){for(var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=[],i=t instanceof Array?t:[t],o=0,a=i.length;o2&&void 0!==arguments[2]?arguments[2]:{},i=r.atRuleType,o=r.atRuleParams,a=t.get("Parser").parserCss.checkNode({selectors:e,style:n})[0],s=a.state,l=a.selectorsAdd,c=t.get("SelectorManager"),u=c.add(a.selectors),h=this.add(u,s,o,{selectorsAdd:l,atRule:i});return h.setStyle(n,r),h},getRule:function(e){var n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},r=t.get("SelectorManager"),i=t.get("Parser").parserCss.checkNode({selectors:e})[0],o=r.get(i.selectors),a=i.state,s=i.selectorsAdd,l=n.atRuleType,c=n.atRuleParams;return o&&this.get(o,a,c,{selectorsAdd:s,atRule:l})},setIdRule:function(e){var n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},i=r.state||"",o=r.mediaText||t.getCurrentMedia(),a=t.get("SelectorManager"),s=a.add({name:e,type:y.a.TYPE_ID}),l=this.add(s,i,o);return l.setStyle(n,r),l},getIdRule:function(e){var n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},r=n.state||"",i=n.mediaText||t.getCurrentMedia(),o=t.get("SelectorManager").get(e,y.a.TYPE_ID);return o&&this.get(o,r,i)},setClassRule:function(e){var n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},r=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},i=r.state||"",o=r.mediaText||t.getCurrentMedia(),a=t.get("SelectorManager"),s=a.add({name:e,type:y.a.TYPE_CLASS}),l=this.add(s,i,o);return l.setStyle(n,r),l},getClassRule:function(e){var n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},r=n.state||"",i=n.mediaText||t.getCurrentMedia(),o=t.get("SelectorManager").get(e,y.a.TYPE_CLASS);return o&&this.get(o,r,i)},render:function(){return n.render().el}}}},function(t,e,n){"use strict";n.r(e);var r,i=n(6),o=n.n(i),a=n(8),s=n.n(a),l=n(2),c=n.n(l),u=n(3),h=n(13),d=n.n(h),f=n(14),p=n.n(f),g=n(0),v=function(){function t(e){d()(this,t),this.em=e;var n=e.get("DomComponents").getWrapper().getEl();return this.el=n,this.counter=0,Object(g.bindAll)(this,"handleDragEnter","handleDragOver","handleDrop","handleDragLeave"),Object(u.p)(n,"dragenter",this.handleDragEnter),Object(u.p)(n,"dragover",this.handleDragOver),Object(u.p)(n,"drop",this.handleDrop),Object(u.p)(n,"dragleave",this.handleDragLeave),this}return p()(t,[{key:"endDrop",value:function(t,e){var n=this.em,r=this.dragStop;this.counter=0,this.over=0,r&&r(t),n.runDefault(),n.trigger("canvas:dragend",e)}},{key:"handleDragLeave",value:function(t){this.updateCounter(-1,t)}},{key:"updateCounter",value:function(t,e){this.counter+=t,0===this.counter&&this.endDrop(1,e)}},{key:"handleDragEnter",value:function(t){var e=this,n=this.em,r=t.dataTransfer;if(this.updateCounter(1,t),!this.over){this.over=1;var i,o,a=n.get("Utils"),s=n.get("Canvas"),l=s.getBody(),c=n.get("dragContent")||"
";if(n.stopDefault(),n.inAbsoluteMode()){var u=n.get("DomComponents").getWrapper(),h=u.append({})[0],d=n.get("Commands").run("core:component-drag",{event:t,guidesInfo:1,center:1,target:h,onEnd:function(t,n,i){if(!i.cancelled){var o=u.append(c)[0],a=h.getStyle(),s=a.left,l=a.top,d=a.position;o.setStyle({left:s,top:l,position:d}),e.handleDragEnd(o,r)}h.remove()}});i=function(e){return d.stop(t,{cancel:e})},o=function(t){return c=t}}else{var f=new a.Sorter({em:n,wmargin:1,nested:1,canvasRelative:1,direction:"a",container:l,placer:s.getPlacerEl(),containerSel:"*",itemSel:"*",pfx:"gjs-",onEndMove:function(t){return e.handleDragEnd(t,r)},document:s.getFrameEl().contentDocument});f.setDropContent(c),f.startSort(),this.sorter=f,i=function(t){t&&(f.moved=0),f.endMove()},o=function(t){return f.setDropContent(t)}}this.dragStop=i,this.dragContent=o,n.trigger("canvas:dragenter",r,c)}}},{key:"handleDragEnd",value:function(t,e){if(t){var n=this.em;n.set("dragResult",t),n.trigger("canvas:drop",e,t)}}},{key:"handleDragOver",value:function(t){t.preventDefault(),this.em.trigger("canvas:dragover",t)}},{key:"handleDrop",value:function(t){t.preventDefault();var e=this.dragContent,n=t.dataTransfer,r=this.getContentByData(n).content;t.target.style.border="",r&&e&&e(r),this.endDrop(!r,t)}},{key:"getContentByData",value:function(t){var e=this.em,n=t.types,r=t.files||[],i=e.get("dragContent"),o=t.getData("text");if(r.length){o=[];for(var a=0;a=0)o=t.getData("text/html").replace(/<\/?meta[^>]*>/g,"");else if(Object(g.indexOf)(n,"text/uri-list")>=0)o={type:"link",attributes:{href:o},content:o};else if(Object(g.indexOf)(n,"text/json")>=0){var c=t.getData("text/json");c&&(o=JSON.parse(c))}var u={content:o};return e.trigger("canvas:dragdata",t,u),u}}]),t}(),m={stylePrefix:"cv-",scripts:[],styles:[],customBadgeLabel:"",autoscrollLimit:50,notTextable:["button","a","input[type=checkbox]","input[type=radio]"]},y=n(1),b=n.n(y),w=b.a.Model.extend({defaults:{wrapper:"",width:"",height:"",head:"",attributes:{}},initialize:function(){this.set("head",[])},getHead:function(){return s()(this.get("head"))},setHead:function(t){return this.set("head",s()(t))},addHeadItem:function(t){var e=this.getHead();e.push(t),this.setHead(e)},getHeadByAttr:function(t,e,n){return this.getHead().filter((function(r){return r.attributes&&r.attributes[t]==e&&(!n||n===r.tag)}))[0]},removeHeadByAttr:function(t,e,n){var r=this.getHead(),i=this.getHeadByAttr(t,e,n),o=r.indexOf(i);o>=0&&(r.splice(o,1),this.setHead(r))},addLink:function(t){!this.getHeadByAttr("href",t,"link")&&this.addHeadItem({tag:"link",attributes:{href:t,rel:"stylesheet"}})},removeLink:function(t){this.removeHeadByAttr("href",t,"link")},addScript:function(t){!this.getHeadByAttr("src",t,"script")&&this.addHeadItem({tag:"script",attributes:{src:t}})},removeScript:function(t){this.removeHeadByAttr("src",t,"script")}}),x=b.a.Model.extend({defaults:{frame:"",wrapper:"",rulers:!1,zoom:100,x:0,y:0},initialize:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=t.styles,n=void 0===e?[]:e,r=t.scripts,i=void 0===r?[]:r,o=new w;n.forEach((function(t){return o.addLink(t)})),i.forEach((function(t){return o.addScript(t)})),this.set("frame",o),this.listenTo(this,"change:zoom",this.onZoomChange)},onZoomChange:function(){this.get("zoom")<1&&this.set("zoom",1)}}),C=n(11),O="transitionend oTransitionEnd transitionend webkitTransitionEnd",S=b.a.View.extend({tagName:"iframe",attributes:{allowfullscreen:"allowfullscreen"},initialize:function(t){Object(g.bindAll)(this,"updateOffset"),this.config=t.config||{},this.ppfx=this.config.pStylePrefix||"",this.em=this.config.em,this.listenTo(this.model,"change:head",this.updateHead),this.listenTo(this.em,"change:device",this.updateDim)},updateHead:function(){var t=this.getHead();Object(C.c)(t),Object(C.b)(t,this.model.getHead())},updateDim:function(){var t=this.em,e=this.el,n=this.$el,r=e.style,i=t.getDeviceModel(),o=r.width||"",a=r.height||"",s=i?i.get("width"):"",l=i?i.get("height"):"",c=o==s&&a==l;r.width=s,r.height=l,this.updateOffset(),t.stopDefault({preserveSelected:1}),c?this.updateOffset():n.on(O,this.updateOffset)},updateOffset:function(){var t=this.em,e=t.get("Canvas").getOffset();t.set("canvasOffset",e),t.runDefault({preserveSelected:1}),this.$el.off(O,this.updateOffset)},getDoc:function(){return this.$el.get(0).contentDocument},getHead:function(){return this.getDoc().querySelector("head")},getBody:function(){return this.getDoc().querySelector("body")},getWrapper:function(){return this.$el.contents().find("body > div")},render:function(){return this.$el.attr({class:this.ppfx+"frame"}),this}}),k=b.a.$,T=b.a.View.extend({events:{wheel:"onWheel"},template:function(){var t=this.pfx;return'\n
\n
\n ')},initialize:function(t){Object(g.bindAll)(this,"renderBody","onFrameScroll","clearOff","onKeyPress"),Object(u.p)(window,"scroll resize",this.clearOff);var e=this.model;this.config=t.config||{},this.em=this.config.em||{},this.pfx=this.config.stylePrefix||"",this.ppfx=this.config.pStylePrefix||"",this.className=this.config.stylePrefix+"canvas",this.listenTo(this.em,"change:canvasOffset",this.clearOff),this.listenTo(e,"change:zoom change:x change:y",this.updateFrames),this.toggleListeners(1),this.frame=new S({model:this.model.get("frame"),config:this.config})},remove:function(){b.a.View.prototype.remove.apply(this,arguments),this.toggleListeners()},preventDefault:function(t){t&&(t.preventDefault(),t._parentEvent&&t._parentEvent.preventDefault())},toggleListeners:function(t){var e=t?"on":"off";({on:u.p,off:u.o})[e](document,"keypress",this.onKeyPress)},onKeyPress:function(t){var e=this.em;" "===Object(u.e)(t)&&1!==e.getZoomDecimal()&&(this.preventDefault(t),e.get("Editor").runCommand("core:canvas-move"))},onWheel:function(t){if((t.ctrlKey||t.metaKey)&&this.em.getConfig("multiFrames")){this.preventDefault(t);var e=this.model,n=Math.max(-1,Math.min(1,t.wheelDelta||-t.detail)),r=e.get("zoom");e.set("zoom",r+2*n)}},updateFrames:function(t){var e=this.em,n=this.model.attributes,i=n.x,o=n.y,a=this.getZoom(),s={preserveSelected:1},l=a?1/a:1;this.framesArea.style.transform="scale(".concat(a,") translate(").concat(i*l,"px, ").concat(o*l,"px)"),this.clearOff(),this.onFrameScroll(),e.stopDefault(s),e.trigger("canvas:update",t),r&&clearTimeout(r),r=setTimeout((function(){return e.runDefault(s)}))},getZoom:function(){return this.em.getZoomDecimal()},isElInViewport:function(t){var e=Object(u.c)(Object(u.d)(t)),n=this.getFrameOffset(),r=e.top,i=e.left;return r>=0&&i>=0&&r<=n.height&&i<=n.width},onFrameScroll:function(){var t=this.frame.el.contentDocument.body,e=this.getZoom();this.toolsEl.style.top="-"+t.scrollTop*e+"px",this.toolsEl.style.left="-"+t.scrollLeft*e+"px",this.em.trigger("canvasScroll")},renderScripts:function(){var t=this.frame,e=this;t.el.onload=function(){!function n(r){if(r.length>0){var i=document.createElement("script");i.type="text/javascript",i.src=r.shift(),i.onerror=i.onload=n.bind(null,r),t.el.contentDocument.head.appendChild(i)}else e.renderBody()}(e.config.scripts.slice(0))}},renderBody:function(){var t=this,e=this.config,n=(this.model,this.model.get("frame").get("wrapper")),r=e.em;if(n){var i=r.get("Canvas"),o=this.ppfx,a=k(i.getBody()),s=k(i.getDocument().head),l=r.get("CssComposer"),c=r.get("Config"),u="";e.styles.forEach((function(t){u+='')}));var h="\n ".concat(r.config.baseCss||"","\n\n .").concat(o,"dashed *[data-highlightable] {\n outline: 1px dashed rgba(170,170,170,0.7);\n outline-offset: -2px;\n }\n\n .").concat(o,"comp-selected {\n outline: 3px solid #3b97e3 !important;\n outline-offset: -3px;\n }\n\n .").concat(o,"comp-selected-parent {\n outline: 2px solid ").concat("#ffca6f"," !important\n }\n\n .").concat(o,"no-select {\n user-select: none;\n -webkit-user-select:none;\n -moz-user-select: none;\n }\n\n .").concat(o,"freezed {\n opacity: 0.5;\n pointer-events: none;\n }\n\n .").concat(o,"no-pointer {\n pointer-events: none;\n }\n\n .").concat(o,"plh-image {\n background: #f5f5f5;\n border: none;\n height: 100px;\n width: 100px;\n display: block;\n outline: 3px solid #ffca6f;\n cursor: pointer;\n outline-offset: -2px\n }\n\n .").concat(o,"grabbing {\n cursor: grabbing;\n cursor: -webkit-grabbing;\n }\n\n .").concat(o,"is__grabbing {\n overflow-x: hidden;\n }\n\n .").concat(o,"is__grabbing,\n .").concat(o,"is__grabbing * {\n cursor: grabbing !important;\n }\n\n ").concat(c.canvasCss||"","\n ").concat(c.protectedCss||"","\n ");u&&s.append(u),a.append(""),a.append(n.render()).append(l.render()),a.append(this.getJsContainer()),r.trigger("loaded"),this.frame.el.contentWindow.onscroll=this.onFrameScroll,this.frame.updateOffset(),a.on("click",(function(t){return t&&"A"==t.target.tagName&&t.preventDefault()})),a.on("submit",(function(t){return t&&t.preventDefault()}));document;var d=this.frame.el.contentDocument;[{event:"keydown keyup keypress",class:"KeyboardEvent"},{event:"wheel",class:"WheelEvent"}].forEach((function(e){return e.event.split(" ").forEach((function(n){d.addEventListener(n,(function(n){return t.el.dispatchEvent(function(t,e){var n;try{n=new window[e](t.type,t)}catch(t){(n=document.createEvent(e)).initEvent(t.type,!0,!0)}return n.keyCodeVal=t.keyCode,n._parentEvent=t,["keyCode","which"].forEach((function(t){Object.defineProperty(n,t,{get:function(){return this.keyCodeVal}})})),n}(n,e.class))}))}))}))}},offset:function(t){var e=Object(u.c)(t),n=t.ownerDocument.body;return{top:e.top+n.scrollTop,left:e.left+n.scrollLeft,width:e.width,height:e.height}},clearOff:function(){this.frmOff=null,this.cvsOff=null},getFrameOffset:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:0;return this.frmOff&&!t||(this.frmOff=this.offset(this.frame.el)),this.frmOff},getCanvasOffset:function(){return this.cvsOff||(this.cvsOff=this.offset(this.el)),this.cvsOff},getElementPos:function(t,e){var n=this.getZoom(),r=e||{},i=this.getFrameOffset(),o=this.getCanvasOffset(),a=this.offset(t),s=r.avoidFrameOffset?0:i.top,l=r.avoidFrameOffset?0:i.left;return{top:a.top*n+s-o.top,left:a.left*n+l-o.left,height:a.height*n,width:a.width*n,zoom:n,rect:a}},getElementOffsets:function(t){var e=this;if(!t||Object(u.l)(t))return{};var n={},r=window.getComputedStyle(t);return["marginTop","marginRight","marginBottom","marginLeft","paddingTop","paddingRight","paddingBottom","paddingLeft"].forEach((function(t){n[t]=parseFloat(r[t])*e.getZoom()})),n},getPosition:function(){var t=this.frame.el.contentDocument;if(t){var e=t.body,n=this.getZoom(),r=this.getFrameOffset(),i=this.getCanvasOffset();return{top:r.top+e.scrollTop*n-i.top,left:r.left+e.scrollLeft*n-i.left,width:i.width,height:i.height}}},updateScript:function(t){var e=t.model,n=e.getId();t.scriptContainer||(t.scriptContainer=k('
')),this.getJsContainer().appendChild(t.scriptContainer.get(0))),t.el.id=n,t.scriptContainer.html("");var r=document.createElement("script");r.innerHTML="\n setTimeout(function() {\n var item = document.getElementById('".concat(n,"');\n if (!item) return;\n (function(){\n ").concat(e.getScriptString(),";\n }.bind(item))()\n }, 1);"),setTimeout((function(){return t.scriptContainer.get(0).appendChild(r)}),0)},getJsContainer:function(){return this.jsContainer||(this.jsContainer=k('
')).get(0)),this.jsContainer},render:function(){var t=this.el,e=this.$el,n=this.ppfx,r=this.model;this.wrapper=r.get("wrapper"),e.html(this.template());var i=e.find("[data-frames]");if(this.framesArea=i.get(0),this.wrapper&&"function"==typeof this.wrapper.render){r.get("frame").set("wrapper",this.wrapper),i.append(this.frame.render().el);var o=this.frame;0===this.config.scripts.length?o.el.onload=this.renderBody:this.renderScripts()}e.find("[data-tools]").append('\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n '));var a=t.querySelector("#".concat(n,"tools"));return this.hlEl=t.querySelector(".".concat(n,"highlighter")),this.badgeEl=t.querySelector(".".concat(n,"badge")),this.placerEl=t.querySelector(".".concat(n,"placeholder")),this.ghostEl=t.querySelector(".".concat(n,"ghost")),this.toolbarEl=t.querySelector(".".concat(n,"toolbar")),this.resizerEl=t.querySelector(".".concat(n,"resizer")),this.offsetEl=t.querySelector(".".concat(n,"offset-v")),this.fixedOffsetEl=t.querySelector(".".concat(n,"offset-fixed-v")),this.toolsEl=a,this.el.className=this.className,this}});function P(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function j(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{};r=j({},m,{},e),this.em=r.em;var i=r.pStylePrefix;i&&(r.stylePrefix=i+r.stylePrefix),t=new x(e),n=new T({model:t,config:r});var o=r.em.get("DomComponents");return o&&this.setWrapper(o),this.startAutoscroll=this.startAutoscroll.bind(this),this.stopAutoscroll=this.stopAutoscroll.bind(this),this.autoscroll=this.autoscroll.bind(this),this.updateClientY=this.updateClientY.bind(this),this},getConfig:function(){return r},setWrapper:function(e){t.set("wrapper",e)},getElement:function(){return n.el},getFrame:function(){return t.get("frame")},getFrameEl:function(){return n.frame.el},getWindow:function(){return this.getFrameEl().contentWindow},getDocument:function(){return this.getFrameEl().contentDocument},getBody:function(){var t=this.getDocument();return t&&t.body},getWrapperEl:function(){var t=this.getBody();return t&&t.querySelector("#wrapper")},getToolsEl:function(){return n.toolsEl},getHighlighter:function(){return n.hlEl},getBadgeEl:function(){return n.badgeEl},getPlacerEl:function(){return n.placerEl},getGhostEl:function(){return n.ghostEl},getToolbarEl:function(){return n.toolbarEl},getResizerEl:function(){return n.resizerEl},getOffsetViewerEl:function(){return n.offsetEl},getFixedOffsetViewerEl:function(){return n.fixedOffsetEl},render:function(){return n.render().el},getOffset:function(){var t=this.offset(this.getFrameEl()),e=this.offset(this.getElement());return{top:t.top-e.top,left:t.left-e.left}},offset:function(t){return n.offset(t)},setCustomBadgeLabel:function(t){r.customBadgeLabel=t},getElementPos:function(t,e){return n.getElementPos(t,e)},getElementOffsets:function(t){return n.getElementOffsets(t)},getRect:function(){var t=n.getPosition(),e=t.top,r=t.left;return j({},n.getCanvasOffset(),{topScroll:e,leftScroll:r})},getTargetToElementDim:function(t,e){var i=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},o=i||{},a=n.getPosition();if(a){var s=o.elPos||n.getElementPos(e),l=i.toRight||0,c=o.targetHeight||t.offsetHeight,u=o.targetWidth||t.offsetWidth,h=o.event||null,d=s.top-c,f=s.left;f+=l?s.width:0;var p=(f=l?f-u:f)s.top+s.height?s.top+s.height:g,left:p,elementTop:s.top,elementLeft:s.left,elementWidth:s.width,elementHeight:s.height,targetWidth:t.offsetWidth,targetHeight:t.offsetHeight,canvasTop:a.top,canvasLeft:a.left,canvasWidth:a.width,canvasHeight:a.height};return h&&r.em&&r.em.trigger(h,v),v}},getMouseRelativePos:function(t,e){var n=0,r=0,i=(e||{}).subWinOffset,o=t.target.ownerDocument,a=o.defaultView||o.parentWindow,s=a.frameElement,l=i?a.pageYOffset:0,c=i?a.pageXOffset:0;if(s){var u=s.getBoundingClientRect();n=u.top||0,r=u.left||0}return{y:t.clientY+n-l,x:t.clientX+r-c}},getMouseRelativeCanvas:function(t){var e=this.getZoomDecimal(),r=n.getPosition(),i=r.top,o=r.left;return{y:t.clientY*e+i,x:t.clientX*e+o}},hasFocus:function(){return this.getDocument().hasFocus()},isInputFocused:function(){var t=this.getDocument(),e=["body"].concat(s()(this.getConfig().notTextable)),n=t&&t.activeElement;return n&&!e.some((function(t){return n.matches(t)}))},scrollTo:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=Object(u.d)(t),r=this.getCanvasView();if(n&&(!r.isElInViewport(n)||e.force)){var i="object"===o()(e)?e:{behavior:"smooth",block:"nearest"};n.scrollIntoView(i)}},startAutoscroll:function(){var t=this;this.dragging=1;var r=this.getScrollListeners();e=n.getFrameOffset(1),setTimeout((function(){Object(u.p)(r,"mousemove dragover",t.updateClientY),Object(u.p)(r,"mouseup",t.stopAutoscroll),E(t.autoscroll)}),0)},updateClientY:function(t){t.preventDefault(),this.lastClientY=Object(u.g)(t).clientY*this.getZoomDecimal()},autoscroll:function(){if(this.dragging){var t=this.getFrameEl().contentWindow,n=t.document.body.scrollTop,r=this.lastClientY,i=this.getConfig().autoscrollLimit,o=e.height-i;ro&&(n+=r-o),t.scrollTo(0,n),E(this.autoscroll)}},stopAutoscroll:function(){this.dragging=0;var t=this.getScrollListeners();Object(u.o)(t,"mousemove dragover",this.updateClientY),Object(u.o)(t,"mouseup",this.stopAutoscroll)},getScrollListeners:function(){return[this.getFrameEl().contentWindow]},postRender:function(){Object(u.i)(r.em)&&(this.droppable=new v(r.em))},setZoom:function(e){return t.set("zoom",parseFloat(e)),this},getZoom:function(){return parseFloat(t.get("zoom"))},getZoomDecimal:function(){return this.getZoom()/100},getZoomMultiplier:function(){var t=this.getZoomDecimal();return t?1/t:1},getFrameWrapperEl:function(){return n.frame.getWrapper()}}}},function(t,e,n){"use strict";n.r(e);var r={devices:[],deviceLabel:"Device"},i=n(1),o=n.n(i),a=o.a.Model.extend({idAttribute:"name",defaults:{name:"",width:null,height:"",widthMedia:null,priority:null},initialize:function(){var t=this;null===this.get("widthMedia")&&this.set("widthMedia",this.get("width")),null===this.get("width")&&this.set("width",this.get("widthMedia")),!this.get("priority")&&this.set("priority",parseFloat(this.get("widthMedia"))||0);["width","height","widthMedia"].forEach((function(e){return t.checkUnit(e)}))},checkUnit:function(t){var e=this.get(t)||"";(parseFloat(e)||0).toString()===e.toString()&&this.set(t,"".concat(e,"px"))}}),s=o.a.Collection.extend({model:a,comparator:function(t,e){var n=Number.MAX_VALUE;return(e.get("priority")||n)-(t.get("priority")||n)},getSorted:function(){return this.sort()}}),l=n(0),c=o.a.View.extend({template:Object(l.template)('\n
<%= deviceLabel %>
\n
\n \n \n \n
\n
\n
\n
\n '),events:{change:"updateDevice"},initialize:function(t){this.config=t.config||{},this.em=this.config.em,this.ppfx=this.config.pStylePrefix||"",this.events["click ."+this.ppfx+"add-trasp"]=this.startAdd,this.listenTo(this.em,"change:device",this.updateSelect),this.delegateEvents()},startAdd:function(){},updateDevice:function(){var t=this.em;if(t){var e=this.devicesEl,n=e?e.val():"";t.set("device",n)}},updateSelect:function(){var t=this.em,e=this.devicesEl;if(t&&t.getDeviceModel&&e){var n=t.getDeviceModel(),r=n?n.get("name"):"";e.val(r)}},getOptions:function(){var t="";return this.collection.each((function(e){var n=e.get("name");t+='"})),t},render:function(){var t=this.ppfx;return this.$el.html(this.template({ppfx:t,deviceLabel:this.config.deviceLabel})),this.devicesEl=this.$el.find("."+t+"devices"),this.devicesEl.append(this.getOptions()),this.el.className=t+"devices-c",this}});e.default=function(){var t,e,n={};return{name:"DeviceManager",init:function(i){for(var o in n=i||{},r)o in n||(n[o]=r[o]);return t=new s(n.devices),e=new c({collection:t,config:n}),this},add:function(e,n,r){var i=r||{};return i.name=e,i.width=n,t.add(i)},get:function(e){return t.get(e)},getAll:function(){return t},render:function(){return e.render().el}}}},function(t,e,n){"use strict";n.r(e);var r=n(2),i=n.n(r),o={stylePrefix:"mdl-",title:"",content:"",backdrop:!0},a=n(1),s=n.n(a),l=s.a.Model.extend({defaults:{title:"",content:"",open:!1}}),c=s.a.View.extend({template:function(t){var e=t.pfx,n=t.ppfx,r=t.content,i=t.title;return'
\n
\n
').concat(i,'
\n
\n
\n
\n
').concat(r,'
\n
\n
\n
\n ')},events:{click:"onClick","click [data-close-modal]":"hide"},initialize:function(t){var e=this.model,n=t.config||{},r=n.stylePrefix||"";this.config=n,this.pfx=r,this.ppfx=n.pStylePrefix||"",this.listenTo(e,"change:open",this.updateOpen),this.listenTo(e,"change:title",this.updateTitle),this.listenTo(e,"change:content",this.updateContent)},onClick:function(t){this.config.backdrop&&t.target===this.el&&this.hide()},getCollector:function(){return this.$collector||(this.$collector=this.$el.find("."+this.pfx+"collector")),this.$collector},getContent:function(){var t=this.pfx;return this.$content||(this.$content=this.$el.find(".".concat(t,"content #").concat(t,"c"))),this.$content},getTitle:function(){return this.$title||(this.$title=this.$el.find("."+this.pfx+"title")),this.$title.get(0)},updateContent:function(){var t=this.getContent(),e=t.children(),n=this.getCollector(),r=this.model.get("content");e.length&&n.append(e),t.empty().append(r)},updateTitle:function(){var t=this.getTitle();t&&(t.innerHTML=this.model.get("title"))},updateOpen:function(){this.el.style.display=this.model.get("open")?"":"none"},hide:function(){this.model.set("open",0)},show:function(){this.model.set("open",1)},render:function(){var t=this.$el,e=this.pfx,n=(this.ppfx,this.model.toJSON());return n.pfx=this.pfx,n.ppfx=this.ppfx,t.html(this.template(n)),t.attr("class","".concat(e,"container")),this.updateOpen(),this}});function u(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function h(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{},a=(n=h({},o,{},i)).em;this.em=a;var s=n.pStylePrefix;return s&&(n.stylePrefix=s+n.stylePrefix),(t=new l(n)).on("change:open",(function(t,e){return r(e,a)})),e=new c({model:t,config:n}),this},postRender:function(t){var e=t.model.getConfig().el||t.el;this.render().appendTo(e)},open:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};return t.title&&this.setTitle(t.title),t.content&&this.setContent(t.content),e.show(),this},close:function(){return e.hide(),this},onceClose:function(t){return this.em.once("modal:close",t),this},onceOpen:function(t){return this.em.once("modal:open",t),this},isOpen:function(){return!!t.get("open")},setTitle:function(e){return t.set("title",e),this},getTitle:function(){return t.get("title")},setContent:function(e){return t.set("content"," "),t.set("content",e),this},getContent:function(){return t.get("content")},getContentEl:function(){return e.getContent().get(0)},getModel:function(){return t},render:function(){return e.render().$el}}}},function(t,e,n){"use strict";n.r(e);var r=n(2),i=n.n(r),o=n(0),a={stylePrefix:"clm-",appendTo:"",selectors:[],label:"Classes",statesLabel:"- State -",selectedLabel:"Selected",states:[{name:"hover",label:"Hover"},{name:"active",label:"Click"},{name:"nth-of-type(2n)",label:"Even/Odd"}],escapeName:0},s=n(7),l=n(9),c=n(1),u=n.n(c),h=u.a.View.extend({template:function(){var t=this.pfx,e=(this.ppfx,this.model.get("label")||"");return'\n \n ').concat(e,'\n \n ⨯\n \n ')},events:{"click [data-tag-remove]":"removeTag","click [data-tag-status]":"changeStatus","dblclick [data-tag-name]":"startEditTag","focusout [data-tag-name]":"endEditTag"},initialize:function(t){var e=t.config||{};this.config=e,this.coll=t.coll||null,this.pfx=e.stylePrefix||"",this.ppfx=e.pStylePrefix||"",this.em=e.em,this.listenTo(this.model,"change:active",this.updateStatus)},getInputEl:function(){return this.inputEl||(this.inputEl=this.el.querySelector("[data-tag-name]")),this.inputEl},startEditTag:function(){var t=this.em,e=this.getInputEl();e.contentEditable=!0,e.focus(),t&&t.setEditing(1)},endEditTag:function(){var t=this.model,e=this.getInputEl(),n=e.textContent,r=this.em,i=r&&r.get("SelectorManager");if(e.contentEditable=!1,r&&r.setEditing(0),i){var o=i.escapeName(n);i.get(o)?e.innerText=t.get("label"):t.set({name:o,label:n})}},changeStatus:function(){var t=this.model;t.set("active",!t.get("active"))},removeTag:function(){var t=this.em,e=this.model,n=t&&t.getSelected();!e.get("protected")&&n&&n.getSelectors().remove(e)},updateStatus:function(){var t=this.model,e=this.$el,n="fa-check-square-o",r=e.find("[data-tag-status]");t.get("active")?(r.removeClass("fa-square-o").addClass(n),e.removeClass("opac50")):(r.removeClass(n).addClass("fa-square-o"),e.addClass("opac50"))},render:function(){var t=this.pfx,e=this.ppfx;return this.$el.html(this.template()),this.$el.attr("class","".concat(t,"tag ").concat(e,"three-bg")),this.updateStatus(),this}}),d=u.a.View.extend({template:Object(o.template)('\n
\n
<%= label %>
\n
\n \n
\n \n \n \n
\n
\n
\n
\n
\n
\n
\n
\n
\n \n \n
\n
\n
<%= selectedLabel %>
\n
\n
\n
'),events:{},initialize:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};this.config=t.config||{},this.pfx=this.config.stylePrefix||"",this.ppfx=this.config.pStylePrefix||"",this.className=this.pfx+"tags",this.addBtnId=this.pfx+"add-tag",this.newInputId=this.pfx+"new",this.stateInputId=this.pfx+"states",this.stateInputC=this.pfx+"input-c",this.states=this.config.states||[],this.events["click #"+this.addBtnId]="startNewTag",this.events["blur #"+this.newInputId]="endNewTag",this.events["keyup #"+this.newInputId]="onInputKeyUp",this.events["change #"+this.stateInputId]="stateChanged";var e=this.config.em,n=this.getStyleEmitter();this.target=this.config.em,this.em=e,this.listenTo(n,"styleManager:update",this.componentChanged),this.listenTo(e,"component:toggled component:update:classes",this.componentChanged),this.listenTo(e,"component:update:classes",this.updateSelector),this.listenTo(this.collection,"add",this.addNew),this.listenTo(this.collection,"reset",this.renderClasses),this.listenTo(this.collection,"remove",this.tagRemoved),this.delegateEvents()},getStyleEmitter:function(){var t=this.em,e=t&&t.get("StyleManager");return e&&e.getEmitter()||{}},tagRemoved:function(t){this.updateStateVis()},getStateOptions:function(){for(var t="",e=0;e'+this.states[e].label+"";return t},addNew:function(t){this.addToClasses(t)},startNewTag:function(t){this.$addBtn.get(0).style.display="none",this.$input.show().focus()},endNewTag:function(t){this.$addBtn.get(0).style.display="",this.$input.hide().val("")},onInputKeyUp:function(t){13===t.keyCode?this.addNewTag(this.$input.val()):27===t.keyCode&&this.endNewTag()},componentChanged:Object(o.debounce)((function(t){t=t||this.getTarget(),this.compTarget=t;var e=[];if(t){var n=t.get("state");n&&this.getStates().val(n),e=t.getSelectors().getValid()}this.collection.reset(e),this.updateStateVis(t)})),getTarget:function(){return this.target.getSelected()},updateStateVis:function(t){var e=this.em,n=e&&e.getConfig("avoidInlineStyle"),r=this.collection.length||n?"block":"none";this.getStatesC().css("display",r),this.updateSelector(t)},updateSelector:function(t){var e=this.pfx,n=this.collection,r=this.el,i=t||this.getTarget();if(this.compTarget=i,i&&i.get){var o=i.get("state"),a=n.getFullString(i.getSelectors().getStyleable());a=a||i.get("selectorsAdd")||(i.getId?"#".concat(i.getId()):""),a+=o?":".concat(o):"";var s=r.querySelector("#".concat(e,"sel"));s&&(s.innerHTML=a)}},stateChanged:function(t){this.compTarget&&(this.compTarget.set("state",this.$states.val()),this.updateSelector())},addNewTag:function(t){var e=this.target,n=this.compTarget;if(t.trim()){if(e){var r=e.get("SelectorManager").add({label:t});if(n)n.getSelectors().add(r),this.collection.add(r),this.updateStateVis()}this.endNewTag()}},addToClasses:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null,n=e,r=this.getClasses(),i=new h({model:t,config:this.config,coll:this.collection}).render().el;return n?n.appendChild(i):r.append(i),i},renderClasses:function(){var t=this,e=document.createDocumentFragment(),n=this.getClasses();n.empty(),this.collection.each((function(n){return t.addToClasses(n,e)})),n.append(e)},getClasses:function(){return this.$el.find("#".concat(this.pfx,"tags-c"))},getStates:function(){return this.$states||(this.$states=this.$el.find("#"+this.stateInputId)),this.$states},getStatesC:function(){return this.$statesC||(this.$statesC=this.$el.find("#"+this.stateInputC)),this.$statesC},render:function(){var t=this.ppfx,e=this.config,n=this.$el;return n.html(this.template({selectedLabel:e.selectedLabel,statesLabel:e.statesLabel,label:e.label,pfx:this.pfx,ppfx:this.ppfx})),this.$input=n.find("input#"+this.newInputId),this.$addBtn=n.find("#"+this.addBtnId),this.$classes=n.find("#"+this.pfx+"tags-c"),this.$states=n.find("#"+this.stateInputId),this.$statesC=n.find("#"+this.stateInputC),this.$states.append(this.getStateOptions()),this.renderClasses(),n.attr("class","".concat(this.className," ").concat(t,"one-bg ").concat(t,"two-color")),this}});function f(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function p(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{},i=(r=p({},a,{},t)).em,o=r.pStylePrefix;return o&&(r.stylePrefix=o+r.stylePrefix),n=new d({collection:new l.a([],{em:i,config:r}),config:r}),(e=new l.a(r.selectors)).on("add",(function(t){return i.trigger("selector:add",t)})),this},postRender:function(){var t=this.getConfig().appendTo;t&&(Object(o.isElement)(t)?t:document.querySelector(t)).appendChild(this.render([]))},addSelector:function(t){var n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},i=p({},n);Object(o.isObject)(t)?i=t:i.name=t,g(i.name)?(i.name=i.name.substr(1),i.type=s.a.TYPE_ID):v(i.name)&&(i.name=i.name.substr(1)),i.label&&!i.name&&(i.name=this.escapeName(i.label));var a=i.name,l=a?this.get(a,i.type):e.where(i)[0];return l||e.add(i,{config:r})},getSelector:function(t){var n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:s.a.TYPE_CLASS;return g(t)?(t=t.substr(1),n=s.a.TYPE_ID):v(t)&&(t=t.substr(1)),e.where({name:t,type:n})[0]},add:function(t){var e=this,n=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return Object(o.isArray)(t)?t.map((function(t){return e.addSelector(t,n)})):this.addSelector(t,n)},addClass:function(t){var e=this,n=[];return Object(o.isString)(t)&&(t=t.trim().split(" ")),t.forEach((function(t){return n.push(e.addSelector(t))})),n},get:function(t,e){var n=this;if(Object(o.isArray)(t)){var r=[];return t.map((function(t){return n.getSelector(t)})).filter((function(t){return t})).forEach((function(t){return r.indexOf(t)<0&&r.push(t)})),r}return this.getSelector(t,e)},getAll:function(){return e},escapeName:function(t){var e=r.escapeName;return e?e(t):s.a.escapeName(t)},render:function(t){return t?new d({collection:new l.a(t),config:r}).render().el:n.render().el}}}},function(t,e,n){"use strict";n.r(e);var r=n(2),i=n.n(r),o={textTags:["br","b","i","u","a","ul","ol"],parserCss:null,parserHtml:null},a=n(0),s={4:"media",5:"font-face",6:"page",7:"keyframes",11:"counter-style",12:"supports",13:"document",14:"font-feature-values",15:"viewport"},l=Object(a.keys)(s),c=["5","6","11","15"],u=["font-face","page","counter-style","viewport"],h=function(){for(var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:"",e=[],n=[],r=t.split(","),i=0,o=r.length;i1&&void 0!==arguments[1]?arguments[1]:{},n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},r={},i=t.length,o=t[i-1],a=o?o.split(/:(.+)/):[],s=a[1],l=n.atRule,c=n.selectorsAdd,h=n.mediaText,d=u.indexOf(l)>=0;return d&&(r.singleAtRule=1),l&&(r.atRuleType=l),c&&(r.selectorsAdd=c),h&&(r.mediaText=h),s&&(t[i-1]=a[0],r.state=s,a.splice(a.length-1,1)),r.selectors=t,r.style=e,r},g=function(t){var e=document.createElement("style");e.innerHTML=t,document.head.appendChild(e);var n=e.sheet;return document.head.removeChild(e),function t(e){for(var n=[],r=e.cssRules||[],i=0,o=r.length;i=0;if(b)g=1,v=s[u],m=f(a);else if(l.indexOf(u)>=0){var w=t(a);m=f(a);for(var x=0,C=w.length;x0&&void 0!==arguments[0]?arguments[0]:{};return{parse:function(e){var n=this,r=[],i=t.parserCss,o=t.em,a=void 0===o?{}:o,s=a&&a.get&&a.get("Editor");return(i?i(e,s):g(e)).forEach((function(t){return r=r.concat(n.checkNode(t))})),r},checkNode:function(t){var e=t,n=e.selectors,r=e.style;if(Object(a.isString)(n)){var i=[],o=h(n),s=o.result,l=o.add.join(", "),c={atRule:t.atRule,mediaText:t.params};if(s.length?s.forEach((function(t){i.push(p(t,r,c))})):i.push(p([],r,c)),l)i[i.length-1].selectorsAdd=l;t=i}return t}}},m=n(26);function y(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function b(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{};return(n=b({},o,{},r)).Parser=this,t=new m.a(n),e=new v(n),this.em=n.em,this.parserCss=e,this.parserHtml=t,this},parseHtml:function(n){var r=this.em,i=this.compTypes;return t.compTypes=r?r.get("DomComponents").getTypes():i,t.parse(n,e)},parseCss:function(t){return e.parse(t)}}}},function(t,e,n){"use strict";n.r(e);var r=n(2),i=n.n(r),o={id:"gjs-",autosave:1,autoload:1,type:"local",stepsBeforeSave:1,storeComponents:1,storeStyles:1,storeHtml:1,storeCss:1,checkLocal:1,params:{},headers:{},urlStore:"",urlLoad:"",beforeSend:function(t,e){},onComplete:function(t,e){},contentTypeJson:!0,credentials:"include",fetchOptions:""},a=n(1),s=n.n(a),l=s.a.Model.extend({defaults:{checkLocal:!0},store:function(t,e){for(var n in this.checkStorageEnvironment(),t)localStorage.setItem(n,t[n]);"function"==typeof e&&e()},load:function(t,e){this.checkStorageEnvironment();for(var n={},r=0,i=t.length;r1&&void 0!==arguments[1]?arguments[1]:{},o=arguments.length>2&&void 0!==arguments[2]?arguments[2]:null,a=arguments.length>3&&void 0!==arguments[3]?arguments[3]:null,s=this.get("contentTypeJson"),l=this.get("headers")||{},c=this.get("params"),h="X-Requested-With",f="Content-Type",p=i.body||{};for(var g in c)p[g]=c[g];if(Object(u.isUndefined)(l[h])&&(l[h]="XMLHttpRequest"),Object(u.isUndefined)(l[f])&&s&&(l[f]="application/json; charset=utf-8"),s)n=JSON.stringify(p);else for(var v in n=new FormData,p)n.append(v,p[v]);"post"===(e={method:i.method||"post",credentials:this.get("credentials"),headers:l}).method&&(e.body=n);var m=this.get("fetchOptions")||{},y=Object(u.isFunction)(m)?m(e):e;this.onStart(),this.fetch(t,d({},e,{},y||{})).then((function(t){return 1==(t.status/200|0)?t.text():t.text().then((function(t){return Promise.reject(t)}))})).then((function(t){return r.onResponse(t,o)})).catch((function(t){return r.onError(t,a)}))}});function p(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function g(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{};return e=g({},o,{},n),t=e.em,e._disable&&(e.type=0),r.remote=new f(e),r.local=new l(e),e.currentStorage=e.type,this.loadDefaultProviders().setCurrent(e.type),this},getConfig:function(){return e},isAutosave:function(){return!!e.autosave},setAutosave:function(t){return e.autosave=!!t,this},getStepsBeforeSave:function(){return e.stepsBeforeSave},setStepsBeforeSave:function(t){return e.stepsBeforeSave=t,this},add:function(t,e){return n[t]=e,this},get:function(t){return n[t]||null},getStorages:function(){return n},getCurrent:function(){return e.currentStorage},setCurrent:function(t){return e.currentStorage=t,this},store:function(t,n){var r=this,i=this.get(this.getCurrent()),o={};for(var a in this.onStart("store",t),t)o[e.id+a]=t[a];return i?i.store(o,(function(t){n&&n(t),r.onEnd("store",t)}),(function(t){r.onError("store",t)})):null},load:function(t,n){var r=this,i=this.get(this.getCurrent()),o=[],a={};"string"==typeof t&&(t=[t]),this.onStart("load",t);for(var s=0,l=t.length;sB",attributes:{title:"Bold"},result:function(t){return t.exec("bold")}},italic:{name:"italic",icon:"I",attributes:{title:"Italic"},result:function(t){return t.exec("italic")}},underline:{name:"underline",icon:"U",attributes:{title:"Underline"},result:function(t){return t.exec("underline")}},strikethrough:{name:"strikethrough",icon:"S",attributes:{title:"Strike-through"},result:function(t){return t.exec("strikeThrough")}},link:{icon:'',name:"link",attributes:{style:"font-size:1.4rem;padding:0 4px 2px;",title:"Link"},result:function(t){var e=t.selection().anchorNode,n=e&&e.nextSibling;n&&"A"==n.nodeName?t.exec("unlink"):t.insertHTML(''.concat(t.selection(),""))}}},p=function(){function t(){var e=this,n=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};a()(this,t);var r=n.el;if(r[d])return r[d];r[d]=this,this.setEl(r),this.updateActiveActions=this.updateActiveActions.bind(this);var i=n.actions||[];i.forEach((function(t,e){"string"==typeof t?t=f[t]:f[t.name]&&(t=h({},f[t.name],{},t)),i[e]=t}));var o=i.length?i:Object.keys(f).map((function(t){return f[t]}));n.classes=h({},{actionbar:"actionbar",button:"action",active:"active"},{},n.classes);var s=n.classes,l=n.actionbar;if(this.actionbar=l,this.settings=n,this.classes=s,this.actions=o,!l){var c=n.actionbarContainer;(l=document.createElement("div")).className=s.actionbar,c.appendChild(l),this.actionbar=l,o.forEach((function(t){return e.addAction(t)}))}return n.styleWithCSS&&this.exec("styleWithCSS"),this.syncActions(),this}return l()(t,[{key:"setEl",value:function(t){this.el=t,this.doc=t.ownerDocument}},{key:"updateActiveActions",value:function(){var t=this;this.getActions().forEach((function(e){var n=e.btn,r=e.update,i=t.classes.active,o=e.name,a=t.doc;n.className=n.className.replace(i,"").trim(),a.queryCommandSupported(o)&&a.queryCommandState(o)&&(n.className+=" ".concat(i)),r&&r(t,e)}))}},{key:"enable",value:function(){return this.enabled?this:(this.actionbarEl().style.display="",this.el.contentEditable=!0,Object(c.p)(this.el,"mouseup keyup",this.updateActiveActions),this.syncActions(),this.updateActiveActions(),this.el.focus(),this.enabled=1,this)}},{key:"disable",value:function(){return this.actionbarEl().style.display="none",this.el.contentEditable=!1,Object(c.o)(this.el,"mouseup keyup",this.updateActiveActions),this.enabled=0,this}},{key:"syncActions",value:function(){var t=this;this.getActions().forEach((function(e){var n=e.event||"click";e.btn["on".concat(n)]=function(n){e.result(t,e),t.updateActiveActions()}}))}},{key:"addAction",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=e.sync,r=document.createElement("span"),i=t.icon,o=t.attributes||{};for(var a in r.className=this.classes.button,t.btn=r,o)r.setAttribute(a,o[a]);"string"==typeof i?r.innerHTML=i:r.appendChild(i),this.actionbarEl().appendChild(r),n&&(this.actions.push(t),this.syncActions())}},{key:"getActions",value:function(){return this.actions}},{key:"selection",value:function(){return this.doc.getSelection()}},{key:"exec",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:null;this.doc.execCommand(t,!1,e)}},{key:"actionbarEl",value:function(){return this.actionbar}},{key:"insertHTML",value:function(t){var e=this.doc,n=e.getSelection();if(n&&n.rangeCount){var r=e.createElement("div"),i=n.getRangeAt(0);i.deleteContents(),r.innerHTML=t,Array.prototype.slice.call(r.childNodes).forEach((function(t){i.insertNode(t),t})),n.removeAllRanges(),n.addRange(i),this.el.focus()}}}]),t}(),g={stylePrefix:"rte-",adjustToolbar:1,actions:["bold","italic","underline","strikethrough","link"]};function v(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function m(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{},i=(r=m({},g,{},e)).pStylePrefix;return i&&(r.stylePrefix=i+r.stylePrefix),this.pfx=r.stylePrefix,r.actions||[],(t=document.createElement("div")).className="".concat(i,"rte-toolbar ").concat(i,"one-bg"),n=this.initRte(document.createElement("div")),Object(c.p)(t,"mousedown",(function(t){return t.stopPropagation()})),this},postRender:function(e){var n=e.model.get("Canvas");t.style.pointerEvents="all",i(),n.getToolsEl().appendChild(t)},initRte:function(e){var i=this.pfx,o=t,a=this.actionbar,s=this.actions||r.actions,l={actionbar:"".concat(i,"actionbar"),button:"".concat(i,"action"),active:"".concat(i,"active")},c=new p({el:e,classes:l,actions:s,actionbar:a,actionbarContainer:o});return n&&n.setEl(e),c.actionbar&&(this.actionbar=c.actionbar),c.actions&&(this.actions=c.actions),c},add:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};e.name=t,n.addAction(e,{sync:1})},get:function(t){var e;return n.getActions().forEach((function(n){n.name==t&&(e=n)})),e},getAll:function(){return n.getActions()},remove:function(t){var e=this.getAll(),n=this.get(t);if(n){var r=n.btn,i=e.indexOf(n);r.parentNode.removeChild(r),e.splice(i,1)}return n},getToolbarEl:function(){return t},updatePosition:function(){var n=r.em.get("Canvas"),i=n.getTargetToElementDim(t,e,{event:"rteToolbarPosUpdate"});if(i){if(r.adjustToolbar){var o=n.getCanvasView().getFrameOffset();i.top<=i.canvasTop&&!(i.elementHeight+i.targetHeight>=o.height)&&(i.top=i.elementTop+i.elementHeight)}var a=t.style;a.top=i.top+"px",a.left=i.left+"px"}},enable:function(n,i){e=n.el;var o=r.em,a=n.getChildrenContainer(),s=this.customRte;if(t.style.display="",i=s?s.enable(a,i):this.initRte(a).enable(),o){setTimeout(this.updatePosition.bind(this),0);var l="change:canvasOffset canvasScroll";o.off(l,this.updatePosition,this),o.on(l,this.updatePosition,this),o.trigger("rte:enable",n,i)}return i},disable:function(t,e){var n=r.em,o=this.customRte,a=t.getChildrenContainer();o?o.disable(a,e):e&&e.disable(),i(),n&&n.trigger("rte:disable",t,e)}}}},function(t,e,n){"use strict";n.r(e);var r=n(17),i=n(2),o=n.n(i),a=n(1),s=n.n(a),l=n(0),c=n(3);function u(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function h(t){for(var e=1;e1&&void 0!==arguments[1]?arguments[1]:{},r=n.target,i=n.avoidChildren,o=void 0===i?1:i,a=this.em,s=this.eV,l=t||s,c=this.dropModel,u=this.dropContent,f=function(t){return t&&r&&t.opt&&t.opt.avoidChildren&&e.isTextableActive(t,r)};if(u&&a){if(f(c)&&(c=null),!c){var p=a.get("DomComponents").getComponents(),g={avoidChildren:o,avoidStore:1,avoidUpdateStyle:1},v=p.add(u,h({},g,{temporary:1}));if(c=(c=p.remove(v,g))instanceof Array?c[0]:c,this.dropModel=c,f(c))return this.getSourceModel(l,{target:r,avoidChildren:0})}return c}return l&&d(l).data("model")},selectTargetModel:function(t){if(!(t instanceof s.a.Collection)){var e=this.targetModel;e&&e.set("status",""),t&&t.set&&(t.set("status","selected-parent"),this.targetModel=t)}},onMove:function(t){var e=t,n=this.em,r=this.onMoveClb,i=this.plh;this.moved=1;var o=i.style.display;o&&"none"!==o||(i.style.display="block");var a=this.offset(this.el);this.elT=this.wmargin?Math.abs(a.top):a.top,this.elL=this.wmargin?Math.abs(a.left):a.left;var s=t.pageY-this.elT+this.el.scrollTop,c=t.pageX-this.elL+this.el.scrollLeft;if(this.canvasRelative&&n){var u=n.get("Canvas").getMouseRelativeCanvas(t);c=u.x,s=u.y}this.rX=c,this.rY=s,this.eventMove=t;var h=this.getSourceModel(),f=this.dimsFromTarget(t.target,c,s),p=this.target,g=this.getTargetModel(p);this.selectTargetModel(g),g||(i.style.display="none"),this.lastDims=f;var v=this.findPosition(f,c,s);this.isTextableActive(h,g)?(this.activeTextModel=g,this.setContentEditable(g,!0),i.style.display="none",this.lastPos=v,this.updateTextViewCursorPosition(e)):(this.disableTextable(),this.activeTextModel=null,this.lastPos&&this.lastPos.index==v.index&&this.lastPos.method==v.method||(this.movePlaceholder(this.plh,f,v,this.prevTargetDim),this.$plh||(this.$plh=d(this.plh)),this.canvasRelative||(this.offTop&&this.$plh.css("top","+="+this.offTop+"px"),this.offLeft&&this.$plh.css("left","+="+this.offLeft+"px")),this.lastPos=v)),Object(l.isFunction)(r)&&r(t),n&&n.trigger("sorter:drag",{target:p,targetModel:g,sourceModel:h,dims:f,pos:v,x:c,y:s})},isTextableActive:function(t,e){return t&&t.get&&t.get("textable")&&e&&e.is("text")},disableTextable:function(){var t=this.activeTextModel;t&&t.getView().disableEditing()},isInFlow:function(t,e){if(!t)return!1;e=e||document.body;var n=t;return n.offsetHeight,!!this.styleInFlow(n,e)},styleInFlow:function(t,e){if(!Object(c.l)(t)){var n=t.style||{},r=d(t),i=e&&d(e);if(!(n.overflow&&"visible"!==n.overflow||"none"!==r.css("float")||i&&"flex"==i.css("display")&&"column"!==i.css("flex-direction"))){switch(n.position){case"static":case"relative":case"":break;default:return}switch(t.tagName){case"TR":case"TBODY":case"THEAD":case"TFOOT":return!0}switch(r.css("display")){case"block":case"list-item":case"table":case"flex":return!0}}}},validTarget:function(t,e){var n=this.getTargetModel(t),r=this.getSourceModel(e,{target:n}),i={valid:!0,src:e=r&&r.view&&r.view.el,srcModel:r,trg:t=n&&n.view&&n.view.el,trgModel:n};if(!e||!t)return i.valid=!1,i;var o=r.get("draggable");o=o instanceof Array?o.join(", "):o,i.dragInfo=o,o=Object(l.isString)(o)?this.matches(t,o):o,i.draggable=o;var a=n.get("droppable");return a=(a=a instanceof s.a.Collection?1:a)instanceof Array?a.join(", "):a,i.dropInfo=a,a=Object(l.isString)(a)?this.matches(e,a):a,a=o&&this.isTextableActive(r,n)?1:a,i.droppable=a,a&&o||(i.valid=!1),i},dimsFromTarget:function(t,e,n){var r=this.em,i=[];if(!t)return i;if(this.matches(t,"".concat(this.itemSel,", ").concat(this.containerSel))||(t=this.closest(t,this.itemSel)),this.draggable instanceof Array&&(t=this.closest(t,this.draggable.join(","))),!t)return i;if(this.prevTarget&&this.prevTarget!=t&&(this.prevTarget=null),!this.prevTarget){this.targetP=this.closest(t,this.containerSel);var o=this.validTarget(t);if(r&&r.trigger("sorter:drag:validation",o),!o.valid&&this.targetP)return this.dimsFromTarget(this.targetP,e,n);this.prevTarget=t,this.prevTargetDim=this.getDim(t),this.cacheDimsP=this.getChildrenDim(this.targetP),this.cacheDims=this.getChildrenDim(t)}if(this.prevTarget==t&&(i=this.cacheDims),this.target=this.prevTarget,this.nearBorders(this.prevTargetDim,e,n)||!this.nested&&!this.cacheDims.length){var a=this.targetP;a&&this.validTarget(a).valid&&(i=this.cacheDimsP,this.target=a)}return this.lastPos=null,i},getTargetFromEl:function(t){var e,n=t,r=this.targetPrev,i=this.em,o=this.containerSel,a=this.itemSel;if(this.matches(n,"".concat(a,", ").concat(o))||(n=this.closest(n,a)),this.draggable instanceof Array&&(n=this.closest(n,this.draggable.join(","))),r&&r!=n&&(this.targetPrev=""),!this.targetPrev){e=this.closest(n,o);var s=this.validTarget(n);if(i&&i.trigger("sorter:drag:validation",s),!s.valid&&e)return this.getTargetFromEl(e);this.targetPrev=n}return this.nearElBorders(n)&&(e=this.closest(n,o))&&this.validTarget(e).valid&&(n=e),n},nearElBorders:function(t){var e=t.getBoundingClientRect(),n=t.ownerDocument.body,r=this.getCurrentPos(),i=r.x,o=r.y,a=e.top+n.scrollTop,s=e.left+n.scrollLeft,l=e.width,c=e.height;if(oa+c-10||is+l-10)return 1},getCurrentPos:function(){var t=this.eventMove;return{x:t.pageX||0,y:t.pageY||0}},getDim:function(t){var e,n,r,i,o=this.em;if(this.canvasRelative&&o){var a=o.get("Canvas"),s=a.getElementPos(t),l=a.getElementOffsets(t);e=s.top-l.marginTop,n=s.left-l.marginLeft,r=s.height+l.marginTop+l.marginBottom,i=s.width+l.marginLeft+l.marginRight}else{var c=this.offset(t);e=this.relative?t.offsetTop:c.top-(this.wmargin?-1:1)*this.elT,n=this.relative?t.offsetLeft:c.left-(this.wmargin?-1:1)*this.elL,r=t.offsetHeight,i=t.offsetWidth}return[e,n,r,i]},getChildrenDim:function(t){var e=this,n=[];if(!t)return n;var r=this.getTargetModel(t);return r&&r.view&&!this.ignoreViewChildren&&(t=r.view.getChildrenContainer()),Object(l.each)(t.children,(function(r,i){var o=Object(c.f)(r,d),a=o&&o.index?o.index():i;if(Object(c.l)(r)||e.matches(r,e.itemSel)){var s=e.getDim(r),l=e.direction;l="v"==l||"h"!=l&&e.isInFlow(r,t),s.push(l,r,a),n.push(s)}})),n},nearBorders:function(t,e,n){var r=0,i=this.borderOffset,o=e||0,a=n||0,s=t[0],l=t[1],c=t[2],u=t[3];return(s+i>a||a>s+c-i||l+i>o||o>l+u-i)&&(r=1),!!r},findPosition:function(t,e,n){for(var r={index:0,indexEl:0,method:"before"},i=0,o=0,a=0,s=0,l=0,c=0,u=0,h=0,d=0,f=t.length;do||s&&c>=s||i&&a0&&void 0!==arguments[0]?arguments[0]:{};return g()(this,t),this.setOptions(e),Object(l.bindAll)(this,"handleKeyDown","handleMouseDown","move","stop"),this}return m()(t,[{key:"getConfig",value:function(){return this.opts}},{key:"setOptions",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{};this.opts=Object(l.defaults)(t,y),this.setup()}},{key:"setup",value:function(){var t=this.opts,e=t.prefix||"",n=t.appendTo||document.body,r=this.container;for(r||((r=document.createElement("div")).className="".concat(e,"resizer-c"),n.appendChild(r),this.container=r);r.firstChild;)r.removeChild(r.firstChild);var i={};for(var o in["tl","tc","tr","cl","cr","bl","bc","br"].forEach((function(e){return i[e]=t[e]?function(t,e){var n=e.prefix||"",r=document.createElement("i");return r.className=n+"resizer-h "+n+"resizer-h-"+t,r.setAttribute("data-"+n+"handler",t),r}(e,t):""})),i){var a=i[o];a&&r.appendChild(a)}this.handlers=i,this.mousePosFetcher=t.mousePosFetcher,this.updateTarget=t.updateTarget,this.posFetcher=t.posFetcher,this.onStart=t.onStart,this.onMove=t.onMove,this.onEnd=t.onEnd}},{key:"toggleFrames",value:function(t){if(this.opts.silentFrames){var e=document.querySelectorAll("iframe");Object(l.each)(e,(function(e){return e.style.pointerEvents=t?"none":""}))}}},{key:"isHandler",value:function(t){var e=this.handlers;for(var n in e)if(e[n]===t)return!0;return!1}},{key:"getFocusedEl",value:function(){return this.el}},{key:"getDocumentEl",value:function(){return[this.el.ownerDocument,document]}},{key:"getElementPos",value:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{},n=this.posFetcher||"";return n?n(t,e):b(t)}},{key:"focus",value:function(t){t&&t===this.el||(this.el=t,this.updateContainer({forceShow:1}),Object(c.p)(this.getDocumentEl(),"mousedown",this.handleMouseDown))}},{key:"blur",value:function(){this.container.style.display="none",this.el&&(Object(c.o)(this.getDocumentEl(),"mousedown",this.handleMouseDown),this.el=null)}},{key:"start",value:function(t){if(0===t.button){t.preventDefault(),t.stopPropagation();var e=this.el,n=this.opts||{},r="data-"+n.prefix+"handler",i=this.getElementPos(e,{target:"el"});this.handlerAttr=t.target.getAttribute(r),this.clickedHandler=t.target,this.startDim={t:i.top,l:i.left,w:i.width,h:i.height},this.rectDim={t:i.top,l:i.left,w:i.width,h:i.height},this.startPos={x:t.clientX,y:t.clientY};var o=this.getDocumentEl();Object(c.p)(o,"mousemove",this.move),Object(c.p)(o,"keydown",this.handleKeyDown),Object(c.p)(o,"mouseup",this.stop),Object(l.isFunction)(this.onStart)&&this.onStart(t,{docs:o,config:n,el:e,resizer:this}),this.toggleFrames(1),this.move(t)}}},{key:"move",value:function(t){var e=this.onMove,n=this.mousePosFetcher,r=n?n(t):{x:t.clientX,y:t.clientY};this.currentPos=r,this.delta={x:r.x-this.startPos.x,y:r.y-this.startPos.y},this.keys={shift:t.shiftKey,ctrl:t.ctrlKey,alt:t.altKey},this.rectDim=this.calc(this),this.updateRect(0),e&&e(t),0===t.which&&this.stop(t)}},{key:"stop",value:function(t){var e=this.opts,n=this.getDocumentEl();Object(c.o)(n,"mousemove",this.move),Object(c.o)(n,"keydown",this.handleKeyDown),Object(c.o)(n,"mouseup",this.stop),this.updateRect(1),this.toggleFrames(),Object(l.isFunction)(this.onEnd)&&this.onEnd(t,{docs:n,config:e})}},{key:"updateRect",value:function(t){var e=this.el,n=this.opts,r=this.rectDim,i=this.updateTarget,o=this.getSelectedHandler(),a=n.unitHeight,s=n.unitWidth,c=n.keyWidth,u=n.keyHeight;if(Object(l.isFunction)(i))i(e,r,{store:t,selectedHandler:o,resizer:this,config:n});else{var h=e.style;h[c]=r.w+s,h[u]=r.h+a}this.updateContainer()}},{key:"updateContainer",value:function(){var t=arguments.length>0&&void 0!==arguments[0]?arguments[0]:{},e=this.opts,n=this.container,r=this.el,i=n.style;if(!e.avoidContainerUpdate&&r){var o=["left","top","width","height"],a=this.getElementPos(r,{target:"container"});o.forEach((function(t){return i[t]="".concat(a[t],"px")})),t.forceShow&&(i.display="block")}}},{key:"getSelectedHandler",value:function(){var t=this.handlers;if(this.selectedHandler)for(var e in t)if(t[e]===this.selectedHandler)return e}},{key:"handleKeyDown",value:function(t){27===t.keyCode&&(this.rectDim=this.startDim,this.stop(t))}},{key:"handleMouseDown",value:function(t){var e=t.target;this.isHandler(e)?(this.selectedHandler=e,this.start(t)):e!==this.el&&(this.selectedHandler="",this.blur())}},{key:"calc",value:function(t){var e,n=this.opts||{},r=n.step,i=this.startDim,o=n.minDim,a=n.maxDim,s=t.delta.x,l=t.delta.y,u=i.w,h=i.h,d={t:0,l:0,w:u,h:h};if(t){var f=t.handlerAttr;~f.indexOf("r")&&(e=Object(c.n)(u+s*r,r),e=Math.max(o,e),a&&(e=Math.min(a,e)),d.w=e),~f.indexOf("b")&&(e=Object(c.n)(h+l*r,r),e=Math.max(o,e),a&&(e=Math.min(a,e)),d.h=e),~f.indexOf("l")&&(e=Object(c.n)(u-s*r,r),e=Math.max(o,e),a&&(e=Math.min(a,e)),d.w=e),~f.indexOf("t")&&(e=Object(c.n)(h-l*r,r),e=Math.max(o,e),a&&(e=Math.min(a,e)),d.h=e);var p=n.ratioDefault?!t.keys.shift:t.keys.shift;if(f.indexOf("c")<0&&p){var g=i.w/i.h;d.w/d.h>g?d.h=Math.round(d.w/g):d.w=Math.round(d.h*g)}return~f.indexOf("l")&&(d.l=i.w-d.w),~f.indexOf("t")&&(d.t=i.h-d.h),d}}}]),t}(),x={init:function(t){return new w(t)}};e.default=function(){return{name:"Utils",init:function(){return this},Sorter:f,Resizer:x,Dragger:r.a}}},function(t,e,n){"use strict";n.r(e);var r=n(8),i=n.n(r),o=n(2),a=n.n(o),s=n(0),l=n(19),c={stylePrefix:"com-",defaults:[],strict:1};function u(t,e){var n=Object.keys(t);if(Object.getOwnPropertySymbols){var r=Object.getOwnPropertySymbols(t);e&&(r=r.filter((function(e){return Object.getOwnPropertyDescriptor(t,e).enumerable}))),n.push.apply(n,r)}return n}function h(t){for(var e=1;e0&&void 0!==arguments[0]?arguments[0]:{};e=h({},c,{},r),t=e.em;var a=e.pStylePrefix;for(var l in a&&(e.stylePrefix=a+e.stylePrefix),e.defaults){var d=e.defaults[l];d.id&&this.add(d.id,d)}return o["tlb-delete"]={run:function(t){return t.runCommand("core:component-delete")}},o["tlb-clone"]={run:function(t){t.runCommand("core:copy"),t.runCommand("core:paste")}},o["tlb-move"]={run:function(t,e){var n=arguments.length>2&&void 0!==arguments[2]?arguments[2]:{},r=t.getModel(),o=n&&n.event,a=n.target,l=a||t.getSelected(),c=a?[a]:i()(t.getSelectedAll()),u=o&&"dragstart"==o.type,h={preserveSelected:1},d=["absolute","translate"],f=function(){return r.stopDefault(h)};if(r.set("_cmpDrag",1),l&&l.get("draggable")){var p=l.get("dmode")||r.get("dmode");u?setTimeout(f,0):f();var g=function(e,n){r.runDefault(h),c.forEach((function(t){return t.set("status","selected")})),t.select(c),l.emitUpdate()};if(Object(s.includes)(d,p))t.runCommand("core:component-drag",{guidesInfo:1,mode:p,target:l,onEnd:g,event:o});else{u&&o.dataTransfer.setDragImage(l.view.el,0,0);var v=t.Commands.get("move-comp");v.onEndMoveFromModel=g,v.initSorterFromModels(c)}c.forEach((function(t){return t.set("status","freezed-selected")}))}else console.warn("The element is not draggable")}},o["core:undo"]=function(t){return t.UndoManager.undo()},o["core:redo"]=function(t){return t.UndoManager.redo()},u.forEach((function(e){var r=e[2],i=n(83)("./".concat(e[1])).default,a="core:".concat(e[0]);o[a]=i,r&&(o[r]=i,["run","stop"].forEach((function(e){t.on("".concat(e,":").concat(r),(function(){for(var n,r=arguments.length,i=new Array(r),o=0;o1&&void 0!==arguments[1]?arguments[1]:{},n=this.get(t);if(n){var r=h({},n.constructor.prototype,{},e);this.add(t,r);var i=u.filter((function(e){return"core:".concat(e[0])===t&&e[2]}))[0];i&&this.add(i[2],r)}return this},has:function(t){return!!r[t]},getAll:function(){return r},run:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return this.runCommand(this.get(t),e)},stop:function(t){var e=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};return this.stopCommand(this.get(t),e)},isActive:function(t){return this.getActive().hasOwnProperty(t)},getActive:function(){return a},loadDefaultCommands:function(){for(var t in o)this.add(t,o[t]);return this},runCommand:function(n){var r,i=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};if(n&&n.run){var o=n.id,s=t.get("Editor");this.isActive(o)&&!i.force&&e.strict||(r=n.callRun(s,i),o&&n.stop&&!n.noStop&&!i.abort&&(a[o]=r))}return r},stopCommand:function(n){var r,i=arguments.length>1&&void 0!==arguments[1]?arguments[1]:{};if(n&&n.run){var o=n.id,s=t.get("Editor");(this.isActive(o)||i.force||!e.strict)&&(o&&delete a[o],r=n.callStop(s,i))}return r},create:function(t){return t.stop||(t.noStop=1),new(l.default.extend(t))(e)}}}}]).default})); +//# sourceMappingURL=grapes.min.js.map \ No newline at end of file diff --git a/dist/grapes.min.js.map b/dist/grapes.min.js.map new file mode 100644 index 000000000..4dfb77113 --- /dev/null +++ b/dist/grapes.min.js.map @@ -0,0 +1 @@ +{"version":3,"sources":["webpack://grapesjs/webpack/universalModuleDefinition","webpack://grapesjs/webpack/bootstrap","webpack://grapesjs/./node_modules/underscore/underscore.js","webpack://grapesjs/./node_modules/backbone/backbone.js","webpack://grapesjs/./node_modules/@babel/runtime/helpers/defineProperty.js","webpack://grapesjs/./src/utils/mixins.js","webpack://grapesjs/./src/trait_manager/model/Trait.js","webpack://grapesjs/./src/trait_manager/model/Traits.js","webpack://grapesjs/./src/trait_manager/model/TraitFactory.js","webpack://grapesjs/./src/dom_components/model/Component.js","webpack://grapesjs/./src/dom_components/view/ComponentView.js","webpack://grapesjs/./node_modules/@babel/runtime/helpers/typeof.js","webpack://grapesjs/./src/selector_manager/model/Selector.js","webpack://grapesjs/./node_modules/@babel/runtime/helpers/toConsumableArray.js","webpack://grapesjs/./src/selector_manager/model/Selectors.js","webpack://grapesjs/./node_modules/codemirror/lib/codemirror.js","webpack://grapesjs/./src/utils/dom.js","webpack://grapesjs/./src/dom_components/view/ToolbarButtonView.js","webpack://grapesjs/./src/dom_components/view/ToolbarView.js","webpack://grapesjs/./src/dom_components/model/ToolbarButton.js","webpack://grapesjs/./src/dom_components/model/Toolbar.js","webpack://grapesjs/./src/commands/view/SelectComponent.js","webpack://grapesjs/./node_modules/@babel/runtime/helpers/classCallCheck.js","webpack://grapesjs/./node_modules/@babel/runtime/helpers/createClass.js","webpack://grapesjs/./src/domain_abstract/ui/Input.js","webpack://grapesjs/./src/style_manager/view/PropertiesView.js","webpack://grapesjs/./src/utils/Dragger.js","webpack://grapesjs/./src/dom_components/model/Components.js","webpack://grapesjs/./src/commands/view/CommandAbstract.js","webpack://grapesjs/./src/domain_abstract/model/Styleable.js","webpack://grapesjs/./node_modules/cash-dom/dist/cash.js","webpack://grapesjs/./src/style_manager/model/Property.js","webpack://grapesjs/./src/style_manager/model/PropertyComposite.js","webpack://grapesjs/./src/style_manager/model/Layer.js","webpack://grapesjs/./src/style_manager/model/Layers.js","webpack://grapesjs/./src/style_manager/model/PropertyStack.js","webpack://grapesjs/./src/style_manager/view/PropertyView.js","webpack://grapesjs/./src/style_manager/view/PropertyCompositeView.js","webpack://grapesjs/./src/style_manager/view/LayerView.js","webpack://grapesjs/./src/style_manager/view/LayersView.js","webpack://grapesjs/./src/style_manager/view/PropertyStackView.js","webpack://grapesjs/./src/style_manager/view/PropertyFileView.js","webpack://grapesjs/./src/style_manager/view/PropertyIntegerView.js","webpack://grapesjs/./src/style_manager/view/PropertyColorView.js","webpack://grapesjs/./src/style_manager/model/PropertyRadio.js","webpack://grapesjs/./src/style_manager/model/PropertySelect.js","webpack://grapesjs/./src/style_manager/view/PropertySelectView.js","webpack://grapesjs/./src/style_manager/view/PropertyRadioView.js","webpack://grapesjs/./src/style_manager/model/PropertyInteger.js","webpack://grapesjs/./src/style_manager/model/PropertySlider.js","webpack://grapesjs/./src/style_manager/view/PropertySliderView.js","webpack://grapesjs/./src/style_manager/model/Properties.js","webpack://grapesjs/(webpack)/buildin/global.js","webpack://grapesjs/./src/commands/view/SelectPosition.js","webpack://grapesjs/./src/utils/fetch.js","webpack://grapesjs/./src/parser/model/ParserHtml.js","webpack://grapesjs/./src/domain_abstract/model/TypeableCollection.js","webpack://grapesjs/./src/domain_abstract/ui/InputNumber.js","webpack://grapesjs/./src/domain_abstract/view/DomainViews.js","webpack://grapesjs/./src/dom_components/view/ComponentsView.js","webpack://grapesjs/./src/navigator/view/ItemView.js","webpack://grapesjs/./src/domain_abstract/ui/InputColor.js","webpack://grapesjs/./src/utils/ColorPicker.js","webpack://grapesjs/./node_modules/keymaster/keymaster.js","webpack://grapesjs/./node_modules/promise-polyfill/src/index.js","webpack://grapesjs/./src/panels/model/Button.js","webpack://grapesjs/./src/panels/model/Buttons.js","webpack://grapesjs/./node_modules/codemirror/mode/css/css.js","webpack://grapesjs/./src/commands/view/CanvasClear.js","webpack://grapesjs/./src/commands/view/CanvasMove.js","webpack://grapesjs/./src/commands/view/ComponentDelete.js","webpack://grapesjs/./src/commands/view/ComponentDrag.js","webpack://grapesjs/./src/commands/view/ComponentEnter.js","webpack://grapesjs/./src/commands/view/ComponentExit.js","webpack://grapesjs/./src/commands/view/ComponentNext.js","webpack://grapesjs/./src/commands/view/ComponentPrev.js","webpack://grapesjs/./src/commands/view/ComponentStyleClear.js","webpack://grapesjs/./src/commands/view/CopyComponent.js","webpack://grapesjs/./src/commands/view/DeleteComponent.js","webpack://grapesjs/./src/commands/view/ExportTemplate.js","webpack://grapesjs/./src/commands/view/Fullscreen.js","webpack://grapesjs/./src/commands/view/MoveComponent.js","webpack://grapesjs/./src/commands/view/OpenAssets.js","webpack://grapesjs/./src/commands/view/OpenBlocks.js","webpack://grapesjs/./src/commands/view/OpenLayers.js","webpack://grapesjs/./src/commands/view/OpenStyleManager.js","webpack://grapesjs/./src/commands/view/OpenTraitManager.js","webpack://grapesjs/./src/commands/view/PasteComponent.js","webpack://grapesjs/./src/commands/view/Preview.js","webpack://grapesjs/./src/commands/view/Resize.js","webpack://grapesjs/./src/commands/view/ShowOffset.js","webpack://grapesjs/./src/commands/view/SwitchVisibility.js","webpack://grapesjs/./src/style_manager/config/config.js","webpack://grapesjs/./src/style_manager/model/PropertyFactory.js","webpack://grapesjs/./src/style_manager/model/Sector.js","webpack://grapesjs/./src/style_manager/model/Sectors.js","webpack://grapesjs/./src/style_manager/view/SectorView.js","webpack://grapesjs/./src/style_manager/view/SectorsView.js","webpack://grapesjs/./src/style_manager/index.js","webpack://grapesjs/./src/navigator/config/config.js","webpack://grapesjs/./src/navigator/index.js","webpack://grapesjs/./node_modules/backbone-undo/Backbone.Undo.js","webpack://grapesjs/./node_modules/promise-polyfill/src/finally.js","webpack://grapesjs/./node_modules/@babel/runtime/helpers/slicedToArray.js","webpack://grapesjs/(webpack)/buildin/module.js","webpack://grapesjs/./src/keymaps/index.js","webpack://grapesjs/./src/undo_manager/index.js","webpack://grapesjs/./node_modules/timers-browserify/main.js","webpack://grapesjs/./node_modules/setimmediate/setImmediate.js","webpack://grapesjs/./node_modules/process/browser.js","webpack://grapesjs/./node_modules/@babel/runtime/helpers/arrayWithoutHoles.js","webpack://grapesjs/./node_modules/@babel/runtime/helpers/iterableToArray.js","webpack://grapesjs/./node_modules/@babel/runtime/helpers/nonIterableSpread.js","webpack://grapesjs/./node_modules/codemirror/mode/htmlmixed/htmlmixed.js","webpack://grapesjs/./node_modules/codemirror/mode/xml/xml.js","webpack://grapesjs/./node_modules/codemirror/mode/javascript/javascript.js","webpack://grapesjs/./node_modules/codemirror-formatting/formatting.js","webpack://grapesjs/./node_modules/@babel/runtime/helpers/arrayWithHoles.js","webpack://grapesjs/./node_modules/@babel/runtime/helpers/iterableToArrayLimit.js","webpack://grapesjs/./node_modules/@babel/runtime/helpers/nonIterableRest.js","webpack://grapesjs/./src/navigator/view/ItemsView.js","webpack://grapesjs/./src/commands/view sync ^\\.\\/.*$","webpack://grapesjs/./src/dom_components/config/config.js","webpack://grapesjs/./src/dom_components/model/ComponentTableCell.js","webpack://grapesjs/./src/dom_components/view/ComponentTableCellView.js","webpack://grapesjs/./src/dom_components/model/ComponentTableRow.js","webpack://grapesjs/./src/dom_components/view/ComponentTableRowView.js","webpack://grapesjs/./src/dom_components/model/ComponentTable.js","webpack://grapesjs/./src/dom_components/view/ComponentTableView.js","webpack://grapesjs/./src/dom_components/model/ComponentTableBody.js","webpack://grapesjs/./src/dom_components/model/ComponentTableHead.js","webpack://grapesjs/./src/dom_components/view/ComponentTableHeadView.js","webpack://grapesjs/./src/dom_components/view/ComponentTableBodyView.js","webpack://grapesjs/./src/dom_components/model/ComponentTableFoot.js","webpack://grapesjs/./src/dom_components/view/ComponentTableFootView.js","webpack://grapesjs/./src/dom_components/model/ComponentImage.js","webpack://grapesjs/./src/dom_components/model/ComponentMap.js","webpack://grapesjs/./src/dom_components/view/ComponentImageView.js","webpack://grapesjs/./src/dom_components/view/ComponentMapView.js","webpack://grapesjs/./src/dom_components/model/ComponentText.js","webpack://grapesjs/./src/dom_components/model/ComponentLink.js","webpack://grapesjs/./src/dom_components/view/ComponentTextView.js","webpack://grapesjs/./src/dom_components/view/ComponentLinkView.js","webpack://grapesjs/./src/dom_components/model/ComponentLabel.js","webpack://grapesjs/./src/dom_components/view/ComponentLabelView.js","webpack://grapesjs/./src/dom_components/model/ComponentVideo.js","webpack://grapesjs/./src/dom_components/view/ComponentVideoView.js","webpack://grapesjs/./src/dom_components/model/ComponentScript.js","webpack://grapesjs/./src/dom_components/view/ComponentScriptView.js","webpack://grapesjs/./src/dom_components/model/ComponentSvg.js","webpack://grapesjs/./src/dom_components/view/ComponentSvgView.js","webpack://grapesjs/./src/dom_components/model/ComponentTextNode.js","webpack://grapesjs/./src/dom_components/model/ComponentComment.js","webpack://grapesjs/./src/dom_components/view/ComponentTextNodeView.js","webpack://grapesjs/./src/dom_components/view/ComponentCommentView.js","webpack://grapesjs/./src/dom_components/model/ComponentWrapper.js","webpack://grapesjs/./src/dom_components/index.js","webpack://grapesjs/./src/editor/config/config.js","webpack://grapesjs/./src/editor/model/Editor.js","webpack://grapesjs/./src/utils/extender.js","webpack://grapesjs/./src/editor/view/EditorView.js","webpack://grapesjs/./src/editor/index.js","webpack://grapesjs/./src/plugin_manager/config/config.js","webpack://grapesjs/./src/utils/polyfills.js","webpack://grapesjs/./src/index.js","webpack://grapesjs/./src/plugin_manager/index.js","webpack://grapesjs/./src/trait_manager/config/config.js","webpack://grapesjs/./src/trait_manager/view/TraitView.js","webpack://grapesjs/./src/trait_manager/view/TraitSelectView.js","webpack://grapesjs/./src/trait_manager/view/TraitCheckboxView.js","webpack://grapesjs/./src/trait_manager/view/TraitNumberView.js","webpack://grapesjs/./src/trait_manager/view/TraitColorView.js","webpack://grapesjs/./src/trait_manager/view/TraitButtonView.js","webpack://grapesjs/./src/trait_manager/view/TraitsView.js","webpack://grapesjs/./src/trait_manager/index.js","webpack://grapesjs/./src/asset_manager/config/config.js","webpack://grapesjs/./src/asset_manager/model/Asset.js","webpack://grapesjs/./src/asset_manager/model/AssetImage.js","webpack://grapesjs/./src/asset_manager/view/AssetImageView.js","webpack://grapesjs/./src/asset_manager/view/AssetView.js","webpack://grapesjs/./src/asset_manager/model/Assets.js","webpack://grapesjs/./src/asset_manager/view/AssetsView.js","webpack://grapesjs/./src/asset_manager/view/FileUploader.js","webpack://grapesjs/./src/asset_manager/index.js","webpack://grapesjs/./src/block_manager/config/config.js","webpack://grapesjs/./src/block_manager/model/Category.js","webpack://grapesjs/./src/block_manager/model/Block.js","webpack://grapesjs/./src/block_manager/model/Blocks.js","webpack://grapesjs/./src/block_manager/model/Categories.js","webpack://grapesjs/./src/block_manager/view/BlockView.js","webpack://grapesjs/./src/block_manager/view/CategoryView.js","webpack://grapesjs/./src/block_manager/view/BlocksView.js","webpack://grapesjs/./src/block_manager/index.js","webpack://grapesjs/./src/panels/config/config.js","webpack://grapesjs/./src/panels/model/Panel.js","webpack://grapesjs/./src/panels/model/Panels.js","webpack://grapesjs/./src/panels/view/ButtonView.js","webpack://grapesjs/./src/panels/view/ButtonsView.js","webpack://grapesjs/./src/panels/view/PanelView.js","webpack://grapesjs/./src/panels/view/PanelsView.js","webpack://grapesjs/./src/panels/index.js","webpack://grapesjs/./src/code_manager/config/config.js","webpack://grapesjs/./src/code_manager/model/HtmlGenerator.js","webpack://grapesjs/./src/code_manager/model/CssGenerator.js","webpack://grapesjs/./src/code_manager/model/JsonGenerator.js","webpack://grapesjs/./src/code_manager/model/JsGenerator.js","webpack://grapesjs/./src/code_manager/model/CodeMirrorEditor.js","webpack://grapesjs/./src/code_manager/view/EditorView.js","webpack://grapesjs/./src/code_manager/index.js","webpack://grapesjs/./src/css_composer/config/config.js","webpack://grapesjs/./src/css_composer/model/CssRule.js","webpack://grapesjs/./src/css_composer/model/CssRules.js","webpack://grapesjs/./src/css_composer/view/CssRuleView.js","webpack://grapesjs/./src/css_composer/view/CssGroupRuleView.js","webpack://grapesjs/./src/css_composer/view/CssRulesView.js","webpack://grapesjs/./src/css_composer/index.js","webpack://grapesjs/./src/canvas/view/CanvasView.js","webpack://grapesjs/./src/utils/Droppable.js","webpack://grapesjs/./src/canvas/config/config.js","webpack://grapesjs/./src/canvas/model/Frame.js","webpack://grapesjs/./src/canvas/model/Canvas.js","webpack://grapesjs/./src/canvas/view/FrameView.js","webpack://grapesjs/./src/canvas/index.js","webpack://grapesjs/./src/device_manager/config/config.js","webpack://grapesjs/./src/device_manager/model/Device.js","webpack://grapesjs/./src/device_manager/model/Devices.js","webpack://grapesjs/./src/device_manager/view/DevicesView.js","webpack://grapesjs/./src/device_manager/index.js","webpack://grapesjs/./src/modal_dialog/config/config.js","webpack://grapesjs/./src/modal_dialog/model/Modal.js","webpack://grapesjs/./src/modal_dialog/view/ModalView.js","webpack://grapesjs/./src/modal_dialog/index.js","webpack://grapesjs/./src/selector_manager/config/config.js","webpack://grapesjs/./src/selector_manager/view/ClassTagView.js","webpack://grapesjs/./src/selector_manager/view/ClassTagsView.js","webpack://grapesjs/./src/selector_manager/index.js","webpack://grapesjs/./src/parser/config/config.js","webpack://grapesjs/./src/parser/model/BrowserParserCss.js","webpack://grapesjs/./src/parser/model/ParserCss.js","webpack://grapesjs/./src/parser/index.js","webpack://grapesjs/./src/storage_manager/config/config.js","webpack://grapesjs/./src/storage_manager/model/LocalStorage.js","webpack://grapesjs/./src/storage_manager/model/RemoteStorage.js","webpack://grapesjs/./src/storage_manager/index.js","webpack://grapesjs/./src/rich_text_editor/model/RichTextEditor.js","webpack://grapesjs/./src/rich_text_editor/config/config.js","webpack://grapesjs/./src/rich_text_editor/index.js","webpack://grapesjs/./src/utils/Sorter.js","webpack://grapesjs/./src/utils/Resizer.js","webpack://grapesjs/./src/utils/index.js","webpack://grapesjs/./src/commands/config/config.js","webpack://grapesjs/./src/commands/index.js"],"names":["root","factory","exports","module","define","amd","window","installedModules","__webpack_require__","moduleId","i","l","modules","call","m","c","d","name","getter","o","Object","defineProperty","enumerable","get","r","Symbol","toStringTag","value","t","mode","__esModule","ns","create","key","bind","n","object","property","prototype","hasOwnProperty","p","s","self","global","this","previousUnderscore","_","ArrayProto","Array","ObjProto","SymbolProto","push","slice","toString","nativeIsArray","isArray","nativeKeys","keys","nativeCreate","Ctor","obj","_wrapped","nodeType","VERSION","builtinIteratee","optimizeCb","func","context","argCount","index","collection","accumulator","apply","arguments","cb","iteratee","identity","isFunction","isObject","matcher","Infinity","restArguments","startIndex","length","Math","max","rest","args","baseCreate","result","shallowProperty","has","path","deepGet","MAX_ARRAY_INDEX","pow","getLength","isArrayLike","each","forEach","map","collect","results","currentKey","createReduce","dir","reducer","memo","initial","reduce","foldl","inject","reduceRight","foldr","find","detect","predicate","findIndex","findKey","filter","select","list","reject","negate","every","all","some","any","contains","includes","include","item","fromIndex","guard","values","indexOf","invoke","contextPath","method","pluck","where","attrs","findWhere","computed","lastComputed","v","min","shuffle","sample","random","clone","last","rand","temp","sortBy","criteria","sort","left","right","a","b","group","behavior","partition","groupBy","indexBy","countBy","reStrSymbol","toArray","isString","match","size","pass","first","head","take","array","tail","drop","compact","Boolean","flatten","input","shallow","strict","output","idx","isArguments","j","len","without","otherArrays","difference","uniq","unique","isSorted","isBoolean","seen","union","arrays","intersection","argsLength","unzip","zip","createPredicateIndexFinder","findLastIndex","sortedIndex","low","high","mid","floor","createIndexFinder","predicateFind","isNaN","lastIndexOf","range","start","stop","step","ceil","chunk","count","executeBound","sourceFunc","boundFunc","callingContext","TypeError","bound","callArgs","concat","partial","boundArgs","placeholder","position","bindAll","Error","memoize","hasher","cache","address","delay","wait","setTimeout","defer","throttle","options","timeout","previous","later","leading","now","throttled","remaining","clearTimeout","trailing","cancel","debounce","immediate","debounced","callNow","wrap","wrapper","compose","after","times","before","once","hasEnumBug","propertyIsEnumerable","nonEnumerableProps","collectNonEnumProps","nonEnumIdx","constructor","proto","prop","allKeys","mapObject","pairs","invert","functions","methods","names","createAssigner","keysFunc","defaults","source","extend","extendOwn","assign","eq","deepEq","keyInObj","pick","omit","String","props","tap","interceptor","isMatch","aStack","bStack","type","className","valueOf","areArrays","aCtor","bCtor","pop","isEqual","isEmpty","isElement","nodelist","document","childNodes","Int8Array","isFinite","isSymbol","parseFloat","isNumber","isNull","isUndefined","noConflict","constant","noop","propertyOf","matches","accum","Date","getTime","escapeMap","unescapeMap","createEscaper","escaper","join","testRegexp","RegExp","replaceRegexp","string","test","replace","escape","unescape","fallback","idCounter","uniqueId","prefix","id","templateSettings","evaluate","interpolate","noMatch","escapes","escapeRegExp","escapeChar","template","text","settings","oldSettings","render","offset","variable","Function","e","data","argument","chain","instance","_chain","chainResult","mixin","toJSON","$","Backbone","previousBackbone","emulateHTTP","emulateJSON","addUnderscoreMethods","Class","attribute","defaultVal","unshift","addMethod","_isModel","modelMatcher","model","attributes","Events","eventSplitter","eventsApi","events","callback","opts","split","on","internalOn","listening","_events","onApi","ctx","_listeners","listenTo","_listenId","listeningTo","_listeningTo","thisId","objId","handlers","off","offApi","listeners","stopListening","ids","handler","_callback","onceMap","listenToOnce","offer","trigger","triggerApi","objEvents","allEvents","triggerEvents","ev","a1","a2","a3","unbind","Model","cid","cidPrefix","parse","set","changed","initialize","validationError","idAttribute","sync","attr","val","_validate","unset","silent","changes","changing","_changing","_previousAttributes","current","prev","_pending","clear","hasChanged","changedAttributes","diff","old","previousAttributes","fetch","success","resp","serverAttrs","wrapError","save","validate","isNew","patch","xhr","destroy","url","base","urlError","encodeURIComponent","isValid","error","Collection","models","comparator","_reset","reset","setOptions","add","remove","merge","addOptions","splice","insert","at","singular","removed","_removeModels","added","merged","toAdd","toMerge","toRemove","modelMap","sortable","sortAttr","existing","_prepareModel","_addReference","orderChanged","_removeReference","previousModels","shift","_byId","modelId","callbackOpts","_onModelEvent","event","prevId","View","viewOptions","_ensureElement","delegateEventSplitter","tagName","selector","$el","_removeElement","setElement","element","undelegateEvents","_setElement","delegateEvents","el","delegate","eventName","listener","undelegate","_createElement","createElement","_setAttributes","methodMap","params","dataType","contentType","JSON","stringify","_method","beforeSend","setRequestHeader","processData","textStatus","errorThrown","ajax","Router","routes","_bindRoutes","optionalParam","namedParam","splatParam","route","isRegExp","_routeToRegExp","router","history","fragment","_extractParameters","execute","navigate","optional","exec","param","decodeURIComponent","History","checkUrl","location","routeStripper","rootStripper","pathStripper","started","interval","atRoot","pathname","getSearch","matchRoot","decodeFragment","decodeURI","href","getHash","getPath","charAt","getFragment","_usePushState","_wantsHashChange","hashChange","_hasHashChange","documentMode","_useHashChange","_wantsPushState","pushState","_hasPushState","rootPath","iframe","src","style","display","tabIndex","body","iWindow","insertBefore","firstChild","contentWindow","open","close","hash","addEventListener","attachEvent","_checkUrlInterval","setInterval","loadUrl","removeEventListener","detachEvent","removeChild","clearInterval","title","_updateHash","protoProps","staticProps","child","parent","__super__","configurable","writable","elProt","Element","webkitMatchesSelector","mozMatchesSelector","msMatchesSelector","shallowDiff","objOrig","objNew","keysNew","origValue","newValue","fn","elem","getUnitFromValue","upFirst","toUpperCase","toLowerCase","camelCase","normalizeFloat","valueDef","stepDecimals","side","toFixed","hasDnd","em","nativeDnD","getElement","isTextNode","getEl","isTaggableNode","isCommentNode","getModel","getElRect","rectText","def","top","width","height","createRange","selectNode","getBoundingClientRect","detach","getPointerEvent","touches","getKeyCode","which","keyCode","getKeyChar","fromCharCode","isEscKey","capitalize","str","substring","label","unit","target","default","changeProp","targetEvent","targetUpdated","getTargetValue","fromTarget","getAttributes","setTargetValue","setValueFromInput","final","toSet","avoidStore","getInitValue","Trait","coll","handleAdd","handleReset","setTarget","opt","tm","tf","config","build","objs","labelPlhText","labelPlhHref","optionsTarget","TraitFactory","getConfig","Component","Styleable","removable","draggable","droppable","badgable","stylable","unstylable","highlightable","copyable","resizable","editable","layerable","selectable","hoverable","void","state","status","content","icon","classes","script","traits","propagate","dmode","toolbar","init","updated","parentAttr","newAttr","toPropagate","voidElements","ccid","createId","initClasses","initTraits","initComponents","initToolbar","scriptUpdated","tagUpdated","attrUpdated","_idUpdated","trim","emitUpdate","temporary","is","setDragMode","query","view","$els","findType","components","closest","replaceWith","class","setClass","setStyle","attrPrev","pr","setAttributes","addAttributes","newAttrs","getStyle","rule","getIdRule","getId","parseStyle","cc","propOrig","setIdRule","hasStyle","sm","cls","avoidInline","Selector","TYPE_ID","addClass","removeClass","selectors","TYPE_CLASS","classe","getClasses","classStr","toListen","clsArr","normalizeClasses","Selectors","comps","Components","addChild","avoidChildren","loadTraits","trait","append","ppfx","tb","command","ed","runCommand","force","Traits","trt","tr","getTrait","updateTrait","getTraitIndex","removeTrait","addTrait","arr","res","clm","md","cloned","getName","customName","tag","getIcon","toHTML","sTag","customAttr","getAttrToHTML","attrString","code","comp","setId","getView","getScriptString","scr","scrStr","tagVarStart","tagVarEnd","reg","onAll","clb","resetId","oldId","newId","_getStyleRule","idS","_getStyleSelector","idUpdate","idPrev","getList","isComponent","nextId","getIncrementId","getNewId","ilen","uid","counter","domc","componentsById","checkId","styles","sel","modelOpt","draggableComponents","pfx","stylePrefix","pStylePrefix","updateStyle","renderAttributes","updateHighlight","updateStatus","updateState","updateContent","handleChange","onActive","avoidRender","dragstart","_clbObj","editor","getEditor","handleDragStart","preventDefault","stopPropagation","run","updateClasses","importClasses","childrenView","renderChildren","cl","selectedCls","selectedParentCls","freezedCls","hoveredCls","actualCls","getAttribute","avoidHover","setAttribute","hl","styleToString","removeAttr","updateAttributes","textable","defaultAttr","contenteditable","nodeName","getChildrenContainer","innerHTML","prevDef","updateScript","getCanvasView","container","getChildrenSelector","querySelector","getTemplate","ComponentsView","componentTypes","appendChild","postRender","onRender","_typeof2","iterator","_typeof","active","private","protected","namePreEsc","escapeName","nameEsc","getFullName","arrayWithoutHoles","iterableToArray","nonIterableSpread","getStyleable","getValid","getFullString","userAgent","navigator","platform","gecko","ie_upto10","ie_11up","edge","ie","ie_version","webkit","qtwebkit","chrome","presto","safari","vendor","mac_geMountainLion","phantom","ios","android","mobile","mac","chromeOS","windows","presto_version","Number","flipCtrlCmd","captureRightClick","classTest","rmClass","node","removeChildren","removeChildrenAndAdd","elt","cssText","createTextNode","eltP","parentNode","host","activeElt","activeElement","shadowRoot","joinClasses","as","end","endNode","setEnd","setStart","createTextRange","moveToElementText","collapse","moveEnd","moveStart","selectInput","f","copyObj","overwrite","countColumn","tabSize","startValue","search","nextTab","selectionStart","selectionEnd","_e","Delayed","ms","scrollerGap","Pass","sel_dontScroll","scroll","sel_mouse","origin","sel_move","findColumn","goal","pos","col","skipped","spaceStrs","spaceStr","lst","out","nothing","createObj","inst","nonASCIISingleCaseWordChar","isWordCharBasic","ch","isWordChar","helper","extendingChars","isExtendingChar","charCodeAt","skipExtendingChars","findFirst","pred","from","to","midF","bidiOther","getBidiPartAt","order","sticky","found","cur","bidiOrdering","lowTypes","arabicTypes","bidiRE","isNeutral","isStrong","countsAsLeft","countsAsNum","BidiSpan","level","direction","outerType","types","i$1","i$2","type$1","i$3","prev$1","type$2","i$4","type$3","i$5","cur$1","type$4","i$6","end$1","replace$1","j$1","i$7","j$2","nstart","reverse","getOrder","line","noHandlers","emitter","map$$1","_handlers","getHandlers","signal","signalDOMEvent","cm","override","defaultPrevented","e_defaultPrevented","codemirrorIgnore","signalCursorActivity","cursorActivity","curOp","cursorActivityHandlers","hasHandler","eventMixin","ctor","e_preventDefault","returnValue","e_stopPropagation","cancelBubble","e_stop","e_target","srcElement","e_button","button","ctrlKey","zwspSupported","badBidiRects","dragAndDrop","div","zeroWidthElement","measure","offsetHeight","offsetWidth","hasBadBidiRects","txt","r0","r1","splitLinesAuto","nl","rt","hasSelection","getSelection","te","range$$1","ownerDocument","selection","parentElement","compareEndPoints","hasCopyEvent","oncopy","badZoomedRects","modes","mimeModes","defineMode","dependencies","resolveMode","spec","getMode","mfactory","modeObj","modeExtensions","exts","helperType","modeProps","prop$1","extendMode","properties","copyState","nstate","innerMode","info","startState","StringStream","lineOracle","lastColumnPos","lastColumnValue","lineStart","getLine","doc","lines","children","sz","chunkSize","getBetween","iter","getLines","updateLineHeight","lineNo","no","lineAtHeight","h","outer","lh","isLine","lineNumberFor","lineNumberFormatter","firstLineNumber","Pos","cmp","equalCursorPos","copyPos","x","maxPos","minPos","clipLine","clipPos","linelen","clipToLen","clipPosArray","eol","sol","peek","undefined","next","eat","eatWhile","eatSpace","skipToEnd","skipTo","backUp","column","indentation","pattern","consume","caseInsensitive","cased","substr","hideFirstChars","inner","lookAhead","oracle","baseToken","SavedContext","Context","maxLookAhead","baseTokens","baseTokenPos","highlightLine","forceToEnd","st","modeGen","lineClasses","runMode","loop","overlay","overlays","i_end","opaque","bgClass","textClass","getLineStyles","updateFrontier","getContextBefore","resetState","maxHighlightLength","stateAfter","styleClasses","highlightFrontier","modeFrontier","precise","minindent","minline","lim","indented","findStartLine","saved","fromSaved","processLine","viewFrom","viewTo","nextLine","startAt","stream","callBlankLine","readToken","blankLine","token","copy","Token","takeToken","asArray","tokens","extractLineClasses","lineClass","flattenSpans","curStart","curStyle","addModeClass","mName","sawReadOnlySpans","sawCollapsedSpans","MarkedSpan","marker","getMarkedSpanFor","spans","span","removeMarkedSpan","stretchSpansOverChange","change","full","oldFirst","markedSpans","oldLast","startCh","endCh","isInsert","nw","inclusiveLeft","insertLeft","endsAfter","inclusiveRight","markedSpansBefore","startsBefore","markedSpansAfter","sameLine","span$1","clearEmptySpans","newMarkers","gapMarkers","gap","clearWhenEmpty","detachMarkedSpans","detachLine","attachMarkedSpans","attachLine","extraLeft","extraRight","compareCollapsedMarkers","lenDiff","aPos","bPos","fromCmp","toCmp","collapsedSpanAtSide","sps","sp","collapsed","collapsedSpanAtStart","collapsedSpanAtEnd","collapsedSpanAround","conflictingCollapsedRange","lineNo$$1","visualLine","visualLineNo","lineN","vis","visualLineEndNo","lastLine","lineIsHidden","widgetNode","lineIsHiddenInner","heightAtLine","lineObj","lineLength","found$1","findMaxLine","maxLine","maxLineLength","maxLineChanged","Line","estimateHeight","cleanUpLine","styleToClassCache","styleToClassCacheWithMode","interpretTokenStyle","buildLineContent","lineView","builder","pre","trailingSpace","splitSpaces","getOption","addToken","buildToken","buildTokenBadBidi","insertLineContent","externalMeasured","maps","caches","lastChild","defaultSpecialCharPlaceholder","startStyle","endStyle","css","displayText","trailingBefore","spaceBefore","special","specialChars","mustWrap","createDocumentFragment","lastIndex","txt$1","tabWidth","specialCharPlaceholder","fullStyle","part","buildCollapsedSpan","ignoreWidget","widget","needsContentAttribute","setUneditable","allText","spanStyle","spanEndStyle","spanStartStyle","nextChange","foundBookmarks","endStyles","upto","tokenText","LineView","visualLineContinued","hidden","buildViewArray","nextPos","operationGroup","orphanDelayedCallbacks","signalLater","delayedCallbacks","fireOrphanDelayed","delayed","updateLineForChanges","dims","updateLineText","updateLineGutter","updateLineClasses","updateLineWidgets","ensureLineWrapped","replaceChild","zIndex","getLineContent","ext","built","background","updateLineBackground","wrapClass","gutter","gutterBackground","gutterClass","fixedGutter","fixedPos","gutterTotalWidth","markers","gutterMarkers","lineNumbers","wrap$1","gutterWrap","lineNumber","gutterLeft","k","gutterSpecs","gutterWidth","alignable","nextSibling","insertLineWidgets","buildLineElement","insertLineWidgetsFor","allowAbove","widgets","ws","handleMouseEvents","positionLineWidget","above","noHScroll","wrapperWidth","coverGutter","paddingLeft","marginLeft","widgetHeight","parentStyle","gutters","clientWidth","eventInWidget","sizer","mover","paddingTop","lineSpace","offsetTop","paddingVert","paddingH","cachedPaddingH","getComputedStyle","currentStyle","parseInt","paddingRight","scrollGap","nativeBarWidth","displayWidth","scroller","barWidth","displayHeight","clientHeight","barHeight","mapFromLineView","measureChar","bias","measureCharPrepared","prepareMeasureForLine","findViewForLine","findViewIndex","getDimensions","forceUpdate","lineMeasure","updateExternalMeasurement","rect","hasHeights","prepared","varHeight","wrapping","lineWrapping","curWidth","heights","rects","getClientRects","abs","bottom","ensureLineHeights","place","nodeAndOffsetInLineMap","coverStart","coverEnd","getUsefulRect","screen","logicalXDPI","deviceXDPI","normal","fromRange","hasBadZoomedRects","scaleX","scaleY","logicalYDPI","deviceYDPI","maybeUpdateRectForZooming","rSpan","charWidth","nullRect","rtop","rbot","bot","bogus","singleCursorHeightPerLine","rbottom","measureCharInner","measureText","mStart","mEnd","clearLineMeasurementCacheFor","clearLineMeasurementCache","externalMeasure","clearCaches","cachedCharWidth","cachedTextHeight","lineNumChars","pageScrollX","pageXOffset","documentElement","scrollLeft","pageScrollY","marginTop","pageYOffset","scrollTop","widgetTopHeight","intoCoordSystem","includeWidgets","yOff","viewOffset","lOff","xOff","fromCoordSystem","coords","localBox","lineSpaceBox","charCoords","cursorCoords","preparedMeasure","getBidi","partPos","other","estimateCoords","PosWithInfo","outside","xRel","coordsChar","y","coordsCharInner","rangeEnd","wrappedLineExtent","begin","wrappedLineExtentChar","boxIsAfter","box","widgetHeight$$1","ltr","coordsBidiPartWrapped","coordsBidiPart","baseX","chAround","boxAround","atLeft","atStart","_lineNo","ref","closestDist","endX","dist","textHeight","anchor","clientLeft","offsetLeft","compensateForHScroll","th","perLine","widgetsHeight","estimateLineHeights","est","estHeight","posFromMouse","liberal","forRect","space","clientX","clientY","colDiff","round","regChange","lendiff","updateLineNumbers","viewChanged","resetView","cut","viewCuttingPoint","cut$1","cutTop","cutBot","regLineChange","oldN","newN","countDirtyView","dirty","updateSelection","showSelection","prepareSelection","primary","curFragment","cursors","selFragment","ranges","primIndex","empty","showCursorWhenSelecting","drawSelectionCursor","drawSelectionRange","cursor","cursorHeight","otherCursor","cmpCoords","padding","leftSide","rightSide","sizerWidth","docLTR","drawForLine","fromArg","toArg","lineLen","wrapX","extent","iterateBidiSections","fromPos","toPos","openStart","openEnd","openRight","topLeft","topRight","botLeft","botRight","sFrom","sTo","fromLine","toLine","singleVLine","leftEnd","rightStart","restartBlink","focused","blinker","cursorDiv","visibility","cursorBlinkRate","ensureFocus","focus","onFocus","delayBlurEvent","delayingBlurEvent","onBlur","readOnly","selForContextMenu","receivedFocus","updateHeightsInViewport","prevBottom","lineDiv","updateWidgetHeight","chWidth","w","visibleLines","viewport","ensure","ensureFrom","ensureTo","calculateScrollPos","snapMargin","screentop","docBottom","atTop","atBottom","newTop","screenleft","screenw","tooWide","addToScrollTop","resolveScrollToPos","ensureCursorVisible","getCursor","scrollToPos","margin","cursorScrollMargin","scrollToCoords","scrollToCoordsRange","sPos","updateScrollTop","updateDisplaySimple","setScrollTop","startWorker","forceScroll","scrollHeight","scrollbars","setScrollLeft","isScroller","scrollWidth","alignHorizontally","measureForScrollbars","gutterW","docH","viewHeight","viewWidth","barLeft","docHeight","NativeScrollbars","vert","horiz","checkedZeroWidth","minHeight","minWidth","update","needsH","needsV","sWidth","totalHeight","totalWidth","zeroWidthHack","disableHoriz","enableZeroWidthBar","disableVert","pointerEvents","bar","maybeDisable","elementFromPoint","NullScrollbars","updateScrollbars","startWidth","startHeight","updateScrollbarsInner","sizes","paddingBottom","heightForcer","borderBottom","scrollbarFiller","coverGutterNextToScrollbar","gutterFiller","scrollbarModel","initScrollbars","scrollbarStyle","axis","nextOpId","startOperation","op","updateInput","typing","changeObjs","cursorActivityCalled","selectionChanged","updateMaxLine","ops","ownsGroup","endOperation","endCb","callbacks","fireCallbacksForOps","finishOperation","endOperation_R1","updatedDisplay","mustUpdate","updateDisplayIfNeeded","endOperation_R2","endOperation_W2","endOperation_finish","endOperations","scrollbarsClipped","marginBottom","borderRightWidth","maybeClipScrollbars","DisplayUpdate","barMeasure","adjustWidthTo","maxScrollLeft","preparedSelection","takeFocus","setDocumentHeight","postUpdateDisplay","wheelStartX","wheelStartY","doScroll","innerHeight","scrollNode","scrollIntoView","maybeScrollWindow","limit","endCoords","scrollPos","startTop","startLeft","scrollPosIntoView","maybeHiddenMarkers","unhidden","maybeUnhiddenMarkers","finish","runInOp","operation","methodOp","docMethodOp","time","highlight","highlightWorker","workTime","changedLines","oldStyles","highlighted","oldCls","newCls","ischange","workDelay","visible","editorIsHidden","wrapperHeight","oldDisplayWidth","renderedView","maybeUpdateLineNumberWidth","viewportMargin","different","lastWrapHeight","lastWrapWidth","adjustView","toUpdate","selSnapshot","hasFocus","anchorNode","anchorOffset","focusNode","focusOffset","selectionSnapshot","updateNumbersFrom","rm","currentWheelTarget","updateNumber","patchDisplay","snapshot","removeAllRanges","addRange","restoreSelection","selectionDiv","reportedViewFrom","reportedViewTo","updateGutterSpace","alignWidgets","align","innerW","lineGutter","lineNumInnerWidth","lineNumWidth","getGutters","sawLineNumbers","renderGutters","specs","gElt","updateGutters","Display","wheelDX","wheelDY","activeTouch","wheelSamples","wheelPixelsPerUnit","wheelEventDelta","dx","wheelDeltaX","dy","wheelDeltaY","detail","HORIZONTAL_AXIS","VERTICAL_AXIS","wheelDelta","wheelEventPixels","delta","onScrollWheel","canScrollX","canScrollY","pixels","movedX","movedY","Selection","equals","here","there","deepCopy","Range","somethingSelected","normalizeSelection","mayTouch","selectionsMayTouch","prim","inv","simpleSelection","changeEnd","adjustForChange","computeSelAfterChange","offsetPos","loadMode","modeOption","resetModeState","isWholeLineUpdate","wholeLineUpdateBefore","updateDoc","estimateHeight$$1","spansFor","updateLine","linesFor","firstLine","lastText","lastSpans","nlines","added$1","added$2","linkedDocs","sharedHistOnly","skip","sharedHist","linked","rel","shared","attachDoc","setDirectionClass","startGen","done","undone","undoDepth","lastModTime","lastSelTime","lastOp","lastSelOp","lastOrigin","lastSelOrigin","generation","maxGeneration","historyChangeFromChange","histChange","attachLocalSpans","clearSelectionEvents","addChangeToHistory","selAfter","opId","hist","historyEventDelay","lastChangeEvent","pushSelectionToHistory","addSelectionToHistory","selectionEventCanBeMerged","clearRedo","dest","removeClearedSpans","explicitlyCleared","mergeOldSpans","getOldSpans","stretched","oldCur","stretchCur","copyHistoryArray","newGroup","instantiateSel","newChanges","extendRange","posBefore","extendSelection","setSelection","extendSelections","heads","replaceOneSelection","setSimpleSelection","setSelectionReplaceHistory","setSelectionNoUndo","NaN","filterSelectionChange","setSelectionInner","skipAtomicInSelection","reCheckSelection","mayClear","newAnchor","skipAtomic","newHead","skipAtomicInner","oldPos","preventCursorLeft","selectLeft","preventCursorRight","selectRight","atomic","near","movePos","far","cantEdit","selectAll","filterChange","canceled","makeChange","ignoreReadOnly","suppressEdits","mark","parts","mk","newParts","dfrom","dto","removeReadOnlyRanges","makeChangeInner","makeChangeSingleDoc","rebased","rebaseHist","makeChangeFromHistory","allowSelectionOnly","suppress","antiChanges","returned","shiftDoc","distance","recomputeMaxLength","checkWidthStart","retreatFrontier","changesHandler","changeHandler","makeChangeSingleDocInEditor","replaceRange","splitLines","rebaseHistSelSingle","rebaseHistArray","sub","ok","copied","changeLine","handle","changeType","LeafChunk","BranchChunk","removeInner","insertInner","iterN","oldHeight","leaf","maybeSpill","me","sibling","myIndex","used","LineWidget","adjustScrollWhenAboveVisible","this$1","oldH","nextMarkerId","TextMarker","markText","cloneNode","isParent","SharedTextMarker","markTextShared","replacedWith","addToHistory","curLine","addMarkedSpan","clearOnEnter","clearHistory","withOp","visual","dHeight","findSharedMarkers","findMarks","detachSharedMarkers","subMarker","nextDocId","Doc","lineSep","cleanGeneration","getValue","lineSeparator","setValue","getRange","getLineHandle","getLineNumber","getLineHandleVisualStart","lineCount","listSelections","setCursor","extendSelectionsBy","setSelections","addSelection","getSelections","replaceSelection","dup","replaceSelections","newSel","hint","oldPrev","newPrev","computeReplacedSel","undo","redo","undoSelection","redoSelection","setExtending","getExtending","historySize","markClean","changeGeneration","forceSplit","isClean","gen","getHistory","setHistory","histData","setGutterMarker","gutterID","clearGutter","lineInfo","addLineClass","removeLineClass","addLineWidget","insertAt","aboveVisible","removeLineWidget","setBookmark","realOpts","findMarksAt","getAllMarks","posFromIndex","sepSize","indexFromPos","copyHistory","linkedDoc","mFrom","mTo","subMark","copySharedMarkers","unlinkDoc","CodeMirror","splitIds","iterLinkedDocs","setDirection","eachLine","lastDrop","onDrop","clearDragCursor","files","dataTransfer","isReadOnly","FileReader","File","read","loadFile","file","allowDropFileTypes","reader","onload","readAsText","draggingText","text$1","getData","selected","dragCursor","forEachCodeMirror","getElementsByClassName","byClass","editors","globalsRegistered","ensureGlobalHandlers","resizeTimer","onResize","setSize","keyNames","3","8","9","13","16","17","18","19","20","27","32","33","34","35","36","37","38","39","40","44","45","46","59","61","91","92","93","106","107","109","110","111","145","173","186","187","188","189","190","191","192","219","220","221","222","63232","63233","63234","63235","63272","63273","63275","63276","63277","63302","keyMap","normalizeKeyName","alt","ctrl","cmd","mod","normalizeKeyMap","keymap","keyname","lookupKey","getKeyMap","fallthrough","isModifierKey","addModifierNames","noShift","altKey","metaKey","shiftKey","keyName","altGraphKey","deleteNearSelection","compute","kill","toKill","replaced","moveCharLogically","moveLogically","endOfLine","visually","prep","targetTop","basic","pcDefault","emacsy","macDefault","commands","singleSelection","killLine","deleteLine","delLineLeft","delWrappedLineLeft","delWrappedLineRight","rightPos","goDocStart","goDocEnd","goLineStart","goLineStartSmart","lineStartSmart","goLineEnd","visualLineEnd","lineEnd","goLineRight","goLineLeft","goLineLeftSmart","goLineUp","moveV","goLineDown","goPageUp","goPageDown","goCharLeft","moveH","goCharRight","goColumnLeft","goColumnRight","goWordLeft","goGroupRight","goGroupLeft","goWordRight","delCharBefore","deleteH","delCharAfter","delWordBefore","delWordAfter","delGroupBefore","delGroupAfter","indentAuto","indentSelection","indentMore","indentLess","insertTab","insertSoftTab","spaces","defaultTab","execCommand","transposeChars","newlineAndIndent","sels","indentLine","openLine","toggleOverwrite","firstNonWS","inWS","doHandleBinding","dropShift","ensurePolled","prevShift","stopSeq","dispatchKey","seq","keySeq","dispatchKeyInner","keyMaps","extraKeys","lookupKeyForEditor","handleKeyBinding","motion","lastStoppedKey","onKeyDown","handled","up","showCrossHair","onKeyUp","onKeyPress","charCode","handleCharBinding","lastClick","lastDoubleClick","PastClick","onMouseDown","supportsTouch","clickInGutter","repeat","compare","clickRepeat","selectingText","handleMappedButton","contained","option","addNew","moveOnDrag","configureMouse","dragDrop","moved","dragEnd","mouseMove","dragStart","e2","leftButtonStartDrag","ourRange","ourIndex","startSel","rangeForUnit","lastPos","extendTo","startCol","posCol","leftPos","oldRange","ranges$1","anchorLine","boundary","headIndex","usePart","bidiSimplify","editorSize","move","buttons","curCount","leftButtonSelect","leftButtonDown","onContextMenu","findWordAt","gutterEvent","prevent","mX","mY","lineBox","g","contextMenuInGutter","themeChanged","theme","Init","optionHandlers","dragDropChanged","funcs","dragFunctions","toggle","enter","over","leave","wrappingChanged","inputStyles","inputStyle","pasteIncoming","cutIncoming","autofocus","word","touchFinished","prevTouch","finishTouch","farAway","touch","radiusX","radiusY","isMouseLikeTouchEvent","pageX","pageY","frag","onDragOver","setData","effectAllowed","setDragImage","img","_top","onDragStart","inp","getField","registerEventHandlers","finishInit","initHooks","textRendering","how","aggressive","indent","curSpace","curSpaceString","indentUnit","indentString","indentWithTabs","pos$1","defineInitHook","lastCopied","setLastCopied","newLastCopied","applyTextInput","inserted","deleted","recent","paste","textLines","multiPaste","pasteLinesPerSelection","lineWise","changeEvent","triggerElectric","handlePaste","pasted","clipboardData","disableInput","electricChars","smartIndent","getModeAt","electricInput","copyableRanges","lineRange","disableBrowserMagic","field","spellcheck","autocorrect","autocapitalize","hiddenTextarea","border","findPosH","origDir","moveOnce","boundToLine","bidi","mv","getWrappedLineExtent","moveInStorageOrder","searchInVisualLine","getRes","nextCh","moveVisually","sawType","getHelper","hitSide","findPosV","pageSize","moveAmount","ContentEditableInput","lastAnchorNode","lastAnchorOffset","lastFocusNode","lastFocusOffset","polling","composing","gracePeriod","readDOMTimeout","posToDOM","badPos","bad","domToPos","lineNode","locateNodeInLineView","textNode","topNode","nodeValue","curNode","textContent","previousSibling","dist$1","onCopyCut","lineWiseCopyCut","clearData","kludge","hadFocus","showPrimarySelection","updateFromDOM","readFromDOMSoon","forceCompositionEnd","showMultipleSelections","curAnchor","curFocus","rng","rangeCount","getRangeAt","startGracePeriod","rememberSelection","selectionInEditor","commonAncestorContainer","blur","pollSelection","pollInterval","poll","scan","isInGutter","triggerOnKeyDown","pollContent","fromNode","toNode","toIndex","newText","closing","extraLinebreak","addText","walk","cmText","markerID","isBlock","domTextBetween","oldText","cutFront","cutEnd","oldTop","maxCutFront","newBot","oldBot","maxCutEnd","chFrom","chTo","contentEditable","readOnlyChanged","resetPosition","TextareaInput","prevInput","pollingFast","createField","textarea","prepareCopyCut","fastPoll","dispatchEvent","Event","_display","moveInputWithCursor","headPos","wrapOff","lineOff","teTop","teLeft","drawn","contextMenuPending","slowPoll","missed","same","resetSelectionOnContextMenu","oldScrollY","oldCSS","oldWrapperCSS","wrapperBox","offsetParent","scrollY","scrollTo","rehide","detectingSelectAll","prepareSelectAllHack","mouseup","extval","disabled","deflt","notOnInit","defineOption","newBreaks","refresh","getInputField","attach","integer","defineOptions","helpers","setOption","getDoc","addKeyMap","removeKeyMap","addOverlay","score","priority","insertSorted","modeSpec","removeOverlay","newRanges","getTokenAt","getLineTokens","getTokenTypeAt","getHelpers","help","_global","getStateAfter","defaultTextHeight","defaultCharWidth","getViewport","addWidget","vspace","hspace","triggerOnKeyPress","triggerOnKeyUp","triggerOnMouseDown","amount","rtlMoveVisually","goalColumn","goals","startChar","check","getScrollInfo","scrollToRange","interpret","swapDoc","phrase","phraseText","phrases","getWrapperElement","getScrollerElement","getGutterElement","registerHelper","registerGlobalHelper","addEditorMethods","dontDelegate","defineMIME","mime","defineExtension","defineDocExtension","fromTextArea","tabindex","realSubmit","form","leaveSubmitMethodAlone","submit","wrappedSubmit","getTextArea","toTextArea","cmpPos","addLegacyProps","version","oldEl","newEl","appendAtIndex","total","appendVNodes","vNodes","vNodesArr","vnode","mousedown","handleClick","DomainViews","itemView","ToolbarButtonView","ToolbarButton","showOffsets","enable","frameOff","canvasOff","adjScroll","startSelectComponent","updateAttached","toggleSelectComponent","stopSelectComponent","getCanvasBody","win","getContentWindow","onHover","onOut","onClick","onFrameScroll","onSelect","onHovered","trg","setHovered","forceChange","component","getElementPos","updateBadge","updateHighlighter","showElementOffset","hideBadge","hideHighlighter","hideElementOffset","elPos","stopCommand","showFixedElementOffset","hideFixedElementOffset","canvas","getHighlighter","multiple","selectToggle","clearSelection","Canvas","getWindow","getSelectedAll","selColl","selIndex","selectAdd","initResize","customeLabel","customBadgeLabel","cacheEl","badge","getBadge","clsBadge","badgeLabel","bStyle","canvasPos","getCanvasPosition","canvasTop","canvasLeft","posTop","badgeW","hlStyle","getSelected","updateToolbar","modelToStyle","resizeClass","toggleBodyClass","docs","onStart","resizer","keyHeight","keyWidth","currentUnit","keepAutoHeight","keepAutoWidth","getModelToStyle","computedStyle","modelStyle","currentWidth","autoWidth","currentHeight","autoHeight","startDim","unitHeight","unitWidth","onMove","onEnd","updateTarget","store","selectedHandler","onlyHeight","onlyWidth","bodyw","getBody","updateEvent","toolbarEl","getToolbarEl","toolbarStyle","showToolbar","opacity","Toolbar","toolbarView","ToolbarView","updateToolbarPos","getTargetToElementDim","frameOffset","getFrameOffset","elementHeight","targetHeight","elementTop","elRight","elementLeft","elementWidth","targetWidth","canvasWidth","getPosition","clean","selEl","hoverClass","getBadgeEl","viewEl","updateContainer","cleanPrevious","frameEl","sender","preserveSelected","setSelected","Constructor","_defineProperties","descriptor","holderClass","inputClass","handleModelChange","elementUpdated","getInputEl","fromInput","inputEl","plh","html","propTarget","onChange","onInputRender","customValue","addTo","appendTo","typeView","rendered","resetPos","Dragger","onDrag","setPosition","guidesStatic","guidesTarget","snapOffset","scale","getDocumentEl","getContainerEl","getWindowEl","drag","keyHandle","handleScroll","lastScroll","actualScroll","scrollDiff","lastScrollDiff","toggleDrag","startPointer","getPointerPos","startPosition","getStartPosition","globScrollDiff","currentPos","glDiff","lockedAxis","detectAxisLock","moveDelta","co","deltaPre","currentPointer","snapGuides","newDelta","trgX","trgY","stat","isY","axs","trgPoint","statPoint","deltaPoint","trgGuide","isPointIn","trgValue","setGuideLock","lock","ofst","guide","trgName","cancelled","xPos","yPos","defaultView","parentWindow","getPos","getPointerPosition","pEv","relX","relY","absX","absY","onAdd","df","it","logWarning","parseString","cssc","parsed","parseHtml","require","addCollection","isMult","processDef","mdl","processor","modelPr","$$typeof","parserHtml","splitPropsFromAttr","getType","setClassRule","editorModel","badgeClass","plhClass","freezClass","getCanvas","$canvas","$wrapper","getCanvasWrapper","getFrameEl","canvasTool","getCanvasTools","bodyEl","getWrapperEl","getToolsEl","callRun","abort","callStop","ParserHtml","extendStyle","propNew","addStyle","removeStyle","imp","important","getSelectors","idMatch","classMatch","htmlMatch","singlet","getElementsByTagName","querySelectorAll","parseHTML","implementation","createHTMLDocument","onReady","readyState","cash","elems","getElementById","oMatchesSelector","getCompareFunction","second","isNumeric","getDataCache","dataset","removeData","notWhiteMatch","hasClass","classList","removeAttribute","removeProp","toggleClass","camelRegex","whiteSpace","letter","getPrefixedProp","ucProp","removeEvent","eventCache","encode","selectedIndex","getSelectSingle_","getSelectMultiple_","insertContent","prepend","insertAdjacentHTML","insertElement","prefixedProp","lower","margins","runOnce","originalCallback","finalCallback","registerEvent","one","ready","evt","createEvent","initEvent","serialize","elements","insertAfter","outerHTML","_this","_this2","prependTo","docEl","clientTop","nextElementSibling","not","parents","previousElementSibling","siblings","Property","functionName","fixedValues","toRequire","requires","requiresParent","callInit","clearValue","complete","parseValue","valueStr","numeric","num","getDefaultValue","getFullValue","hasValue","callParentInit","skipInit","detached","separator","Properties","updateValues","getSplitSeparator","defaultProps","getPropertyAt","preview","getPropertyValue","Layer","onReset","noIncrement","getSeparator","getLayersFromValue","layers","cleaned","layerValue","getLayersFromStyle","styleObj","propModel","layer","propertyObj","layerProprs","propertyName","getPropertyValues","layerSeparator","layersColl","Layers","getLayers","getCurrentLayer","getLayersFromTarget","templateLabel","templateInput","inputHolderId","sector","modelValueChanged","updateVisibility","updatedCls","computedCls","labelEl","clearStyleEl","getClearEl","clearStyle","clearProperties","clearEl","getTarget","getTargetModel","getHelperModel","inputValueChanged","getInputValue","setStatus","emitUpdateTarget","checkVisibility","targetValue","ignoreDefault","defaultValue","computedValue","getComputedValue","highlightChanged","showComputed","highlightComputed","hideNotStylable","isTargetStylable","isComponentStylable","show","hide","customFetchValue","ignoreCustomValue","computedDef","computedDefault","avoid","avoidComputed","notToSkip","fromParent","updateTargetStyle","stylableReq","sectors","parentEl","setRawValue","cleanValue","clearCached","$input","targetUpdate","PropertyView","propView","$props","console","warn","propsView","PropertiesView","getPropsConfig","that","mIndex","valueOnIndex","click","textLayer","stackModel","sorter","propsConfig","customPreview","onPreview","updatePreview","initSorter","startSort","stackIndex","valueInt","previewEl","getPreviewEl","getPropertiesWrapper","propsWrapEl","wrapEl","deselectAll","utils","Sorter","ignoreViewChildren","containerSel","itemSel","addToCollection","fragmentEl","LayerView","PropertyCompositeView","indexChanged","refreshLayers","addLayer","deepClone","getLayerValues","layersObj","fieldEl","subModel","subProp","LayersView","assetsLabel","modal","am","$preview","$previewBox","componentValue","setPreviewView","setPreview","pv","spreadUrl","removeFile","openAssetManager","accept","onDblClick","asset","inputInst","unitEl","$unit","PropertyIntegerView","InputColor","$color","colorEl","onOptionChange","getOptions","addOption","updateOptions","optionsStr","styleAttr","inputH","itemCls","inputStr","labelTxt","titleAttr","inputHld","inputChk","getCheckedEl","inputIn","checked","units","InputNumber","validateInputValue","deepCheck","showInput","getSliderEl","slider","inputValueChangedSoft","TypeableCollection","PropertyStack","PropertyStackView","isType","PropertyComposite","PropertyFileView","PropertyColorView","PropertySelect","PropertySelectView","PropertyRadio","PropertyRadioView","PropertySlider","PropertySliderView","PropertyInteger","startSelectPosition","isPointed","placer","getPlacerEl","wmargin","nested","canvasRelative","getZoomDecimal","getOffsetDim","stopSelectPosition","posTargetCollection","posIndex","posMethod","cDim","endMove","posIsLastEl","posTargetEl","outsideElem","posTargetModel","nearFloat","isLast","Promise","rej","req","XMLHttpRequest","withCredentials","credentials","headers","statusText","resolve","responseText","onerror","upload","onProgress","onprogress","send","compTypes","modelAttrStart","modelAttr","valueLen","valStr","firstChar","lastChar","decls","decl","parseClass","parseNode","nodes","attrsLen","nodePrev","nodeChild","ct","compType","keepEmptyTextNodes","allTxt","foundTextNode","ci","cType","textTags","parserCss","scripts","allowScripts","styleStr","baseType","getBaseType","typeFound","recognizeType","getTypes","addType","definition","ModelInst","ViewInst","Input","contClass","valid","validObj","handleUnitChange","getUnitEl","upArrowClick","normalizeValue","downArrowClick","downIncrement","moveIncrement","upIncrement","prValue","defValue","fixed","regFixed","valCopy","uN","itemsView","itemType","itemViewNotFound","reuseView","typeField","resetChildren","tempComp","tempRemove","scriptContainer","allRules","getAll","hasSign","optStyle","triggerAdd","compView","dt","viewObject","ItemsView","clsNoEdit","hidable","countChildren","clsNoChild","clsTitle","clsTitleC","clsCaret","clsInput","inputNameCls","gut","clsBase","isVisible","clsCount","clsMove","clsChildren","checkChildren","updateOpening","clsEdit","viewLayer","getVisibilityEl","eyeEl","hClass","toggleVisibility","handleEdit","getInputName","setEditing","handleEditEnd","inputName","opened","getCaret","toggleOpening","handleSelect","fromLayers","scrollCanvas","handleHover","showHover","freeze","unfreeze","ComponentView","highlightHover","noChildCls","cnt","isCountable","hideTextnode","caret","setRoot","getWrapper","showWrapper","defaultOpts","beforeShow","color","flat","allowEmpty","showButtons","clickoutFiresChange","showInitial","showPalette","showPaletteOnly","hideAfterPaletteSelect","togglePaletteOnly","showSelectionPalette","localStorageKey","maxSelectionSize","cancelText","chooseText","togglePaletteMoreText","togglePaletteLessText","clearText","noColorSelectedText","preferredFormat","containerClassName","replacerClassName","showAlpha","palette","selectionPalette","spectrums","IE","rgbaSupport","backgroundColor","replaceInput","markup","gradientFix","paletteTemplate","tiny","tinycolor","toHsl","formattedString","swatchStyle","toRgbString","toFilter","spectrum","callbackContext","instanceOptions","resize","reflow","throttler","isDragging","dragWidth","dragHeight","dragHelperHeight","slideHeight","alphaWidth","alphaSlideHelperWidth","slideHelperHeight","currentHue","currentSaturation","currentValue","currentAlpha","paletteArray","paletteLookup","draggingClass","shiftMovementDirection","boundElement","pickerContainer","dragger","dragHelper","slideHelper","alphaSliderInner","alphaSlider","alphaSlideHelper","textInput","paletteContainer","initialColorContainer","cancelButton","clearButton","chooseButton","toggleButton","isInput","isInputTypeColor","inputTypeColorSupport","shouldReplace","replacer","offsetElement","previewElement","initialColor","colorOnShow","currentPreferredFormat","applyOptions","rgb","updateSelectionPaletteFromStorage","localStorage","oldPalette","addColorToSelectionPalette","inArray","drawPalette","currentColor","getUniqueSelectionPalette","drawInitial","dragStop","setFromTextInput","updateOriginalInput","isDefaultPrevented","hideAll","$doc","onkeydown","clickout","updateUI","revert","ignoreFormatChange","newColor","newHsv","toHsv","getFormat","fromRatio","format","updateHelperLocations","flatColor","toHexString","realColor","displayColor","realHex","realRgb","alpha","toRgb","realAlpha","gradient","gradientType","dragX","dragY","alphaX","slideY","fireCallback","picker","dpWidth","outerWidth","dpHeight","outerHeight","inputHeight","docElem","cW","cH","scL","scT","getOffset","disable","paletteElementClick","ignore","keydown","oldDragX","oldDragY","furtherFromX","paletteEvent","spect","optionName","optionValue","coord","onmove","onstart","onstop","dragging","maxHeight","maxWidth","hasTouch","duringDragEvents","t0","dataID","extra","load","loadOpts","_cachedResult","colorInput","localization","palettes","processNativeColorInputs","colorInputs","trimLeft","trimRight","tinyCounter","math","mathRound","mathMin","mathMax","mathRandom","named","matchers","rgba","hsl","hsla","hsv","hsva","hex8","parseIntFromHex","hex6","hex3","stringInputToObject","bound01","convertToPercentage","q","hsvToRgb","hue2rgb","hslToRgb","boundAlpha","inputToRGB","_originalInput","_r","_g","_b","_a","_roundA","_format","_gradientType","_ok","_tc_id","rgbToHsl","rgbToHsv","rgbToHex","allow3Char","hex","pad2","rgbaToHex","desaturate","clamp01","saturate","greyscale","lighten","brighten","darken","spin","hue","complement","triad","tetrad","splitcomplement","analogous","slices","ret","monochromatic","modification","isDark","getBrightness","isLight","getOriginalInput","getAlpha","setAlpha","toHsvString","toHslString","toHex","toHex8","toHex8String","toPercentageRgb","toPercentageRgbString","toName","hexNames","secondColor","hex8String","secondHex8String","formatSet","hasAlpha","_applyModification","_applyCombination","color1","color2","mix","w1","rgb1","rgb2","w2","readability","c1","c2","brightnessA","brightnessB","colorDiff","brightness","isReadable","mostReadable","baseColor","colorList","bestColor","bestScore","bestIsReadable","readable","aliceblue","antiquewhite","aqua","aquamarine","azure","beige","bisque","black","blanchedalmond","blue","blueviolet","brown","burlywood","burntsienna","cadetblue","chartreuse","chocolate","coral","cornflowerblue","cornsilk","crimson","cyan","darkblue","darkcyan","darkgoldenrod","darkgray","darkgreen","darkgrey","darkkhaki","darkmagenta","darkolivegreen","darkorange","darkorchid","darkred","darksalmon","darkseagreen","darkslateblue","darkslategray","darkslategrey","darkturquoise","darkviolet","deeppink","deepskyblue","dimgray","dimgrey","dodgerblue","firebrick","floralwhite","forestgreen","fuchsia","gainsboro","ghostwhite","gold","goldenrod","gray","green","greenyellow","grey","honeydew","hotpink","indianred","indigo","ivory","khaki","lavender","lavenderblush","lawngreen","lemonchiffon","lightblue","lightcoral","lightcyan","lightgoldenrodyellow","lightgray","lightgreen","lightgrey","lightpink","lightsalmon","lightseagreen","lightskyblue","lightslategray","lightslategrey","lightsteelblue","lightyellow","lime","limegreen","linen","magenta","maroon","mediumaquamarine","mediumblue","mediumorchid","mediumpurple","mediumseagreen","mediumslateblue","mediumspringgreen","mediumturquoise","mediumvioletred","midnightblue","mintcream","mistyrose","moccasin","navajowhite","navy","oldlace","olive","olivedrab","orange","orangered","orchid","palegoldenrod","palegreen","paleturquoise","palevioletred","papayawhip","peachpuff","peru","pink","plum","powderblue","purple","rebeccapurple","red","rosybrown","royalblue","saddlebrown","salmon","sandybrown","seagreen","seashell","sienna","silver","skyblue","slateblue","slategray","slategrey","snow","springgreen","steelblue","tan","teal","thistle","tomato","turquoise","violet","wheat","white","whitesmoke","yellow","yellowgreen","flipped","flip","isOnePointZero","processPercent","isPercentage","CSS_UNIT","PERMISSIVE_MATCH3","PERMISSIVE_MATCH4","ColorPicker","getColorEl","valueClr","noneColor","previousColor","cpStyle","elToAppend","colorPickerConfig","getColor","_mods","_scope","_MODIFIERS","control","_MAP","backspace","tab","esc","down","del","home","pageup","pagedown","'","_downKeys","compareArray","modifierMap","updateModifierKey","assignKey","scope","mods","getKeys","getMods","shortcut","getScope","mi","addEvent","modifiersMatch","dispatch","previousKey","setScope","deleteScope","isPressed","getPressedKeyCodes","multipleKeys","setTimeoutFunc","_state","_handled","_value","_deferreds","doResolve","deferred","_immediateFn","onFulfilled","onRejected","promise","then","finale","thisArg","_unhandledRejectionFn","Handler","reason","ex","prom","promiseFinally","race","setImmediate","err","togglable","runDefaultCommand","stopDefaultCommand","Buttons","Button","deactivateAllExceptOne","except","deactivateAll","fromCollection","disableAllButtons","disableAllButtonsExceptOne","keySet","parserConfig","inline","propertyKeywords","tokenHooks","documentTypes","mediaTypes","mediaFeatures","mediaValueKeywords","nonStandardPropertyKeywords","fontProperties","counterDescriptors","colorKeywords","valueKeywords","allowNested","lineComment","supportsAtComponent","tp","tokenBase","tokenize","tokenString","tokenParenthesized","quote","escaped","pushContext","popContext","states","popAndPass","wordAsValue","stateArg","_stream","atBlock","textAfter","cx","blockCommentStart","blockCommentEnd","blockCommentContinue","fold","documentTypes_","mediaTypes_","mediaFeatures_","mediaValueKeywords_","propertyKeywords_","nonStandardPropertyKeywords_","colorKeywords_","valueKeywords_","allWords","tokenCComment","maybeEnd","DomComponents","CssComposer","canvasModel","toggleMove","disableDragger","enableDragger","toggleDragger","methodCls","methodEv","methodsEv","setupGuides","isTran","guidesContainer","getGuidesContainer","getGuidesTarget","getGuidesStatic","drg","guides","guidesEl","elInfoX","elInfoY","guideContent","elGuideInfoX","elGuideInfoY","elGuideInfoContentX","elGuideInfoContentY","updateGuides","debug","renderGuide","getElementGuides","getGuidePosUpdate","getRect","topScroll","frameTop","un","guideSize","numEl","originRect","getTranslate","transform","itemStr","setTranslate","en","adds","center","getMouseRelativeCanvas","guidesInfo","renderGuideInfo","hideGuidesInfo","rectOrigin","origEdge1","origEdge1Raw","origEdge2","origEdge2Raw","elGuideInfo","elGuideInfoCnt","guideInfoStyle","statEdge2","isEdge1","statEdge1","statEdge1Raw","statEdge2Raw","pos2","sizeRaw","toSelect","snd","dc","rules","toClear","selectorsToString","SelectComponent","mouseover","startDelete","mouseout","stopDelete","onDelete","$this","attachBadge","removeBadge","updateBadgeLabel","Modal","CodeManager","$editors","oHtmlEd","buildEditor","oCsslEd","htmlEditor","cssEditor","textViewCode","setContent","getHtml","getCss","codeName","codeMirror","getViewer","EditorView","isEnabled","fullscreenElement","webkitFullscreenElement","mozFullScreenElement","requestFullscreen","webkitRequestFullscreen","mozRequestFullScreen","msRequestFullscreen","exitFullscreen","webkitExitFullscreen","mozCancelFullScreen","msExitFullscreen","fsChanged","targetEl","getContainer","SelectPosition","noSelClass","getHighlighterEl","wp","toggleClipboard","contentDocument","onEndMove","rollback","initSorterFromModel","onEndMoveFromModel","initSorterFromModels","lastModel","toMove","$badge","$hl","AssetManager","amContainer","modalTitle","assets","uploadEl","bm","BlockManager","pn","Panels","blocks","panels","getPanel","addPanel","lm","LayerManager","$cn","$cn2","dvm","DeviceManager","showDevices","SelectorManager","StyleManager","smConfig","$header","textNoElement","panel","toggleSm","Config","TraitManager","tmView","getTraitsViewer","confTm","labelContainer","toggleTm","clp","cop","getPanels","getPanelsEl","tglPointers","elP","stopDefault","editorEl","onclick","canvasS","runDefault","canvasResizer","canvasView","getResizerEl","posFetcher","mousePosFetcher","getMouseRelativePos","forceNew","Utils","Resizer","getOffsetMethod","zoom","showOffsetsSelected","stateVar","offsetViewer","marginT","marginB","marginL","marginR","padT","padB","padL","padR","stateLow","marginName","paddingName","marginV","paddingV","paddingEls","fullMargName","fullPadName","marginLeftSt","marginRightSt","marginRight","marginTopSt","marginBottomSt","mtStyle","mbStyle","mlStyle","mrStyle","ptStyle","pbStyle","plStyle","prStyle","posLeft","widthEl","marginSideH","marginSideT","padTop","padBot","padSideH","padSideT","padRight","ss","fonts","font","buildProps","extendBuilded","builded","buildProperties","extendProperties","propsModel","moProps","pLen","mProps","isolated","mProp","mPProps","buildP","propFactory","PropertyFactory","Sector","caretR","caretD","updateOpen","getPropertiesEl","$caret","renderProperties","dummy","pt","devicePreviewMode","stateStr","helperCls","helperRule","getClassRule","appendStateRule","targetIsClass","selectorsAdd","SectorView","SectView","Sectors","SectorsView","onLoad","elTo","addSector","getSector","_logNoSector","removeSector","getSectors","addProperty","sectorId","getProperty","removeProperty","getProperties","um","cssC","hasClasses","deviceW","getCurrentMedia","avoidInlineStyle","createType","getEmitter","block","scrollLayers","ItemView","componentChanged","getRoot","core_slice","hasKeys","callstackWasIndexed","magicFusionIndex","getMagicFusionIndex","ObjectRegistry","registeredObjects","cidIndexes","onoff","objects","objectRegistry","register","unregister","actionUndoRedo","action","undoTypes","managerUndoRedo","manager","stack","magic","everything","isCurrentlyUndoRedoing","pointer","actions","isUndo","addToStack","track","undoTypesType","condition","validateUndoActionCreation","maximumStackLength","isRegistered","UndoTypes","unsetData","afterAttributes","keysAfter","keysPrevious","OwnedUndoTypes","manipulateUndoType","manipType","undoType","fns","undoTypesInstance","Action","UndoStack","setMaxLength","UndoManager","startTracking","stopTracking","isTracking","_addToStack","unregisterAll","undoAll","redoAll","isAvailable","undoManager","addUndoType","changeUndoType","removeUndoType","defaultAttributes","finallyConstructor","arrayWithHoles","iterableToArrayLimit","nonIterableRest","webpackPolyfill","deprecate","paths","keymaps","configDef","keymaster","defKeys","pk","isEditing","isInputFocused","removeAll","beforeCache","customUndoType","bf","af","entity","hasUndo","hasRedo","getStack","getInstance","Timeout","clearFn","_id","_clearFn","unref","enroll","msecs","_idleTimeoutId","_idleTimeout","unenroll","_unrefActive","_onTimeout","clearImmediate","registerImmediate","channel","messagePrefix","onGlobalMessage","nextHandle","tasksByHandle","currentlyRunningATask","attachTo","getPrototypeOf","process","nextTick","runIfPresent","postMessage","importScripts","postMessageIsAsynchronous","oldOnMessage","onmessage","canUsePostMessage","MessageChannel","port1","port2","onreadystatechange","task","cachedSetTimeout","cachedClearTimeout","defaultSetTimout","defaultClearTimeout","runTimeout","fun","currentQueue","queue","draining","queueIndex","cleanUpNextTick","drainQueue","runClearTimeout","Item","browser","env","argv","versions","addListener","removeListener","removeAllListeners","emit","prependListener","prependOnceListener","binding","cwd","chdir","umask","arr2","defaultTags","attrRegexpCache","getAttrValue","regexp","getAttrRegexp","getTagRegexp","anchored","addTags","htmlMode","multilineTagIndentFactor","multilineTagIndentPastTag","tags","configTags","configScript","scriptTypes","htmlState","inTag","tagInfo","tagText","findMatchingMode","endTagA","endTag","localState","localMode","pat","maybeBackup","local","htmlConfig","autoSelfClosers","implicitlyClosed","contextGrabbers","doNotIndent","allowUnquoted","allowMissing","caseFold","xmlConfig","allowMissingTagName","editorConf","config_","inText","parser","inBlock","doctype","depth","closure","baseState","tagStart","isInAttribute","stringStartCol","terminator","startOfLine","noIndent","maybePopContext","nextTagName","parentTagName","tagNameState","closeTagNameState","attrState","matchClosing","closeState","closeStateErr","attrEqState","attrValueState","attrContinuedState","isInText","baseIndent","fullLine","alignCDATA","tagAfter","grabbers","configuration","skipAttribute","statementIndent","jsonldMode","jsonld","jsonMode","json","isTS","typescript","wordRE","wordCharacters","keywords","kw","A","B","C","D","operator","atom","isOperatorChar","isJsonldKeyword","cont","tokenComment","expressionAllowed","inSet","readRegexp","tokenQuasi","lexical","lastType","brackets","findFatArrow","fatArrowAt","arrow","sawSomething","bracket","atomicTypes","JSLexical","inScope","varname","localVars","vars","marked","inList","newContext","registerVarScoped","Var","globalVars","isModifier","defaultVars","pushcontext","pushblockcontext","popcontext","pushlex","lex","poplex","expect","wanted","exp","statement","vardef","parenExpr","maybeexpression","maybeelse","functiondef","forspec","enumdef","typename","typeexpr","expression","maybelabel","maybeCatchBinding","afterExport","afterImport","funarg","expressionInner","expressionNoComma","noComma","arrowBodyNoComma","arrowBody","commasep","maybeop","maybeoperatorNoComma","maybeoperatorComma","classExpression","arrayLiteral","contCommasep","objprop","quasi","targetNoComma","maybeTypeArgs","maybeTarget","expr","continueQuasi","getterSetter","afterprop","maybetype","what","sep","proceed","maybetypeOrIn","mayberettype","isKW","afterType","typeprop","typearg","maybeReturnType","functiondecl","typeparam","maybeTypeDefault","maybeAssign","vardefCont","eltpattern","proppattern","_type","forspec1","forspec2","classNameAfter","classBody","classfield","maybeFrom","exportField","importSpec","maybeMoreImports","maybeAs","enummember","basecolumn","parseJS","isContinuedStatement","doubleIndentSwitch","closeBrackets","skipExpression","commentStart","commentEnd","newlineAfterToken","inlineElements","isComment","curMode","selText","endIndex","cmInstance","atSol","newline","_arr","_n","_d","_s","_i","sortContainer","created","srcModel","getSourceModel","avoidSelectOnEnd","webpackContext","webpackContextResolve","wrapperId","wrapperName","storeWrapper","cells","columns","rows","rowsToAdd","columnsToAdd","ComponentTableBody","svgAttrs","ratioDefault","cmdName","hasButtonBool","getSrcResult","btoa","isDefaultSrc","parseUri","uri","qrs","pair","hostname","protocol","port","mapUrl","mapType","frameborder","OComponent","parseFromSrc","updateSrc","getMapUrl","addr","qr","z","dblclick","classEmpty","fetchFile","FileUploader","uploadFile","srcExists","onError","noDrag","getIframe","ifrm","frameBorder","onmousedown","compProt","disableEditing","updateContentText","syncContent","rte","fromDisable","rteEnabled","activeRte","toggleEvents","contentOpt","customRte","onInput","disablePropagation","mixins","elDocs","ComponentLinkView","yt","vi","ytnc","videoId","provider","ytUrl","ytncUrl","viUrl","poster","muted","autoplay","controls","modestbranding","sources","allowfullscreen","prov","getYoutubeTraits","getVimeoTraits","getSourceTraits","updateTraits","getYoutubeSrc","getYoutubeNoCookieSrc","getVimeoSrc","getProviderTrait","getAutoplayTrait","getLoopTrait","getControlsTrait","isYtProv","isYtncProv","isViProv","isExtProv","OComponentView","updateVideo","updateProvider","renderByProvider","videoEl","renderYoutube","renderYoutubeNoCookie","renderVimeo","renderSource","initVideoEl","scriptCount","svar","svarNext","SVGElement","createElementNS","createComment","componentView","ComponentTableCell","ComponentTableCellView","ComponentTableRow","ComponentTableRowView","ComponentTable","ComponentTableView","ComponentTableHead","ComponentTableHeadView","ComponentTableBodyView","ComponentTableFoot","ComponentTableFootView","ComponentMap","ComponentMapView","ComponentLink","ComponentLabel","ComponentLabelView","ComponentVideo","ComponentVideoView","ComponentImage","ComponentImageView","ComponentScript","ComponentScriptView","ComponentSvg","ComponentSvgView","ComponentComment","ComponentCommentView","ComponentTextNode","ComponentTextNodeView","ComponentText","ComponentTextView","ComponentWrapper","storageKey","smc","stm","storeHtml","storeComponents","componentHovered","selectRemove","setComponents","postLoad","handleChanges","handleUpdates","handleChangesColl","handleRemoves","evn","els","getCacheLoad","logError","isObj","getComponents","noStore","toStore","getComponent","addComponent","extendView","extendFn","extendFnView","extendType","extendViewType","typeToExtend","modelToExt","viewToExt","getExtendedObj","srcToExt","parentFn","removeType","fromElement","noticeOnUnload","forceClass","log","baseCss","protectedCss","canvasCss","defaultCommand","mediaCondition","jsInHtml","multipleSelection","exportWrapper","wrapperIsBody","avoidDefaults","clearStyles","dragMode","assetManager","storageManager","richTextEditor","domComponents","codeManager","cssComposer","selectorManager","deviceManager","devices","widthMedia","styleManager","blockManager","traitManager","keepUnusedStyles","multiFrames","timedInterval","updateItr","deps","ViewProt","eventNsMap","vid","eventMap","getEvents","getNamespaces","namespaces","bval","baseVal","Window","items","ar","Extender","logs","warning","editing","clipboard","previousModel","changesCount","storables","toLoad","device","toLog","attrsOrig","loadModule","updateChanges","listenLog","eventFrom","eventTo","loadOnStart","canAutoload","onbeforeunload","isAutosave","getStepsBeforeSave","moduleName","Mod","cfgParent","cfg","_disable","removeSelected","addSelected","toggleSelected","wrp","getCode","js","getJs","avoidProt","avoidProtected","protCss","cacheLoad","getDeviceModel","defaultRunning","refreshCanvas","getDirtyCount","inAbsoluteMode","destroyAll","Keymaps","msg","logNs","logInfo","conf","disableButtons","contEl","EditorModel","editorView","StorageManager","Commands","RichTextEditor","Parser","addComponents","getSelectedToStyle","setDevice","getDevice","setCustomRte","setCustomParserCss","plugins","agent","isIE","originalCreateHTMLDocument","DOMImplementation","polyfills","plugin","defaultConfig","autorender","pluginsOpts","Editor","pluginId","plgOptions","wplg","eventCapture","appendInput","getLabel","clsField","onValueChange","removeView","rerender","getClbOpts","elInput","getInputElem","onUpdate","onEvent","getValueForTarget","setInputValue","postUpdate","renderLabel","tpl","createLabel","getModelValue","getElInput","renderField","inputs","createInput","hasLabel","noLabel","tmpl","TraitView","getCheckedValue","valueTrue","valueFalse","toInit","inputNumber","labelButton","number","TraitNumberView","TraitSelectView","checkbox","TraitCheckboxView","TraitColorView","TraitButtonView","updatedCollection","TraitsViewer","TraitsView","noAssets","uploadName","multiUpload","autoAdd","uploadText","addBtnText","customFetch","embedAsBase64","dropzone","openAssetsOnDrop","dropzoneContent","inputPlaceholder","beforeUpload","getFilename","getExtension","Asset","unitDim","AssetView","getPreview","getInfo","dim","onRemove","stopImmediatePropagation","AssetImage","AssetImageView","renderAssets","addToAsset","removedAsset","handleSubmit","getAddInput","getAssetsEl","globalCollection","inputUrl","toggleNoAssets","addAsset","assetsEl","fuRendered","fu","uploadId","disableUpload","onUploadStart","onUploadEnd","onUploadError","onUploadResponse","FormData","fetchOpts","catch","initDrop","uploadForm","ondragover","ondragleave","ondrop","initDropzone","addedCls","edEl","dropzoneCls","cleanEditorElCls","onDragLeave","response","promises","mimeTypeMatcher","image","Image","readAsDataURL","Assets","FileUpload","AssetsView","getAllVisible","toRender","appendOnClick","activate","media","category","Category","Block","dragend","endDrag","getSorter","setDropContent","validTarget","startDrag","setDragHelper","handleDrag","handleDragEnd","oldActive","dragResult","dragContent","iconClass","activeClass","getIconEl","getBlocksEl","iconEl","blocksEl","categories","renderedCategories","noCatClass","blockContClass","catsClass","tac","grabbingCls","updateConfig","BlockView","ignoreCategories","catModel","catId","catView","getCategoriesEl","CategoryView","catsEl","blocksVisible","blocksView","Blocks","BlockCategories","BlocksView","getCategories","external","swv","expt","ola","obl","ful","prv","delayBtnsShow","btn","Panel","activeCls","disableCls","btnsVisCls","updateActive","checkActive","updateBtnsVis","updateClassName","updateDisable","attrCls","$buttons","commandName","noStop","clicked","toogleActive","parentM","ButtonView","appendContent","toggleVisible","tc","cr","bc","resz","resLen","tl","bl","br","silentFrames","avoidContainerUpdate","forContainer","styleWidth","styleHeight","ButtonsView","PanelView","PanelsViewObj","PanelsView","removePanel","addButton","panelId","removeButton","getButton","inlineCss","buildModels","maxValue","MAX_VALUE","compCls","buildFromModel","isWrapper","atRules","dump","atRule","getAtRule","mRules","buildFromRule","sortMediaObject","rulesStr","ruleStr","selectorStrNoAdd","skipAdd","singleAtRule","getDeclaration","getQueryLength","mediaQuery","itemsArr","isMobFirst","mquery","beforeEach","mapModel","mapJs","getContent","autoFormatRange","noRefresh","generators","defGenerators","viewers","defViewers","gHtml","gCss","gJson","gJs","eCM","loadDefaultGenerators","loadDefaultViewers","addGenerator","generator","getGenerator","getGenerators","addViewer","viewer","getViewers","createViewer","txtarea","updateViewer","genId","staticRules","mediaText","atRuleType","slct","typeStr","addSelector","isBody","toCSS","ruleProps","wd","re","CssRule","parseCss","toTrack","CssRuleView","getBlockId","renderStarted","atRuleEl","styleEl","CssGroupRuleView","appendData","clsName","defaultBlockId","blockId","getMediaWidth","contRules","prs","rulesView","storeCss","storeStyles","elStyle","CssRules","CssRulesView","sl","newSels","le","selec","modelExists","avoidUpdateStyle","styleUpdate","setRule","atRuleParams","checkNode","getRule","timerZoom","Droppable","handleDragEnter","handleDragOver","handleDrop","handleDragLeave","updateCounter","endDrop","getContentByData","autoscrollLimit","notTextable","getHead","setHead","addHeadItem","getHeadByAttr","removeHeadByAttr","addLink","removeLink","addScript","removeScript","frame","rulers","Frame","onZoomChange","motionsEv","updateHead","updateDim","headEl","currW","currH","newW","newH","noChanges","updateOffset","contents","wheel","clearOff","updateFrames","toggleListeners","FrameView","_parentEvent","onWheel","getZoom","defOpts","mpl","framesArea","isElInViewport","frameRect","rTop","rLeft","toolsEl","renderScripts","appendScript","renderBody","getDocument","externalStyles","frameCss","getJsContainer","onscroll","fdoc","oEvent","keyCodeVal","createCustomEvent","docBody","frmOff","cvsOff","getCanvasOffset","eo","frmTop","avoidFrameOffset","frmLeft","getElementOffsets","bEl","fo","jsContainer","$frames","hlEl","badgeEl","placerEl","ghostEl","resizerEl","offsetEl","fixedOffsetEl","requestAnimationFrame","CanvasView","setWrapper","startAutoscroll","stopAutoscroll","autoscroll","updateClientY","getFrame","getGhostEl","getOffsetViewerEl","getFixedOffsetViewerEl","setCustomBadgeLabel","leftScroll","toRight","eventToTrigger","elTop","elLeft","topPos","canvasHeight","addTop","addLeft","subWinOffset","frameElement","yOffset","xOffset","toIgnore","cv","getScrollListeners","lastClientY","frameWindow","nextTop","limitTop","limitBottom","setZoom","getZoomMultiplier","getFrameWrapperEl","deviceLabel","checkUnit","Device","getSorted","startAdd","updateSelect","updateDevice","devEl","devicesEl","Devices","DevicesView","backdrop","updateTitle","getCollector","$collector","$content","getTitle","$title","triggerEvent","ModalM","enb","ModalView","setTitle","onceClose","onceOpen","isOpen","getContentEl","statesLabel","selectedLabel","startEditTag","endEditTag","innerText","changeStatus","removeTag","chkOn","$chk","addBtnId","newInputId","stateInputId","stateInputC","getStyleEmitter","updateSelector","renderClasses","tagRemoved","updateStateVis","getStateOptions","strInput","addToClasses","startNewTag","$addBtn","endNewTag","onInputKeyUp","addNewTag","compTarget","validSelectors","getStates","getStatesC","elSel","stateChanged","$states","ClassTagView","$statesC","$classes","isId","isClass","selectorTags","ClassTagsView","cname","getSelector","4","5","6","7","11","12","14","15","atRuleKeys","singleAtRules","singleAtRulesNames","parseSelector","stl","propName","propValue","getPropertyPriority","parseCondition","conditionText","selectorText","createNode","selLen","lastClass","stateArr","sheet","cssRules","keyText","isSingleAtRule","subRules","lens","subRule","selsParsed","selsAdd","lastRule","len3","selsAddStr","BrowserCssParser","classSets","classSet","pHtml","pCss","autosave","autoload","stepsBeforeSave","checkLocal","urlStore","urlLoad","jqXHR","onComplete","contentTypeJson","fetchOptions","checkStorageEnvironment","setItem","getItem","removeItem","clbErr","onResponse","request","typeJson","reqHead","typeHead","bodyObj","bodyKey","addOpts","storages","defaultStorages","remote","RemoteStorage","LocalStorage","currentStorage","loadDefaultProviders","setCurrent","setAutosave","setStepsBeforeSave","storage","getStorages","getCurrent","keysF","itemKey","itemKeyR","getCurrentStorage","RTE_KEY","defActions","bold","italic","underline","strikethrough","link","insertHTML","setEl","updateActiveActions","settAct","actionbar","actionbarCont","actionbarContainer","addAction","styleWithCSS","syncActions","getActions","queryCommandSupported","queryCommandState","enabled","actionbarEl","deleteContents","nd","insertNode","adjustToolbar","lastEl","globalRte","hideToolbar","initRte","updatePosition","elT","elL","borderOffset","freezeClass","onMoveClb","relative","ignoreModels","offTop","offLeft","$document","dropContent","selectOnEnd","activeTextModel","getScale","getDocuments","canvasDoc","dropModel","updateTextViewCursorPosition","targetDoc","caretRangeFromPoint","poiner","rangeParent","rangeOffset","setContentEditable","toggleSortCursor","clonedEl","moveDragHelper","posY","posX","dragHelperStyle","useBody","createPlaceholder","ins","contSel","eV","isTextable","isTextableActive","tempModel","selectTargetModel","prevModel","targetModel","dsp","eO","rY","rX","mousePos","eventMove","sourceModel","dimsFromTarget","lastDims","findPosition","disableTextable","movePlaceholder","prevTargetDim","$plh","isInFlow","styleInFlow","$parent","overflow","trgModel","dragInfo","dropInfo","prevTarget","targetP","validResult","getDim","cacheDimsP","getChildrenDim","cacheDims","nearBorders","targetParent","getTargetFromEl","targetPrev","nearElBorders","getCurrentPos","elOffsets","elIndex","indexEl","leftLimit","xLimit","dimRight","yLimit","xCenter","yCenter","dimDown","trgDim","elDim","borderColor","borderWidth","brd","marg","brdCol","margI","dst","srcEl","modelToDrop","modelTemp","warns","targetCollection","viewActive","modelEl","minDim","maxDim","getBoundingRect","setup","hdl","createHandler","frames","forceShow","handleMouseDown","attrName","handlerAttr","clickedHandler","rectDim","startPos","handleKeyDown","toggleFrames","mouseFetch","calc","updateRect","getSelectedHandler","rectEl","isHandler","deltaX","deltaY","startW","startH","ratioActive","ratio","defaultCommands","commandsDef","CommandAbstract","selAll","nativeDrag","defComOptions","hideTlb","cmdMove","oldCmd","loadDefaultCommands","cmdObj","isActive","getActive"],"mappings":"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","file":"dist/grapes.min.js","sourcesContent":["(function webpackUniversalModuleDefinition(root, factory) {\n\tif(typeof exports === 'object' && typeof module === 'object')\n\t\tmodule.exports = factory();\n\telse if(typeof define === 'function' && define.amd)\n\t\tdefine([], factory);\n\telse if(typeof exports === 'object')\n\t\texports[\"grapesjs\"] = factory();\n\telse\n\t\troot[\"grapesjs\"] = factory();\n})(window, function() {\nreturn "," \t// The module cache\n \tvar installedModules = {};\n\n \t// The require function\n \tfunction __webpack_require__(moduleId) {\n\n \t\t// Check if module is in cache\n \t\tif(installedModules[moduleId]) {\n \t\t\treturn installedModules[moduleId].exports;\n \t\t}\n \t\t// Create a new module (and put it into the cache)\n \t\tvar module = installedModules[moduleId] = {\n \t\t\ti: moduleId,\n \t\t\tl: false,\n \t\t\texports: {}\n \t\t};\n\n \t\t// Execute the module function\n \t\tmodules[moduleId].call(module.exports, module, module.exports, __webpack_require__);\n\n \t\t// Flag the module as loaded\n \t\tmodule.l = true;\n\n \t\t// Return the exports of the module\n \t\treturn module.exports;\n \t}\n\n\n \t// expose the modules object (__webpack_modules__)\n \t__webpack_require__.m = modules;\n\n \t// expose the module cache\n \t__webpack_require__.c = installedModules;\n\n \t// define getter function for harmony exports\n \t__webpack_require__.d = function(exports, name, getter) {\n \t\tif(!__webpack_require__.o(exports, name)) {\n \t\t\tObject.defineProperty(exports, name, { enumerable: true, get: getter });\n \t\t}\n \t};\n\n \t// define __esModule on exports\n \t__webpack_require__.r = function(exports) {\n \t\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n \t\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n \t\t}\n \t\tObject.defineProperty(exports, '__esModule', { value: true });\n \t};\n\n \t// create a fake namespace object\n \t// mode & 1: value is a module id, require it\n \t// mode & 2: merge all properties of value into the ns\n \t// mode & 4: return value when already ns object\n \t// mode & 8|1: behave like require\n \t__webpack_require__.t = function(value, mode) {\n \t\tif(mode & 1) value = __webpack_require__(value);\n \t\tif(mode & 8) return value;\n \t\tif((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;\n \t\tvar ns = Object.create(null);\n \t\t__webpack_require__.r(ns);\n \t\tObject.defineProperty(ns, 'default', { enumerable: true, value: value });\n \t\tif(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));\n \t\treturn ns;\n \t};\n\n \t// getDefaultExport function for compatibility with non-harmony modules\n \t__webpack_require__.n = function(module) {\n \t\tvar getter = module && module.__esModule ?\n \t\t\tfunction getDefault() { return module['default']; } :\n \t\t\tfunction getModuleExports() { return module; };\n \t\t__webpack_require__.d(getter, 'a', getter);\n \t\treturn getter;\n \t};\n\n \t// Object.prototype.hasOwnProperty.call\n \t__webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };\n\n \t// __webpack_public_path__\n \t__webpack_require__.p = \"\";\n\n\n \t// Load entry module and return exports\n \treturn __webpack_require__(__webpack_require__.s = 85);\n","// Underscore.js 1.9.1\n// http://underscorejs.org\n// (c) 2009-2018 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n// Underscore may be freely distributed under the MIT license.\n\n(function() {\n\n // Baseline setup\n // --------------\n\n // Establish the root object, `window` (`self`) in the browser, `global`\n // on the server, or `this` in some virtual machines. We use `self`\n // instead of `window` for `WebWorker` support.\n var root = typeof self == 'object' && self.self === self && self ||\n typeof global == 'object' && global.global === global && global ||\n this ||\n {};\n\n // Save the previous value of the `_` variable.\n var previousUnderscore = root._;\n\n // Save bytes in the minified (but not gzipped) version:\n var ArrayProto = Array.prototype, ObjProto = Object.prototype;\n var SymbolProto = typeof Symbol !== 'undefined' ? Symbol.prototype : null;\n\n // Create quick reference variables for speed access to core prototypes.\n var push = ArrayProto.push,\n slice = ArrayProto.slice,\n toString = ObjProto.toString,\n hasOwnProperty = ObjProto.hasOwnProperty;\n\n // All **ECMAScript 5** native function implementations that we hope to use\n // are declared here.\n var nativeIsArray = Array.isArray,\n nativeKeys = Object.keys,\n nativeCreate = Object.create;\n\n // Naked function reference for surrogate-prototype-swapping.\n var Ctor = function(){};\n\n // Create a safe reference to the Underscore object for use below.\n var _ = function(obj) {\n if (obj instanceof _) return obj;\n if (!(this instanceof _)) return new _(obj);\n this._wrapped = obj;\n };\n\n // Export the Underscore object for **Node.js**, with\n // backwards-compatibility for their old module API. If we're in\n // the browser, add `_` as a global object.\n // (`nodeType` is checked to ensure that `module`\n // and `exports` are not HTML elements.)\n if (typeof exports != 'undefined' && !exports.nodeType) {\n if (typeof module != 'undefined' && !module.nodeType && module.exports) {\n exports = module.exports = _;\n }\n exports._ = _;\n } else {\n root._ = _;\n }\n\n // Current version.\n _.VERSION = '1.9.1';\n\n // Internal function that returns an efficient (for current engines) version\n // of the passed-in callback, to be repeatedly applied in other Underscore\n // functions.\n var optimizeCb = function(func, context, argCount) {\n if (context === void 0) return func;\n switch (argCount == null ? 3 : argCount) {\n case 1: return function(value) {\n return func.call(context, value);\n };\n // The 2-argument case is omitted because we’re not using it.\n case 3: return function(value, index, collection) {\n return func.call(context, value, index, collection);\n };\n case 4: return function(accumulator, value, index, collection) {\n return func.call(context, accumulator, value, index, collection);\n };\n }\n return function() {\n return func.apply(context, arguments);\n };\n };\n\n var builtinIteratee;\n\n // An internal function to generate callbacks that can be applied to each\n // element in a collection, returning the desired result — either `identity`,\n // an arbitrary callback, a property matcher, or a property accessor.\n var cb = function(value, context, argCount) {\n if (_.iteratee !== builtinIteratee) return _.iteratee(value, context);\n if (value == null) return _.identity;\n if (_.isFunction(value)) return optimizeCb(value, context, argCount);\n if (_.isObject(value) && !_.isArray(value)) return _.matcher(value);\n return _.property(value);\n };\n\n // External wrapper for our callback generator. Users may customize\n // `_.iteratee` if they want additional predicate/iteratee shorthand styles.\n // This abstraction hides the internal-only argCount argument.\n _.iteratee = builtinIteratee = function(value, context) {\n return cb(value, context, Infinity);\n };\n\n // Some functions take a variable number of arguments, or a few expected\n // arguments at the beginning and then a variable number of values to operate\n // on. This helper accumulates all remaining arguments past the function’s\n // argument length (or an explicit `startIndex`), into an array that becomes\n // the last argument. Similar to ES6’s \"rest parameter\".\n var restArguments = function(func, startIndex) {\n startIndex = startIndex == null ? func.length - 1 : +startIndex;\n return function() {\n var length = Math.max(arguments.length - startIndex, 0),\n rest = Array(length),\n index = 0;\n for (; index < length; index++) {\n rest[index] = arguments[index + startIndex];\n }\n switch (startIndex) {\n case 0: return func.call(this, rest);\n case 1: return func.call(this, arguments[0], rest);\n case 2: return func.call(this, arguments[0], arguments[1], rest);\n }\n var args = Array(startIndex + 1);\n for (index = 0; index < startIndex; index++) {\n args[index] = arguments[index];\n }\n args[startIndex] = rest;\n return func.apply(this, args);\n };\n };\n\n // An internal function for creating a new object that inherits from another.\n var baseCreate = function(prototype) {\n if (!_.isObject(prototype)) return {};\n if (nativeCreate) return nativeCreate(prototype);\n Ctor.prototype = prototype;\n var result = new Ctor;\n Ctor.prototype = null;\n return result;\n };\n\n var shallowProperty = function(key) {\n return function(obj) {\n return obj == null ? void 0 : obj[key];\n };\n };\n\n var has = function(obj, path) {\n return obj != null && hasOwnProperty.call(obj, path);\n }\n\n var deepGet = function(obj, path) {\n var length = path.length;\n for (var i = 0; i < length; i++) {\n if (obj == null) return void 0;\n obj = obj[path[i]];\n }\n return length ? obj : void 0;\n };\n\n // Helper for collection methods to determine whether a collection\n // should be iterated as an array or as an object.\n // Related: http://people.mozilla.org/~jorendorff/es6-draft.html#sec-tolength\n // Avoids a very nasty iOS 8 JIT bug on ARM-64. #2094\n var MAX_ARRAY_INDEX = Math.pow(2, 53) - 1;\n var getLength = shallowProperty('length');\n var isArrayLike = function(collection) {\n var length = getLength(collection);\n return typeof length == 'number' && length >= 0 && length <= MAX_ARRAY_INDEX;\n };\n\n // Collection Functions\n // --------------------\n\n // The cornerstone, an `each` implementation, aka `forEach`.\n // Handles raw objects in addition to array-likes. Treats all\n // sparse array-likes as if they were dense.\n _.each = _.forEach = function(obj, iteratee, context) {\n iteratee = optimizeCb(iteratee, context);\n var i, length;\n if (isArrayLike(obj)) {\n for (i = 0, length = obj.length; i < length; i++) {\n iteratee(obj[i], i, obj);\n }\n } else {\n var keys = _.keys(obj);\n for (i = 0, length = keys.length; i < length; i++) {\n iteratee(obj[keys[i]], keys[i], obj);\n }\n }\n return obj;\n };\n\n // Return the results of applying the iteratee to each element.\n _.map = _.collect = function(obj, iteratee, context) {\n iteratee = cb(iteratee, context);\n var keys = !isArrayLike(obj) && _.keys(obj),\n length = (keys || obj).length,\n results = Array(length);\n for (var index = 0; index < length; index++) {\n var currentKey = keys ? keys[index] : index;\n results[index] = iteratee(obj[currentKey], currentKey, obj);\n }\n return results;\n };\n\n // Create a reducing function iterating left or right.\n var createReduce = function(dir) {\n // Wrap code that reassigns argument variables in a separate function than\n // the one that accesses `arguments.length` to avoid a perf hit. (#1991)\n var reducer = function(obj, iteratee, memo, initial) {\n var keys = !isArrayLike(obj) && _.keys(obj),\n length = (keys || obj).length,\n index = dir > 0 ? 0 : length - 1;\n if (!initial) {\n memo = obj[keys ? keys[index] : index];\n index += dir;\n }\n for (; index >= 0 && index < length; index += dir) {\n var currentKey = keys ? keys[index] : index;\n memo = iteratee(memo, obj[currentKey], currentKey, obj);\n }\n return memo;\n };\n\n return function(obj, iteratee, memo, context) {\n var initial = arguments.length >= 3;\n return reducer(obj, optimizeCb(iteratee, context, 4), memo, initial);\n };\n };\n\n // **Reduce** builds up a single result from a list of values, aka `inject`,\n // or `foldl`.\n _.reduce = _.foldl = _.inject = createReduce(1);\n\n // The right-associative version of reduce, also known as `foldr`.\n _.reduceRight = _.foldr = createReduce(-1);\n\n // Return the first value which passes a truth test. Aliased as `detect`.\n _.find = _.detect = function(obj, predicate, context) {\n var keyFinder = isArrayLike(obj) ? _.findIndex : _.findKey;\n var key = keyFinder(obj, predicate, context);\n if (key !== void 0 && key !== -1) return obj[key];\n };\n\n // Return all the elements that pass a truth test.\n // Aliased as `select`.\n _.filter = _.select = function(obj, predicate, context) {\n var results = [];\n predicate = cb(predicate, context);\n _.each(obj, function(value, index, list) {\n if (predicate(value, index, list)) results.push(value);\n });\n return results;\n };\n\n // Return all the elements for which a truth test fails.\n _.reject = function(obj, predicate, context) {\n return _.filter(obj, _.negate(cb(predicate)), context);\n };\n\n // Determine whether all of the elements match a truth test.\n // Aliased as `all`.\n _.every = _.all = function(obj, predicate, context) {\n predicate = cb(predicate, context);\n var keys = !isArrayLike(obj) && _.keys(obj),\n length = (keys || obj).length;\n for (var index = 0; index < length; index++) {\n var currentKey = keys ? keys[index] : index;\n if (!predicate(obj[currentKey], currentKey, obj)) return false;\n }\n return true;\n };\n\n // Determine if at least one element in the object matches a truth test.\n // Aliased as `any`.\n _.some = _.any = function(obj, predicate, context) {\n predicate = cb(predicate, context);\n var keys = !isArrayLike(obj) && _.keys(obj),\n length = (keys || obj).length;\n for (var index = 0; index < length; index++) {\n var currentKey = keys ? keys[index] : index;\n if (predicate(obj[currentKey], currentKey, obj)) return true;\n }\n return false;\n };\n\n // Determine if the array or object contains a given item (using `===`).\n // Aliased as `includes` and `include`.\n _.contains = _.includes = _.include = function(obj, item, fromIndex, guard) {\n if (!isArrayLike(obj)) obj = _.values(obj);\n if (typeof fromIndex != 'number' || guard) fromIndex = 0;\n return _.indexOf(obj, item, fromIndex) >= 0;\n };\n\n // Invoke a method (with arguments) on every item in a collection.\n _.invoke = restArguments(function(obj, path, args) {\n var contextPath, func;\n if (_.isFunction(path)) {\n func = path;\n } else if (_.isArray(path)) {\n contextPath = path.slice(0, -1);\n path = path[path.length - 1];\n }\n return _.map(obj, function(context) {\n var method = func;\n if (!method) {\n if (contextPath && contextPath.length) {\n context = deepGet(context, contextPath);\n }\n if (context == null) return void 0;\n method = context[path];\n }\n return method == null ? method : method.apply(context, args);\n });\n });\n\n // Convenience version of a common use case of `map`: fetching a property.\n _.pluck = function(obj, key) {\n return _.map(obj, _.property(key));\n };\n\n // Convenience version of a common use case of `filter`: selecting only objects\n // containing specific `key:value` pairs.\n _.where = function(obj, attrs) {\n return _.filter(obj, _.matcher(attrs));\n };\n\n // Convenience version of a common use case of `find`: getting the first object\n // containing specific `key:value` pairs.\n _.findWhere = function(obj, attrs) {\n return _.find(obj, _.matcher(attrs));\n };\n\n // Return the maximum element (or element-based computation).\n _.max = function(obj, iteratee, context) {\n var result = -Infinity, lastComputed = -Infinity,\n value, computed;\n if (iteratee == null || typeof iteratee == 'number' && typeof obj[0] != 'object' && obj != null) {\n obj = isArrayLike(obj) ? obj : _.values(obj);\n for (var i = 0, length = obj.length; i < length; i++) {\n value = obj[i];\n if (value != null && value > result) {\n result = value;\n }\n }\n } else {\n iteratee = cb(iteratee, context);\n _.each(obj, function(v, index, list) {\n computed = iteratee(v, index, list);\n if (computed > lastComputed || computed === -Infinity && result === -Infinity) {\n result = v;\n lastComputed = computed;\n }\n });\n }\n return result;\n };\n\n // Return the minimum element (or element-based computation).\n _.min = function(obj, iteratee, context) {\n var result = Infinity, lastComputed = Infinity,\n value, computed;\n if (iteratee == null || typeof iteratee == 'number' && typeof obj[0] != 'object' && obj != null) {\n obj = isArrayLike(obj) ? obj : _.values(obj);\n for (var i = 0, length = obj.length; i < length; i++) {\n value = obj[i];\n if (value != null && value < result) {\n result = value;\n }\n }\n } else {\n iteratee = cb(iteratee, context);\n _.each(obj, function(v, index, list) {\n computed = iteratee(v, index, list);\n if (computed < lastComputed || computed === Infinity && result === Infinity) {\n result = v;\n lastComputed = computed;\n }\n });\n }\n return result;\n };\n\n // Shuffle a collection.\n _.shuffle = function(obj) {\n return _.sample(obj, Infinity);\n };\n\n // Sample **n** random values from a collection using the modern version of the\n // [Fisher-Yates shuffle](http://en.wikipedia.org/wiki/Fisher–Yates_shuffle).\n // If **n** is not specified, returns a single random element.\n // The internal `guard` argument allows it to work with `map`.\n _.sample = function(obj, n, guard) {\n if (n == null || guard) {\n if (!isArrayLike(obj)) obj = _.values(obj);\n return obj[_.random(obj.length - 1)];\n }\n var sample = isArrayLike(obj) ? _.clone(obj) : _.values(obj);\n var length = getLength(sample);\n n = Math.max(Math.min(n, length), 0);\n var last = length - 1;\n for (var index = 0; index < n; index++) {\n var rand = _.random(index, last);\n var temp = sample[index];\n sample[index] = sample[rand];\n sample[rand] = temp;\n }\n return sample.slice(0, n);\n };\n\n // Sort the object's values by a criterion produced by an iteratee.\n _.sortBy = function(obj, iteratee, context) {\n var index = 0;\n iteratee = cb(iteratee, context);\n return _.pluck(_.map(obj, function(value, key, list) {\n return {\n value: value,\n index: index++,\n criteria: iteratee(value, key, list)\n };\n }).sort(function(left, right) {\n var a = left.criteria;\n var b = right.criteria;\n if (a !== b) {\n if (a > b || a === void 0) return 1;\n if (a < b || b === void 0) return -1;\n }\n return left.index - right.index;\n }), 'value');\n };\n\n // An internal function used for aggregate \"group by\" operations.\n var group = function(behavior, partition) {\n return function(obj, iteratee, context) {\n var result = partition ? [[], []] : {};\n iteratee = cb(iteratee, context);\n _.each(obj, function(value, index) {\n var key = iteratee(value, index, obj);\n behavior(result, value, key);\n });\n return result;\n };\n };\n\n // Groups the object's values by a criterion. Pass either a string attribute\n // to group by, or a function that returns the criterion.\n _.groupBy = group(function(result, value, key) {\n if (has(result, key)) result[key].push(value); else result[key] = [value];\n });\n\n // Indexes the object's values by a criterion, similar to `groupBy`, but for\n // when you know that your index values will be unique.\n _.indexBy = group(function(result, value, key) {\n result[key] = value;\n });\n\n // Counts instances of an object that group by a certain criterion. Pass\n // either a string attribute to count by, or a function that returns the\n // criterion.\n _.countBy = group(function(result, value, key) {\n if (has(result, key)) result[key]++; else result[key] = 1;\n });\n\n var reStrSymbol = /[^\\ud800-\\udfff]|[\\ud800-\\udbff][\\udc00-\\udfff]|[\\ud800-\\udfff]/g;\n // Safely create a real, live array from anything iterable.\n _.toArray = function(obj) {\n if (!obj) return [];\n if (_.isArray(obj)) return slice.call(obj);\n if (_.isString(obj)) {\n // Keep surrogate pair characters together\n return obj.match(reStrSymbol);\n }\n if (isArrayLike(obj)) return _.map(obj, _.identity);\n return _.values(obj);\n };\n\n // Return the number of elements in an object.\n _.size = function(obj) {\n if (obj == null) return 0;\n return isArrayLike(obj) ? obj.length : _.keys(obj).length;\n };\n\n // Split a collection into two arrays: one whose elements all satisfy the given\n // predicate, and one whose elements all do not satisfy the predicate.\n _.partition = group(function(result, value, pass) {\n result[pass ? 0 : 1].push(value);\n }, true);\n\n // Array Functions\n // ---------------\n\n // Get the first element of an array. Passing **n** will return the first N\n // values in the array. Aliased as `head` and `take`. The **guard** check\n // allows it to work with `_.map`.\n _.first = _.head = _.take = function(array, n, guard) {\n if (array == null || array.length < 1) return n == null ? void 0 : [];\n if (n == null || guard) return array[0];\n return _.initial(array, array.length - n);\n };\n\n // Returns everything but the last entry of the array. Especially useful on\n // the arguments object. Passing **n** will return all the values in\n // the array, excluding the last N.\n _.initial = function(array, n, guard) {\n return slice.call(array, 0, Math.max(0, array.length - (n == null || guard ? 1 : n)));\n };\n\n // Get the last element of an array. Passing **n** will return the last N\n // values in the array.\n _.last = function(array, n, guard) {\n if (array == null || array.length < 1) return n == null ? void 0 : [];\n if (n == null || guard) return array[array.length - 1];\n return _.rest(array, Math.max(0, array.length - n));\n };\n\n // Returns everything but the first entry of the array. Aliased as `tail` and `drop`.\n // Especially useful on the arguments object. Passing an **n** will return\n // the rest N values in the array.\n _.rest = _.tail = _.drop = function(array, n, guard) {\n return slice.call(array, n == null || guard ? 1 : n);\n };\n\n // Trim out all falsy values from an array.\n _.compact = function(array) {\n return _.filter(array, Boolean);\n };\n\n // Internal implementation of a recursive `flatten` function.\n var flatten = function(input, shallow, strict, output) {\n output = output || [];\n var idx = output.length;\n for (var i = 0, length = getLength(input); i < length; i++) {\n var value = input[i];\n if (isArrayLike(value) && (_.isArray(value) || _.isArguments(value))) {\n // Flatten current level of array or arguments object.\n if (shallow) {\n var j = 0, len = value.length;\n while (j < len) output[idx++] = value[j++];\n } else {\n flatten(value, shallow, strict, output);\n idx = output.length;\n }\n } else if (!strict) {\n output[idx++] = value;\n }\n }\n return output;\n };\n\n // Flatten out an array, either recursively (by default), or just one level.\n _.flatten = function(array, shallow) {\n return flatten(array, shallow, false);\n };\n\n // Return a version of the array that does not contain the specified value(s).\n _.without = restArguments(function(array, otherArrays) {\n return _.difference(array, otherArrays);\n });\n\n // Produce a duplicate-free version of the array. If the array has already\n // been sorted, you have the option of using a faster algorithm.\n // The faster algorithm will not work with an iteratee if the iteratee\n // is not a one-to-one function, so providing an iteratee will disable\n // the faster algorithm.\n // Aliased as `unique`.\n _.uniq = _.unique = function(array, isSorted, iteratee, context) {\n if (!_.isBoolean(isSorted)) {\n context = iteratee;\n iteratee = isSorted;\n isSorted = false;\n }\n if (iteratee != null) iteratee = cb(iteratee, context);\n var result = [];\n var seen = [];\n for (var i = 0, length = getLength(array); i < length; i++) {\n var value = array[i],\n computed = iteratee ? iteratee(value, i, array) : value;\n if (isSorted && !iteratee) {\n if (!i || seen !== computed) result.push(value);\n seen = computed;\n } else if (iteratee) {\n if (!_.contains(seen, computed)) {\n seen.push(computed);\n result.push(value);\n }\n } else if (!_.contains(result, value)) {\n result.push(value);\n }\n }\n return result;\n };\n\n // Produce an array that contains the union: each distinct element from all of\n // the passed-in arrays.\n _.union = restArguments(function(arrays) {\n return _.uniq(flatten(arrays, true, true));\n });\n\n // Produce an array that contains every item shared between all the\n // passed-in arrays.\n _.intersection = function(array) {\n var result = [];\n var argsLength = arguments.length;\n for (var i = 0, length = getLength(array); i < length; i++) {\n var item = array[i];\n if (_.contains(result, item)) continue;\n var j;\n for (j = 1; j < argsLength; j++) {\n if (!_.contains(arguments[j], item)) break;\n }\n if (j === argsLength) result.push(item);\n }\n return result;\n };\n\n // Take the difference between one array and a number of other arrays.\n // Only the elements present in just the first array will remain.\n _.difference = restArguments(function(array, rest) {\n rest = flatten(rest, true, true);\n return _.filter(array, function(value){\n return !_.contains(rest, value);\n });\n });\n\n // Complement of _.zip. Unzip accepts an array of arrays and groups\n // each array's elements on shared indices.\n _.unzip = function(array) {\n var length = array && _.max(array, getLength).length || 0;\n var result = Array(length);\n\n for (var index = 0; index < length; index++) {\n result[index] = _.pluck(array, index);\n }\n return result;\n };\n\n // Zip together multiple lists into a single array -- elements that share\n // an index go together.\n _.zip = restArguments(_.unzip);\n\n // Converts lists into objects. Pass either a single array of `[key, value]`\n // pairs, or two parallel arrays of the same length -- one of keys, and one of\n // the corresponding values. Passing by pairs is the reverse of _.pairs.\n _.object = function(list, values) {\n var result = {};\n for (var i = 0, length = getLength(list); i < length; i++) {\n if (values) {\n result[list[i]] = values[i];\n } else {\n result[list[i][0]] = list[i][1];\n }\n }\n return result;\n };\n\n // Generator function to create the findIndex and findLastIndex functions.\n var createPredicateIndexFinder = function(dir) {\n return function(array, predicate, context) {\n predicate = cb(predicate, context);\n var length = getLength(array);\n var index = dir > 0 ? 0 : length - 1;\n for (; index >= 0 && index < length; index += dir) {\n if (predicate(array[index], index, array)) return index;\n }\n return -1;\n };\n };\n\n // Returns the first index on an array-like that passes a predicate test.\n _.findIndex = createPredicateIndexFinder(1);\n _.findLastIndex = createPredicateIndexFinder(-1);\n\n // Use a comparator function to figure out the smallest index at which\n // an object should be inserted so as to maintain order. Uses binary search.\n _.sortedIndex = function(array, obj, iteratee, context) {\n iteratee = cb(iteratee, context, 1);\n var value = iteratee(obj);\n var low = 0, high = getLength(array);\n while (low < high) {\n var mid = Math.floor((low + high) / 2);\n if (iteratee(array[mid]) < value) low = mid + 1; else high = mid;\n }\n return low;\n };\n\n // Generator function to create the indexOf and lastIndexOf functions.\n var createIndexFinder = function(dir, predicateFind, sortedIndex) {\n return function(array, item, idx) {\n var i = 0, length = getLength(array);\n if (typeof idx == 'number') {\n if (dir > 0) {\n i = idx >= 0 ? idx : Math.max(idx + length, i);\n } else {\n length = idx >= 0 ? Math.min(idx + 1, length) : idx + length + 1;\n }\n } else if (sortedIndex && idx && length) {\n idx = sortedIndex(array, item);\n return array[idx] === item ? idx : -1;\n }\n if (item !== item) {\n idx = predicateFind(slice.call(array, i, length), _.isNaN);\n return idx >= 0 ? idx + i : -1;\n }\n for (idx = dir > 0 ? i : length - 1; idx >= 0 && idx < length; idx += dir) {\n if (array[idx] === item) return idx;\n }\n return -1;\n };\n };\n\n // Return the position of the first occurrence of an item in an array,\n // or -1 if the item is not included in the array.\n // If the array is large and already in sort order, pass `true`\n // for **isSorted** to use binary search.\n _.indexOf = createIndexFinder(1, _.findIndex, _.sortedIndex);\n _.lastIndexOf = createIndexFinder(-1, _.findLastIndex);\n\n // Generate an integer Array containing an arithmetic progression. A port of\n // the native Python `range()` function. See\n // [the Python documentation](http://docs.python.org/library/functions.html#range).\n _.range = function(start, stop, step) {\n if (stop == null) {\n stop = start || 0;\n start = 0;\n }\n if (!step) {\n step = stop < start ? -1 : 1;\n }\n\n var length = Math.max(Math.ceil((stop - start) / step), 0);\n var range = Array(length);\n\n for (var idx = 0; idx < length; idx++, start += step) {\n range[idx] = start;\n }\n\n return range;\n };\n\n // Chunk a single array into multiple arrays, each containing `count` or fewer\n // items.\n _.chunk = function(array, count) {\n if (count == null || count < 1) return [];\n var result = [];\n var i = 0, length = array.length;\n while (i < length) {\n result.push(slice.call(array, i, i += count));\n }\n return result;\n };\n\n // Function (ahem) Functions\n // ------------------\n\n // Determines whether to execute a function as a constructor\n // or a normal function with the provided arguments.\n var executeBound = function(sourceFunc, boundFunc, context, callingContext, args) {\n if (!(callingContext instanceof boundFunc)) return sourceFunc.apply(context, args);\n var self = baseCreate(sourceFunc.prototype);\n var result = sourceFunc.apply(self, args);\n if (_.isObject(result)) return result;\n return self;\n };\n\n // Create a function bound to a given object (assigning `this`, and arguments,\n // optionally). Delegates to **ECMAScript 5**'s native `Function.bind` if\n // available.\n _.bind = restArguments(function(func, context, args) {\n if (!_.isFunction(func)) throw new TypeError('Bind must be called on a function');\n var bound = restArguments(function(callArgs) {\n return executeBound(func, bound, context, this, args.concat(callArgs));\n });\n return bound;\n });\n\n // Partially apply a function by creating a version that has had some of its\n // arguments pre-filled, without changing its dynamic `this` context. _ acts\n // as a placeholder by default, allowing any combination of arguments to be\n // pre-filled. Set `_.partial.placeholder` for a custom placeholder argument.\n _.partial = restArguments(function(func, boundArgs) {\n var placeholder = _.partial.placeholder;\n var bound = function() {\n var position = 0, length = boundArgs.length;\n var args = Array(length);\n for (var i = 0; i < length; i++) {\n args[i] = boundArgs[i] === placeholder ? arguments[position++] : boundArgs[i];\n }\n while (position < arguments.length) args.push(arguments[position++]);\n return executeBound(func, bound, this, this, args);\n };\n return bound;\n });\n\n _.partial.placeholder = _;\n\n // Bind a number of an object's methods to that object. Remaining arguments\n // are the method names to be bound. Useful for ensuring that all callbacks\n // defined on an object belong to it.\n _.bindAll = restArguments(function(obj, keys) {\n keys = flatten(keys, false, false);\n var index = keys.length;\n if (index < 1) throw new Error('bindAll must be passed function names');\n while (index--) {\n var key = keys[index];\n obj[key] = _.bind(obj[key], obj);\n }\n });\n\n // Memoize an expensive function by storing its results.\n _.memoize = function(func, hasher) {\n var memoize = function(key) {\n var cache = memoize.cache;\n var address = '' + (hasher ? hasher.apply(this, arguments) : key);\n if (!has(cache, address)) cache[address] = func.apply(this, arguments);\n return cache[address];\n };\n memoize.cache = {};\n return memoize;\n };\n\n // Delays a function for the given number of milliseconds, and then calls\n // it with the arguments supplied.\n _.delay = restArguments(function(func, wait, args) {\n return setTimeout(function() {\n return func.apply(null, args);\n }, wait);\n });\n\n // Defers a function, scheduling it to run after the current call stack has\n // cleared.\n _.defer = _.partial(_.delay, _, 1);\n\n // Returns a function, that, when invoked, will only be triggered at most once\n // during a given window of time. Normally, the throttled function will run\n // as much as it can, without ever going more than once per `wait` duration;\n // but if you'd like to disable the execution on the leading edge, pass\n // `{leading: false}`. To disable execution on the trailing edge, ditto.\n _.throttle = function(func, wait, options) {\n var timeout, context, args, result;\n var previous = 0;\n if (!options) options = {};\n\n var later = function() {\n previous = options.leading === false ? 0 : _.now();\n timeout = null;\n result = func.apply(context, args);\n if (!timeout) context = args = null;\n };\n\n var throttled = function() {\n var now = _.now();\n if (!previous && options.leading === false) previous = now;\n var remaining = wait - (now - previous);\n context = this;\n args = arguments;\n if (remaining <= 0 || remaining > wait) {\n if (timeout) {\n clearTimeout(timeout);\n timeout = null;\n }\n previous = now;\n result = func.apply(context, args);\n if (!timeout) context = args = null;\n } else if (!timeout && options.trailing !== false) {\n timeout = setTimeout(later, remaining);\n }\n return result;\n };\n\n throttled.cancel = function() {\n clearTimeout(timeout);\n previous = 0;\n timeout = context = args = null;\n };\n\n return throttled;\n };\n\n // Returns a function, that, as long as it continues to be invoked, will not\n // be triggered. The function will be called after it stops being called for\n // N milliseconds. If `immediate` is passed, trigger the function on the\n // leading edge, instead of the trailing.\n _.debounce = function(func, wait, immediate) {\n var timeout, result;\n\n var later = function(context, args) {\n timeout = null;\n if (args) result = func.apply(context, args);\n };\n\n var debounced = restArguments(function(args) {\n if (timeout) clearTimeout(timeout);\n if (immediate) {\n var callNow = !timeout;\n timeout = setTimeout(later, wait);\n if (callNow) result = func.apply(this, args);\n } else {\n timeout = _.delay(later, wait, this, args);\n }\n\n return result;\n });\n\n debounced.cancel = function() {\n clearTimeout(timeout);\n timeout = null;\n };\n\n return debounced;\n };\n\n // Returns the first function passed as an argument to the second,\n // allowing you to adjust arguments, run code before and after, and\n // conditionally execute the original function.\n _.wrap = function(func, wrapper) {\n return _.partial(wrapper, func);\n };\n\n // Returns a negated version of the passed-in predicate.\n _.negate = function(predicate) {\n return function() {\n return !predicate.apply(this, arguments);\n };\n };\n\n // Returns a function that is the composition of a list of functions, each\n // consuming the return value of the function that follows.\n _.compose = function() {\n var args = arguments;\n var start = args.length - 1;\n return function() {\n var i = start;\n var result = args[start].apply(this, arguments);\n while (i--) result = args[i].call(this, result);\n return result;\n };\n };\n\n // Returns a function that will only be executed on and after the Nth call.\n _.after = function(times, func) {\n return function() {\n if (--times < 1) {\n return func.apply(this, arguments);\n }\n };\n };\n\n // Returns a function that will only be executed up to (but not including) the Nth call.\n _.before = function(times, func) {\n var memo;\n return function() {\n if (--times > 0) {\n memo = func.apply(this, arguments);\n }\n if (times <= 1) func = null;\n return memo;\n };\n };\n\n // Returns a function that will be executed at most one time, no matter how\n // often you call it. Useful for lazy initialization.\n _.once = _.partial(_.before, 2);\n\n _.restArguments = restArguments;\n\n // Object Functions\n // ----------------\n\n // Keys in IE < 9 that won't be iterated by `for key in ...` and thus missed.\n var hasEnumBug = !{toString: null}.propertyIsEnumerable('toString');\n var nonEnumerableProps = ['valueOf', 'isPrototypeOf', 'toString',\n 'propertyIsEnumerable', 'hasOwnProperty', 'toLocaleString'];\n\n var collectNonEnumProps = function(obj, keys) {\n var nonEnumIdx = nonEnumerableProps.length;\n var constructor = obj.constructor;\n var proto = _.isFunction(constructor) && constructor.prototype || ObjProto;\n\n // Constructor is a special case.\n var prop = 'constructor';\n if (has(obj, prop) && !_.contains(keys, prop)) keys.push(prop);\n\n while (nonEnumIdx--) {\n prop = nonEnumerableProps[nonEnumIdx];\n if (prop in obj && obj[prop] !== proto[prop] && !_.contains(keys, prop)) {\n keys.push(prop);\n }\n }\n };\n\n // Retrieve the names of an object's own properties.\n // Delegates to **ECMAScript 5**'s native `Object.keys`.\n _.keys = function(obj) {\n if (!_.isObject(obj)) return [];\n if (nativeKeys) return nativeKeys(obj);\n var keys = [];\n for (var key in obj) if (has(obj, key)) keys.push(key);\n // Ahem, IE < 9.\n if (hasEnumBug) collectNonEnumProps(obj, keys);\n return keys;\n };\n\n // Retrieve all the property names of an object.\n _.allKeys = function(obj) {\n if (!_.isObject(obj)) return [];\n var keys = [];\n for (var key in obj) keys.push(key);\n // Ahem, IE < 9.\n if (hasEnumBug) collectNonEnumProps(obj, keys);\n return keys;\n };\n\n // Retrieve the values of an object's properties.\n _.values = function(obj) {\n var keys = _.keys(obj);\n var length = keys.length;\n var values = Array(length);\n for (var i = 0; i < length; i++) {\n values[i] = obj[keys[i]];\n }\n return values;\n };\n\n // Returns the results of applying the iteratee to each element of the object.\n // In contrast to _.map it returns an object.\n _.mapObject = function(obj, iteratee, context) {\n iteratee = cb(iteratee, context);\n var keys = _.keys(obj),\n length = keys.length,\n results = {};\n for (var index = 0; index < length; index++) {\n var currentKey = keys[index];\n results[currentKey] = iteratee(obj[currentKey], currentKey, obj);\n }\n return results;\n };\n\n // Convert an object into a list of `[key, value]` pairs.\n // The opposite of _.object.\n _.pairs = function(obj) {\n var keys = _.keys(obj);\n var length = keys.length;\n var pairs = Array(length);\n for (var i = 0; i < length; i++) {\n pairs[i] = [keys[i], obj[keys[i]]];\n }\n return pairs;\n };\n\n // Invert the keys and values of an object. The values must be serializable.\n _.invert = function(obj) {\n var result = {};\n var keys = _.keys(obj);\n for (var i = 0, length = keys.length; i < length; i++) {\n result[obj[keys[i]]] = keys[i];\n }\n return result;\n };\n\n // Return a sorted list of the function names available on the object.\n // Aliased as `methods`.\n _.functions = _.methods = function(obj) {\n var names = [];\n for (var key in obj) {\n if (_.isFunction(obj[key])) names.push(key);\n }\n return names.sort();\n };\n\n // An internal function for creating assigner functions.\n var createAssigner = function(keysFunc, defaults) {\n return function(obj) {\n var length = arguments.length;\n if (defaults) obj = Object(obj);\n if (length < 2 || obj == null) return obj;\n for (var index = 1; index < length; index++) {\n var source = arguments[index],\n keys = keysFunc(source),\n l = keys.length;\n for (var i = 0; i < l; i++) {\n var key = keys[i];\n if (!defaults || obj[key] === void 0) obj[key] = source[key];\n }\n }\n return obj;\n };\n };\n\n // Extend a given object with all the properties in passed-in object(s).\n _.extend = createAssigner(_.allKeys);\n\n // Assigns a given object with all the own properties in the passed-in object(s).\n // (https://developer.mozilla.org/docs/Web/JavaScript/Reference/Global_Objects/Object/assign)\n _.extendOwn = _.assign = createAssigner(_.keys);\n\n // Returns the first key on an object that passes a predicate test.\n _.findKey = function(obj, predicate, context) {\n predicate = cb(predicate, context);\n var keys = _.keys(obj), key;\n for (var i = 0, length = keys.length; i < length; i++) {\n key = keys[i];\n if (predicate(obj[key], key, obj)) return key;\n }\n };\n\n // Internal pick helper function to determine if `obj` has key `key`.\n var keyInObj = function(value, key, obj) {\n return key in obj;\n };\n\n // Return a copy of the object only containing the whitelisted properties.\n _.pick = restArguments(function(obj, keys) {\n var result = {}, iteratee = keys[0];\n if (obj == null) return result;\n if (_.isFunction(iteratee)) {\n if (keys.length > 1) iteratee = optimizeCb(iteratee, keys[1]);\n keys = _.allKeys(obj);\n } else {\n iteratee = keyInObj;\n keys = flatten(keys, false, false);\n obj = Object(obj);\n }\n for (var i = 0, length = keys.length; i < length; i++) {\n var key = keys[i];\n var value = obj[key];\n if (iteratee(value, key, obj)) result[key] = value;\n }\n return result;\n });\n\n // Return a copy of the object without the blacklisted properties.\n _.omit = restArguments(function(obj, keys) {\n var iteratee = keys[0], context;\n if (_.isFunction(iteratee)) {\n iteratee = _.negate(iteratee);\n if (keys.length > 1) context = keys[1];\n } else {\n keys = _.map(flatten(keys, false, false), String);\n iteratee = function(value, key) {\n return !_.contains(keys, key);\n };\n }\n return _.pick(obj, iteratee, context);\n });\n\n // Fill in a given object with default properties.\n _.defaults = createAssigner(_.allKeys, true);\n\n // Creates an object that inherits from the given prototype object.\n // If additional properties are provided then they will be added to the\n // created object.\n _.create = function(prototype, props) {\n var result = baseCreate(prototype);\n if (props) _.extendOwn(result, props);\n return result;\n };\n\n // Create a (shallow-cloned) duplicate of an object.\n _.clone = function(obj) {\n if (!_.isObject(obj)) return obj;\n return _.isArray(obj) ? obj.slice() : _.extend({}, obj);\n };\n\n // Invokes interceptor with the obj, and then returns obj.\n // The primary purpose of this method is to \"tap into\" a method chain, in\n // order to perform operations on intermediate results within the chain.\n _.tap = function(obj, interceptor) {\n interceptor(obj);\n return obj;\n };\n\n // Returns whether an object has a given set of `key:value` pairs.\n _.isMatch = function(object, attrs) {\n var keys = _.keys(attrs), length = keys.length;\n if (object == null) return !length;\n var obj = Object(object);\n for (var i = 0; i < length; i++) {\n var key = keys[i];\n if (attrs[key] !== obj[key] || !(key in obj)) return false;\n }\n return true;\n };\n\n\n // Internal recursive comparison function for `isEqual`.\n var eq, deepEq;\n eq = function(a, b, aStack, bStack) {\n // Identical objects are equal. `0 === -0`, but they aren't identical.\n // See the [Harmony `egal` proposal](http://wiki.ecmascript.org/doku.php?id=harmony:egal).\n if (a === b) return a !== 0 || 1 / a === 1 / b;\n // `null` or `undefined` only equal to itself (strict comparison).\n if (a == null || b == null) return false;\n // `NaN`s are equivalent, but non-reflexive.\n if (a !== a) return b !== b;\n // Exhaust primitive checks\n var type = typeof a;\n if (type !== 'function' && type !== 'object' && typeof b != 'object') return false;\n return deepEq(a, b, aStack, bStack);\n };\n\n // Internal recursive comparison function for `isEqual`.\n deepEq = function(a, b, aStack, bStack) {\n // Unwrap any wrapped objects.\n if (a instanceof _) a = a._wrapped;\n if (b instanceof _) b = b._wrapped;\n // Compare `[[Class]]` names.\n var className = toString.call(a);\n if (className !== toString.call(b)) return false;\n switch (className) {\n // Strings, numbers, regular expressions, dates, and booleans are compared by value.\n case '[object RegExp]':\n // RegExps are coerced to strings for comparison (Note: '' + /a/i === '/a/i')\n case '[object String]':\n // Primitives and their corresponding object wrappers are equivalent; thus, `\"5\"` is\n // equivalent to `new String(\"5\")`.\n return '' + a === '' + b;\n case '[object Number]':\n // `NaN`s are equivalent, but non-reflexive.\n // Object(NaN) is equivalent to NaN.\n if (+a !== +a) return +b !== +b;\n // An `egal` comparison is performed for other numeric values.\n return +a === 0 ? 1 / +a === 1 / b : +a === +b;\n case '[object Date]':\n case '[object Boolean]':\n // Coerce dates and booleans to numeric primitive values. Dates are compared by their\n // millisecond representations. Note that invalid dates with millisecond representations\n // of `NaN` are not equivalent.\n return +a === +b;\n case '[object Symbol]':\n return SymbolProto.valueOf.call(a) === SymbolProto.valueOf.call(b);\n }\n\n var areArrays = className === '[object Array]';\n if (!areArrays) {\n if (typeof a != 'object' || typeof b != 'object') return false;\n\n // Objects with different constructors are not equivalent, but `Object`s or `Array`s\n // from different frames are.\n var aCtor = a.constructor, bCtor = b.constructor;\n if (aCtor !== bCtor && !(_.isFunction(aCtor) && aCtor instanceof aCtor &&\n _.isFunction(bCtor) && bCtor instanceof bCtor)\n && ('constructor' in a && 'constructor' in b)) {\n return false;\n }\n }\n // Assume equality for cyclic structures. The algorithm for detecting cyclic\n // structures is adapted from ES 5.1 section 15.12.3, abstract operation `JO`.\n\n // Initializing stack of traversed objects.\n // It's done here since we only need them for objects and arrays comparison.\n aStack = aStack || [];\n bStack = bStack || [];\n var length = aStack.length;\n while (length--) {\n // Linear search. Performance is inversely proportional to the number of\n // unique nested structures.\n if (aStack[length] === a) return bStack[length] === b;\n }\n\n // Add the first object to the stack of traversed objects.\n aStack.push(a);\n bStack.push(b);\n\n // Recursively compare objects and arrays.\n if (areArrays) {\n // Compare array lengths to determine if a deep comparison is necessary.\n length = a.length;\n if (length !== b.length) return false;\n // Deep compare the contents, ignoring non-numeric properties.\n while (length--) {\n if (!eq(a[length], b[length], aStack, bStack)) return false;\n }\n } else {\n // Deep compare objects.\n var keys = _.keys(a), key;\n length = keys.length;\n // Ensure that both objects contain the same number of properties before comparing deep equality.\n if (_.keys(b).length !== length) return false;\n while (length--) {\n // Deep compare each member\n key = keys[length];\n if (!(has(b, key) && eq(a[key], b[key], aStack, bStack))) return false;\n }\n }\n // Remove the first object from the stack of traversed objects.\n aStack.pop();\n bStack.pop();\n return true;\n };\n\n // Perform a deep comparison to check if two objects are equal.\n _.isEqual = function(a, b) {\n return eq(a, b);\n };\n\n // Is a given array, string, or object empty?\n // An \"empty\" object has no enumerable own-properties.\n _.isEmpty = function(obj) {\n if (obj == null) return true;\n if (isArrayLike(obj) && (_.isArray(obj) || _.isString(obj) || _.isArguments(obj))) return obj.length === 0;\n return _.keys(obj).length === 0;\n };\n\n // Is a given value a DOM element?\n _.isElement = function(obj) {\n return !!(obj && obj.nodeType === 1);\n };\n\n // Is a given value an array?\n // Delegates to ECMA5's native Array.isArray\n _.isArray = nativeIsArray || function(obj) {\n return toString.call(obj) === '[object Array]';\n };\n\n // Is a given variable an object?\n _.isObject = function(obj) {\n var type = typeof obj;\n return type === 'function' || type === 'object' && !!obj;\n };\n\n // Add some isType methods: isArguments, isFunction, isString, isNumber, isDate, isRegExp, isError, isMap, isWeakMap, isSet, isWeakSet.\n _.each(['Arguments', 'Function', 'String', 'Number', 'Date', 'RegExp', 'Error', 'Symbol', 'Map', 'WeakMap', 'Set', 'WeakSet'], function(name) {\n _['is' + name] = function(obj) {\n return toString.call(obj) === '[object ' + name + ']';\n };\n });\n\n // Define a fallback version of the method in browsers (ahem, IE < 9), where\n // there isn't any inspectable \"Arguments\" type.\n if (!_.isArguments(arguments)) {\n _.isArguments = function(obj) {\n return has(obj, 'callee');\n };\n }\n\n // Optimize `isFunction` if appropriate. Work around some typeof bugs in old v8,\n // IE 11 (#1621), Safari 8 (#1929), and PhantomJS (#2236).\n var nodelist = root.document && root.document.childNodes;\n if (typeof /./ != 'function' && typeof Int8Array != 'object' && typeof nodelist != 'function') {\n _.isFunction = function(obj) {\n return typeof obj == 'function' || false;\n };\n }\n\n // Is a given object a finite number?\n _.isFinite = function(obj) {\n return !_.isSymbol(obj) && isFinite(obj) && !isNaN(parseFloat(obj));\n };\n\n // Is the given value `NaN`?\n _.isNaN = function(obj) {\n return _.isNumber(obj) && isNaN(obj);\n };\n\n // Is a given value a boolean?\n _.isBoolean = function(obj) {\n return obj === true || obj === false || toString.call(obj) === '[object Boolean]';\n };\n\n // Is a given value equal to null?\n _.isNull = function(obj) {\n return obj === null;\n };\n\n // Is a given variable undefined?\n _.isUndefined = function(obj) {\n return obj === void 0;\n };\n\n // Shortcut function for checking if an object has a given property directly\n // on itself (in other words, not on a prototype).\n _.has = function(obj, path) {\n if (!_.isArray(path)) {\n return has(obj, path);\n }\n var length = path.length;\n for (var i = 0; i < length; i++) {\n var key = path[i];\n if (obj == null || !hasOwnProperty.call(obj, key)) {\n return false;\n }\n obj = obj[key];\n }\n return !!length;\n };\n\n // Utility Functions\n // -----------------\n\n // Run Underscore.js in *noConflict* mode, returning the `_` variable to its\n // previous owner. Returns a reference to the Underscore object.\n _.noConflict = function() {\n root._ = previousUnderscore;\n return this;\n };\n\n // Keep the identity function around for default iteratees.\n _.identity = function(value) {\n return value;\n };\n\n // Predicate-generating functions. Often useful outside of Underscore.\n _.constant = function(value) {\n return function() {\n return value;\n };\n };\n\n _.noop = function(){};\n\n // Creates a function that, when passed an object, will traverse that object’s\n // properties down the given `path`, specified as an array of keys or indexes.\n _.property = function(path) {\n if (!_.isArray(path)) {\n return shallowProperty(path);\n }\n return function(obj) {\n return deepGet(obj, path);\n };\n };\n\n // Generates a function for a given object that returns a given property.\n _.propertyOf = function(obj) {\n if (obj == null) {\n return function(){};\n }\n return function(path) {\n return !_.isArray(path) ? obj[path] : deepGet(obj, path);\n };\n };\n\n // Returns a predicate for checking whether an object has a given set of\n // `key:value` pairs.\n _.matcher = _.matches = function(attrs) {\n attrs = _.extendOwn({}, attrs);\n return function(obj) {\n return _.isMatch(obj, attrs);\n };\n };\n\n // Run a function **n** times.\n _.times = function(n, iteratee, context) {\n var accum = Array(Math.max(0, n));\n iteratee = optimizeCb(iteratee, context, 1);\n for (var i = 0; i < n; i++) accum[i] = iteratee(i);\n return accum;\n };\n\n // Return a random integer between min and max (inclusive).\n _.random = function(min, max) {\n if (max == null) {\n max = min;\n min = 0;\n }\n return min + Math.floor(Math.random() * (max - min + 1));\n };\n\n // A (possibly faster) way to get the current timestamp as an integer.\n _.now = Date.now || function() {\n return new Date().getTime();\n };\n\n // List of HTML entities for escaping.\n var escapeMap = {\n '&': '&',\n '<': '<',\n '>': '>',\n '\"': '"',\n \"'\": ''',\n '`': '`'\n };\n var unescapeMap = _.invert(escapeMap);\n\n // Functions for escaping and unescaping strings to/from HTML interpolation.\n var createEscaper = function(map) {\n var escaper = function(match) {\n return map[match];\n };\n // Regexes for identifying a key that needs to be escaped.\n var source = '(?:' + _.keys(map).join('|') + ')';\n var testRegexp = RegExp(source);\n var replaceRegexp = RegExp(source, 'g');\n return function(string) {\n string = string == null ? '' : '' + string;\n return testRegexp.test(string) ? string.replace(replaceRegexp, escaper) : string;\n };\n };\n _.escape = createEscaper(escapeMap);\n _.unescape = createEscaper(unescapeMap);\n\n // Traverses the children of `obj` along `path`. If a child is a function, it\n // is invoked with its parent as context. Returns the value of the final\n // child, or `fallback` if any child is undefined.\n _.result = function(obj, path, fallback) {\n if (!_.isArray(path)) path = [path];\n var length = path.length;\n if (!length) {\n return _.isFunction(fallback) ? fallback.call(obj) : fallback;\n }\n for (var i = 0; i < length; i++) {\n var prop = obj == null ? void 0 : obj[path[i]];\n if (prop === void 0) {\n prop = fallback;\n i = length; // Ensure we don't continue iterating.\n }\n obj = _.isFunction(prop) ? prop.call(obj) : prop;\n }\n return obj;\n };\n\n // Generate a unique integer id (unique within the entire client session).\n // Useful for temporary DOM ids.\n var idCounter = 0;\n _.uniqueId = function(prefix) {\n var id = ++idCounter + '';\n return prefix ? prefix + id : id;\n };\n\n // By default, Underscore uses ERB-style template delimiters, change the\n // following template settings to use alternative delimiters.\n _.templateSettings = {\n evaluate: /<%([\\s\\S]+?)%>/g,\n interpolate: /<%=([\\s\\S]+?)%>/g,\n escape: /<%-([\\s\\S]+?)%>/g\n };\n\n // When customizing `templateSettings`, if you don't want to define an\n // interpolation, evaluation or escaping regex, we need one that is\n // guaranteed not to match.\n var noMatch = /(.)^/;\n\n // Certain characters need to be escaped so that they can be put into a\n // string literal.\n var escapes = {\n \"'\": \"'\",\n '\\\\': '\\\\',\n '\\r': 'r',\n '\\n': 'n',\n '\\u2028': 'u2028',\n '\\u2029': 'u2029'\n };\n\n var escapeRegExp = /\\\\|'|\\r|\\n|\\u2028|\\u2029/g;\n\n var escapeChar = function(match) {\n return '\\\\' + escapes[match];\n };\n\n // JavaScript micro-templating, similar to John Resig's implementation.\n // Underscore templating handles arbitrary delimiters, preserves whitespace,\n // and correctly escapes quotes within interpolated code.\n // NB: `oldSettings` only exists for backwards compatibility.\n _.template = function(text, settings, oldSettings) {\n if (!settings && oldSettings) settings = oldSettings;\n settings = _.defaults({}, settings, _.templateSettings);\n\n // Combine delimiters into one regular expression via alternation.\n var matcher = RegExp([\n (settings.escape || noMatch).source,\n (settings.interpolate || noMatch).source,\n (settings.evaluate || noMatch).source\n ].join('|') + '|$', 'g');\n\n // Compile the template source, escaping string literals appropriately.\n var index = 0;\n var source = \"__p+='\";\n text.replace(matcher, function(match, escape, interpolate, evaluate, offset) {\n source += text.slice(index, offset).replace(escapeRegExp, escapeChar);\n index = offset + match.length;\n\n if (escape) {\n source += \"'+\\n((__t=(\" + escape + \"))==null?'':_.escape(__t))+\\n'\";\n } else if (interpolate) {\n source += \"'+\\n((__t=(\" + interpolate + \"))==null?'':__t)+\\n'\";\n } else if (evaluate) {\n source += \"';\\n\" + evaluate + \"\\n__p+='\";\n }\n\n // Adobe VMs need the match returned to produce the correct offset.\n return match;\n });\n source += \"';\\n\";\n\n // If a variable is not specified, place data values in local scope.\n if (!settings.variable) source = 'with(obj||{}){\\n' + source + '}\\n';\n\n source = \"var __t,__p='',__j=Array.prototype.join,\" +\n \"print=function(){__p+=__j.call(arguments,'');};\\n\" +\n source + 'return __p;\\n';\n\n var render;\n try {\n render = new Function(settings.variable || 'obj', '_', source);\n } catch (e) {\n e.source = source;\n throw e;\n }\n\n var template = function(data) {\n return render.call(this, data, _);\n };\n\n // Provide the compiled source as a convenience for precompilation.\n var argument = settings.variable || 'obj';\n template.source = 'function(' + argument + '){\\n' + source + '}';\n\n return template;\n };\n\n // Add a \"chain\" function. Start chaining a wrapped Underscore object.\n _.chain = function(obj) {\n var instance = _(obj);\n instance._chain = true;\n return instance;\n };\n\n // OOP\n // ---------------\n // If Underscore is called as a function, it returns a wrapped object that\n // can be used OO-style. This wrapper holds altered versions of all the\n // underscore functions. Wrapped objects may be chained.\n\n // Helper function to continue chaining intermediate results.\n var chainResult = function(instance, obj) {\n return instance._chain ? _(obj).chain() : obj;\n };\n\n // Add your own custom functions to the Underscore object.\n _.mixin = function(obj) {\n _.each(_.functions(obj), function(name) {\n var func = _[name] = obj[name];\n _.prototype[name] = function() {\n var args = [this._wrapped];\n push.apply(args, arguments);\n return chainResult(this, func.apply(_, args));\n };\n });\n return _;\n };\n\n // Add all of the Underscore functions to the wrapper object.\n _.mixin(_);\n\n // Add all mutator Array functions to the wrapper.\n _.each(['pop', 'push', 'reverse', 'shift', 'sort', 'splice', 'unshift'], function(name) {\n var method = ArrayProto[name];\n _.prototype[name] = function() {\n var obj = this._wrapped;\n method.apply(obj, arguments);\n if ((name === 'shift' || name === 'splice') && obj.length === 0) delete obj[0];\n return chainResult(this, obj);\n };\n });\n\n // Add all accessor Array functions to the wrapper.\n _.each(['concat', 'join', 'slice'], function(name) {\n var method = ArrayProto[name];\n _.prototype[name] = function() {\n return chainResult(this, method.apply(this._wrapped, arguments));\n };\n });\n\n // Extracts the result from a wrapped and chained object.\n _.prototype.value = function() {\n return this._wrapped;\n };\n\n // Provide unwrapping proxy for some methods used in engine operations\n // such as arithmetic and JSON stringification.\n _.prototype.valueOf = _.prototype.toJSON = _.prototype.value;\n\n _.prototype.toString = function() {\n return String(this._wrapped);\n };\n\n // AMD registration happens at the end for compatibility with AMD loaders\n // that may not enforce next-turn semantics on modules. Even though general\n // practice for AMD registration is to be anonymous, underscore registers\n // as a named module because, like jQuery, it is a base library that is\n // popular enough to be bundled in a third party lib, but not be part of\n // an AMD load request. Those cases could generate an error when an\n // anonymous define() is called outside of a loader request.\n if (typeof define == 'function' && define.amd) {\n define('underscore', [], function() {\n return _;\n });\n }\n}());\n","// Backbone.js 1.3.3\n\n// (c) 2010-2016 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n// Backbone may be freely distributed under the MIT license.\n// For all details and documentation:\n// http://backbonejs.org\n\n(function(factory) {\n\n // Establish the root object, `window` (`self`) in the browser, or `global` on the server.\n // We use `self` instead of `window` for `WebWorker` support.\n var root = (typeof self == 'object' && self.self === self && self) ||\n (typeof global == 'object' && global.global === global && global);\n\n // Set up Backbone appropriately for the environment. Start with AMD.\n if (typeof define === 'function' && define.amd) {\n define(['underscore', 'jquery', 'exports'], function(_, $, exports) {\n // Export global even in AMD case in case this script is loaded with\n // others that may still expect a global Backbone.\n root.Backbone = factory(root, exports, _, $);\n });\n\n // Next for Node.js or CommonJS. jQuery may not be needed as a module.\n } else if (typeof exports !== 'undefined') {\n var _ = require('underscore'), $;\n try { $ = require('jquery'); } catch (e) {}\n factory(root, exports, _, $);\n\n // Finally, as a browser global.\n } else {\n root.Backbone = factory(root, {}, root._, (root.jQuery || root.Zepto || root.ender || root.$));\n }\n\n})(function(root, Backbone, _, $) {\n\n // Initial Setup\n // -------------\n\n // Save the previous value of the `Backbone` variable, so that it can be\n // restored later on, if `noConflict` is used.\n var previousBackbone = root.Backbone;\n\n // Create a local reference to a common array method we'll want to use later.\n var slice = Array.prototype.slice;\n\n // Current version of the library. Keep in sync with `package.json`.\n Backbone.VERSION = '1.3.3';\n\n // For Backbone's purposes, jQuery, Zepto, Ender, or My Library (kidding) owns\n // the `$` variable.\n Backbone.$ = $;\n\n // Runs Backbone.js in *noConflict* mode, returning the `Backbone` variable\n // to its previous owner. Returns a reference to this Backbone object.\n Backbone.noConflict = function() {\n root.Backbone = previousBackbone;\n return this;\n };\n\n // Turn on `emulateHTTP` to support legacy HTTP servers. Setting this option\n // will fake `\"PATCH\"`, `\"PUT\"` and `\"DELETE\"` requests via the `_method` parameter and\n // set a `X-Http-Method-Override` header.\n Backbone.emulateHTTP = false;\n\n // Turn on `emulateJSON` to support legacy servers that can't deal with direct\n // `application/json` requests ... this will encode the body as\n // `application/x-www-form-urlencoded` instead and will send the model in a\n // form param named `model`.\n Backbone.emulateJSON = false;\n\n // Proxy Backbone class methods to Underscore functions, wrapping the model's\n // `attributes` object or collection's `models` array behind the scenes.\n //\n // collection.filter(function(model) { return model.get('age') > 10 });\n // collection.each(this.addView);\n //\n // `Function#apply` can be slow so we use the method's arg count, if we know it.\n var addMethod = function(length, method, attribute) {\n switch (length) {\n case 1: return function() {\n return _[method](this[attribute]);\n };\n case 2: return function(value) {\n return _[method](this[attribute], value);\n };\n case 3: return function(iteratee, context) {\n return _[method](this[attribute], cb(iteratee, this), context);\n };\n case 4: return function(iteratee, defaultVal, context) {\n return _[method](this[attribute], cb(iteratee, this), defaultVal, context);\n };\n default: return function() {\n var args = slice.call(arguments);\n args.unshift(this[attribute]);\n return _[method].apply(_, args);\n };\n }\n };\n var addUnderscoreMethods = function(Class, methods, attribute) {\n _.each(methods, function(length, method) {\n if (_[method]) Class.prototype[method] = addMethod(length, method, attribute);\n });\n };\n\n // Support `collection.sortBy('attr')` and `collection.findWhere({id: 1})`.\n var cb = function(iteratee, instance) {\n if (_.isFunction(iteratee)) return iteratee;\n if (_.isObject(iteratee) && !instance._isModel(iteratee)) return modelMatcher(iteratee);\n if (_.isString(iteratee)) return function(model) { return model.get(iteratee); };\n return iteratee;\n };\n var modelMatcher = function(attrs) {\n var matcher = _.matches(attrs);\n return function(model) {\n return matcher(model.attributes);\n };\n };\n\n // Backbone.Events\n // ---------------\n\n // A module that can be mixed in to *any object* in order to provide it with\n // a custom event channel. You may bind a callback to an event with `on` or\n // remove with `off`; `trigger`-ing an event fires all callbacks in\n // succession.\n //\n // var object = {};\n // _.extend(object, Backbone.Events);\n // object.on('expand', function(){ alert('expanded'); });\n // object.trigger('expand');\n //\n var Events = Backbone.Events = {};\n\n // Regular expression used to split event strings.\n var eventSplitter = /\\s+/;\n\n // Iterates over the standard `event, callback` (as well as the fancy multiple\n // space-separated events `\"change blur\", callback` and jQuery-style event\n // maps `{event: callback}`).\n var eventsApi = function(iteratee, events, name, callback, opts) {\n var i = 0, names;\n if (name && typeof name === 'object') {\n // Handle event maps.\n if (callback !== void 0 && 'context' in opts && opts.context === void 0) opts.context = callback;\n for (names = _.keys(name); i < names.length ; i++) {\n events = eventsApi(iteratee, events, names[i], name[names[i]], opts);\n }\n } else if (name && eventSplitter.test(name)) {\n // Handle space-separated event names by delegating them individually.\n for (names = name.split(eventSplitter); i < names.length; i++) {\n events = iteratee(events, names[i], callback, opts);\n }\n } else {\n // Finally, standard events.\n events = iteratee(events, name, callback, opts);\n }\n return events;\n };\n\n // Bind an event to a `callback` function. Passing `\"all\"` will bind\n // the callback to all events fired.\n Events.on = function(name, callback, context) {\n return internalOn(this, name, callback, context);\n };\n\n // Guard the `listening` argument from the public API.\n var internalOn = function(obj, name, callback, context, listening) {\n obj._events = eventsApi(onApi, obj._events || {}, name, callback, {\n context: context,\n ctx: obj,\n listening: listening\n });\n\n if (listening) {\n var listeners = obj._listeners || (obj._listeners = {});\n listeners[listening.id] = listening;\n }\n\n return obj;\n };\n\n // Inversion-of-control versions of `on`. Tell *this* object to listen to\n // an event in another object... keeping track of what it's listening to\n // for easier unbinding later.\n Events.listenTo = function(obj, name, callback) {\n if (!obj) return this;\n var id = obj._listenId || (obj._listenId = _.uniqueId('l'));\n var listeningTo = this._listeningTo || (this._listeningTo = {});\n var listening = listeningTo[id];\n\n // This object is not listening to any other events on `obj` yet.\n // Setup the necessary references to track the listening callbacks.\n if (!listening) {\n var thisId = this._listenId || (this._listenId = _.uniqueId('l'));\n listening = listeningTo[id] = {obj: obj, objId: id, id: thisId, listeningTo: listeningTo, count: 0};\n }\n\n // Bind callbacks on obj, and keep track of them on listening.\n internalOn(obj, name, callback, this, listening);\n return this;\n };\n\n // The reducing API that adds a callback to the `events` object.\n var onApi = function(events, name, callback, options) {\n if (callback) {\n var handlers = events[name] || (events[name] = []);\n var context = options.context, ctx = options.ctx, listening = options.listening;\n if (listening) listening.count++;\n\n handlers.push({callback: callback, context: context, ctx: context || ctx, listening: listening});\n }\n return events;\n };\n\n // Remove one or many callbacks. If `context` is null, removes all\n // callbacks with that function. If `callback` is null, removes all\n // callbacks for the event. If `name` is null, removes all bound\n // callbacks for all events.\n Events.off = function(name, callback, context) {\n if (!this._events) return this;\n this._events = eventsApi(offApi, this._events, name, callback, {\n context: context,\n listeners: this._listeners\n });\n return this;\n };\n\n // Tell this object to stop listening to either specific events ... or\n // to every object it's currently listening to.\n Events.stopListening = function(obj, name, callback) {\n var listeningTo = this._listeningTo;\n if (!listeningTo) return this;\n\n var ids = obj ? [obj._listenId] : _.keys(listeningTo);\n\n for (var i = 0; i < ids.length; i++) {\n var listening = listeningTo[ids[i]];\n\n // If listening doesn't exist, this object is not currently\n // listening to obj. Break out early.\n if (!listening) break;\n\n listening.obj.off(name, callback, this);\n }\n\n return this;\n };\n\n // The reducing API that removes a callback from the `events` object.\n var offApi = function(events, name, callback, options) {\n if (!events) return;\n\n var i = 0, listening;\n var context = options.context, listeners = options.listeners;\n\n // Delete all events listeners and \"drop\" events.\n if (!name && !callback && !context) {\n var ids = _.keys(listeners);\n for (; i < ids.length; i++) {\n listening = listeners[ids[i]];\n delete listeners[listening.id];\n delete listening.listeningTo[listening.objId];\n }\n return;\n }\n\n var names = name ? [name] : _.keys(events);\n for (; i < names.length; i++) {\n name = names[i];\n var handlers = events[name];\n\n // Bail out if there are no events stored.\n if (!handlers) break;\n\n // Replace events if there are any remaining. Otherwise, clean up.\n var remaining = [];\n for (var j = 0; j < handlers.length; j++) {\n var handler = handlers[j];\n if (\n callback && callback !== handler.callback &&\n callback !== handler.callback._callback ||\n context && context !== handler.context\n ) {\n remaining.push(handler);\n } else {\n listening = handler.listening;\n if (listening && --listening.count === 0) {\n delete listeners[listening.id];\n delete listening.listeningTo[listening.objId];\n }\n }\n }\n\n // Update tail event if the list has any events. Otherwise, clean up.\n if (remaining.length) {\n events[name] = remaining;\n } else {\n delete events[name];\n }\n }\n return events;\n };\n\n // Bind an event to only be triggered a single time. After the first time\n // the callback is invoked, its listener will be removed. If multiple events\n // are passed in using the space-separated syntax, the handler will fire\n // once for each event, not once for a combination of all events.\n Events.once = function(name, callback, context) {\n // Map the event into a `{event: once}` object.\n var events = eventsApi(onceMap, {}, name, callback, _.bind(this.off, this));\n if (typeof name === 'string' && context == null) callback = void 0;\n return this.on(events, callback, context);\n };\n\n // Inversion-of-control versions of `once`.\n Events.listenToOnce = function(obj, name, callback) {\n // Map the event into a `{event: once}` object.\n var events = eventsApi(onceMap, {}, name, callback, _.bind(this.stopListening, this, obj));\n return this.listenTo(obj, events);\n };\n\n // Reduces the event callbacks into a map of `{event: onceWrapper}`.\n // `offer` unbinds the `onceWrapper` after it has been called.\n var onceMap = function(map, name, callback, offer) {\n if (callback) {\n var once = map[name] = _.once(function() {\n offer(name, once);\n callback.apply(this, arguments);\n });\n once._callback = callback;\n }\n return map;\n };\n\n // Trigger one or many events, firing all bound callbacks. Callbacks are\n // passed the same arguments as `trigger` is, apart from the event name\n // (unless you're listening on `\"all\"`, which will cause your callback to\n // receive the true name of the event as the first argument).\n Events.trigger = function(name) {\n if (!this._events) return this;\n\n var length = Math.max(0, arguments.length - 1);\n var args = Array(length);\n for (var i = 0; i < length; i++) args[i] = arguments[i + 1];\n\n eventsApi(triggerApi, this._events, name, void 0, args);\n return this;\n };\n\n // Handles triggering the appropriate event callbacks.\n var triggerApi = function(objEvents, name, callback, args) {\n if (objEvents) {\n var events = objEvents[name];\n var allEvents = objEvents.all;\n if (events && allEvents) allEvents = allEvents.slice();\n if (events) triggerEvents(events, args);\n if (allEvents) triggerEvents(allEvents, [name].concat(args));\n }\n return objEvents;\n };\n\n // A difficult-to-believe, but optimized internal dispatch function for\n // triggering events. Tries to keep the usual cases speedy (most internal\n // Backbone events have 3 arguments).\n var triggerEvents = function(events, args) {\n var ev, i = -1, l = events.length, a1 = args[0], a2 = args[1], a3 = args[2];\n switch (args.length) {\n case 0: while (++i < l) (ev = events[i]).callback.call(ev.ctx); return;\n case 1: while (++i < l) (ev = events[i]).callback.call(ev.ctx, a1); return;\n case 2: while (++i < l) (ev = events[i]).callback.call(ev.ctx, a1, a2); return;\n case 3: while (++i < l) (ev = events[i]).callback.call(ev.ctx, a1, a2, a3); return;\n default: while (++i < l) (ev = events[i]).callback.apply(ev.ctx, args); return;\n }\n };\n\n // Aliases for backwards compatibility.\n Events.bind = Events.on;\n Events.unbind = Events.off;\n\n // Allow the `Backbone` object to serve as a global event bus, for folks who\n // want global \"pubsub\" in a convenient place.\n _.extend(Backbone, Events);\n\n // Backbone.Model\n // --------------\n\n // Backbone **Models** are the basic data object in the framework --\n // frequently representing a row in a table in a database on your server.\n // A discrete chunk of data and a bunch of useful, related methods for\n // performing computations and transformations on that data.\n\n // Create a new model with the specified attributes. A client id (`cid`)\n // is automatically generated and assigned for you.\n var Model = Backbone.Model = function(attributes, options) {\n var attrs = attributes || {};\n options || (options = {});\n this.cid = _.uniqueId(this.cidPrefix);\n this.attributes = {};\n if (options.collection) this.collection = options.collection;\n if (options.parse) attrs = this.parse(attrs, options) || {};\n var defaults = _.result(this, 'defaults');\n attrs = _.defaults(_.extend({}, defaults, attrs), defaults);\n this.set(attrs, options);\n this.changed = {};\n this.initialize.apply(this, arguments);\n };\n\n // Attach all inheritable methods to the Model prototype.\n _.extend(Model.prototype, Events, {\n\n // A hash of attributes whose current and previous value differ.\n changed: null,\n\n // The value returned during the last failed validation.\n validationError: null,\n\n // The default name for the JSON `id` attribute is `\"id\"`. MongoDB and\n // CouchDB users may want to set this to `\"_id\"`.\n idAttribute: 'id',\n\n // The prefix is used to create the client id which is used to identify models locally.\n // You may want to override this if you're experiencing name clashes with model ids.\n cidPrefix: 'c',\n\n // Initialize is an empty function by default. Override it with your own\n // initialization logic.\n initialize: function(){},\n\n // Return a copy of the model's `attributes` object.\n toJSON: function(options) {\n return _.clone(this.attributes);\n },\n\n // Proxy `Backbone.sync` by default -- but override this if you need\n // custom syncing semantics for *this* particular model.\n sync: function() {\n return Backbone.sync.apply(this, arguments);\n },\n\n // Get the value of an attribute.\n get: function(attr) {\n return this.attributes[attr];\n },\n\n // Get the HTML-escaped value of an attribute.\n escape: function(attr) {\n return _.escape(this.get(attr));\n },\n\n // Returns `true` if the attribute contains a value that is not null\n // or undefined.\n has: function(attr) {\n return this.get(attr) != null;\n },\n\n // Special-cased proxy to underscore's `_.matches` method.\n matches: function(attrs) {\n return !!_.iteratee(attrs, this)(this.attributes);\n },\n\n // Set a hash of model attributes on the object, firing `\"change\"`. This is\n // the core primitive operation of a model, updating the data and notifying\n // anyone who needs to know about the change in state. The heart of the beast.\n set: function(key, val, options) {\n if (key == null) return this;\n\n // Handle both `\"key\", value` and `{key: value}` -style arguments.\n var attrs;\n if (typeof key === 'object') {\n attrs = key;\n options = val;\n } else {\n (attrs = {})[key] = val;\n }\n\n options || (options = {});\n\n // Run validation.\n if (!this._validate(attrs, options)) return false;\n\n // Extract attributes and options.\n var unset = options.unset;\n var silent = options.silent;\n var changes = [];\n var changing = this._changing;\n this._changing = true;\n\n if (!changing) {\n this._previousAttributes = _.clone(this.attributes);\n this.changed = {};\n }\n\n var current = this.attributes;\n var changed = this.changed;\n var prev = this._previousAttributes;\n\n // For each `set` attribute, update or delete the current value.\n for (var attr in attrs) {\n val = attrs[attr];\n if (!_.isEqual(current[attr], val)) changes.push(attr);\n if (!_.isEqual(prev[attr], val)) {\n changed[attr] = val;\n } else {\n delete changed[attr];\n }\n unset ? delete current[attr] : current[attr] = val;\n }\n\n // Update the `id`.\n if (this.idAttribute in attrs) this.id = this.get(this.idAttribute);\n\n // Trigger all relevant attribute changes.\n if (!silent) {\n if (changes.length) this._pending = options;\n for (var i = 0; i < changes.length; i++) {\n this.trigger('change:' + changes[i], this, current[changes[i]], options);\n }\n }\n\n // You might be wondering why there's a `while` loop here. Changes can\n // be recursively nested within `\"change\"` events.\n if (changing) return this;\n if (!silent) {\n while (this._pending) {\n options = this._pending;\n this._pending = false;\n this.trigger('change', this, options);\n }\n }\n this._pending = false;\n this._changing = false;\n return this;\n },\n\n // Remove an attribute from the model, firing `\"change\"`. `unset` is a noop\n // if the attribute doesn't exist.\n unset: function(attr, options) {\n return this.set(attr, void 0, _.extend({}, options, {unset: true}));\n },\n\n // Clear all attributes on the model, firing `\"change\"`.\n clear: function(options) {\n var attrs = {};\n for (var key in this.attributes) attrs[key] = void 0;\n return this.set(attrs, _.extend({}, options, {unset: true}));\n },\n\n // Determine if the model has changed since the last `\"change\"` event.\n // If you specify an attribute name, determine if that attribute has changed.\n hasChanged: function(attr) {\n if (attr == null) return !_.isEmpty(this.changed);\n return _.has(this.changed, attr);\n },\n\n // Return an object containing all the attributes that have changed, or\n // false if there are no changed attributes. Useful for determining what\n // parts of a view need to be updated and/or what attributes need to be\n // persisted to the server. Unset attributes will be set to undefined.\n // You can also pass an attributes object to diff against the model,\n // determining if there *would be* a change.\n changedAttributes: function(diff) {\n if (!diff) return this.hasChanged() ? _.clone(this.changed) : false;\n var old = this._changing ? this._previousAttributes : this.attributes;\n var changed = {};\n for (var attr in diff) {\n var val = diff[attr];\n if (_.isEqual(old[attr], val)) continue;\n changed[attr] = val;\n }\n return _.size(changed) ? changed : false;\n },\n\n // Get the previous value of an attribute, recorded at the time the last\n // `\"change\"` event was fired.\n previous: function(attr) {\n if (attr == null || !this._previousAttributes) return null;\n return this._previousAttributes[attr];\n },\n\n // Get all of the attributes of the model at the time of the previous\n // `\"change\"` event.\n previousAttributes: function() {\n return _.clone(this._previousAttributes);\n },\n\n // Fetch the model from the server, merging the response with the model's\n // local attributes. Any changed attributes will trigger a \"change\" event.\n fetch: function(options) {\n options = _.extend({parse: true}, options);\n var model = this;\n var success = options.success;\n options.success = function(resp) {\n var serverAttrs = options.parse ? model.parse(resp, options) : resp;\n if (!model.set(serverAttrs, options)) return false;\n if (success) success.call(options.context, model, resp, options);\n model.trigger('sync', model, resp, options);\n };\n wrapError(this, options);\n return this.sync('read', this, options);\n },\n\n // Set a hash of model attributes, and sync the model to the server.\n // If the server returns an attributes hash that differs, the model's\n // state will be `set` again.\n save: function(key, val, options) {\n // Handle both `\"key\", value` and `{key: value}` -style arguments.\n var attrs;\n if (key == null || typeof key === 'object') {\n attrs = key;\n options = val;\n } else {\n (attrs = {})[key] = val;\n }\n\n options = _.extend({validate: true, parse: true}, options);\n var wait = options.wait;\n\n // If we're not waiting and attributes exist, save acts as\n // `set(attr).save(null, opts)` with validation. Otherwise, check if\n // the model will be valid when the attributes, if any, are set.\n if (attrs && !wait) {\n if (!this.set(attrs, options)) return false;\n } else if (!this._validate(attrs, options)) {\n return false;\n }\n\n // After a successful server-side save, the client is (optionally)\n // updated with the server-side state.\n var model = this;\n var success = options.success;\n var attributes = this.attributes;\n options.success = function(resp) {\n // Ensure attributes are restored during synchronous saves.\n model.attributes = attributes;\n var serverAttrs = options.parse ? model.parse(resp, options) : resp;\n if (wait) serverAttrs = _.extend({}, attrs, serverAttrs);\n if (serverAttrs && !model.set(serverAttrs, options)) return false;\n if (success) success.call(options.context, model, resp, options);\n model.trigger('sync', model, resp, options);\n };\n wrapError(this, options);\n\n // Set temporary attributes if `{wait: true}` to properly find new ids.\n if (attrs && wait) this.attributes = _.extend({}, attributes, attrs);\n\n var method = this.isNew() ? 'create' : (options.patch ? 'patch' : 'update');\n if (method === 'patch' && !options.attrs) options.attrs = attrs;\n var xhr = this.sync(method, this, options);\n\n // Restore attributes.\n this.attributes = attributes;\n\n return xhr;\n },\n\n // Destroy this model on the server if it was already persisted.\n // Optimistically removes the model from its collection, if it has one.\n // If `wait: true` is passed, waits for the server to respond before removal.\n destroy: function(options) {\n options = options ? _.clone(options) : {};\n var model = this;\n var success = options.success;\n var wait = options.wait;\n\n var destroy = function() {\n model.stopListening();\n model.trigger('destroy', model, model.collection, options);\n };\n\n options.success = function(resp) {\n if (wait) destroy();\n if (success) success.call(options.context, model, resp, options);\n if (!model.isNew()) model.trigger('sync', model, resp, options);\n };\n\n var xhr = false;\n if (this.isNew()) {\n _.defer(options.success);\n } else {\n wrapError(this, options);\n xhr = this.sync('delete', this, options);\n }\n if (!wait) destroy();\n return xhr;\n },\n\n // Default URL for the model's representation on the server -- if you're\n // using Backbone's restful methods, override this to change the endpoint\n // that will be called.\n url: function() {\n var base =\n _.result(this, 'urlRoot') ||\n _.result(this.collection, 'url') ||\n urlError();\n if (this.isNew()) return base;\n var id = this.get(this.idAttribute);\n return base.replace(/[^\\/]$/, '$&/') + encodeURIComponent(id);\n },\n\n // **parse** converts a response into the hash of attributes to be `set` on\n // the model. The default implementation is just to pass the response along.\n parse: function(resp, options) {\n return resp;\n },\n\n // Create a new model with identical attributes to this one.\n clone: function() {\n return new this.constructor(this.attributes);\n },\n\n // A model is new if it has never been saved to the server, and lacks an id.\n isNew: function() {\n return !this.has(this.idAttribute);\n },\n\n // Check if the model is currently in a valid state.\n isValid: function(options) {\n return this._validate({}, _.extend({}, options, {validate: true}));\n },\n\n // Run validation against the next complete set of model attributes,\n // returning `true` if all is well. Otherwise, fire an `\"invalid\"` event.\n _validate: function(attrs, options) {\n if (!options.validate || !this.validate) return true;\n attrs = _.extend({}, this.attributes, attrs);\n var error = this.validationError = this.validate(attrs, options) || null;\n if (!error) return true;\n this.trigger('invalid', this, error, _.extend(options, {validationError: error}));\n return false;\n }\n\n });\n\n // Underscore methods that we want to implement on the Model, mapped to the\n // number of arguments they take.\n var modelMethods = {keys: 1, values: 1, pairs: 1, invert: 1, pick: 0,\n omit: 0, chain: 1, isEmpty: 1};\n\n // Mix in each Underscore method as a proxy to `Model#attributes`.\n addUnderscoreMethods(Model, modelMethods, 'attributes');\n\n // Backbone.Collection\n // -------------------\n\n // If models tend to represent a single row of data, a Backbone Collection is\n // more analogous to a table full of data ... or a small slice or page of that\n // table, or a collection of rows that belong together for a particular reason\n // -- all of the messages in this particular folder, all of the documents\n // belonging to this particular author, and so on. Collections maintain\n // indexes of their models, both in order, and for lookup by `id`.\n\n // Create a new **Collection**, perhaps to contain a specific type of `model`.\n // If a `comparator` is specified, the Collection will maintain\n // its models in sort order, as they're added and removed.\n var Collection = Backbone.Collection = function(models, options) {\n options || (options = {});\n if (options.model) this.model = options.model;\n if (options.comparator !== void 0) this.comparator = options.comparator;\n this._reset();\n this.initialize.apply(this, arguments);\n if (models) this.reset(models, _.extend({silent: true}, options));\n };\n\n // Default options for `Collection#set`.\n var setOptions = {add: true, remove: true, merge: true};\n var addOptions = {add: true, remove: false};\n\n // Splices `insert` into `array` at index `at`.\n var splice = function(array, insert, at) {\n at = Math.min(Math.max(at, 0), array.length);\n var tail = Array(array.length - at);\n var length = insert.length;\n var i;\n for (i = 0; i < tail.length; i++) tail[i] = array[i + at];\n for (i = 0; i < length; i++) array[i + at] = insert[i];\n for (i = 0; i < tail.length; i++) array[i + length + at] = tail[i];\n };\n\n // Define the Collection's inheritable methods.\n _.extend(Collection.prototype, Events, {\n\n // The default model for a collection is just a **Backbone.Model**.\n // This should be overridden in most cases.\n model: Model,\n\n // Initialize is an empty function by default. Override it with your own\n // initialization logic.\n initialize: function(){},\n\n // The JSON representation of a Collection is an array of the\n // models' attributes.\n toJSON: function(options) {\n return this.map(function(model) { return model.toJSON(options); });\n },\n\n // Proxy `Backbone.sync` by default.\n sync: function() {\n return Backbone.sync.apply(this, arguments);\n },\n\n // Add a model, or list of models to the set. `models` may be Backbone\n // Models or raw JavaScript objects to be converted to Models, or any\n // combination of the two.\n add: function(models, options) {\n return this.set(models, _.extend({merge: false}, options, addOptions));\n },\n\n // Remove a model, or a list of models from the set.\n remove: function(models, options) {\n options = _.extend({}, options);\n var singular = !_.isArray(models);\n models = singular ? [models] : models.slice();\n var removed = this._removeModels(models, options);\n if (!options.silent && removed.length) {\n options.changes = {added: [], merged: [], removed: removed};\n this.trigger('update', this, options);\n }\n return singular ? removed[0] : removed;\n },\n\n // Update a collection by `set`-ing a new list of models, adding new ones,\n // removing models that are no longer present, and merging models that\n // already exist in the collection, as necessary. Similar to **Model#set**,\n // the core operation for updating the data contained by the collection.\n set: function(models, options) {\n if (models == null) return;\n\n options = _.extend({}, setOptions, options);\n if (options.parse && !this._isModel(models)) {\n models = this.parse(models, options) || [];\n }\n\n var singular = !_.isArray(models);\n models = singular ? [models] : models.slice();\n\n var at = options.at;\n if (at != null) at = +at;\n if (at > this.length) at = this.length;\n if (at < 0) at += this.length + 1;\n\n var set = [];\n var toAdd = [];\n var toMerge = [];\n var toRemove = [];\n var modelMap = {};\n\n var add = options.add;\n var merge = options.merge;\n var remove = options.remove;\n\n var sort = false;\n var sortable = this.comparator && at == null && options.sort !== false;\n var sortAttr = _.isString(this.comparator) ? this.comparator : null;\n\n // Turn bare objects into model references, and prevent invalid models\n // from being added.\n var model, i;\n for (i = 0; i < models.length; i++) {\n model = models[i];\n\n // If a duplicate is found, prevent it from being added and\n // optionally merge it into the existing model.\n var existing = this.get(model);\n if (existing) {\n if (merge && model !== existing) {\n var attrs = this._isModel(model) ? model.attributes : model;\n if (options.parse) attrs = existing.parse(attrs, options);\n existing.set(attrs, options);\n toMerge.push(existing);\n if (sortable && !sort) sort = existing.hasChanged(sortAttr);\n }\n if (!modelMap[existing.cid]) {\n modelMap[existing.cid] = true;\n set.push(existing);\n }\n models[i] = existing;\n\n // If this is a new, valid model, push it to the `toAdd` list.\n } else if (add) {\n model = models[i] = this._prepareModel(model, options);\n if (model) {\n toAdd.push(model);\n this._addReference(model, options);\n modelMap[model.cid] = true;\n set.push(model);\n }\n }\n }\n\n // Remove stale models.\n if (remove) {\n for (i = 0; i < this.length; i++) {\n model = this.models[i];\n if (!modelMap[model.cid]) toRemove.push(model);\n }\n if (toRemove.length) this._removeModels(toRemove, options);\n }\n\n // See if sorting is needed, update `length` and splice in new models.\n var orderChanged = false;\n var replace = !sortable && add && remove;\n if (set.length && replace) {\n orderChanged = this.length !== set.length || _.some(this.models, function(m, index) {\n return m !== set[index];\n });\n this.models.length = 0;\n splice(this.models, set, 0);\n this.length = this.models.length;\n } else if (toAdd.length) {\n if (sortable) sort = true;\n splice(this.models, toAdd, at == null ? this.length : at);\n this.length = this.models.length;\n }\n\n // Silently sort the collection if appropriate.\n if (sort) this.sort({silent: true});\n\n // Unless silenced, it's time to fire all appropriate add/sort/update events.\n if (!options.silent) {\n for (i = 0; i < toAdd.length; i++) {\n if (at != null) options.index = at + i;\n model = toAdd[i];\n model.trigger('add', model, this, options);\n }\n if (sort || orderChanged) this.trigger('sort', this, options);\n if (toAdd.length || toRemove.length || toMerge.length) {\n options.changes = {\n added: toAdd,\n removed: toRemove,\n merged: toMerge\n };\n this.trigger('update', this, options);\n }\n }\n\n // Return the added (or merged) model (or models).\n return singular ? models[0] : models;\n },\n\n // When you have more items than you want to add or remove individually,\n // you can reset the entire set with a new list of models, without firing\n // any granular `add` or `remove` events. Fires `reset` when finished.\n // Useful for bulk operations and optimizations.\n reset: function(models, options) {\n options = options ? _.clone(options) : {};\n for (var i = 0; i < this.models.length; i++) {\n this._removeReference(this.models[i], options);\n }\n options.previousModels = this.models;\n this._reset();\n models = this.add(models, _.extend({silent: true}, options));\n if (!options.silent) this.trigger('reset', this, options);\n return models;\n },\n\n // Add a model to the end of the collection.\n push: function(model, options) {\n return this.add(model, _.extend({at: this.length}, options));\n },\n\n // Remove a model from the end of the collection.\n pop: function(options) {\n var model = this.at(this.length - 1);\n return this.remove(model, options);\n },\n\n // Add a model to the beginning of the collection.\n unshift: function(model, options) {\n return this.add(model, _.extend({at: 0}, options));\n },\n\n // Remove a model from the beginning of the collection.\n shift: function(options) {\n var model = this.at(0);\n return this.remove(model, options);\n },\n\n // Slice out a sub-array of models from the collection.\n slice: function() {\n return slice.apply(this.models, arguments);\n },\n\n // Get a model from the set by id, cid, model object with id or cid\n // properties, or an attributes object that is transformed through modelId.\n get: function(obj) {\n if (obj == null) return void 0;\n return this._byId[obj] ||\n this._byId[this.modelId(obj.attributes || obj)] ||\n obj.cid && this._byId[obj.cid];\n },\n\n // Returns `true` if the model is in the collection.\n has: function(obj) {\n return this.get(obj) != null;\n },\n\n // Get the model at the given index.\n at: function(index) {\n if (index < 0) index += this.length;\n return this.models[index];\n },\n\n // Return models with matching attributes. Useful for simple cases of\n // `filter`.\n where: function(attrs, first) {\n return this[first ? 'find' : 'filter'](attrs);\n },\n\n // Return the first model with matching attributes. Useful for simple cases\n // of `find`.\n findWhere: function(attrs) {\n return this.where(attrs, true);\n },\n\n // Force the collection to re-sort itself. You don't need to call this under\n // normal circumstances, as the set will maintain sort order as each item\n // is added.\n sort: function(options) {\n var comparator = this.comparator;\n if (!comparator) throw new Error('Cannot sort a set without a comparator');\n options || (options = {});\n\n var length = comparator.length;\n if (_.isFunction(comparator)) comparator = _.bind(comparator, this);\n\n // Run sort based on type of `comparator`.\n if (length === 1 || _.isString(comparator)) {\n this.models = this.sortBy(comparator);\n } else {\n this.models.sort(comparator);\n }\n if (!options.silent) this.trigger('sort', this, options);\n return this;\n },\n\n // Pluck an attribute from each model in the collection.\n pluck: function(attr) {\n return this.map(attr + '');\n },\n\n // Fetch the default set of models for this collection, resetting the\n // collection when they arrive. If `reset: true` is passed, the response\n // data will be passed through the `reset` method instead of `set`.\n fetch: function(options) {\n options = _.extend({parse: true}, options);\n var success = options.success;\n var collection = this;\n options.success = function(resp) {\n var method = options.reset ? 'reset' : 'set';\n collection[method](resp, options);\n if (success) success.call(options.context, collection, resp, options);\n collection.trigger('sync', collection, resp, options);\n };\n wrapError(this, options);\n return this.sync('read', this, options);\n },\n\n // Create a new instance of a model in this collection. Add the model to the\n // collection immediately, unless `wait: true` is passed, in which case we\n // wait for the server to agree.\n create: function(model, options) {\n options = options ? _.clone(options) : {};\n var wait = options.wait;\n model = this._prepareModel(model, options);\n if (!model) return false;\n if (!wait) this.add(model, options);\n var collection = this;\n var success = options.success;\n options.success = function(m, resp, callbackOpts) {\n if (wait) collection.add(m, callbackOpts);\n if (success) success.call(callbackOpts.context, m, resp, callbackOpts);\n };\n model.save(null, options);\n return model;\n },\n\n // **parse** converts a response into a list of models to be added to the\n // collection. The default implementation is just to pass it through.\n parse: function(resp, options) {\n return resp;\n },\n\n // Create a new collection with an identical list of models as this one.\n clone: function() {\n return new this.constructor(this.models, {\n model: this.model,\n comparator: this.comparator\n });\n },\n\n // Define how to uniquely identify models in the collection.\n modelId: function(attrs) {\n return attrs[this.model.prototype.idAttribute || 'id'];\n },\n\n // Private method to reset all internal state. Called when the collection\n // is first initialized or reset.\n _reset: function() {\n this.length = 0;\n this.models = [];\n this._byId = {};\n },\n\n // Prepare a hash of attributes (or other model) to be added to this\n // collection.\n _prepareModel: function(attrs, options) {\n if (this._isModel(attrs)) {\n if (!attrs.collection) attrs.collection = this;\n return attrs;\n }\n options = options ? _.clone(options) : {};\n options.collection = this;\n var model = new this.model(attrs, options);\n if (!model.validationError) return model;\n this.trigger('invalid', this, model.validationError, options);\n return false;\n },\n\n // Internal method called by both remove and set.\n _removeModels: function(models, options) {\n var removed = [];\n for (var i = 0; i < models.length; i++) {\n var model = this.get(models[i]);\n if (!model) continue;\n\n var index = this.indexOf(model);\n this.models.splice(index, 1);\n this.length--;\n\n // Remove references before triggering 'remove' event to prevent an\n // infinite loop. #3693\n delete this._byId[model.cid];\n var id = this.modelId(model.attributes);\n if (id != null) delete this._byId[id];\n\n if (!options.silent) {\n options.index = index;\n model.trigger('remove', model, this, options);\n }\n\n removed.push(model);\n this._removeReference(model, options);\n }\n return removed;\n },\n\n // Method for checking whether an object should be considered a model for\n // the purposes of adding to the collection.\n _isModel: function(model) {\n return model instanceof Model;\n },\n\n // Internal method to create a model's ties to a collection.\n _addReference: function(model, options) {\n this._byId[model.cid] = model;\n var id = this.modelId(model.attributes);\n if (id != null) this._byId[id] = model;\n model.on('all', this._onModelEvent, this);\n },\n\n // Internal method to sever a model's ties to a collection.\n _removeReference: function(model, options) {\n delete this._byId[model.cid];\n var id = this.modelId(model.attributes);\n if (id != null) delete this._byId[id];\n if (this === model.collection) delete model.collection;\n model.off('all', this._onModelEvent, this);\n },\n\n // Internal method called every time a model in the set fires an event.\n // Sets need to update their indexes when models change ids. All other\n // events simply proxy through. \"add\" and \"remove\" events that originate\n // in other collections are ignored.\n _onModelEvent: function(event, model, collection, options) {\n if (model) {\n if ((event === 'add' || event === 'remove') && collection !== this) return;\n if (event === 'destroy') this.remove(model, options);\n if (event === 'change') {\n var prevId = this.modelId(model.previousAttributes());\n var id = this.modelId(model.attributes);\n if (prevId !== id) {\n if (prevId != null) delete this._byId[prevId];\n if (id != null) this._byId[id] = model;\n }\n }\n }\n this.trigger.apply(this, arguments);\n }\n\n });\n\n // Underscore methods that we want to implement on the Collection.\n // 90% of the core usefulness of Backbone Collections is actually implemented\n // right here:\n var collectionMethods = {forEach: 3, each: 3, map: 3, collect: 3, reduce: 0,\n foldl: 0, inject: 0, reduceRight: 0, foldr: 0, find: 3, detect: 3, filter: 3,\n select: 3, reject: 3, every: 3, all: 3, some: 3, any: 3, include: 3, includes: 3,\n contains: 3, invoke: 0, max: 3, min: 3, toArray: 1, size: 1, first: 3,\n head: 3, take: 3, initial: 3, rest: 3, tail: 3, drop: 3, last: 3,\n without: 0, difference: 0, indexOf: 3, shuffle: 1, lastIndexOf: 3,\n isEmpty: 1, chain: 1, sample: 3, partition: 3, groupBy: 3, countBy: 3,\n sortBy: 3, indexBy: 3, findIndex: 3, findLastIndex: 3};\n\n // Mix in each Underscore method as a proxy to `Collection#models`.\n addUnderscoreMethods(Collection, collectionMethods, 'models');\n\n // Backbone.View\n // -------------\n\n // Backbone Views are almost more convention than they are actual code. A View\n // is simply a JavaScript object that represents a logical chunk of UI in the\n // DOM. This might be a single item, an entire list, a sidebar or panel, or\n // even the surrounding frame which wraps your whole app. Defining a chunk of\n // UI as a **View** allows you to define your DOM events declaratively, without\n // having to worry about render order ... and makes it easy for the view to\n // react to specific changes in the state of your models.\n\n // Creating a Backbone.View creates its initial element outside of the DOM,\n // if an existing element is not provided...\n var View = Backbone.View = function(options) {\n this.cid = _.uniqueId('view');\n _.extend(this, _.pick(options, viewOptions));\n this._ensureElement();\n this.initialize.apply(this, arguments);\n };\n\n // Cached regex to split keys for `delegate`.\n var delegateEventSplitter = /^(\\S+)\\s*(.*)$/;\n\n // List of view options to be set as properties.\n var viewOptions = ['model', 'collection', 'el', 'id', 'attributes', 'className', 'tagName', 'events'];\n\n // Set up all inheritable **Backbone.View** properties and methods.\n _.extend(View.prototype, Events, {\n\n // The default `tagName` of a View's element is `\"div\"`.\n tagName: 'div',\n\n // jQuery delegate for element lookup, scoped to DOM elements within the\n // current view. This should be preferred to global lookups where possible.\n $: function(selector) {\n return this.$el.find(selector);\n },\n\n // Initialize is an empty function by default. Override it with your own\n // initialization logic.\n initialize: function(){},\n\n // **render** is the core function that your view should override, in order\n // to populate its element (`this.el`), with the appropriate HTML. The\n // convention is for **render** to always return `this`.\n render: function() {\n return this;\n },\n\n // Remove this view by taking the element out of the DOM, and removing any\n // applicable Backbone.Events listeners.\n remove: function() {\n this._removeElement();\n this.stopListening();\n return this;\n },\n\n // Remove this view's element from the document and all event listeners\n // attached to it. Exposed for subclasses using an alternative DOM\n // manipulation API.\n _removeElement: function() {\n this.$el.remove();\n },\n\n // Change the view's element (`this.el` property) and re-delegate the\n // view's events on the new element.\n setElement: function(element) {\n this.undelegateEvents();\n this._setElement(element);\n this.delegateEvents();\n return this;\n },\n\n // Creates the `this.el` and `this.$el` references for this view using the\n // given `el`. `el` can be a CSS selector or an HTML string, a jQuery\n // context or an element. Subclasses can override this to utilize an\n // alternative DOM manipulation API and are only required to set the\n // `this.el` property.\n _setElement: function(el) {\n this.$el = el instanceof Backbone.$ ? el : Backbone.$(el);\n this.el = this.$el[0];\n },\n\n // Set callbacks, where `this.events` is a hash of\n //\n // *{\"event selector\": \"callback\"}*\n //\n // {\n // 'mousedown .title': 'edit',\n // 'click .button': 'save',\n // 'click .open': function(e) { ... }\n // }\n //\n // pairs. Callbacks will be bound to the view, with `this` set properly.\n // Uses event delegation for efficiency.\n // Omitting the selector binds the event to `this.el`.\n delegateEvents: function(events) {\n events || (events = _.result(this, 'events'));\n if (!events) return this;\n this.undelegateEvents();\n for (var key in events) {\n var method = events[key];\n if (!_.isFunction(method)) method = this[method];\n if (!method) continue;\n var match = key.match(delegateEventSplitter);\n this.delegate(match[1], match[2], _.bind(method, this));\n }\n return this;\n },\n\n // Add a single event listener to the view's element (or a child element\n // using `selector`). This only works for delegate-able events: not `focus`,\n // `blur`, and not `change`, `submit`, and `reset` in Internet Explorer.\n delegate: function(eventName, selector, listener) {\n this.$el.on(eventName + '.delegateEvents' + this.cid, selector, listener);\n return this;\n },\n\n // Clears all callbacks previously bound to the view by `delegateEvents`.\n // You usually don't need to use this, but may wish to if you have multiple\n // Backbone views attached to the same DOM element.\n undelegateEvents: function() {\n if (this.$el) this.$el.off('.delegateEvents' + this.cid);\n return this;\n },\n\n // A finer-grained `undelegateEvents` for removing a single delegated event.\n // `selector` and `listener` are both optional.\n undelegate: function(eventName, selector, listener) {\n this.$el.off(eventName + '.delegateEvents' + this.cid, selector, listener);\n return this;\n },\n\n // Produces a DOM element to be assigned to your view. Exposed for\n // subclasses using an alternative DOM manipulation API.\n _createElement: function(tagName) {\n return document.createElement(tagName);\n },\n\n // Ensure that the View has a DOM element to render into.\n // If `this.el` is a string, pass it through `$()`, take the first\n // matching element, and re-assign it to `el`. Otherwise, create\n // an element from the `id`, `className` and `tagName` properties.\n _ensureElement: function() {\n if (!this.el) {\n var attrs = _.extend({}, _.result(this, 'attributes'));\n if (this.id) attrs.id = _.result(this, 'id');\n if (this.className) attrs['class'] = _.result(this, 'className');\n this.setElement(this._createElement(_.result(this, 'tagName')));\n this._setAttributes(attrs);\n } else {\n this.setElement(_.result(this, 'el'));\n }\n },\n\n // Set attributes from a hash on this view's element. Exposed for\n // subclasses using an alternative DOM manipulation API.\n _setAttributes: function(attributes) {\n this.$el.attr(attributes);\n }\n\n });\n\n // Backbone.sync\n // -------------\n\n // Override this function to change the manner in which Backbone persists\n // models to the server. You will be passed the type of request, and the\n // model in question. By default, makes a RESTful Ajax request\n // to the model's `url()`. Some possible customizations could be:\n //\n // * Use `setTimeout` to batch rapid-fire updates into a single request.\n // * Send up the models as XML instead of JSON.\n // * Persist models via WebSockets instead of Ajax.\n //\n // Turn on `Backbone.emulateHTTP` in order to send `PUT` and `DELETE` requests\n // as `POST`, with a `_method` parameter containing the true HTTP method,\n // as well as all requests with the body as `application/x-www-form-urlencoded`\n // instead of `application/json` with the model in a param named `model`.\n // Useful when interfacing with server-side languages like **PHP** that make\n // it difficult to read the body of `PUT` requests.\n Backbone.sync = function(method, model, options) {\n var type = methodMap[method];\n\n // Default options, unless specified.\n _.defaults(options || (options = {}), {\n emulateHTTP: Backbone.emulateHTTP,\n emulateJSON: Backbone.emulateJSON\n });\n\n // Default JSON-request options.\n var params = {type: type, dataType: 'json'};\n\n // Ensure that we have a URL.\n if (!options.url) {\n params.url = _.result(model, 'url') || urlError();\n }\n\n // Ensure that we have the appropriate request data.\n if (options.data == null && model && (method === 'create' || method === 'update' || method === 'patch')) {\n params.contentType = 'application/json';\n params.data = JSON.stringify(options.attrs || model.toJSON(options));\n }\n\n // For older servers, emulate JSON by encoding the request into an HTML-form.\n if (options.emulateJSON) {\n params.contentType = 'application/x-www-form-urlencoded';\n params.data = params.data ? {model: params.data} : {};\n }\n\n // For older servers, emulate HTTP by mimicking the HTTP method with `_method`\n // And an `X-HTTP-Method-Override` header.\n if (options.emulateHTTP && (type === 'PUT' || type === 'DELETE' || type === 'PATCH')) {\n params.type = 'POST';\n if (options.emulateJSON) params.data._method = type;\n var beforeSend = options.beforeSend;\n options.beforeSend = function(xhr) {\n xhr.setRequestHeader('X-HTTP-Method-Override', type);\n if (beforeSend) return beforeSend.apply(this, arguments);\n };\n }\n\n // Don't process data on a non-GET request.\n if (params.type !== 'GET' && !options.emulateJSON) {\n params.processData = false;\n }\n\n // Pass along `textStatus` and `errorThrown` from jQuery.\n var error = options.error;\n options.error = function(xhr, textStatus, errorThrown) {\n options.textStatus = textStatus;\n options.errorThrown = errorThrown;\n if (error) error.call(options.context, xhr, textStatus, errorThrown);\n };\n\n // Make the request, allowing the user to override any Ajax options.\n var xhr = options.xhr = Backbone.ajax(_.extend(params, options));\n model.trigger('request', model, xhr, options);\n return xhr;\n };\n\n // Map from CRUD to HTTP for our default `Backbone.sync` implementation.\n var methodMap = {\n 'create': 'POST',\n 'update': 'PUT',\n 'patch': 'PATCH',\n 'delete': 'DELETE',\n 'read': 'GET'\n };\n\n // Set the default implementation of `Backbone.ajax` to proxy through to `$`.\n // Override this if you'd like to use a different library.\n Backbone.ajax = function() {\n return Backbone.$.ajax.apply(Backbone.$, arguments);\n };\n\n // Backbone.Router\n // ---------------\n\n // Routers map faux-URLs to actions, and fire events when routes are\n // matched. Creating a new one sets its `routes` hash, if not set statically.\n var Router = Backbone.Router = function(options) {\n options || (options = {});\n if (options.routes) this.routes = options.routes;\n this._bindRoutes();\n this.initialize.apply(this, arguments);\n };\n\n // Cached regular expressions for matching named param parts and splatted\n // parts of route strings.\n var optionalParam = /\\((.*?)\\)/g;\n var namedParam = /(\\(\\?)?:\\w+/g;\n var splatParam = /\\*\\w+/g;\n var escapeRegExp = /[\\-{}\\[\\]+?.,\\\\\\^$|#\\s]/g;\n\n // Set up all inheritable **Backbone.Router** properties and methods.\n _.extend(Router.prototype, Events, {\n\n // Initialize is an empty function by default. Override it with your own\n // initialization logic.\n initialize: function(){},\n\n // Manually bind a single named route to a callback. For example:\n //\n // this.route('search/:query/p:num', 'search', function(query, num) {\n // ...\n // });\n //\n route: function(route, name, callback) {\n if (!_.isRegExp(route)) route = this._routeToRegExp(route);\n if (_.isFunction(name)) {\n callback = name;\n name = '';\n }\n if (!callback) callback = this[name];\n var router = this;\n Backbone.history.route(route, function(fragment) {\n var args = router._extractParameters(route, fragment);\n if (router.execute(callback, args, name) !== false) {\n router.trigger.apply(router, ['route:' + name].concat(args));\n router.trigger('route', name, args);\n Backbone.history.trigger('route', router, name, args);\n }\n });\n return this;\n },\n\n // Execute a route handler with the provided parameters. This is an\n // excellent place to do pre-route setup or post-route cleanup.\n execute: function(callback, args, name) {\n if (callback) callback.apply(this, args);\n },\n\n // Simple proxy to `Backbone.history` to save a fragment into the history.\n navigate: function(fragment, options) {\n Backbone.history.navigate(fragment, options);\n return this;\n },\n\n // Bind all defined routes to `Backbone.history`. We have to reverse the\n // order of the routes here to support behavior where the most general\n // routes can be defined at the bottom of the route map.\n _bindRoutes: function() {\n if (!this.routes) return;\n this.routes = _.result(this, 'routes');\n var route, routes = _.keys(this.routes);\n while ((route = routes.pop()) != null) {\n this.route(route, this.routes[route]);\n }\n },\n\n // Convert a route string into a regular expression, suitable for matching\n // against the current location hash.\n _routeToRegExp: function(route) {\n route = route.replace(escapeRegExp, '\\\\$&')\n .replace(optionalParam, '(?:$1)?')\n .replace(namedParam, function(match, optional) {\n return optional ? match : '([^/?]+)';\n })\n .replace(splatParam, '([^?]*?)');\n return new RegExp('^' + route + '(?:\\\\?([\\\\s\\\\S]*))?$');\n },\n\n // Given a route, and a URL fragment that it matches, return the array of\n // extracted decoded parameters. Empty or unmatched parameters will be\n // treated as `null` to normalize cross-browser behavior.\n _extractParameters: function(route, fragment) {\n var params = route.exec(fragment).slice(1);\n return _.map(params, function(param, i) {\n // Don't decode the search params.\n if (i === params.length - 1) return param || null;\n return param ? decodeURIComponent(param) : null;\n });\n }\n\n });\n\n // Backbone.History\n // ----------------\n\n // Handles cross-browser history management, based on either\n // [pushState](http://diveintohtml5.info/history.html) and real URLs, or\n // [onhashchange](https://developer.mozilla.org/en-US/docs/DOM/window.onhashchange)\n // and URL fragments. If the browser supports neither (old IE, natch),\n // falls back to polling.\n var History = Backbone.History = function() {\n this.handlers = [];\n this.checkUrl = _.bind(this.checkUrl, this);\n\n // Ensure that `History` can be used outside of the browser.\n if (typeof window !== 'undefined') {\n this.location = window.location;\n this.history = window.history;\n }\n };\n\n // Cached regex for stripping a leading hash/slash and trailing space.\n var routeStripper = /^[#\\/]|\\s+$/g;\n\n // Cached regex for stripping leading and trailing slashes.\n var rootStripper = /^\\/+|\\/+$/g;\n\n // Cached regex for stripping urls of hash.\n var pathStripper = /#.*$/;\n\n // Has the history handling already been started?\n History.started = false;\n\n // Set up all inheritable **Backbone.History** properties and methods.\n _.extend(History.prototype, Events, {\n\n // The default interval to poll for hash changes, if necessary, is\n // twenty times a second.\n interval: 50,\n\n // Are we at the app root?\n atRoot: function() {\n var path = this.location.pathname.replace(/[^\\/]$/, '$&/');\n return path === this.root && !this.getSearch();\n },\n\n // Does the pathname match the root?\n matchRoot: function() {\n var path = this.decodeFragment(this.location.pathname);\n var rootPath = path.slice(0, this.root.length - 1) + '/';\n return rootPath === this.root;\n },\n\n // Unicode characters in `location.pathname` are percent encoded so they're\n // decoded for comparison. `%25` should not be decoded since it may be part\n // of an encoded parameter.\n decodeFragment: function(fragment) {\n return decodeURI(fragment.replace(/%25/g, '%2525'));\n },\n\n // In IE6, the hash fragment and search params are incorrect if the\n // fragment contains `?`.\n getSearch: function() {\n var match = this.location.href.replace(/#.*/, '').match(/\\?.+/);\n return match ? match[0] : '';\n },\n\n // Gets the true hash value. Cannot use location.hash directly due to bug\n // in Firefox where location.hash will always be decoded.\n getHash: function(window) {\n var match = (window || this).location.href.match(/#(.*)$/);\n return match ? match[1] : '';\n },\n\n // Get the pathname and search params, without the root.\n getPath: function() {\n var path = this.decodeFragment(\n this.location.pathname + this.getSearch()\n ).slice(this.root.length - 1);\n return path.charAt(0) === '/' ? path.slice(1) : path;\n },\n\n // Get the cross-browser normalized URL fragment from the path or hash.\n getFragment: function(fragment) {\n if (fragment == null) {\n if (this._usePushState || !this._wantsHashChange) {\n fragment = this.getPath();\n } else {\n fragment = this.getHash();\n }\n }\n return fragment.replace(routeStripper, '');\n },\n\n // Start the hash change handling, returning `true` if the current URL matches\n // an existing route, and `false` otherwise.\n start: function(options) {\n if (History.started) throw new Error('Backbone.history has already been started');\n History.started = true;\n\n // Figure out the initial configuration. Do we need an iframe?\n // Is pushState desired ... is it available?\n this.options = _.extend({root: '/'}, this.options, options);\n this.root = this.options.root;\n this._wantsHashChange = this.options.hashChange !== false;\n this._hasHashChange = 'onhashchange' in window && (document.documentMode === void 0 || document.documentMode > 7);\n this._useHashChange = this._wantsHashChange && this._hasHashChange;\n this._wantsPushState = !!this.options.pushState;\n this._hasPushState = !!(this.history && this.history.pushState);\n this._usePushState = this._wantsPushState && this._hasPushState;\n this.fragment = this.getFragment();\n\n // Normalize root to always include a leading and trailing slash.\n this.root = ('/' + this.root + '/').replace(rootStripper, '/');\n\n // Transition from hashChange to pushState or vice versa if both are\n // requested.\n if (this._wantsHashChange && this._wantsPushState) {\n\n // If we've started off with a route from a `pushState`-enabled\n // browser, but we're currently in a browser that doesn't support it...\n if (!this._hasPushState && !this.atRoot()) {\n var rootPath = this.root.slice(0, -1) || '/';\n this.location.replace(rootPath + '#' + this.getPath());\n // Return immediately as browser will do redirect to new url\n return true;\n\n // Or if we've started out with a hash-based route, but we're currently\n // in a browser where it could be `pushState`-based instead...\n } else if (this._hasPushState && this.atRoot()) {\n this.navigate(this.getHash(), {replace: true});\n }\n\n }\n\n // Proxy an iframe to handle location events if the browser doesn't\n // support the `hashchange` event, HTML5 history, or the user wants\n // `hashChange` but not `pushState`.\n if (!this._hasHashChange && this._wantsHashChange && !this._usePushState) {\n this.iframe = document.createElement('iframe');\n this.iframe.src = 'javascript:0';\n this.iframe.style.display = 'none';\n this.iframe.tabIndex = -1;\n var body = document.body;\n // Using `appendChild` will throw on IE < 9 if the document is not ready.\n var iWindow = body.insertBefore(this.iframe, body.firstChild).contentWindow;\n iWindow.document.open();\n iWindow.document.close();\n iWindow.location.hash = '#' + this.fragment;\n }\n\n // Add a cross-platform `addEventListener` shim for older browsers.\n var addEventListener = window.addEventListener || function(eventName, listener) {\n return attachEvent('on' + eventName, listener);\n };\n\n // Depending on whether we're using pushState or hashes, and whether\n // 'onhashchange' is supported, determine how we check the URL state.\n if (this._usePushState) {\n addEventListener('popstate', this.checkUrl, false);\n } else if (this._useHashChange && !this.iframe) {\n addEventListener('hashchange', this.checkUrl, false);\n } else if (this._wantsHashChange) {\n this._checkUrlInterval = setInterval(this.checkUrl, this.interval);\n }\n\n if (!this.options.silent) return this.loadUrl();\n },\n\n // Disable Backbone.history, perhaps temporarily. Not useful in a real app,\n // but possibly useful for unit testing Routers.\n stop: function() {\n // Add a cross-platform `removeEventListener` shim for older browsers.\n var removeEventListener = window.removeEventListener || function(eventName, listener) {\n return detachEvent('on' + eventName, listener);\n };\n\n // Remove window listeners.\n if (this._usePushState) {\n removeEventListener('popstate', this.checkUrl, false);\n } else if (this._useHashChange && !this.iframe) {\n removeEventListener('hashchange', this.checkUrl, false);\n }\n\n // Clean up the iframe if necessary.\n if (this.iframe) {\n document.body.removeChild(this.iframe);\n this.iframe = null;\n }\n\n // Some environments will throw when clearing an undefined interval.\n if (this._checkUrlInterval) clearInterval(this._checkUrlInterval);\n History.started = false;\n },\n\n // Add a route to be tested when the fragment changes. Routes added later\n // may override previous routes.\n route: function(route, callback) {\n this.handlers.unshift({route: route, callback: callback});\n },\n\n // Checks the current URL to see if it has changed, and if it has,\n // calls `loadUrl`, normalizing across the hidden iframe.\n checkUrl: function(e) {\n var current = this.getFragment();\n\n // If the user pressed the back button, the iframe's hash will have\n // changed and we should use that for comparison.\n if (current === this.fragment && this.iframe) {\n current = this.getHash(this.iframe.contentWindow);\n }\n\n if (current === this.fragment) return false;\n if (this.iframe) this.navigate(current);\n this.loadUrl();\n },\n\n // Attempt to load the current URL fragment. If a route succeeds with a\n // match, returns `true`. If no defined routes matches the fragment,\n // returns `false`.\n loadUrl: function(fragment) {\n // If the root doesn't match, no routes can match either.\n if (!this.matchRoot()) return false;\n fragment = this.fragment = this.getFragment(fragment);\n return _.some(this.handlers, function(handler) {\n if (handler.route.test(fragment)) {\n handler.callback(fragment);\n return true;\n }\n });\n },\n\n // Save a fragment into the hash history, or replace the URL state if the\n // 'replace' option is passed. You are responsible for properly URL-encoding\n // the fragment in advance.\n //\n // The options object can contain `trigger: true` if you wish to have the\n // route callback be fired (not usually desirable), or `replace: true`, if\n // you wish to modify the current URL without adding an entry to the history.\n navigate: function(fragment, options) {\n if (!History.started) return false;\n if (!options || options === true) options = {trigger: !!options};\n\n // Normalize the fragment.\n fragment = this.getFragment(fragment || '');\n\n // Don't include a trailing slash on the root.\n var rootPath = this.root;\n if (fragment === '' || fragment.charAt(0) === '?') {\n rootPath = rootPath.slice(0, -1) || '/';\n }\n var url = rootPath + fragment;\n\n // Strip the hash and decode for matching.\n fragment = this.decodeFragment(fragment.replace(pathStripper, ''));\n\n if (this.fragment === fragment) return;\n this.fragment = fragment;\n\n // If pushState is available, we use it to set the fragment as a real URL.\n if (this._usePushState) {\n this.history[options.replace ? 'replaceState' : 'pushState']({}, document.title, url);\n\n // If hash changes haven't been explicitly disabled, update the hash\n // fragment to store history.\n } else if (this._wantsHashChange) {\n this._updateHash(this.location, fragment, options.replace);\n if (this.iframe && fragment !== this.getHash(this.iframe.contentWindow)) {\n var iWindow = this.iframe.contentWindow;\n\n // Opening and closing the iframe tricks IE7 and earlier to push a\n // history entry on hash-tag change. When replace is true, we don't\n // want this.\n if (!options.replace) {\n iWindow.document.open();\n iWindow.document.close();\n }\n\n this._updateHash(iWindow.location, fragment, options.replace);\n }\n\n // If you've told us that you explicitly don't want fallback hashchange-\n // based history, then `navigate` becomes a page refresh.\n } else {\n return this.location.assign(url);\n }\n if (options.trigger) return this.loadUrl(fragment);\n },\n\n // Update the hash location, either replacing the current entry, or adding\n // a new one to the browser history.\n _updateHash: function(location, fragment, replace) {\n if (replace) {\n var href = location.href.replace(/(javascript:|#).*$/, '');\n location.replace(href + '#' + fragment);\n } else {\n // Some browsers require that `hash` contains a leading #.\n location.hash = '#' + fragment;\n }\n }\n\n });\n\n // Create the default Backbone.history.\n Backbone.history = new History;\n\n // Helpers\n // -------\n\n // Helper function to correctly set up the prototype chain for subclasses.\n // Similar to `goog.inherits`, but uses a hash of prototype properties and\n // class properties to be extended.\n var extend = function(protoProps, staticProps) {\n var parent = this;\n var child;\n\n // The constructor function for the new subclass is either defined by you\n // (the \"constructor\" property in your `extend` definition), or defaulted\n // by us to simply call the parent constructor.\n if (protoProps && _.has(protoProps, 'constructor')) {\n child = protoProps.constructor;\n } else {\n child = function(){ return parent.apply(this, arguments); };\n }\n\n // Add static properties to the constructor function, if supplied.\n _.extend(child, parent, staticProps);\n\n // Set the prototype chain to inherit from `parent`, without calling\n // `parent`'s constructor function and add the prototype properties.\n child.prototype = _.create(parent.prototype, protoProps);\n child.prototype.constructor = child;\n\n // Set a convenience property in case the parent's prototype is needed\n // later.\n child.__super__ = parent.prototype;\n\n return child;\n };\n\n // Set up inheritance for the model, collection, router, view and history.\n Model.extend = Collection.extend = Router.extend = View.extend = History.extend = extend;\n\n // Throw an error when a URL is needed, and none is supplied.\n var urlError = function() {\n throw new Error('A \"url\" property or function must be specified');\n };\n\n // Wrap an optional error callback with a fallback error event.\n var wrapError = function(model, options) {\n var error = options.error;\n options.error = function(resp) {\n if (error) error.call(options.context, model, resp, options);\n model.trigger('error', model, resp, options);\n };\n };\n\n return Backbone;\n});\n","function _defineProperty(obj, key, value) {\n if (key in obj) {\n Object.defineProperty(obj, key, {\n value: value,\n enumerable: true,\n configurable: true,\n writable: true\n });\n } else {\n obj[key] = value;\n }\n\n return obj;\n}\n\nmodule.exports = _defineProperty;","import { keys, isUndefined, isElement } from 'underscore';\n\nconst elProt = window.Element.prototype;\nconst matches =\n elProt.matches ||\n elProt.webkitMatchesSelector ||\n elProt.mozMatchesSelector ||\n elProt.msMatchesSelector;\n\n/**\n * Returns shallow diff between 2 objects\n * @param {Object} objOrig\n * @param {Objec} objNew\n * @return {Object}\n * @example\n * var a = {foo: 'bar', baz: 1, faz: 'sop'};\n * var b = {foo: 'bar', baz: 2, bar: ''};\n * shallowDiff(a, b);\n * // -> {baz: 2, faz: null, bar: ''};\n */\nconst shallowDiff = (objOrig, objNew) => {\n const result = {};\n const keysNew = keys(objNew);\n\n for (let prop in objOrig) {\n if (objOrig.hasOwnProperty(prop)) {\n const origValue = objOrig[prop];\n const newValue = objNew[prop];\n\n if (keysNew.indexOf(prop) >= 0) {\n if (origValue !== newValue) {\n result[prop] = newValue;\n }\n } else {\n result[prop] = null;\n }\n }\n }\n\n for (let prop in objNew) {\n if (objNew.hasOwnProperty(prop)) {\n if (isUndefined(objOrig[prop])) {\n result[prop] = objNew[prop];\n }\n }\n }\n\n return result;\n};\n\nconst on = (el, ev, fn) => {\n ev = ev.split(/\\s+/);\n el = el instanceof Array ? el : [el];\n\n for (let i = 0; i < ev.length; ++i) {\n el.forEach(elem => elem.addEventListener(ev[i], fn));\n }\n};\n\nconst off = (el, ev, fn) => {\n ev = ev.split(/\\s+/);\n el = el instanceof Array ? el : [el];\n\n for (let i = 0; i < ev.length; ++i) {\n el.forEach(elem => elem.removeEventListener(ev[i], fn));\n }\n};\n\nconst getUnitFromValue = value => {\n return value.replace(parseFloat(value), '');\n};\n\nconst upFirst = value => value[0].toUpperCase() + value.toLowerCase().slice(1);\n\nconst camelCase = value => {\n const values = value.split('-').filter(String);\n return values[0].toLowerCase() + values.slice(1).map(upFirst);\n};\n\nconst normalizeFloat = (value, step = 1, valueDef = 0) => {\n let stepDecimals = 0;\n if (isNaN(value)) return valueDef;\n value = parseFloat(value);\n\n if (Math.floor(value) !== value) {\n const side = step.toString().split('.')[1];\n stepDecimals = side ? side.length : 0;\n }\n\n return stepDecimals ? parseFloat(value.toFixed(stepDecimals)) : value;\n};\n\nconst hasDnd = em => {\n return (\n 'draggable' in document.createElement('i') &&\n (em ? em.get('Config').nativeDnD : 1)\n );\n};\n\n/**\n * Ensure to fetch the element from the input argument\n * @param {HTMLElement|Component} el Component or HTML element\n * @return {HTMLElement}\n */\nconst getElement = el => {\n if (isElement(el) || isTextNode(el)) {\n return el;\n } else if (el && el.getEl) {\n return el.getEl();\n }\n};\n\n/**\n * Check if element is a text node\n * @param {HTMLElement} el\n * @return {Boolean}\n */\nconst isTextNode = el => el && el.nodeType === 3;\n\n/**\n * Check if element is a comment node\n * @param {HTMLElement} el\n * @return {Boolean}\n */\nexport const isCommentNode = el => el && el.nodeType === 8;\n\n/**\n * Check if element is a comment node\n * @param {HTMLElement} el\n * @return {Boolean}\n */\nexport const isTaggableNode = el => el && !isTextNode(el) && !isCommentNode(el);\n\n/**\n * Ensure to fetch the model from the input argument\n * @param {HTMLElement|Component} el Component or HTML element\n * @return {Component}\n */\nconst getModel = (el, $) => {\n let model = el;\n isElement(el) && (model = $(el).data('model'));\n return model;\n};\n\nconst getElRect = el => {\n const def = {\n top: 0,\n left: 0,\n width: 0,\n height: 0\n };\n if (!el) return def;\n let rectText;\n\n if (isTextNode(el)) {\n const range = document.createRange();\n range.selectNode(el);\n rectText = range.getBoundingClientRect();\n range.detach();\n }\n\n return (\n rectText || (el.getBoundingClientRect ? el.getBoundingClientRect() : def)\n );\n};\n\n/**\n * Get cross-device pointer event\n * @param {Event} ev\n * @return {Event}\n */\nconst getPointerEvent = ev =>\n ev.touches && ev.touches[0] ? ev.touches[0] : ev;\n\n/**\n * Get cross-browser keycode\n * @param {Event} ev\n * @return {Number}\n */\nconst getKeyCode = ev => ev.which || ev.keyCode;\nconst getKeyChar = ev => String.fromCharCode(getKeyCode(ev));\nconst isEscKey = ev => getKeyCode(ev) === 27;\n\nconst capitalize = str => str.charAt(0).toUpperCase() + str.substring(1);\n\nexport {\n on,\n off,\n hasDnd,\n upFirst,\n matches,\n getModel,\n getElRect,\n camelCase,\n isTextNode,\n getKeyCode,\n getKeyChar,\n isEscKey,\n getElement,\n shallowDiff,\n normalizeFloat,\n getPointerEvent,\n getUnitFromValue,\n capitalize\n};\n","import Backbone from 'backbone';\nimport { isUndefined } from 'underscore';\n\nexport default Backbone.Model.extend({\n defaults: {\n type: 'text', // text, number, range, select\n label: '',\n name: '',\n min: '',\n max: '',\n unit: '',\n step: 1,\n value: '',\n target: '',\n default: '',\n placeholder: '',\n changeProp: 0,\n options: []\n },\n\n initialize() {\n const target = this.get('target');\n const name = this.get('name');\n const changeProp = this.get('changeProp');\n\n if (target) {\n this.target = target;\n this.unset('target');\n const targetEvent = changeProp\n ? `change:${name}`\n : `change:attributes:${name}`;\n this.listenTo(target, targetEvent, this.targetUpdated);\n }\n },\n\n /**\n * Return all the propeties\n * @returns {Object}\n */\n props() {\n return this.attributes;\n },\n\n targetUpdated() {\n const value = this.getTargetValue();\n this.set({ value }, { fromTarget: 1 });\n },\n\n getTargetValue() {\n const name = this.get('name');\n const target = this.target;\n let value;\n\n if (this.get('changeProp')) {\n value = target.get(name);\n } else {\n value = target.getAttributes()[name];\n }\n\n return !isUndefined(value) ? value : '';\n },\n\n setTargetValue(value, opts = {}) {\n const target = this.target;\n const name = this.get('name');\n if (isUndefined(value)) return;\n\n if (this.get('changeProp')) {\n target.set(name, value, opts);\n } else {\n const attrs = { ...target.get('attributes') };\n attrs[name] = value;\n target.set('attributes', attrs, opts);\n }\n },\n\n setValueFromInput(value, final = 1, opts = {}) {\n const toSet = { value };\n this.set(toSet, { ...opts, avoidStore: 1 });\n\n // Have to trigger the change\n if (final) {\n this.set('value', '', opts);\n this.set(toSet, opts);\n }\n },\n\n /**\n * Get the initial value of the trait\n * @return {string}\n */\n getInitValue() {\n const target = this.target;\n const name = this.get('name');\n let value;\n\n if (target) {\n const attrs = target.get('attributes');\n value = this.get('changeProp') ? target.get(name) : attrs[name];\n }\n\n return value || this.get('value') || this.get('default');\n }\n});\n","import Backbone from 'backbone';\nimport { isString, isArray } from 'underscore';\nimport Trait from './Trait';\nimport TraitFactory from './TraitFactory';\n\nexport default Backbone.Collection.extend({\n model: Trait,\n\n initialize(coll, options = {}) {\n this.em = options.em || '';\n this.listenTo(this, 'add', this.handleAdd);\n this.listenTo(this, 'reset', this.handleReset);\n },\n\n handleReset(coll, { previousModels = [] } = {}) {\n previousModels.forEach(model => model.trigger('remove'));\n },\n\n handleAdd(model) {\n const target = this.target;\n\n if (target) {\n model.target = target;\n }\n },\n\n setTarget(target) {\n this.target = target;\n },\n\n add(models, opt) {\n const em = this.em;\n\n // Use TraitFactory if necessary\n if (isString(models) || isArray(models)) {\n const tm = em && em.get && em.get('TraitManager');\n const tmOpts = tm && tm.getConfig();\n const tf = TraitFactory(tmOpts);\n\n if (isString(models)) {\n models = [models];\n }\n\n for (var i = 0, len = models.length; i < len; i++) {\n const str = models[i];\n const model = isString(str) ? tf.build(str)[0] : str;\n model.target = this.target;\n models[i] = model;\n }\n }\n\n return Backbone.Collection.prototype.add.apply(this, [models, opt]);\n }\n});\n","export default (config = {}) => ({\n /**\n * Build props object by their name\n * @param {Array|string} props Array of properties name\n * @return {Array}\n */\n build(props) {\n var objs = [];\n\n if (typeof props === 'string') props = [props];\n\n for (var i = 0; i < props.length; i++) {\n var obj = {};\n var prop = props[i];\n obj.name = prop;\n\n // Define type\n switch (prop) {\n case 'target':\n obj.type = 'select';\n break;\n }\n\n // Define placeholder\n switch (prop) {\n case 'title':\n case 'alt':\n case 'id':\n obj.placeholder = config.labelPlhText;\n break;\n case 'href':\n obj.placeholder = config.labelPlhHref;\n break;\n }\n\n // Define options\n switch (prop) {\n case 'target':\n obj.options = config.optionsTarget;\n break;\n }\n\n objs.push(obj);\n }\n\n return objs;\n }\n});\n","import {\n isUndefined,\n isFunction,\n isObject,\n isArray,\n isEmpty,\n isBoolean,\n has,\n isString,\n forEach,\n result,\n keys\n} from 'underscore';\nimport { shallowDiff } from 'utils/mixins';\nimport Styleable from 'domain_abstract/model/Styleable';\nimport Backbone from 'backbone';\nimport Components from './Components';\nimport Selector from 'selector_manager/model/Selector';\nimport Selectors from 'selector_manager/model/Selectors';\nimport Traits from 'trait_manager/model/Traits';\n\nconst componentList = {};\nlet componentIndex = 0;\n\nconst escapeRegExp = str => {\n return str.replace(/[|\\\\{}()[\\]^$+*?.]/g, '\\\\$&');\n};\n\nconst avoidInline = em => em && em.getConfig('avoidInlineStyle');\n\n/**\n * The Component object represents a single node of our template structure, so when you update its properties the changes are\n * immediately reflected on the canvas and in the code to export (indeed, when you ask to export the code we just go through all\n * the tree of nodes).\n * An example on how to update properties:\n * ```js\n * component.set({\n * tagName: 'span',\n * attributes: { ... },\n * removable: false,\n * });\n * component.get('tagName');\n * // -> 'span'\n * ```\n *\n * @typedef Component\n * @property {String} [type=''] Component type, eg. `text`, `image`, `video`, etc.\n * @property {String} [tagName='div'] HTML tag of the component, eg. `span`. Default: `div`\n * @property {Object} [attributes={}] Key-value object of the component's attributes, eg. `{ title: 'Hello' }` Default: `{}`\n * @property {String} [name=''] Name of the component. Will be used, for example, in Layers and badges\n * @property {Boolean} [removable=true] When `true` the component is removable from the canvas, default: `true`\n * @property {Boolean|String} [draggable=true] Indicates if it's possible to drag the component inside others.\n * You can also specify a query string to indentify elements,\n * eg. `'.some-class[title=Hello], [data-gjs-type=column]'` means you can drag the component only inside elements\n * containing `some-class` class and `Hello` title, and `column` components. Default: `true`\n * @property {Boolean|String} [droppable=true] Indicates if it's possible to drop other components inside. You can use\n * a query string as with `draggable`. Default: `true`\n * @property {Boolean} [badgable=true] Set to false if you don't want to see the badge (with the name) over the component. Default: `true`\n * @property {Boolean|Array} [stylable=true] True if it's possible to style the component.\n * You can also indicate an array of CSS properties which is possible to style, eg. `['color', 'width']`, all other properties\n * will be hidden from the style manager. Default: `true`\n * @property {Array} [stylable-require=[]] Indicate an array of style properties to show up which has been marked as `toRequire`. Default: `[]`\n * @property {Array} [unstylable=[]] Indicate an array of style properties which should be hidden from the style manager. Default: `[]`\n * @property {Array} [style-signature=''] This option comes handy when you need to remove or export strictly component-specific rules. Be default, if this option is not empty, the editor will remove rules when there are no components, of that type, in the canvas. Eg. '['.navbar', '[navbar-']'. Default: `''`\n * @property {Boolean} [highlightable=true] It can be highlighted with 'dotted' borders if true. Default: `true`\n * @property {Boolean} [copyable=true] True if it's possible to clone the component. Default: `true`\n * @property {Boolean} [resizable=false] Indicates if it's possible to resize the component. It's also possible to pass an object as [options for the Resizer](https://github.com/artf/grapesjs/blob/master/src/utils/Resizer.js). Default: `false`\n * @property {Boolean} [editable=false] Allow to edit the content of the component (used on Text components). Default: `false`\n * @property {Boolean} [layerable=true] Set to `false` if you need to hide the component inside Layers. Default: `true`\n * @property {Boolean} [selectable=true] Allow component to be selected when clicked. Default: `true`\n * @property {Boolean} [hoverable=true] Shows a highlight outline when hovering on the element if `true`. Default: `true`\n * @property {Boolean} [void=false] This property is used by the HTML exporter as void elements don't have closing tags, eg. `
`, `
`, etc. Default: `false`\n * @property {String} [content=''] Content of the component (not escaped) which will be appended before children rendering. Default: `''`\n * @property {String} [icon=''] Component's icon, this string will be inserted before the name (in Layers and badge), eg. it can be an HTML string ''. Default: `''`\n * @property {String|Function} [script=''] Component's javascript. More about it [here](/modules/Components-js.html). Default: `''`\n * @property {String|Function} [script-export=''] You can specify javascript available only in export functions (eg. when you get the HTML).\n * If this property is defined it will overwrite the `script` one (in export functions). Default: `''`\n * @property {Array} [traits=''] Component's traits. More about it [here](/modules/Traits.html). Default: `['id', 'title']`\n * @property {Array} [propagate=[]] Indicates an array of properties which will be inhereted by all NEW appended children.\n * For example if you create a component likes this: `{ removable: false, draggable: false, propagate: ['removable', 'draggable'] }`\n * and append some new component inside, the new added component will get the exact same properties indicated in the `propagate` array (and the `propagate` property itself). Default: `[]`\n * @property {Array} [toolbar=null] Set an array of items to show up inside the toolbar when the component is selected (move, clone, delete).\n * Eg. `toolbar: [ { attributes: {class: 'fa fa-arrows'}, command: 'tlb-move' }, ... ]`.\n * By default, when `toolbar` property is falsy the editor will add automatically commands like `move`, `delete`, etc. based on its properties.\n * @property {Collection} [components=null] Children components. Default: `null`\n */\nconst Component = Backbone.Model.extend(Styleable).extend(\n {\n defaults: {\n tagName: 'div',\n type: '',\n name: '',\n removable: true,\n draggable: true,\n droppable: true,\n badgable: true,\n stylable: true,\n 'stylable-require': '',\n 'style-signature': '',\n unstylable: '',\n highlightable: true,\n copyable: true,\n resizable: false,\n editable: false,\n layerable: true,\n selectable: true,\n hoverable: true,\n void: false,\n state: '', // Indicates if the component is in some CSS state like ':hover', ':active', etc.\n status: '', // State, eg. 'selected'\n content: '',\n icon: '',\n style: '', // Component related style\n classes: '', // Array of classes\n script: '',\n 'script-export': '',\n attributes: '',\n traits: ['id', 'title'],\n propagate: '',\n dmode: '',\n toolbar: null\n },\n\n /**\n * Hook method, called once the model is created\n */\n init() {},\n\n /**\n * Hook method, called when the model has been updated (eg. updated some model's property)\n * @param {String} property Property name, if triggered after some property update\n * @param {*} value Property value, if triggered after some property update\n * @param {*} previous Property previous value, if triggered after some property update\n */\n updated(property, value, previous) {},\n\n /**\n * Hook method, called once the model has been removed\n */\n removed() {},\n\n initialize(props = {}, opt = {}) {\n const em = opt.em;\n\n // Propagate properties from parent if indicated\n const parent = this.parent();\n const parentAttr = parent && parent.attributes;\n\n if (parentAttr && parentAttr.propagate) {\n let newAttr = {};\n const toPropagate = parentAttr.propagate;\n toPropagate.forEach(prop => (newAttr[prop] = parent.get(prop)));\n newAttr.propagate = toPropagate;\n newAttr = { ...newAttr, ...props };\n this.set(newAttr);\n }\n\n const propagate = this.get('propagate');\n propagate &&\n this.set('propagate', isArray(propagate) ? propagate : [propagate]);\n\n // Check void elements\n if (\n opt &&\n opt.config &&\n opt.config.voidElements.indexOf(this.get('tagName')) >= 0\n ) {\n this.set('void', true);\n }\n\n opt.em = em;\n this.opt = opt;\n this.em = em;\n this.config = opt.config || {};\n this.set('attributes', {\n ...(this.defaults.attributes || {}),\n ...(this.get('attributes') || {})\n });\n this.ccid = Component.createId(this);\n this.initClasses();\n this.initTraits();\n this.initComponents();\n this.initToolbar();\n this.listenTo(this, 'change:script', this.scriptUpdated);\n this.listenTo(this, 'change:tagName', this.tagUpdated);\n this.listenTo(this, 'change:attributes', this.attrUpdated);\n this.listenTo(this, 'change:attributes:id', this._idUpdated);\n this.set('status', '');\n\n // Register global updates for collection properties\n ['classes', 'traits', 'components'].forEach(name => {\n const events = `add remove ${name !== 'components' ? 'change' : ''}`;\n this.listenTo(this.get(name), events.trim(), (...args) =>\n this.emitUpdate(name, ...args)\n );\n });\n\n if (!opt.temporary) {\n this.init();\n em && em.trigger('component:create', this);\n }\n },\n\n /**\n * Check component's type\n * @param {string} type Component type\n * @return {Boolean}\n * @example\n * component.is('image')\n * // -> false\n */\n is(type) {\n return !!(this.get('type') == type);\n },\n\n /**\n * Return all the propeties\n * @returns {Object}\n */\n props() {\n return this.attributes;\n },\n\n /**\n * Get the index of the component in the parent collection.\n * @return {Number}\n */\n index() {\n const { collection } = this;\n return collection && collection.indexOf(this);\n },\n\n /**\n * Change the drag mode of the component.\n * To get more about this feature read: https://github.com/artf/grapesjs/issues/1936\n * @param {String} value Drag mode, options: 'absolute' | 'translate'\n * @returns {this}\n */\n setDragMode(value) {\n return this.set('dmode', value);\n },\n\n /**\n * Find inner components by query string.\n * **ATTENTION**: this method works only with already rendered component\n * @param {String} query Query string\n * @return {Array} Array of components\n * @example\n * component.find('div > .class');\n * // -> [Component, Component, ...]\n */\n find(query) {\n const result = [];\n\n this.view.$el.find(query).each((el, i, $els) => {\n const $el = $els.eq(i);\n const model = $el.data('model');\n model && result.push(model);\n });\n\n return result;\n },\n\n /**\n * Find all inner components by component id.\n * The advantage of this method over `find` is that you can use it\n * also before rendering the component\n * @param {String} id Component id\n * @returns {Array}\n * @example\n * const allImages = component.findType('image');\n * console.log(allImages[0]) // prints the first found component\n */\n findType(id) {\n const result = [];\n const find = components =>\n components.forEach(item => {\n item.is(id) && result.push(item);\n find(item.components());\n });\n find(this.components());\n return result;\n },\n\n /**\n * Find the closest parent component by query string.\n * **ATTENTION**: this method works only with already rendered component\n * @param {string} query Query string\n * @return {Component}\n * @example\n * component.closest('div.some-class');\n * // -> Component\n */\n closest(query) {\n const result = this.view.$el.closest(query);\n return result.length && result.data('model');\n },\n\n /**\n * Once the tag is updated I have to remove the node and replace it\n * @private\n */\n tagUpdated() {\n const coll = this.collection;\n const at = coll.indexOf(this);\n coll.remove(this);\n coll.add(this, { at });\n },\n\n /**\n * Replace a component with another one\n * @param {String|Component} el Component or HTML string\n * @return {Component|Array} New added component/s\n * @example\n * component.replaceWith('
Some new content
');\n * // -> Component\n */\n replaceWith(el) {\n const coll = this.collection;\n const at = coll.indexOf(this);\n coll.remove(this);\n return coll.add(el, { at });\n },\n\n /**\n * Emit changes for each updated attribute\n * @private\n */\n attrUpdated(m, v, opts = {}) {\n const attrs = this.get('attributes');\n\n // Handle classes\n const classes = attrs.class;\n classes && this.setClass(classes);\n delete attrs.class;\n\n // Handle style\n const style = attrs.style;\n style && this.setStyle(style);\n delete attrs.style;\n\n const attrPrev = { ...this.previous('attributes') };\n const diff = shallowDiff(attrPrev, this.get('attributes'));\n keys(diff).forEach(pr =>\n this.trigger(`change:attributes:${pr}`, this, diff[pr], opts)\n );\n },\n\n /**\n * Update attributes of the component\n * @param {Object} attrs Key value attributes\n * @return {this}\n * @example\n * component.setAttributes({ id: 'test', 'data-key': 'value' });\n */\n setAttributes(attrs, opts = {}) {\n this.set('attributes', { ...attrs }, opts);\n return this;\n },\n\n /**\n * Add attributes to the component\n * @param {Object} attrs Key value attributes\n * @return {this}\n * @example\n * component.addAttributes({ 'data-key': 'value' });\n */\n addAttributes(attrs) {\n const newAttrs = { ...this.getAttributes(), ...attrs };\n this.setAttributes(newAttrs);\n\n return this;\n },\n\n /**\n * Get the style of the component\n * @return {Object}\n */\n getStyle() {\n const em = this.em;\n\n if (em && em.getConfig('avoidInlineStyle')) {\n const state = this.get('state');\n const cc = em.get('CssComposer');\n const rule = cc.getIdRule(this.getId(), { state });\n this.rule = rule;\n\n if (rule) {\n return rule.getStyle();\n }\n }\n\n return Styleable.getStyle.call(this);\n },\n\n /**\n * Set the style on the component\n * @param {Object} prop Key value style object\n * @return {Object}\n * @example\n * component.setStyle({ color: 'red' });\n */\n setStyle(prop = {}, opts = {}) {\n const em = this.em;\n const { opt } = this;\n\n if (em && em.getConfig('avoidInlineStyle') && !opt.temporary) {\n const style = this.get('style') || {};\n prop = isString(prop) ? this.parseStyle(prop) : prop;\n prop = { ...prop, ...style };\n const state = this.get('state');\n const cc = em.get('CssComposer');\n const propOrig = this.getStyle();\n this.rule = cc.setIdRule(this.getId(), prop, { ...opts, state });\n const diff = shallowDiff(propOrig, prop);\n this.set('style', {}, { silent: 1 });\n keys(diff).forEach(pr => this.trigger(`change:style:${pr}`));\n } else {\n prop = Styleable.setStyle.apply(this, arguments);\n }\n\n return prop;\n },\n\n /**\n * Return all component's attributes\n * @return {Object}\n */\n getAttributes() {\n const { em } = this;\n const classes = [];\n const attributes = { ...this.get('attributes') };\n const sm = em && em.get('SelectorManager');\n const id = this.getId();\n\n // Add classes\n this.get('classes').forEach(cls =>\n classes.push(isString(cls) ? cls : cls.get('name'))\n );\n classes.length && (attributes.class = classes.join(' '));\n\n // Check if we need an ID on the component\n if (!has(attributes, 'id')) {\n let hasStyle;\n\n // If we don't rely on inline styling we have to check\n // for the ID selector\n if (avoidInline(em)) {\n hasStyle = sm && sm.get(id, sm.Selector.TYPE_ID);\n } else if (!isEmpty(this.getStyle())) {\n hasStyle = 1;\n }\n\n if (hasStyle) {\n attributes.id = this.getId();\n }\n }\n\n return attributes;\n },\n\n /**\n * Add classes\n * @param {Array|String} classes Array or string of classes\n * @return {Array} Array of added selectors\n * @example\n * model.addClass('class1');\n * model.addClass('class1 class2');\n * model.addClass(['class1', 'class2']);\n * // -> [SelectorObject, ...]\n */\n addClass(classes) {\n const added = this.em.get('SelectorManager').addClass(classes);\n return this.get('classes').add(added);\n },\n\n /**\n * Set classes (resets current collection)\n * @param {Array|String} classes Array or string of classes\n * @return {Array} Array of added selectors\n * @example\n * model.setClass('class1');\n * model.setClass('class1 class2');\n * model.setClass(['class1', 'class2']);\n * // -> [SelectorObject, ...]\n */\n setClass(classes) {\n this.get('classes').reset();\n return this.addClass(classes);\n },\n\n /**\n * Remove classes\n * @param {Array|String} classes Array or string of classes\n * @return {Array} Array of removed selectors\n * @example\n * model.removeClass('class1');\n * model.removeClass('class1 class2');\n * model.removeClass(['class1', 'class2']);\n * // -> [SelectorObject, ...]\n */\n removeClass(classes) {\n const removed = [];\n classes = isArray(classes) ? classes : [classes];\n const selectors = this.get('classes');\n const type = Selector.TYPE_CLASS;\n\n classes.forEach(classe => {\n const classes = classe.split(' ');\n classes.forEach(name => {\n const selector = selectors.where({ name, type })[0];\n selector && removed.push(selectors.remove(selector));\n });\n });\n\n return removed;\n },\n\n /**\n * Returns component's classes as an array of strings\n * @return {Array}\n */\n getClasses() {\n const attr = this.getAttributes();\n const classStr = attr.class;\n return classStr ? classStr.split(' ') : [];\n },\n\n initClasses() {\n const event = 'change:classes';\n const toListen = [this, event, this.initClasses];\n const cls = this.get('classes') || [];\n const clsArr = isString(cls) ? cls.split(' ') : cls;\n this.stopListening(...toListen);\n const classes = this.normalizeClasses(clsArr);\n const selectors = new Selectors([]);\n this.set('classes', selectors);\n selectors.add(classes);\n this.listenTo(...toListen);\n return this;\n },\n\n initComponents() {\n const event = 'change:components';\n const toListen = [this, event, this.initComponents];\n this.stopListening(...toListen);\n // Have to add components after the init, otherwise the parent\n // is not visible\n const comps = new Components(null, this.opt);\n comps.parent = this;\n const components = this.get('components');\n const addChild = !this.opt.avoidChildren;\n this.set('components', comps);\n addChild &&\n comps.add(isFunction(components) ? components(this) : components);\n this.listenTo(...toListen);\n return this;\n },\n\n initTraits(changed) {\n const { em } = this;\n const event = 'change:traits';\n const toListen = [this, event, this.initTraits];\n this.stopListening(...toListen);\n this.loadTraits();\n const attrs = { ...this.get('attributes') };\n const traits = this.get('traits');\n traits.each(trait => {\n if (!trait.get('changeProp')) {\n const name = trait.get('name');\n const value = trait.getInitValue();\n if (name && value) attrs[name] = value;\n }\n });\n traits.length && this.set('attributes', attrs);\n this.listenTo(...toListen);\n changed && em && em.trigger('component:toggled');\n return this;\n },\n\n /**\n * Add new component children\n * @param {Component|String} components Component to add\n * @param {Object} [opts={}] Options, same as in `model.add()`(from backbone)\n * @return {Array} Array of appended components\n * @example\n * someComponent.get('components').length // -> 0\n * const videoComponent = someComponent.append('
')[0];\n * // This will add 2 components (`video` and `div`) to your `someComponent`\n * someComponent.get('components').length // -> 2\n * // You can pass components directly\n * otherComponent.append(otherComponent2);\n * otherComponent.append([otherComponent3, otherComponent4]);\n */\n append(components, opts = {}) {\n const result = this.components().add(components, opts);\n return isArray(result) ? result : [result];\n },\n\n /**\n * Set new collection if `components` are provided, otherwise the\n * current collection is returned\n * @param {Component|String} [components] Components to set\n * @return {Collection|Array}\n * @example\n * // Set new collection\n * component.components('
');\n * // Get current collection\n * const collection = component.components();\n * console.log(collection.length);\n * // -> 2\n */\n components(components) {\n const coll = this.get('components');\n\n if (isUndefined(components)) {\n return coll;\n } else {\n coll.reset();\n return components && this.append(components);\n }\n },\n\n /**\n * Get the parent component, if exists\n * @return {Component}\n * @example\n * component.parent();\n * // -> Component\n */\n parent() {\n const coll = this.collection;\n return coll && coll.parent;\n },\n\n /**\n * Script updated\n * @private\n */\n scriptUpdated() {\n this.set('scriptUpdated', 1);\n },\n\n /**\n * Init toolbar\n * @private\n */\n initToolbar() {\n const { em } = this;\n const model = this;\n const ppfx = (em && em.getConfig('stylePrefix')) || '';\n\n if (!model.get('toolbar')) {\n var tb = [];\n if (model.collection) {\n tb.push({\n attributes: { class: 'fa fa-arrow-up' },\n command: ed => ed.runCommand('core:component-exit', { force: 1 })\n });\n }\n if (model.get('draggable')) {\n tb.push({\n attributes: {\n class: `fa fa-arrows ${ppfx}no-touch-actions`,\n draggable: true\n },\n //events: hasDnd(this.em) ? { dragstart: 'execCommand' } : '',\n command: 'tlb-move'\n });\n }\n if (model.get('copyable')) {\n tb.push({\n attributes: { class: 'fa fa-clone' },\n command: 'tlb-clone'\n });\n }\n if (model.get('removable')) {\n tb.push({\n attributes: { class: 'fa fa-trash-o' },\n command: 'tlb-delete'\n });\n }\n model.set('toolbar', tb);\n }\n },\n\n /**\n * Load traits\n * @param {Array} traits\n * @private\n */\n loadTraits(traits, opts = {}) {\n traits = traits || this.get('traits');\n traits = isFunction(traits) ? traits(this) : traits;\n\n if (!(traits instanceof Traits)) {\n const trt = new Traits([], this.opt);\n trt.setTarget(this);\n\n if (traits.length) {\n traits.forEach(tr => tr.attributes && delete tr.attributes.value);\n trt.add(traits);\n }\n\n this.set('traits', trt, opts);\n }\n\n return this;\n },\n\n /**\n * Get the trait by id/name\n * @param {String} id The `id` or `name` of the trait\n * @return {Trait} Trait model\n * @example\n * const traitTitle = component.getTrait('title');\n * traitTitle && traitTitle.set('label', 'New label');\n */\n getTrait(id) {\n return this.get('traits').filter(trait => {\n return trait.get('id') === id || trait.get('name') === id;\n })[0];\n },\n\n /**\n * Update a trait\n * @param {String} id The `id` or `name` of the trait\n * @param {Object} props Object with the props to update\n * @return {this}\n * @example\n * component.updateTrait('title', {\n * type: 'select',\n * options: [ 'Option 1', 'Option 2' ],\n * });\n */\n updateTrait(id, props) {\n const { em } = this;\n const trait = this.getTrait(id);\n trait && trait.set(props);\n em && em.trigger('component:toggled');\n return this;\n },\n\n /**\n * Get the trait position index by id/name. Useful in case you want to\n * replace some trait, at runtime, with something else.\n * @param {String} id The `id` or `name` of the trait\n * @return {Number} Index position of the current trait\n * @example\n * const traitTitle = component.getTraitIndex('title');\n * console.log(traitTitle); // 1\n */\n getTraitIndex(id) {\n const trait = this.getTrait(id);\n return trait ? this.get('traits').indexOf(trait) : trait;\n },\n\n /**\n * Remove trait/s by id/s.\n * @param {String|Array} id The `id`/`name` of the trait (or an array)\n * @return {Array} Array of removed traits\n * @example\n * component.removeTrait('title');\n * component.removeTrait(['title', 'id']);\n */\n removeTrait(id) {\n const { em } = this;\n const ids = isArray(id) ? id : [id];\n const toRemove = ids.map(id => this.getTrait(id));\n const removed = this.get('traits').remove(toRemove);\n em && em.trigger('component:toggled');\n return removed;\n },\n\n /**\n * Add trait/s by id/s.\n * @param {String|Object|Array} trait Trait to add (or an array of traits)\n * @param {Options} opts Options for the add\n * @return {Array} Array of added traits\n * @example\n * component.addTrait('title', { at: 1 }); // Add title trait (`at` option is the position index)\n * component.addTrait({\n * type: 'checkbox',\n * name: 'disabled',\n * });\n * component.addTrait(['title', {...}, ...]);\n */\n addTrait(trait, opts = {}) {\n const { em } = this;\n const added = this.get('traits').add(trait, opts);\n em && em.trigger('component:toggled');\n return added;\n },\n\n /**\n * Normalize input classes from array to array of objects\n * @param {Array} arr\n * @return {Array}\n * @private\n */\n normalizeClasses(arr) {\n var res = [];\n const em = this.em;\n\n if (!em) return;\n\n var clm = em.get('SelectorManager');\n if (!clm) return;\n\n arr.forEach(val => {\n var name = '';\n\n if (typeof val === 'string') name = val;\n else name = val.name;\n\n var model = clm.add(name);\n res.push(model);\n });\n return res;\n },\n\n /**\n * Override original clone method\n * @private\n */\n clone() {\n const em = this.em;\n const style = this.getStyle();\n const attr = { ...this.attributes };\n const opts = { ...this.opt };\n attr.attributes = { ...attr.attributes };\n delete attr.attributes.id;\n attr.components = [];\n attr.classes = [];\n attr.traits = [];\n\n this.get('components').each((md, i) => {\n attr.components[i] = md.clone();\n });\n this.get('traits').each((md, i) => {\n attr.traits[i] = md.clone();\n });\n this.get('classes').each((md, i) => {\n attr.classes[i] = md.get('name');\n });\n\n attr.status = '';\n attr.view = '';\n opts.collection = null;\n\n if (em && em.getConfig('avoidInlineStyle') && !isEmpty(style)) {\n attr.style = style;\n }\n\n const cloned = new this.constructor(attr, opts);\n const event = 'component:clone';\n em && em.trigger(event, cloned);\n this.trigger(event, cloned);\n\n return cloned;\n },\n\n /**\n * Get the name of the component\n * @return {String}\n * */\n getName() {\n let customName = this.get('name') || this.get('custom-name');\n let tag = this.get('tagName');\n tag = tag == 'div' ? 'box' : tag;\n let name = this.get('type') || tag;\n name = name.charAt(0).toUpperCase() + name.slice(1);\n return customName || name;\n },\n\n /**\n * Get the icon string\n * @return {String}\n */\n getIcon() {\n let icon = this.get('icon');\n return icon ? icon + ' ' : '';\n },\n\n /**\n * Return HTML string of the component\n * @param {Object} [opts={}] Options\n * @param {Object|Function} [opts.attributes=null] You can pass an object of custom attributes to replace\n * with the current one or you can even pass a function to generate attributes dynamically\n * @return {String} HTML string\n * @example\n * // Simple HTML return\n * component.set({ tagName: 'span' });\n * component.setAttributes({ title: 'Hello' });\n * component.toHTML();\n * // -> \n *\n * // Custom attributes\n * component.toHTML({ attributes: { 'data-test': 'Hello' } });\n * // -> \n *\n * // Custom dynamic attributes\n * component.toHTML({\n * attributes(component, attributes) {\n * if (component.get('tagName') == 'span') {\n * attributes.title = 'Custom attribute';\n * }\n * return attributes;\n * },\n * });\n * // -> \n */\n toHTML(opts = {}) {\n const model = this;\n const attrs = [];\n const classes = [];\n const tag = model.get('tagName');\n const sTag = model.get('void');\n const customAttr = opts.attributes;\n let attributes = this.getAttrToHTML();\n\n // Get custom attributes if requested\n if (customAttr) {\n if (isFunction(customAttr)) {\n attributes = customAttr(model, attributes) || {};\n } else if (isObject(customAttr)) {\n attributes = customAttr;\n }\n }\n\n for (let attr in attributes) {\n const val = attributes[attr];\n const value = isString(val) ? val.replace(/\"/g, '"') : val;\n\n if (!isUndefined(value)) {\n if (isBoolean(value)) {\n value && attrs.push(attr);\n } else {\n attrs.push(`${attr}=\"${value}\"`);\n }\n }\n }\n\n let attrString = attrs.length ? ` ${attrs.join(' ')}` : '';\n let code = `<${tag}${attrString}${sTag ? '/' : ''}>${model.get(\n 'content'\n )}`;\n model.get('components').each(comp => (code += comp.toHTML(opts)));\n !sTag && (code += ``);\n\n return code;\n },\n\n /**\n * Returns object of attributes for HTML\n * @return {Object}\n * @private\n */\n getAttrToHTML() {\n var attr = this.getAttributes();\n delete attr.style;\n return attr;\n },\n\n /**\n * Return a shallow copy of the model's attributes for JSON\n * stringification.\n * @return {Object}\n * @private\n */\n toJSON(...args) {\n const obj = Backbone.Model.prototype.toJSON.apply(this, args);\n obj.attributes = this.getAttributes();\n delete obj.attributes.class;\n delete obj.toolbar;\n delete obj.traits;\n\n if (this.em.getConfig('avoidDefaults')) {\n const defaults = result(this, 'defaults');\n\n forEach(defaults, (value, key) => {\n if (['type', 'content'].indexOf(key) === -1 && obj[key] === value) {\n delete obj[key];\n }\n });\n\n if (isEmpty(obj.type)) {\n delete obj.type;\n }\n\n forEach(['attributes', 'style'], prop => {\n if (isEmpty(defaults[prop]) && isEmpty(obj[prop])) {\n delete obj[prop];\n }\n });\n\n forEach(['classes', 'components'], prop => {\n if (isEmpty(defaults[prop]) && !obj[prop].length) {\n delete obj[prop];\n }\n });\n }\n\n return obj;\n },\n\n /**\n * Return the component id\n * @return {String}\n */\n getId() {\n let attrs = this.get('attributes') || {};\n return attrs.id || this.ccid || this.cid;\n },\n\n /**\n * Set new id on the component\n * @param {String} id\n * @return {this}\n */\n setId(id, opts) {\n const attrs = { ...this.get('attributes') };\n attrs.id = id;\n this.set('attributes', attrs, opts);\n return this;\n },\n\n /**\n * Get the DOM element of the component.\n * This works only if the component is already rendered\n * @return {HTMLElement}\n */\n getEl() {\n return this.view && this.view.el;\n },\n\n /**\n * Get the View of the component.\n * This works only if the component is already rendered\n * @return {ComponentView}\n */\n getView() {\n return this.view;\n },\n\n /**\n * Return script in string format, cleans 'function() {..' from scripts\n * if it's a function\n * @param {string|Function} script\n * @return {string}\n * @private\n */\n getScriptString(script) {\n var scr = script || this.get('script');\n\n if (!scr) {\n return scr;\n }\n\n // Need to convert script functions to strings\n if (typeof scr == 'function') {\n var scrStr = scr.toString().trim();\n scrStr = scrStr\n .replace(/^function[\\s\\w]*\\(\\)\\s?\\{/, '')\n .replace(/\\}$/, '');\n scr = scrStr.trim();\n }\n\n var config = this.em.getConfig();\n var tagVarStart = escapeRegExp(config.tagVarStart || '{[ ');\n var tagVarEnd = escapeRegExp(config.tagVarEnd || ' ]}');\n var reg = new RegExp(`${tagVarStart}([\\\\w\\\\d-]*)${tagVarEnd}`, 'g');\n scr = scr.replace(reg, (match, v) => {\n // If at least one match is found I have to track this change for a\n // better optimization inside JS generator\n this.scriptUpdated();\n const result = this.attributes[v] || '';\n return isArray(result) || typeof result == 'object'\n ? JSON.stringify(result)\n : result;\n });\n\n return scr;\n },\n\n emitUpdate(property, ...args) {\n const em = this.em;\n const event = 'component:update' + (property ? `:${property}` : '');\n property &&\n this.updated(\n property,\n property && this.get(property),\n property && this.previous(property),\n ...args\n );\n this.trigger(event, ...args);\n em && em.trigger(event, this, ...args);\n },\n\n /**\n * Execute callback function on itself and all inner components\n * @param {Function} clb Callback function, the model is passed as an argument\n * @return {this}\n * @example\n * component.onAll(component => {\n * // do something with component\n * })\n */\n onAll(clb) {\n if (isFunction(clb)) {\n clb(this);\n this.components().forEach(model => model.onAll(clb));\n }\n return this;\n },\n\n /**\n * Remove the component\n * @return {this}\n */\n remove() {\n const coll = this.collection;\n return coll && coll.remove(this);\n },\n\n /**\n * Reset id of the component and any of its style rule\n * @param {Object} [opts={}] Options\n * @return {this}\n * @private\n */\n resetId(opts = {}) {\n const { em } = this;\n const oldId = this.getId();\n if (!oldId) return;\n const newId = Component.createId(this);\n this.setId(newId);\n const rule = em && em.get('CssComposer').getIdRule(oldId);\n const selector = rule && rule.get('selectors').at(0);\n selector && selector.set('name', newId);\n return this;\n },\n\n _getStyleRule({ id } = {}) {\n const { em } = this;\n const idS = id || this.getId();\n return em && em.get('CssComposer').getIdRule(idS);\n },\n\n _getStyleSelector(opts) {\n const rule = this._getStyleRule(opts);\n return rule && rule.get('selectors').at(0);\n },\n\n _idUpdated(m, v, opts = {}) {\n if (opts.idUpdate) return;\n\n const { ccid } = this;\n const { id } = this.get('attributes') || {};\n const idPrev = (this.previous('attributes') || {}).id || ccid;\n const list = Component.getList(this);\n\n // If the ID already exists I need to rollback to the old one\n if (list[id]) {\n return this.setId(idPrev, { idUpdate: 1 });\n }\n\n // Remove the old ID reference and add the new one\n delete list[idPrev];\n list[id] = this;\n this.ccid = id;\n\n // Update the style selector name\n const selector = this._getStyleSelector({ id: idPrev });\n selector && selector.set({ name: id, label: id });\n }\n },\n {\n /**\n * Detect if the passed element is a valid component.\n * In case the element is valid an object abstracted\n * from the element will be returned\n * @param {HTMLElement}\n * @return {Object}\n * @private\n */\n isComponent(el) {\n return { tagName: el.tagName ? el.tagName.toLowerCase() : '' };\n },\n\n /**\n * Relying simply on the number of components becomes a problem when you\n * store and load them back, you might hit collisions with new components\n * @param {Model} model\n * @return {string}\n * @private\n */\n createId(model) {\n const list = Component.getList(model);\n let { id } = model.get('attributes');\n let nextId;\n\n if (id) {\n nextId = Component.getIncrementId(id, list);\n model.setId(nextId);\n } else {\n nextId = Component.getNewId(list);\n }\n\n list[nextId] = model;\n return nextId;\n },\n\n getNewId(list) {\n const count = Object.keys(list).length;\n // Testing 1000000 components with `+ 2` returns 0 collisions\n const ilen = count.toString().length + 2;\n const uid = (Math.random() + 1.1).toString(36).slice(-ilen);\n let newId = `i${uid}`;\n\n while (list[newId]) {\n newId = Component.getNewId(list);\n }\n\n return newId;\n },\n\n getIncrementId(id, list) {\n let counter = 1;\n let newId = id;\n\n while (list[newId]) {\n counter++;\n newId = `${id}-${counter}`;\n }\n\n return newId;\n },\n\n /**\n * The list of components is taken from the Components module.\n * Initially, the list, was set statically on the Component object but it was\n * not ok, as it was shared between multiple editor instances\n */\n getList(model) {\n const domc = model.opt && model.opt.domc;\n return domc ? domc.componentsById : {};\n },\n\n /**\n * This method checks, for each parsed component and style object\n * (are not Components/CSSRules yet), for duplicated id and fixes them\n * This method is used in Components.js just after the parsing\n */\n checkId(components, styles = [], list = {}) {\n const comps = isArray(components) ? components : [components];\n comps.forEach(comp => {\n const { attributes = {}, components } = comp;\n const { id } = attributes;\n\n // Check if we have collisions with current components\n if (id && list[id]) {\n const newId = Component.getIncrementId(id, list);\n attributes.id = newId;\n // Update passed styles\n isArray(styles) &&\n styles.forEach(style => {\n const { selectors } = style;\n selectors.forEach((sel, idx) => {\n if (sel === `#${id}`) selectors[idx] = `#${newId}`;\n });\n });\n }\n\n components && Component.checkId(components, styles, list);\n });\n }\n }\n);\n\nexport default Component;\n","import Backbone from 'backbone';\nimport { isArray, isEmpty, each, keys } from 'underscore';\nimport Components from '../model/Components';\nimport ComponentsView from './ComponentsView';\nimport Selectors from 'selector_manager/model/Selectors';\nimport { replaceWith } from 'utils/dom';\n\nexport default Backbone.View.extend({\n className() {\n return this.getClasses();\n },\n\n tagName() {\n return this.model.get('tagName');\n },\n\n initialize(opt = {}) {\n const model = this.model;\n const config = opt.config || {};\n const em = config.em;\n const modelOpt = model.opt || {};\n const { $el } = this;\n const { draggableComponents } = config;\n this.opts = opt;\n this.modelOpt = modelOpt;\n this.config = config;\n this.em = em || '';\n this.pfx = config.stylePrefix || '';\n this.ppfx = config.pStylePrefix || '';\n this.attr = model.get('attributes');\n this.classe = this.attr.class || [];\n this.listenTo(model, 'change:style', this.updateStyle);\n this.listenTo(model, 'change:attributes', this.renderAttributes);\n this.listenTo(model, 'change:highlightable', this.updateHighlight);\n this.listenTo(model, 'change:status', this.updateStatus);\n this.listenTo(model, 'change:state', this.updateState);\n this.listenTo(model, 'change:script', this.reset);\n this.listenTo(model, 'change:content', this.updateContent);\n this.listenTo(model, 'change', this.handleChange);\n this.listenTo(model, 'active', this.onActive);\n $el.data('model', model);\n model.view = this;\n this.initClasses();\n this.initComponents({ avoidRender: 1 });\n this.events = {\n ...this.events,\n ...(draggableComponents && { dragstart: 'handleDragStart' })\n };\n this.delegateEvents();\n !modelOpt.temporary && this.init(this._clbObj());\n },\n\n _clbObj() {\n const { em, model, el } = this;\n return {\n editor: em && em.getEditor(),\n model,\n el\n };\n },\n\n /**\n * Initialize callback\n */\n init() {},\n\n /**\n * Remove callback\n */\n removed() {},\n\n /**\n * Callback executed when the `active` event is triggered on component\n */\n onActive() {},\n\n remove() {\n Backbone.View.prototype.remove.apply(this, arguments);\n this.removed(this._clbObj());\n return this;\n },\n\n handleDragStart(event) {\n event.preventDefault();\n event.stopPropagation();\n this.em.get('Commands').run('tlb-move', {\n target: this.model,\n event\n });\n },\n\n initClasses() {\n const { model } = this;\n const event = 'change:classes';\n const classes = model.get('classes');\n\n if (classes instanceof Selectors) {\n this.stopListening(model, event, this.initClasses);\n this.listenTo(model, event, this.initClasses);\n this.listenTo(classes, 'add remove change', this.updateClasses);\n classes.length && this.importClasses();\n }\n },\n\n initComponents(opts = {}) {\n const { model, $el, childrenView } = this;\n const event = 'change:components';\n const comps = model.get('components');\n const toListen = [model, event, this.initComponents];\n\n if (comps instanceof Components) {\n $el.data('collection', comps);\n childrenView && childrenView.remove();\n this.stopListening(...toListen);\n !opts.avoidRender && this.renderChildren();\n this.listenTo(...toListen);\n }\n },\n\n /**\n * Handle any property change\n * @private\n */\n handleChange() {\n const model = this.model;\n model.emitUpdate();\n\n for (let prop in model.changed) {\n model.emitUpdate(prop);\n }\n },\n\n /**\n * Import, if possible, classes inside main container\n * @private\n * */\n importClasses() {\n var clm = this.config.em.get('SelectorManager');\n\n if (clm) {\n this.model.get('classes').each(m => {\n clm.add(m.get('name'));\n });\n }\n },\n\n /**\n * Fires on state update. If the state is not empty will add a helper class\n * @param {Event} e\n * @private\n * */\n updateState(e) {\n var cl = 'hc-state';\n var state = this.model.get('state');\n\n if (state) {\n this.$el.addClass(cl);\n } else {\n this.$el.removeClass(cl);\n }\n },\n\n /**\n * Update item on status change\n * @param {Event} e\n * @private\n * */\n updateStatus(opts = {}) {\n const em = this.em;\n const el = this.el;\n const status = this.model.get('status');\n const pfx = this.pfx;\n const ppfx = this.ppfx;\n const selectedCls = `${pfx}selected`;\n const selectedParentCls = `${selectedCls}-parent`;\n const freezedCls = `${ppfx}freezed`;\n const hoveredCls = `${ppfx}hovered`;\n const toRemove = [selectedCls, selectedParentCls, freezedCls, hoveredCls];\n this.$el.removeClass(toRemove.join(' '));\n var actualCls = el.getAttribute('class') || '';\n var cls = '';\n\n switch (status) {\n case 'selected':\n cls = `${actualCls} ${selectedCls}`;\n break;\n case 'selected-parent':\n cls = `${actualCls} ${selectedParentCls}`;\n break;\n case 'freezed':\n cls = `${actualCls} ${freezedCls}`;\n break;\n case 'freezed-selected':\n cls = `${actualCls} ${freezedCls} ${selectedCls}`;\n break;\n case 'hovered':\n cls = !opts.avoidHover ? `${actualCls} ${hoveredCls}` : '';\n break;\n }\n\n cls = cls.trim();\n cls && el.setAttribute('class', cls);\n },\n\n /**\n * Update highlight attribute\n * @private\n * */\n updateHighlight() {\n const hl = this.model.get('highlightable');\n this.setAttribute('data-highlightable', hl ? 1 : '');\n },\n\n /**\n * Update style attribute\n * @private\n * */\n updateStyle() {\n const em = this.em;\n const model = this.model;\n\n if (em && em.get('avoidInlineStyle')) {\n this.el.id = model.getId();\n const style = model.getStyle();\n !isEmpty(style) && model.setStyle(style);\n } else {\n this.setAttribute('style', model.styleToString());\n }\n },\n\n /**\n * Update classe attribute\n * @private\n * */\n updateClasses() {\n const str = this.model\n .get('classes')\n .pluck('name')\n .join(' ');\n this.setAttribute('class', str);\n\n // Regenerate status class\n this.updateStatus();\n },\n\n /**\n * Update single attribute\n * @param {[type]} name [description]\n * @param {[type]} value [description]\n */\n setAttribute(name, value) {\n const el = this.$el;\n value ? el.attr(name, value) : el.removeAttr(name);\n },\n\n /**\n * Get classes from attributes.\n * This method is called before initialize\n *\n * @return {Array}|null\n * @private\n * */\n getClasses() {\n return this.model.getClasses().join(' ');\n },\n\n /**\n * Update attributes\n * @private\n * */\n updateAttributes() {\n const attrs = [];\n const { model, $el, el, config } = this;\n const { highlightable, textable, type } = model.attributes;\n const { draggableComponents } = config;\n\n const defaultAttr = {\n 'data-gjs-type': type || 'default',\n ...(draggableComponents ? { draggable: true } : {}),\n ...(highlightable ? { 'data-highlightable': 1 } : {}),\n ...(textable\n ? {\n contenteditable: 'false',\n 'data-gjs-textable': 'true'\n }\n : {})\n };\n\n // Remove all current attributes\n each(el.attributes, attr => attrs.push(attr.nodeName));\n attrs.forEach(attr => $el.removeAttr(attr));\n const attr = {\n ...defaultAttr,\n ...model.getAttributes()\n };\n\n // Remove all `false` attributes\n keys(attr).forEach(key => attr[key] === false && delete attr[key]);\n\n $el.attr(attr);\n this.updateStyle();\n },\n\n /**\n * Update component content\n * @private\n * */\n updateContent() {\n this.getChildrenContainer().innerHTML = this.model.get('content');\n },\n\n /**\n * Prevent default helper\n * @param {Event} e\n * @private\n */\n prevDef(e) {\n e.preventDefault();\n },\n\n /**\n * Render component's script\n * @private\n */\n updateScript() {\n const { model, em } = this;\n if (!model.get('script')) return;\n em &&\n em\n .get('Canvas')\n .getCanvasView()\n .updateScript(this);\n },\n\n /**\n * Return children container\n * Differently from a simple component where children container is the\n * component itself\n * \n * \n * \n * You could have the children container more deeper\n * \n *
\n *
\n *
\n *
\n * \n *
\n *
\n *
\n * @return HTMLElement\n * @private\n */\n getChildrenContainer() {\n var container = this.el;\n\n if (typeof this.getChildrenSelector == 'function') {\n container = this.el.querySelector(this.getChildrenSelector());\n } else if (typeof this.getTemplate == 'function') {\n // Need to find deepest first child\n }\n\n return container;\n },\n\n /**\n * Recreate the element of the view\n */\n reset() {\n const { el, model } = this;\n const collection = model.components();\n this.el = '';\n this._ensureElement();\n this.$el.data({ model, collection });\n replaceWith(el, this.el);\n this.render();\n },\n\n /**\n * Render children components\n * @private\n */\n renderChildren() {\n this.updateContent();\n const container = this.getChildrenContainer();\n const view = new ComponentsView({\n collection: this.model.get('components'),\n config: this.config,\n componentTypes: this.opts.componentTypes\n });\n\n view.render(container);\n this.childrenView = view;\n const childNodes = Array.prototype.slice.call(view.el.childNodes);\n\n for (var i = 0, len = childNodes.length; i < len; i++) {\n container.appendChild(childNodes.shift());\n }\n },\n\n renderAttributes() {\n this.updateAttributes();\n this.updateClasses();\n },\n\n render() {\n this.renderAttributes();\n if (this.modelOpt.temporary) return this;\n this.renderChildren();\n this.updateScript();\n this.postRender();\n\n return this;\n },\n\n postRender() {\n const { em, model, modelOpt } = this;\n\n if (!modelOpt.temporary) {\n this.onRender(this._clbObj());\n em && em.trigger('component:mount', model);\n }\n },\n\n onRender() {}\n});\n","function _typeof2(obj) { if (typeof Symbol === \"function\" && typeof Symbol.iterator === \"symbol\") { _typeof2 = function _typeof2(obj) { return typeof obj; }; } else { _typeof2 = function _typeof2(obj) { return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : typeof obj; }; } return _typeof2(obj); }\n\nfunction _typeof(obj) {\n if (typeof Symbol === \"function\" && _typeof2(Symbol.iterator) === \"symbol\") {\n module.exports = _typeof = function _typeof(obj) {\n return _typeof2(obj);\n };\n } else {\n module.exports = _typeof = function _typeof(obj) {\n return obj && typeof Symbol === \"function\" && obj.constructor === Symbol && obj !== Symbol.prototype ? \"symbol\" : _typeof2(obj);\n };\n }\n\n return _typeof(obj);\n}\n\nmodule.exports = _typeof;","import Backbone from 'backbone';\n\nconst TYPE_CLASS = 1;\nconst TYPE_ID = 2;\n\nconst Selector = Backbone.Model.extend(\n {\n idAttribute: 'name',\n\n defaults: {\n name: '',\n\n label: '',\n\n // Type of the selector\n type: TYPE_CLASS,\n\n // If not active it's not selectable by the style manager (uncheckboxed)\n active: true,\n\n // Can't be seen by the style manager, therefore even by the user\n // Will be rendered only in export code\n private: false,\n\n // If true, can't be removed from the attacched element\n protected: false\n },\n\n initialize(props, opts = {}) {\n const { config = {} } = opts;\n const name = this.get('name');\n const label = this.get('label');\n\n if (!name) {\n this.set('name', label);\n } else if (!label) {\n this.set('label', name);\n }\n\n const namePreEsc = this.get('name');\n const { escapeName } = config;\n const nameEsc = escapeName\n ? escapeName(namePreEsc)\n : Selector.escapeName(namePreEsc);\n this.set('name', nameEsc);\n },\n\n /**\n * Get full selector name\n * @return {string}\n */\n getFullName() {\n let init = '';\n\n switch (this.get('type')) {\n case TYPE_CLASS:\n init = '.';\n break;\n case TYPE_ID:\n init = '#';\n break;\n }\n\n return init + this.get('name');\n }\n },\n {\n // All type selectors: https://developer.mozilla.org/it/docs/Web/CSS/CSS_Selectors\n // Here I define only what I need\n TYPE_CLASS,\n\n TYPE_ID,\n\n /**\n * Escape string\n * @param {string} name\n * @return {string}\n * @private\n */\n escapeName(name) {\n return `${name}`.trim().replace(/([^a-z0-9\\w-\\:]+)/gi, '-');\n }\n }\n);\n\nexport default Selector;\n","var arrayWithoutHoles = require(\"./arrayWithoutHoles\");\n\nvar iterableToArray = require(\"./iterableToArray\");\n\nvar nonIterableSpread = require(\"./nonIterableSpread\");\n\nfunction _toConsumableArray(arr) {\n return arrayWithoutHoles(arr) || iterableToArray(arr) || nonIterableSpread();\n}\n\nmodule.exports = _toConsumableArray;","import { filter } from 'underscore';\nimport Backbone from 'backbone';\nimport Selector from './Selector';\n\nexport default Backbone.Collection.extend({\n model: Selector,\n\n modelId: attr => `${attr.name}_${attr.type || Selector.TYPE_CLASS}`,\n\n getStyleable() {\n return filter(\n this.models,\n item => item.get('active') && !item.get('private')\n );\n },\n\n getValid() {\n return filter(this.models, item => !item.get('private'));\n },\n\n getFullString(collection) {\n const result = [];\n const coll = collection || this;\n coll.forEach(selector => result.push(selector.getFullName()));\n return result.join('').trim();\n }\n});\n","// CodeMirror, copyright (c) by Marijn Haverbeke and others\n// Distributed under an MIT license: https://codemirror.net/LICENSE\n\n// This is CodeMirror (https://codemirror.net), a code editor\n// implemented in JavaScript on top of the browser's DOM.\n//\n// You can find some technical background for some of the code below\n// at http://marijnhaverbeke.nl/blog/#cm-internals .\n\n(function (global, factory) {\n typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :\n typeof define === 'function' && define.amd ? define(factory) :\n (global.CodeMirror = factory());\n}(this, (function () { 'use strict';\n\n // Kludges for bugs and behavior differences that can't be feature\n // detected are enabled based on userAgent etc sniffing.\n var userAgent = navigator.userAgent;\n var platform = navigator.platform;\n\n var gecko = /gecko\\/\\d/i.test(userAgent);\n var ie_upto10 = /MSIE \\d/.test(userAgent);\n var ie_11up = /Trident\\/(?:[7-9]|\\d{2,})\\..*rv:(\\d+)/.exec(userAgent);\n var edge = /Edge\\/(\\d+)/.exec(userAgent);\n var ie = ie_upto10 || ie_11up || edge;\n var ie_version = ie && (ie_upto10 ? document.documentMode || 6 : +(edge || ie_11up)[1]);\n var webkit = !edge && /WebKit\\//.test(userAgent);\n var qtwebkit = webkit && /Qt\\/\\d+\\.\\d+/.test(userAgent);\n var chrome = !edge && /Chrome\\//.test(userAgent);\n var presto = /Opera\\//.test(userAgent);\n var safari = /Apple Computer/.test(navigator.vendor);\n var mac_geMountainLion = /Mac OS X 1\\d\\D([8-9]|\\d\\d)\\D/.test(userAgent);\n var phantom = /PhantomJS/.test(userAgent);\n\n var ios = !edge && /AppleWebKit/.test(userAgent) && /Mobile\\/\\w+/.test(userAgent);\n var android = /Android/.test(userAgent);\n // This is woefully incomplete. Suggestions for alternative methods welcome.\n var mobile = ios || android || /webOS|BlackBerry|Opera Mini|Opera Mobi|IEMobile/i.test(userAgent);\n var mac = ios || /Mac/.test(platform);\n var chromeOS = /\\bCrOS\\b/.test(userAgent);\n var windows = /win/i.test(platform);\n\n var presto_version = presto && userAgent.match(/Version\\/(\\d*\\.\\d*)/);\n if (presto_version) { presto_version = Number(presto_version[1]); }\n if (presto_version && presto_version >= 15) { presto = false; webkit = true; }\n // Some browsers use the wrong event properties to signal cmd/ctrl on OS X\n var flipCtrlCmd = mac && (qtwebkit || presto && (presto_version == null || presto_version < 12.11));\n var captureRightClick = gecko || (ie && ie_version >= 9);\n\n function classTest(cls) { return new RegExp(\"(^|\\\\s)\" + cls + \"(?:$|\\\\s)\\\\s*\") }\n\n var rmClass = function(node, cls) {\n var current = node.className;\n var match = classTest(cls).exec(current);\n if (match) {\n var after = current.slice(match.index + match[0].length);\n node.className = current.slice(0, match.index) + (after ? match[1] + after : \"\");\n }\n };\n\n function removeChildren(e) {\n for (var count = e.childNodes.length; count > 0; --count)\n { e.removeChild(e.firstChild); }\n return e\n }\n\n function removeChildrenAndAdd(parent, e) {\n return removeChildren(parent).appendChild(e)\n }\n\n function elt(tag, content, className, style) {\n var e = document.createElement(tag);\n if (className) { e.className = className; }\n if (style) { e.style.cssText = style; }\n if (typeof content == \"string\") { e.appendChild(document.createTextNode(content)); }\n else if (content) { for (var i = 0; i < content.length; ++i) { e.appendChild(content[i]); } }\n return e\n }\n // wrapper for elt, which removes the elt from the accessibility tree\n function eltP(tag, content, className, style) {\n var e = elt(tag, content, className, style);\n e.setAttribute(\"role\", \"presentation\");\n return e\n }\n\n var range;\n if (document.createRange) { range = function(node, start, end, endNode) {\n var r = document.createRange();\n r.setEnd(endNode || node, end);\n r.setStart(node, start);\n return r\n }; }\n else { range = function(node, start, end) {\n var r = document.body.createTextRange();\n try { r.moveToElementText(node.parentNode); }\n catch(e) { return r }\n r.collapse(true);\n r.moveEnd(\"character\", end);\n r.moveStart(\"character\", start);\n return r\n }; }\n\n function contains(parent, child) {\n if (child.nodeType == 3) // Android browser always returns false when child is a textnode\n { child = child.parentNode; }\n if (parent.contains)\n { return parent.contains(child) }\n do {\n if (child.nodeType == 11) { child = child.host; }\n if (child == parent) { return true }\n } while (child = child.parentNode)\n }\n\n function activeElt() {\n // IE and Edge may throw an \"Unspecified Error\" when accessing document.activeElement.\n // IE < 10 will throw when accessed while the page is loading or in an iframe.\n // IE > 9 and Edge will throw when accessed in an iframe if document.body is unavailable.\n var activeElement;\n try {\n activeElement = document.activeElement;\n } catch(e) {\n activeElement = document.body || null;\n }\n while (activeElement && activeElement.shadowRoot && activeElement.shadowRoot.activeElement)\n { activeElement = activeElement.shadowRoot.activeElement; }\n return activeElement\n }\n\n function addClass(node, cls) {\n var current = node.className;\n if (!classTest(cls).test(current)) { node.className += (current ? \" \" : \"\") + cls; }\n }\n function joinClasses(a, b) {\n var as = a.split(\" \");\n for (var i = 0; i < as.length; i++)\n { if (as[i] && !classTest(as[i]).test(b)) { b += \" \" + as[i]; } }\n return b\n }\n\n var selectInput = function(node) { node.select(); };\n if (ios) // Mobile Safari apparently has a bug where select() is broken.\n { selectInput = function(node) { node.selectionStart = 0; node.selectionEnd = node.value.length; }; }\n else if (ie) // Suppress mysterious IE10 errors\n { selectInput = function(node) { try { node.select(); } catch(_e) {} }; }\n\n function bind(f) {\n var args = Array.prototype.slice.call(arguments, 1);\n return function(){return f.apply(null, args)}\n }\n\n function copyObj(obj, target, overwrite) {\n if (!target) { target = {}; }\n for (var prop in obj)\n { if (obj.hasOwnProperty(prop) && (overwrite !== false || !target.hasOwnProperty(prop)))\n { target[prop] = obj[prop]; } }\n return target\n }\n\n // Counts the column offset in a string, taking tabs into account.\n // Used mostly to find indentation.\n function countColumn(string, end, tabSize, startIndex, startValue) {\n if (end == null) {\n end = string.search(/[^\\s\\u00a0]/);\n if (end == -1) { end = string.length; }\n }\n for (var i = startIndex || 0, n = startValue || 0;;) {\n var nextTab = string.indexOf(\"\\t\", i);\n if (nextTab < 0 || nextTab >= end)\n { return n + (end - i) }\n n += nextTab - i;\n n += tabSize - (n % tabSize);\n i = nextTab + 1;\n }\n }\n\n var Delayed = function() {this.id = null;};\n Delayed.prototype.set = function (ms, f) {\n clearTimeout(this.id);\n this.id = setTimeout(f, ms);\n };\n\n function indexOf(array, elt) {\n for (var i = 0; i < array.length; ++i)\n { if (array[i] == elt) { return i } }\n return -1\n }\n\n // Number of pixels added to scroller and sizer to hide scrollbar\n var scrollerGap = 30;\n\n // Returned or thrown by various protocols to signal 'I'm not\n // handling this'.\n var Pass = {toString: function(){return \"CodeMirror.Pass\"}};\n\n // Reused option objects for setSelection & friends\n var sel_dontScroll = {scroll: false}, sel_mouse = {origin: \"*mouse\"}, sel_move = {origin: \"+move\"};\n\n // The inverse of countColumn -- find the offset that corresponds to\n // a particular column.\n function findColumn(string, goal, tabSize) {\n for (var pos = 0, col = 0;;) {\n var nextTab = string.indexOf(\"\\t\", pos);\n if (nextTab == -1) { nextTab = string.length; }\n var skipped = nextTab - pos;\n if (nextTab == string.length || col + skipped >= goal)\n { return pos + Math.min(skipped, goal - col) }\n col += nextTab - pos;\n col += tabSize - (col % tabSize);\n pos = nextTab + 1;\n if (col >= goal) { return pos }\n }\n }\n\n var spaceStrs = [\"\"];\n function spaceStr(n) {\n while (spaceStrs.length <= n)\n { spaceStrs.push(lst(spaceStrs) + \" \"); }\n return spaceStrs[n]\n }\n\n function lst(arr) { return arr[arr.length-1] }\n\n function map(array, f) {\n var out = [];\n for (var i = 0; i < array.length; i++) { out[i] = f(array[i], i); }\n return out\n }\n\n function insertSorted(array, value, score) {\n var pos = 0, priority = score(value);\n while (pos < array.length && score(array[pos]) <= priority) { pos++; }\n array.splice(pos, 0, value);\n }\n\n function nothing() {}\n\n function createObj(base, props) {\n var inst;\n if (Object.create) {\n inst = Object.create(base);\n } else {\n nothing.prototype = base;\n inst = new nothing();\n }\n if (props) { copyObj(props, inst); }\n return inst\n }\n\n var nonASCIISingleCaseWordChar = /[\\u00df\\u0587\\u0590-\\u05f4\\u0600-\\u06ff\\u3040-\\u309f\\u30a0-\\u30ff\\u3400-\\u4db5\\u4e00-\\u9fcc\\uac00-\\ud7af]/;\n function isWordCharBasic(ch) {\n return /\\w/.test(ch) || ch > \"\\x80\" &&\n (ch.toUpperCase() != ch.toLowerCase() || nonASCIISingleCaseWordChar.test(ch))\n }\n function isWordChar(ch, helper) {\n if (!helper) { return isWordCharBasic(ch) }\n if (helper.source.indexOf(\"\\\\w\") > -1 && isWordCharBasic(ch)) { return true }\n return helper.test(ch)\n }\n\n function isEmpty(obj) {\n for (var n in obj) { if (obj.hasOwnProperty(n) && obj[n]) { return false } }\n return true\n }\n\n // Extending unicode characters. A series of a non-extending char +\n // any number of extending chars is treated as a single unit as far\n // as editing and measuring is concerned. This is not fully correct,\n // since some scripts/fonts/browsers also treat other configurations\n // of code points as a group.\n var extendingChars = /[\\u0300-\\u036f\\u0483-\\u0489\\u0591-\\u05bd\\u05bf\\u05c1\\u05c2\\u05c4\\u05c5\\u05c7\\u0610-\\u061a\\u064b-\\u065e\\u0670\\u06d6-\\u06dc\\u06de-\\u06e4\\u06e7\\u06e8\\u06ea-\\u06ed\\u0711\\u0730-\\u074a\\u07a6-\\u07b0\\u07eb-\\u07f3\\u0816-\\u0819\\u081b-\\u0823\\u0825-\\u0827\\u0829-\\u082d\\u0900-\\u0902\\u093c\\u0941-\\u0948\\u094d\\u0951-\\u0955\\u0962\\u0963\\u0981\\u09bc\\u09be\\u09c1-\\u09c4\\u09cd\\u09d7\\u09e2\\u09e3\\u0a01\\u0a02\\u0a3c\\u0a41\\u0a42\\u0a47\\u0a48\\u0a4b-\\u0a4d\\u0a51\\u0a70\\u0a71\\u0a75\\u0a81\\u0a82\\u0abc\\u0ac1-\\u0ac5\\u0ac7\\u0ac8\\u0acd\\u0ae2\\u0ae3\\u0b01\\u0b3c\\u0b3e\\u0b3f\\u0b41-\\u0b44\\u0b4d\\u0b56\\u0b57\\u0b62\\u0b63\\u0b82\\u0bbe\\u0bc0\\u0bcd\\u0bd7\\u0c3e-\\u0c40\\u0c46-\\u0c48\\u0c4a-\\u0c4d\\u0c55\\u0c56\\u0c62\\u0c63\\u0cbc\\u0cbf\\u0cc2\\u0cc6\\u0ccc\\u0ccd\\u0cd5\\u0cd6\\u0ce2\\u0ce3\\u0d3e\\u0d41-\\u0d44\\u0d4d\\u0d57\\u0d62\\u0d63\\u0dca\\u0dcf\\u0dd2-\\u0dd4\\u0dd6\\u0ddf\\u0e31\\u0e34-\\u0e3a\\u0e47-\\u0e4e\\u0eb1\\u0eb4-\\u0eb9\\u0ebb\\u0ebc\\u0ec8-\\u0ecd\\u0f18\\u0f19\\u0f35\\u0f37\\u0f39\\u0f71-\\u0f7e\\u0f80-\\u0f84\\u0f86\\u0f87\\u0f90-\\u0f97\\u0f99-\\u0fbc\\u0fc6\\u102d-\\u1030\\u1032-\\u1037\\u1039\\u103a\\u103d\\u103e\\u1058\\u1059\\u105e-\\u1060\\u1071-\\u1074\\u1082\\u1085\\u1086\\u108d\\u109d\\u135f\\u1712-\\u1714\\u1732-\\u1734\\u1752\\u1753\\u1772\\u1773\\u17b7-\\u17bd\\u17c6\\u17c9-\\u17d3\\u17dd\\u180b-\\u180d\\u18a9\\u1920-\\u1922\\u1927\\u1928\\u1932\\u1939-\\u193b\\u1a17\\u1a18\\u1a56\\u1a58-\\u1a5e\\u1a60\\u1a62\\u1a65-\\u1a6c\\u1a73-\\u1a7c\\u1a7f\\u1b00-\\u1b03\\u1b34\\u1b36-\\u1b3a\\u1b3c\\u1b42\\u1b6b-\\u1b73\\u1b80\\u1b81\\u1ba2-\\u1ba5\\u1ba8\\u1ba9\\u1c2c-\\u1c33\\u1c36\\u1c37\\u1cd0-\\u1cd2\\u1cd4-\\u1ce0\\u1ce2-\\u1ce8\\u1ced\\u1dc0-\\u1de6\\u1dfd-\\u1dff\\u200c\\u200d\\u20d0-\\u20f0\\u2cef-\\u2cf1\\u2de0-\\u2dff\\u302a-\\u302f\\u3099\\u309a\\ua66f-\\ua672\\ua67c\\ua67d\\ua6f0\\ua6f1\\ua802\\ua806\\ua80b\\ua825\\ua826\\ua8c4\\ua8e0-\\ua8f1\\ua926-\\ua92d\\ua947-\\ua951\\ua980-\\ua982\\ua9b3\\ua9b6-\\ua9b9\\ua9bc\\uaa29-\\uaa2e\\uaa31\\uaa32\\uaa35\\uaa36\\uaa43\\uaa4c\\uaab0\\uaab2-\\uaab4\\uaab7\\uaab8\\uaabe\\uaabf\\uaac1\\uabe5\\uabe8\\uabed\\udc00-\\udfff\\ufb1e\\ufe00-\\ufe0f\\ufe20-\\ufe26\\uff9e\\uff9f]/;\n function isExtendingChar(ch) { return ch.charCodeAt(0) >= 768 && extendingChars.test(ch) }\n\n // Returns a number from the range [`0`; `str.length`] unless `pos` is outside that range.\n function skipExtendingChars(str, pos, dir) {\n while ((dir < 0 ? pos > 0 : pos < str.length) && isExtendingChar(str.charAt(pos))) { pos += dir; }\n return pos\n }\n\n // Returns the value from the range [`from`; `to`] that satisfies\n // `pred` and is closest to `from`. Assumes that at least `to`\n // satisfies `pred`. Supports `from` being greater than `to`.\n function findFirst(pred, from, to) {\n // At any point we are certain `to` satisfies `pred`, don't know\n // whether `from` does.\n var dir = from > to ? -1 : 1;\n for (;;) {\n if (from == to) { return from }\n var midF = (from + to) / 2, mid = dir < 0 ? Math.ceil(midF) : Math.floor(midF);\n if (mid == from) { return pred(mid) ? from : to }\n if (pred(mid)) { to = mid; }\n else { from = mid + dir; }\n }\n }\n\n // BIDI HELPERS\n\n function iterateBidiSections(order, from, to, f) {\n if (!order) { return f(from, to, \"ltr\", 0) }\n var found = false;\n for (var i = 0; i < order.length; ++i) {\n var part = order[i];\n if (part.from < to && part.to > from || from == to && part.to == from) {\n f(Math.max(part.from, from), Math.min(part.to, to), part.level == 1 ? \"rtl\" : \"ltr\", i);\n found = true;\n }\n }\n if (!found) { f(from, to, \"ltr\"); }\n }\n\n var bidiOther = null;\n function getBidiPartAt(order, ch, sticky) {\n var found;\n bidiOther = null;\n for (var i = 0; i < order.length; ++i) {\n var cur = order[i];\n if (cur.from < ch && cur.to > ch) { return i }\n if (cur.to == ch) {\n if (cur.from != cur.to && sticky == \"before\") { found = i; }\n else { bidiOther = i; }\n }\n if (cur.from == ch) {\n if (cur.from != cur.to && sticky != \"before\") { found = i; }\n else { bidiOther = i; }\n }\n }\n return found != null ? found : bidiOther\n }\n\n // Bidirectional ordering algorithm\n // See http://unicode.org/reports/tr9/tr9-13.html for the algorithm\n // that this (partially) implements.\n\n // One-char codes used for character types:\n // L (L): Left-to-Right\n // R (R): Right-to-Left\n // r (AL): Right-to-Left Arabic\n // 1 (EN): European Number\n // + (ES): European Number Separator\n // % (ET): European Number Terminator\n // n (AN): Arabic Number\n // , (CS): Common Number Separator\n // m (NSM): Non-Spacing Mark\n // b (BN): Boundary Neutral\n // s (B): Paragraph Separator\n // t (S): Segment Separator\n // w (WS): Whitespace\n // N (ON): Other Neutrals\n\n // Returns null if characters are ordered as they appear\n // (left-to-right), or an array of sections ({from, to, level}\n // objects) in the order in which they occur visually.\n var bidiOrdering = (function() {\n // Character types for codepoints 0 to 0xff\n var lowTypes = \"bbbbbbbbbtstwsbbbbbbbbbbbbbbssstwNN%%%NNNNNN,N,N1111111111NNNNNNNLLLLLLLLLLLLLLLLLLLLLLLLLLNNNNNNLLLLLLLLLLLLLLLLLLLLLLLLLLNNNNbbbbbbsbbbbbbbbbbbbbbbbbbbbbbbbbb,N%%%%NNNNLNNNNN%%11NLNNN1LNNNNNLLLLLLLLLLLLLLLLLLLLLLLNLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLLN\";\n // Character types for codepoints 0x600 to 0x6f9\n var arabicTypes = \"nnnnnnNNr%%r,rNNmmmmmmmmmmmrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrmmmmmmmmmmmmmmmmmmmmmnnnnnnnnnn%nnrrrmrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrmmmmmmmnNmmmmmmrrmmNmmmmrr1111111111\";\n function charType(code) {\n if (code <= 0xf7) { return lowTypes.charAt(code) }\n else if (0x590 <= code && code <= 0x5f4) { return \"R\" }\n else if (0x600 <= code && code <= 0x6f9) { return arabicTypes.charAt(code - 0x600) }\n else if (0x6ee <= code && code <= 0x8ac) { return \"r\" }\n else if (0x2000 <= code && code <= 0x200b) { return \"w\" }\n else if (code == 0x200c) { return \"b\" }\n else { return \"L\" }\n }\n\n var bidiRE = /[\\u0590-\\u05f4\\u0600-\\u06ff\\u0700-\\u08ac]/;\n var isNeutral = /[stwN]/, isStrong = /[LRr]/, countsAsLeft = /[Lb1n]/, countsAsNum = /[1n]/;\n\n function BidiSpan(level, from, to) {\n this.level = level;\n this.from = from; this.to = to;\n }\n\n return function(str, direction) {\n var outerType = direction == \"ltr\" ? \"L\" : \"R\";\n\n if (str.length == 0 || direction == \"ltr\" && !bidiRE.test(str)) { return false }\n var len = str.length, types = [];\n for (var i = 0; i < len; ++i)\n { types.push(charType(str.charCodeAt(i))); }\n\n // W1. Examine each non-spacing mark (NSM) in the level run, and\n // change the type of the NSM to the type of the previous\n // character. If the NSM is at the start of the level run, it will\n // get the type of sor.\n for (var i$1 = 0, prev = outerType; i$1 < len; ++i$1) {\n var type = types[i$1];\n if (type == \"m\") { types[i$1] = prev; }\n else { prev = type; }\n }\n\n // W2. Search backwards from each instance of a European number\n // until the first strong type (R, L, AL, or sor) is found. If an\n // AL is found, change the type of the European number to Arabic\n // number.\n // W3. Change all ALs to R.\n for (var i$2 = 0, cur = outerType; i$2 < len; ++i$2) {\n var type$1 = types[i$2];\n if (type$1 == \"1\" && cur == \"r\") { types[i$2] = \"n\"; }\n else if (isStrong.test(type$1)) { cur = type$1; if (type$1 == \"r\") { types[i$2] = \"R\"; } }\n }\n\n // W4. A single European separator between two European numbers\n // changes to a European number. A single common separator between\n // two numbers of the same type changes to that type.\n for (var i$3 = 1, prev$1 = types[0]; i$3 < len - 1; ++i$3) {\n var type$2 = types[i$3];\n if (type$2 == \"+\" && prev$1 == \"1\" && types[i$3+1] == \"1\") { types[i$3] = \"1\"; }\n else if (type$2 == \",\" && prev$1 == types[i$3+1] &&\n (prev$1 == \"1\" || prev$1 == \"n\")) { types[i$3] = prev$1; }\n prev$1 = type$2;\n }\n\n // W5. A sequence of European terminators adjacent to European\n // numbers changes to all European numbers.\n // W6. Otherwise, separators and terminators change to Other\n // Neutral.\n for (var i$4 = 0; i$4 < len; ++i$4) {\n var type$3 = types[i$4];\n if (type$3 == \",\") { types[i$4] = \"N\"; }\n else if (type$3 == \"%\") {\n var end = (void 0);\n for (end = i$4 + 1; end < len && types[end] == \"%\"; ++end) {}\n var replace = (i$4 && types[i$4-1] == \"!\") || (end < len && types[end] == \"1\") ? \"1\" : \"N\";\n for (var j = i$4; j < end; ++j) { types[j] = replace; }\n i$4 = end - 1;\n }\n }\n\n // W7. Search backwards from each instance of a European number\n // until the first strong type (R, L, or sor) is found. If an L is\n // found, then change the type of the European number to L.\n for (var i$5 = 0, cur$1 = outerType; i$5 < len; ++i$5) {\n var type$4 = types[i$5];\n if (cur$1 == \"L\" && type$4 == \"1\") { types[i$5] = \"L\"; }\n else if (isStrong.test(type$4)) { cur$1 = type$4; }\n }\n\n // N1. A sequence of neutrals takes the direction of the\n // surrounding strong text if the text on both sides has the same\n // direction. European and Arabic numbers act as if they were R in\n // terms of their influence on neutrals. Start-of-level-run (sor)\n // and end-of-level-run (eor) are used at level run boundaries.\n // N2. Any remaining neutrals take the embedding direction.\n for (var i$6 = 0; i$6 < len; ++i$6) {\n if (isNeutral.test(types[i$6])) {\n var end$1 = (void 0);\n for (end$1 = i$6 + 1; end$1 < len && isNeutral.test(types[end$1]); ++end$1) {}\n var before = (i$6 ? types[i$6-1] : outerType) == \"L\";\n var after = (end$1 < len ? types[end$1] : outerType) == \"L\";\n var replace$1 = before == after ? (before ? \"L\" : \"R\") : outerType;\n for (var j$1 = i$6; j$1 < end$1; ++j$1) { types[j$1] = replace$1; }\n i$6 = end$1 - 1;\n }\n }\n\n // Here we depart from the documented algorithm, in order to avoid\n // building up an actual levels array. Since there are only three\n // levels (0, 1, 2) in an implementation that doesn't take\n // explicit embedding into account, we can build up the order on\n // the fly, without following the level-based algorithm.\n var order = [], m;\n for (var i$7 = 0; i$7 < len;) {\n if (countsAsLeft.test(types[i$7])) {\n var start = i$7;\n for (++i$7; i$7 < len && countsAsLeft.test(types[i$7]); ++i$7) {}\n order.push(new BidiSpan(0, start, i$7));\n } else {\n var pos = i$7, at = order.length;\n for (++i$7; i$7 < len && types[i$7] != \"L\"; ++i$7) {}\n for (var j$2 = pos; j$2 < i$7;) {\n if (countsAsNum.test(types[j$2])) {\n if (pos < j$2) { order.splice(at, 0, new BidiSpan(1, pos, j$2)); }\n var nstart = j$2;\n for (++j$2; j$2 < i$7 && countsAsNum.test(types[j$2]); ++j$2) {}\n order.splice(at, 0, new BidiSpan(2, nstart, j$2));\n pos = j$2;\n } else { ++j$2; }\n }\n if (pos < i$7) { order.splice(at, 0, new BidiSpan(1, pos, i$7)); }\n }\n }\n if (direction == \"ltr\") {\n if (order[0].level == 1 && (m = str.match(/^\\s+/))) {\n order[0].from = m[0].length;\n order.unshift(new BidiSpan(0, 0, m[0].length));\n }\n if (lst(order).level == 1 && (m = str.match(/\\s+$/))) {\n lst(order).to -= m[0].length;\n order.push(new BidiSpan(0, len - m[0].length, len));\n }\n }\n\n return direction == \"rtl\" ? order.reverse() : order\n }\n })();\n\n // Get the bidi ordering for the given line (and cache it). Returns\n // false for lines that are fully left-to-right, and an array of\n // BidiSpan objects otherwise.\n function getOrder(line, direction) {\n var order = line.order;\n if (order == null) { order = line.order = bidiOrdering(line.text, direction); }\n return order\n }\n\n // EVENT HANDLING\n\n // Lightweight event framework. on/off also work on DOM nodes,\n // registering native DOM handlers.\n\n var noHandlers = [];\n\n var on = function(emitter, type, f) {\n if (emitter.addEventListener) {\n emitter.addEventListener(type, f, false);\n } else if (emitter.attachEvent) {\n emitter.attachEvent(\"on\" + type, f);\n } else {\n var map$$1 = emitter._handlers || (emitter._handlers = {});\n map$$1[type] = (map$$1[type] || noHandlers).concat(f);\n }\n };\n\n function getHandlers(emitter, type) {\n return emitter._handlers && emitter._handlers[type] || noHandlers\n }\n\n function off(emitter, type, f) {\n if (emitter.removeEventListener) {\n emitter.removeEventListener(type, f, false);\n } else if (emitter.detachEvent) {\n emitter.detachEvent(\"on\" + type, f);\n } else {\n var map$$1 = emitter._handlers, arr = map$$1 && map$$1[type];\n if (arr) {\n var index = indexOf(arr, f);\n if (index > -1)\n { map$$1[type] = arr.slice(0, index).concat(arr.slice(index + 1)); }\n }\n }\n }\n\n function signal(emitter, type /*, values...*/) {\n var handlers = getHandlers(emitter, type);\n if (!handlers.length) { return }\n var args = Array.prototype.slice.call(arguments, 2);\n for (var i = 0; i < handlers.length; ++i) { handlers[i].apply(null, args); }\n }\n\n // The DOM events that CodeMirror handles can be overridden by\n // registering a (non-DOM) handler on the editor for the event name,\n // and preventDefault-ing the event in that handler.\n function signalDOMEvent(cm, e, override) {\n if (typeof e == \"string\")\n { e = {type: e, preventDefault: function() { this.defaultPrevented = true; }}; }\n signal(cm, override || e.type, cm, e);\n return e_defaultPrevented(e) || e.codemirrorIgnore\n }\n\n function signalCursorActivity(cm) {\n var arr = cm._handlers && cm._handlers.cursorActivity;\n if (!arr) { return }\n var set = cm.curOp.cursorActivityHandlers || (cm.curOp.cursorActivityHandlers = []);\n for (var i = 0; i < arr.length; ++i) { if (indexOf(set, arr[i]) == -1)\n { set.push(arr[i]); } }\n }\n\n function hasHandler(emitter, type) {\n return getHandlers(emitter, type).length > 0\n }\n\n // Add on and off methods to a constructor's prototype, to make\n // registering events on such objects more convenient.\n function eventMixin(ctor) {\n ctor.prototype.on = function(type, f) {on(this, type, f);};\n ctor.prototype.off = function(type, f) {off(this, type, f);};\n }\n\n // Due to the fact that we still support jurassic IE versions, some\n // compatibility wrappers are needed.\n\n function e_preventDefault(e) {\n if (e.preventDefault) { e.preventDefault(); }\n else { e.returnValue = false; }\n }\n function e_stopPropagation(e) {\n if (e.stopPropagation) { e.stopPropagation(); }\n else { e.cancelBubble = true; }\n }\n function e_defaultPrevented(e) {\n return e.defaultPrevented != null ? e.defaultPrevented : e.returnValue == false\n }\n function e_stop(e) {e_preventDefault(e); e_stopPropagation(e);}\n\n function e_target(e) {return e.target || e.srcElement}\n function e_button(e) {\n var b = e.which;\n if (b == null) {\n if (e.button & 1) { b = 1; }\n else if (e.button & 2) { b = 3; }\n else if (e.button & 4) { b = 2; }\n }\n if (mac && e.ctrlKey && b == 1) { b = 3; }\n return b\n }\n\n // Detect drag-and-drop\n var dragAndDrop = function() {\n // There is *some* kind of drag-and-drop support in IE6-8, but I\n // couldn't get it to work yet.\n if (ie && ie_version < 9) { return false }\n var div = elt('div');\n return \"draggable\" in div || \"dragDrop\" in div\n }();\n\n var zwspSupported;\n function zeroWidthElement(measure) {\n if (zwspSupported == null) {\n var test = elt(\"span\", \"\\u200b\");\n removeChildrenAndAdd(measure, elt(\"span\", [test, document.createTextNode(\"x\")]));\n if (measure.firstChild.offsetHeight != 0)\n { zwspSupported = test.offsetWidth <= 1 && test.offsetHeight > 2 && !(ie && ie_version < 8); }\n }\n var node = zwspSupported ? elt(\"span\", \"\\u200b\") :\n elt(\"span\", \"\\u00a0\", null, \"display: inline-block; width: 1px; margin-right: -1px\");\n node.setAttribute(\"cm-text\", \"\");\n return node\n }\n\n // Feature-detect IE's crummy client rect reporting for bidi text\n var badBidiRects;\n function hasBadBidiRects(measure) {\n if (badBidiRects != null) { return badBidiRects }\n var txt = removeChildrenAndAdd(measure, document.createTextNode(\"A\\u062eA\"));\n var r0 = range(txt, 0, 1).getBoundingClientRect();\n var r1 = range(txt, 1, 2).getBoundingClientRect();\n removeChildren(measure);\n if (!r0 || r0.left == r0.right) { return false } // Safari returns null in some cases (#2780)\n return badBidiRects = (r1.right - r0.right < 3)\n }\n\n // See if \"\".split is the broken IE version, if so, provide an\n // alternative way to split lines.\n var splitLinesAuto = \"\\n\\nb\".split(/\\n/).length != 3 ? function (string) {\n var pos = 0, result = [], l = string.length;\n while (pos <= l) {\n var nl = string.indexOf(\"\\n\", pos);\n if (nl == -1) { nl = string.length; }\n var line = string.slice(pos, string.charAt(nl - 1) == \"\\r\" ? nl - 1 : nl);\n var rt = line.indexOf(\"\\r\");\n if (rt != -1) {\n result.push(line.slice(0, rt));\n pos += rt + 1;\n } else {\n result.push(line);\n pos = nl + 1;\n }\n }\n return result\n } : function (string) { return string.split(/\\r\\n?|\\n/); };\n\n var hasSelection = window.getSelection ? function (te) {\n try { return te.selectionStart != te.selectionEnd }\n catch(e) { return false }\n } : function (te) {\n var range$$1;\n try {range$$1 = te.ownerDocument.selection.createRange();}\n catch(e) {}\n if (!range$$1 || range$$1.parentElement() != te) { return false }\n return range$$1.compareEndPoints(\"StartToEnd\", range$$1) != 0\n };\n\n var hasCopyEvent = (function () {\n var e = elt(\"div\");\n if (\"oncopy\" in e) { return true }\n e.setAttribute(\"oncopy\", \"return;\");\n return typeof e.oncopy == \"function\"\n })();\n\n var badZoomedRects = null;\n function hasBadZoomedRects(measure) {\n if (badZoomedRects != null) { return badZoomedRects }\n var node = removeChildrenAndAdd(measure, elt(\"span\", \"x\"));\n var normal = node.getBoundingClientRect();\n var fromRange = range(node, 0, 1).getBoundingClientRect();\n return badZoomedRects = Math.abs(normal.left - fromRange.left) > 1\n }\n\n // Known modes, by name and by MIME\n var modes = {}, mimeModes = {};\n\n // Extra arguments are stored as the mode's dependencies, which is\n // used by (legacy) mechanisms like loadmode.js to automatically\n // load a mode. (Preferred mechanism is the require/define calls.)\n function defineMode(name, mode) {\n if (arguments.length > 2)\n { mode.dependencies = Array.prototype.slice.call(arguments, 2); }\n modes[name] = mode;\n }\n\n function defineMIME(mime, spec) {\n mimeModes[mime] = spec;\n }\n\n // Given a MIME type, a {name, ...options} config object, or a name\n // string, return a mode config object.\n function resolveMode(spec) {\n if (typeof spec == \"string\" && mimeModes.hasOwnProperty(spec)) {\n spec = mimeModes[spec];\n } else if (spec && typeof spec.name == \"string\" && mimeModes.hasOwnProperty(spec.name)) {\n var found = mimeModes[spec.name];\n if (typeof found == \"string\") { found = {name: found}; }\n spec = createObj(found, spec);\n spec.name = found.name;\n } else if (typeof spec == \"string\" && /^[\\w\\-]+\\/[\\w\\-]+\\+xml$/.test(spec)) {\n return resolveMode(\"application/xml\")\n } else if (typeof spec == \"string\" && /^[\\w\\-]+\\/[\\w\\-]+\\+json$/.test(spec)) {\n return resolveMode(\"application/json\")\n }\n if (typeof spec == \"string\") { return {name: spec} }\n else { return spec || {name: \"null\"} }\n }\n\n // Given a mode spec (anything that resolveMode accepts), find and\n // initialize an actual mode object.\n function getMode(options, spec) {\n spec = resolveMode(spec);\n var mfactory = modes[spec.name];\n if (!mfactory) { return getMode(options, \"text/plain\") }\n var modeObj = mfactory(options, spec);\n if (modeExtensions.hasOwnProperty(spec.name)) {\n var exts = modeExtensions[spec.name];\n for (var prop in exts) {\n if (!exts.hasOwnProperty(prop)) { continue }\n if (modeObj.hasOwnProperty(prop)) { modeObj[\"_\" + prop] = modeObj[prop]; }\n modeObj[prop] = exts[prop];\n }\n }\n modeObj.name = spec.name;\n if (spec.helperType) { modeObj.helperType = spec.helperType; }\n if (spec.modeProps) { for (var prop$1 in spec.modeProps)\n { modeObj[prop$1] = spec.modeProps[prop$1]; } }\n\n return modeObj\n }\n\n // This can be used to attach properties to mode objects from\n // outside the actual mode definition.\n var modeExtensions = {};\n function extendMode(mode, properties) {\n var exts = modeExtensions.hasOwnProperty(mode) ? modeExtensions[mode] : (modeExtensions[mode] = {});\n copyObj(properties, exts);\n }\n\n function copyState(mode, state) {\n if (state === true) { return state }\n if (mode.copyState) { return mode.copyState(state) }\n var nstate = {};\n for (var n in state) {\n var val = state[n];\n if (val instanceof Array) { val = val.concat([]); }\n nstate[n] = val;\n }\n return nstate\n }\n\n // Given a mode and a state (for that mode), find the inner mode and\n // state at the position that the state refers to.\n function innerMode(mode, state) {\n var info;\n while (mode.innerMode) {\n info = mode.innerMode(state);\n if (!info || info.mode == mode) { break }\n state = info.state;\n mode = info.mode;\n }\n return info || {mode: mode, state: state}\n }\n\n function startState(mode, a1, a2) {\n return mode.startState ? mode.startState(a1, a2) : true\n }\n\n // STRING STREAM\n\n // Fed to the mode parsers, provides helper functions to make\n // parsers more succinct.\n\n var StringStream = function(string, tabSize, lineOracle) {\n this.pos = this.start = 0;\n this.string = string;\n this.tabSize = tabSize || 8;\n this.lastColumnPos = this.lastColumnValue = 0;\n this.lineStart = 0;\n this.lineOracle = lineOracle;\n };\n\n StringStream.prototype.eol = function () {return this.pos >= this.string.length};\n StringStream.prototype.sol = function () {return this.pos == this.lineStart};\n StringStream.prototype.peek = function () {return this.string.charAt(this.pos) || undefined};\n StringStream.prototype.next = function () {\n if (this.pos < this.string.length)\n { return this.string.charAt(this.pos++) }\n };\n StringStream.prototype.eat = function (match) {\n var ch = this.string.charAt(this.pos);\n var ok;\n if (typeof match == \"string\") { ok = ch == match; }\n else { ok = ch && (match.test ? match.test(ch) : match(ch)); }\n if (ok) {++this.pos; return ch}\n };\n StringStream.prototype.eatWhile = function (match) {\n var start = this.pos;\n while (this.eat(match)){}\n return this.pos > start\n };\n StringStream.prototype.eatSpace = function () {\n var this$1 = this;\n\n var start = this.pos;\n while (/[\\s\\u00a0]/.test(this.string.charAt(this.pos))) { ++this$1.pos; }\n return this.pos > start\n };\n StringStream.prototype.skipToEnd = function () {this.pos = this.string.length;};\n StringStream.prototype.skipTo = function (ch) {\n var found = this.string.indexOf(ch, this.pos);\n if (found > -1) {this.pos = found; return true}\n };\n StringStream.prototype.backUp = function (n) {this.pos -= n;};\n StringStream.prototype.column = function () {\n if (this.lastColumnPos < this.start) {\n this.lastColumnValue = countColumn(this.string, this.start, this.tabSize, this.lastColumnPos, this.lastColumnValue);\n this.lastColumnPos = this.start;\n }\n return this.lastColumnValue - (this.lineStart ? countColumn(this.string, this.lineStart, this.tabSize) : 0)\n };\n StringStream.prototype.indentation = function () {\n return countColumn(this.string, null, this.tabSize) -\n (this.lineStart ? countColumn(this.string, this.lineStart, this.tabSize) : 0)\n };\n StringStream.prototype.match = function (pattern, consume, caseInsensitive) {\n if (typeof pattern == \"string\") {\n var cased = function (str) { return caseInsensitive ? str.toLowerCase() : str; };\n var substr = this.string.substr(this.pos, pattern.length);\n if (cased(substr) == cased(pattern)) {\n if (consume !== false) { this.pos += pattern.length; }\n return true\n }\n } else {\n var match = this.string.slice(this.pos).match(pattern);\n if (match && match.index > 0) { return null }\n if (match && consume !== false) { this.pos += match[0].length; }\n return match\n }\n };\n StringStream.prototype.current = function (){return this.string.slice(this.start, this.pos)};\n StringStream.prototype.hideFirstChars = function (n, inner) {\n this.lineStart += n;\n try { return inner() }\n finally { this.lineStart -= n; }\n };\n StringStream.prototype.lookAhead = function (n) {\n var oracle = this.lineOracle;\n return oracle && oracle.lookAhead(n)\n };\n StringStream.prototype.baseToken = function () {\n var oracle = this.lineOracle;\n return oracle && oracle.baseToken(this.pos)\n };\n\n // Find the line object corresponding to the given line number.\n function getLine(doc, n) {\n n -= doc.first;\n if (n < 0 || n >= doc.size) { throw new Error(\"There is no line \" + (n + doc.first) + \" in the document.\") }\n var chunk = doc;\n while (!chunk.lines) {\n for (var i = 0;; ++i) {\n var child = chunk.children[i], sz = child.chunkSize();\n if (n < sz) { chunk = child; break }\n n -= sz;\n }\n }\n return chunk.lines[n]\n }\n\n // Get the part of a document between two positions, as an array of\n // strings.\n function getBetween(doc, start, end) {\n var out = [], n = start.line;\n doc.iter(start.line, end.line + 1, function (line) {\n var text = line.text;\n if (n == end.line) { text = text.slice(0, end.ch); }\n if (n == start.line) { text = text.slice(start.ch); }\n out.push(text);\n ++n;\n });\n return out\n }\n // Get the lines between from and to, as array of strings.\n function getLines(doc, from, to) {\n var out = [];\n doc.iter(from, to, function (line) { out.push(line.text); }); // iter aborts when callback returns truthy value\n return out\n }\n\n // Update the height of a line, propagating the height change\n // upwards to parent nodes.\n function updateLineHeight(line, height) {\n var diff = height - line.height;\n if (diff) { for (var n = line; n; n = n.parent) { n.height += diff; } }\n }\n\n // Given a line object, find its line number by walking up through\n // its parent links.\n function lineNo(line) {\n if (line.parent == null) { return null }\n var cur = line.parent, no = indexOf(cur.lines, line);\n for (var chunk = cur.parent; chunk; cur = chunk, chunk = chunk.parent) {\n for (var i = 0;; ++i) {\n if (chunk.children[i] == cur) { break }\n no += chunk.children[i].chunkSize();\n }\n }\n return no + cur.first\n }\n\n // Find the line at the given vertical position, using the height\n // information in the document tree.\n function lineAtHeight(chunk, h) {\n var n = chunk.first;\n outer: do {\n for (var i$1 = 0; i$1 < chunk.children.length; ++i$1) {\n var child = chunk.children[i$1], ch = child.height;\n if (h < ch) { chunk = child; continue outer }\n h -= ch;\n n += child.chunkSize();\n }\n return n\n } while (!chunk.lines)\n var i = 0;\n for (; i < chunk.lines.length; ++i) {\n var line = chunk.lines[i], lh = line.height;\n if (h < lh) { break }\n h -= lh;\n }\n return n + i\n }\n\n function isLine(doc, l) {return l >= doc.first && l < doc.first + doc.size}\n\n function lineNumberFor(options, i) {\n return String(options.lineNumberFormatter(i + options.firstLineNumber))\n }\n\n // A Pos instance represents a position within the text.\n function Pos(line, ch, sticky) {\n if ( sticky === void 0 ) sticky = null;\n\n if (!(this instanceof Pos)) { return new Pos(line, ch, sticky) }\n this.line = line;\n this.ch = ch;\n this.sticky = sticky;\n }\n\n // Compare two positions, return 0 if they are the same, a negative\n // number when a is less, and a positive number otherwise.\n function cmp(a, b) { return a.line - b.line || a.ch - b.ch }\n\n function equalCursorPos(a, b) { return a.sticky == b.sticky && cmp(a, b) == 0 }\n\n function copyPos(x) {return Pos(x.line, x.ch)}\n function maxPos(a, b) { return cmp(a, b) < 0 ? b : a }\n function minPos(a, b) { return cmp(a, b) < 0 ? a : b }\n\n // Most of the external API clips given positions to make sure they\n // actually exist within the document.\n function clipLine(doc, n) {return Math.max(doc.first, Math.min(n, doc.first + doc.size - 1))}\n function clipPos(doc, pos) {\n if (pos.line < doc.first) { return Pos(doc.first, 0) }\n var last = doc.first + doc.size - 1;\n if (pos.line > last) { return Pos(last, getLine(doc, last).text.length) }\n return clipToLen(pos, getLine(doc, pos.line).text.length)\n }\n function clipToLen(pos, linelen) {\n var ch = pos.ch;\n if (ch == null || ch > linelen) { return Pos(pos.line, linelen) }\n else if (ch < 0) { return Pos(pos.line, 0) }\n else { return pos }\n }\n function clipPosArray(doc, array) {\n var out = [];\n for (var i = 0; i < array.length; i++) { out[i] = clipPos(doc, array[i]); }\n return out\n }\n\n var SavedContext = function(state, lookAhead) {\n this.state = state;\n this.lookAhead = lookAhead;\n };\n\n var Context = function(doc, state, line, lookAhead) {\n this.state = state;\n this.doc = doc;\n this.line = line;\n this.maxLookAhead = lookAhead || 0;\n this.baseTokens = null;\n this.baseTokenPos = 1;\n };\n\n Context.prototype.lookAhead = function (n) {\n var line = this.doc.getLine(this.line + n);\n if (line != null && n > this.maxLookAhead) { this.maxLookAhead = n; }\n return line\n };\n\n Context.prototype.baseToken = function (n) {\n var this$1 = this;\n\n if (!this.baseTokens) { return null }\n while (this.baseTokens[this.baseTokenPos] <= n)\n { this$1.baseTokenPos += 2; }\n var type = this.baseTokens[this.baseTokenPos + 1];\n return {type: type && type.replace(/( |^)overlay .*/, \"\"),\n size: this.baseTokens[this.baseTokenPos] - n}\n };\n\n Context.prototype.nextLine = function () {\n this.line++;\n if (this.maxLookAhead > 0) { this.maxLookAhead--; }\n };\n\n Context.fromSaved = function (doc, saved, line) {\n if (saved instanceof SavedContext)\n { return new Context(doc, copyState(doc.mode, saved.state), line, saved.lookAhead) }\n else\n { return new Context(doc, copyState(doc.mode, saved), line) }\n };\n\n Context.prototype.save = function (copy) {\n var state = copy !== false ? copyState(this.doc.mode, this.state) : this.state;\n return this.maxLookAhead > 0 ? new SavedContext(state, this.maxLookAhead) : state\n };\n\n\n // Compute a style array (an array starting with a mode generation\n // -- for invalidation -- followed by pairs of end positions and\n // style strings), which is used to highlight the tokens on the\n // line.\n function highlightLine(cm, line, context, forceToEnd) {\n // A styles array always starts with a number identifying the\n // mode/overlays that it is based on (for easy invalidation).\n var st = [cm.state.modeGen], lineClasses = {};\n // Compute the base array of styles\n runMode(cm, line.text, cm.doc.mode, context, function (end, style) { return st.push(end, style); },\n lineClasses, forceToEnd);\n var state = context.state;\n\n // Run overlays, adjust style array.\n var loop = function ( o ) {\n context.baseTokens = st;\n var overlay = cm.state.overlays[o], i = 1, at = 0;\n context.state = true;\n runMode(cm, line.text, overlay.mode, context, function (end, style) {\n var start = i;\n // Ensure there's a token end at the current position, and that i points at it\n while (at < end) {\n var i_end = st[i];\n if (i_end > end)\n { st.splice(i, 1, end, st[i+1], i_end); }\n i += 2;\n at = Math.min(end, i_end);\n }\n if (!style) { return }\n if (overlay.opaque) {\n st.splice(start, i - start, end, \"overlay \" + style);\n i = start + 2;\n } else {\n for (; start < i; start += 2) {\n var cur = st[start+1];\n st[start+1] = (cur ? cur + \" \" : \"\") + \"overlay \" + style;\n }\n }\n }, lineClasses);\n context.state = state;\n context.baseTokens = null;\n context.baseTokenPos = 1;\n };\n\n for (var o = 0; o < cm.state.overlays.length; ++o) loop( o );\n\n return {styles: st, classes: lineClasses.bgClass || lineClasses.textClass ? lineClasses : null}\n }\n\n function getLineStyles(cm, line, updateFrontier) {\n if (!line.styles || line.styles[0] != cm.state.modeGen) {\n var context = getContextBefore(cm, lineNo(line));\n var resetState = line.text.length > cm.options.maxHighlightLength && copyState(cm.doc.mode, context.state);\n var result = highlightLine(cm, line, context);\n if (resetState) { context.state = resetState; }\n line.stateAfter = context.save(!resetState);\n line.styles = result.styles;\n if (result.classes) { line.styleClasses = result.classes; }\n else if (line.styleClasses) { line.styleClasses = null; }\n if (updateFrontier === cm.doc.highlightFrontier)\n { cm.doc.modeFrontier = Math.max(cm.doc.modeFrontier, ++cm.doc.highlightFrontier); }\n }\n return line.styles\n }\n\n function getContextBefore(cm, n, precise) {\n var doc = cm.doc, display = cm.display;\n if (!doc.mode.startState) { return new Context(doc, true, n) }\n var start = findStartLine(cm, n, precise);\n var saved = start > doc.first && getLine(doc, start - 1).stateAfter;\n var context = saved ? Context.fromSaved(doc, saved, start) : new Context(doc, startState(doc.mode), start);\n\n doc.iter(start, n, function (line) {\n processLine(cm, line.text, context);\n var pos = context.line;\n line.stateAfter = pos == n - 1 || pos % 5 == 0 || pos >= display.viewFrom && pos < display.viewTo ? context.save() : null;\n context.nextLine();\n });\n if (precise) { doc.modeFrontier = context.line; }\n return context\n }\n\n // Lightweight form of highlight -- proceed over this line and\n // update state, but don't save a style array. Used for lines that\n // aren't currently visible.\n function processLine(cm, text, context, startAt) {\n var mode = cm.doc.mode;\n var stream = new StringStream(text, cm.options.tabSize, context);\n stream.start = stream.pos = startAt || 0;\n if (text == \"\") { callBlankLine(mode, context.state); }\n while (!stream.eol()) {\n readToken(mode, stream, context.state);\n stream.start = stream.pos;\n }\n }\n\n function callBlankLine(mode, state) {\n if (mode.blankLine) { return mode.blankLine(state) }\n if (!mode.innerMode) { return }\n var inner = innerMode(mode, state);\n if (inner.mode.blankLine) { return inner.mode.blankLine(inner.state) }\n }\n\n function readToken(mode, stream, state, inner) {\n for (var i = 0; i < 10; i++) {\n if (inner) { inner[0] = innerMode(mode, state).mode; }\n var style = mode.token(stream, state);\n if (stream.pos > stream.start) { return style }\n }\n throw new Error(\"Mode \" + mode.name + \" failed to advance stream.\")\n }\n\n var Token = function(stream, type, state) {\n this.start = stream.start; this.end = stream.pos;\n this.string = stream.current();\n this.type = type || null;\n this.state = state;\n };\n\n // Utility for getTokenAt and getLineTokens\n function takeToken(cm, pos, precise, asArray) {\n var doc = cm.doc, mode = doc.mode, style;\n pos = clipPos(doc, pos);\n var line = getLine(doc, pos.line), context = getContextBefore(cm, pos.line, precise);\n var stream = new StringStream(line.text, cm.options.tabSize, context), tokens;\n if (asArray) { tokens = []; }\n while ((asArray || stream.pos < pos.ch) && !stream.eol()) {\n stream.start = stream.pos;\n style = readToken(mode, stream, context.state);\n if (asArray) { tokens.push(new Token(stream, style, copyState(doc.mode, context.state))); }\n }\n return asArray ? tokens : new Token(stream, style, context.state)\n }\n\n function extractLineClasses(type, output) {\n if (type) { for (;;) {\n var lineClass = type.match(/(?:^|\\s+)line-(background-)?(\\S+)/);\n if (!lineClass) { break }\n type = type.slice(0, lineClass.index) + type.slice(lineClass.index + lineClass[0].length);\n var prop = lineClass[1] ? \"bgClass\" : \"textClass\";\n if (output[prop] == null)\n { output[prop] = lineClass[2]; }\n else if (!(new RegExp(\"(?:^|\\s)\" + lineClass[2] + \"(?:$|\\s)\")).test(output[prop]))\n { output[prop] += \" \" + lineClass[2]; }\n } }\n return type\n }\n\n // Run the given mode's parser over a line, calling f for each token.\n function runMode(cm, text, mode, context, f, lineClasses, forceToEnd) {\n var flattenSpans = mode.flattenSpans;\n if (flattenSpans == null) { flattenSpans = cm.options.flattenSpans; }\n var curStart = 0, curStyle = null;\n var stream = new StringStream(text, cm.options.tabSize, context), style;\n var inner = cm.options.addModeClass && [null];\n if (text == \"\") { extractLineClasses(callBlankLine(mode, context.state), lineClasses); }\n while (!stream.eol()) {\n if (stream.pos > cm.options.maxHighlightLength) {\n flattenSpans = false;\n if (forceToEnd) { processLine(cm, text, context, stream.pos); }\n stream.pos = text.length;\n style = null;\n } else {\n style = extractLineClasses(readToken(mode, stream, context.state, inner), lineClasses);\n }\n if (inner) {\n var mName = inner[0].name;\n if (mName) { style = \"m-\" + (style ? mName + \" \" + style : mName); }\n }\n if (!flattenSpans || curStyle != style) {\n while (curStart < stream.start) {\n curStart = Math.min(stream.start, curStart + 5000);\n f(curStart, curStyle);\n }\n curStyle = style;\n }\n stream.start = stream.pos;\n }\n while (curStart < stream.pos) {\n // Webkit seems to refuse to render text nodes longer than 57444\n // characters, and returns inaccurate measurements in nodes\n // starting around 5000 chars.\n var pos = Math.min(stream.pos, curStart + 5000);\n f(pos, curStyle);\n curStart = pos;\n }\n }\n\n // Finds the line to start with when starting a parse. Tries to\n // find a line with a stateAfter, so that it can start with a\n // valid state. If that fails, it returns the line with the\n // smallest indentation, which tends to need the least context to\n // parse correctly.\n function findStartLine(cm, n, precise) {\n var minindent, minline, doc = cm.doc;\n var lim = precise ? -1 : n - (cm.doc.mode.innerMode ? 1000 : 100);\n for (var search = n; search > lim; --search) {\n if (search <= doc.first) { return doc.first }\n var line = getLine(doc, search - 1), after = line.stateAfter;\n if (after && (!precise || search + (after instanceof SavedContext ? after.lookAhead : 0) <= doc.modeFrontier))\n { return search }\n var indented = countColumn(line.text, null, cm.options.tabSize);\n if (minline == null || minindent > indented) {\n minline = search - 1;\n minindent = indented;\n }\n }\n return minline\n }\n\n function retreatFrontier(doc, n) {\n doc.modeFrontier = Math.min(doc.modeFrontier, n);\n if (doc.highlightFrontier < n - 10) { return }\n var start = doc.first;\n for (var line = n - 1; line > start; line--) {\n var saved = getLine(doc, line).stateAfter;\n // change is on 3\n // state on line 1 looked ahead 2 -- so saw 3\n // test 1 + 2 < 3 should cover this\n if (saved && (!(saved instanceof SavedContext) || line + saved.lookAhead < n)) {\n start = line + 1;\n break\n }\n }\n doc.highlightFrontier = Math.min(doc.highlightFrontier, start);\n }\n\n // Optimize some code when these features are not used.\n var sawReadOnlySpans = false, sawCollapsedSpans = false;\n\n function seeReadOnlySpans() {\n sawReadOnlySpans = true;\n }\n\n function seeCollapsedSpans() {\n sawCollapsedSpans = true;\n }\n\n // TEXTMARKER SPANS\n\n function MarkedSpan(marker, from, to) {\n this.marker = marker;\n this.from = from; this.to = to;\n }\n\n // Search an array of spans for a span matching the given marker.\n function getMarkedSpanFor(spans, marker) {\n if (spans) { for (var i = 0; i < spans.length; ++i) {\n var span = spans[i];\n if (span.marker == marker) { return span }\n } }\n }\n // Remove a span from an array, returning undefined if no spans are\n // left (we don't store arrays for lines without spans).\n function removeMarkedSpan(spans, span) {\n var r;\n for (var i = 0; i < spans.length; ++i)\n { if (spans[i] != span) { (r || (r = [])).push(spans[i]); } }\n return r\n }\n // Add a span to a line.\n function addMarkedSpan(line, span) {\n line.markedSpans = line.markedSpans ? line.markedSpans.concat([span]) : [span];\n span.marker.attachLine(line);\n }\n\n // Used for the algorithm that adjusts markers for a change in the\n // document. These functions cut an array of spans at a given\n // character position, returning an array of remaining chunks (or\n // undefined if nothing remains).\n function markedSpansBefore(old, startCh, isInsert) {\n var nw;\n if (old) { for (var i = 0; i < old.length; ++i) {\n var span = old[i], marker = span.marker;\n var startsBefore = span.from == null || (marker.inclusiveLeft ? span.from <= startCh : span.from < startCh);\n if (startsBefore || span.from == startCh && marker.type == \"bookmark\" && (!isInsert || !span.marker.insertLeft)) {\n var endsAfter = span.to == null || (marker.inclusiveRight ? span.to >= startCh : span.to > startCh)\n ;(nw || (nw = [])).push(new MarkedSpan(marker, span.from, endsAfter ? null : span.to));\n }\n } }\n return nw\n }\n function markedSpansAfter(old, endCh, isInsert) {\n var nw;\n if (old) { for (var i = 0; i < old.length; ++i) {\n var span = old[i], marker = span.marker;\n var endsAfter = span.to == null || (marker.inclusiveRight ? span.to >= endCh : span.to > endCh);\n if (endsAfter || span.from == endCh && marker.type == \"bookmark\" && (!isInsert || span.marker.insertLeft)) {\n var startsBefore = span.from == null || (marker.inclusiveLeft ? span.from <= endCh : span.from < endCh)\n ;(nw || (nw = [])).push(new MarkedSpan(marker, startsBefore ? null : span.from - endCh,\n span.to == null ? null : span.to - endCh));\n }\n } }\n return nw\n }\n\n // Given a change object, compute the new set of marker spans that\n // cover the line in which the change took place. Removes spans\n // entirely within the change, reconnects spans belonging to the\n // same marker that appear on both sides of the change, and cuts off\n // spans partially within the change. Returns an array of span\n // arrays with one element for each line in (after) the change.\n function stretchSpansOverChange(doc, change) {\n if (change.full) { return null }\n var oldFirst = isLine(doc, change.from.line) && getLine(doc, change.from.line).markedSpans;\n var oldLast = isLine(doc, change.to.line) && getLine(doc, change.to.line).markedSpans;\n if (!oldFirst && !oldLast) { return null }\n\n var startCh = change.from.ch, endCh = change.to.ch, isInsert = cmp(change.from, change.to) == 0;\n // Get the spans that 'stick out' on both sides\n var first = markedSpansBefore(oldFirst, startCh, isInsert);\n var last = markedSpansAfter(oldLast, endCh, isInsert);\n\n // Next, merge those two ends\n var sameLine = change.text.length == 1, offset = lst(change.text).length + (sameLine ? startCh : 0);\n if (first) {\n // Fix up .to properties of first\n for (var i = 0; i < first.length; ++i) {\n var span = first[i];\n if (span.to == null) {\n var found = getMarkedSpanFor(last, span.marker);\n if (!found) { span.to = startCh; }\n else if (sameLine) { span.to = found.to == null ? null : found.to + offset; }\n }\n }\n }\n if (last) {\n // Fix up .from in last (or move them into first in case of sameLine)\n for (var i$1 = 0; i$1 < last.length; ++i$1) {\n var span$1 = last[i$1];\n if (span$1.to != null) { span$1.to += offset; }\n if (span$1.from == null) {\n var found$1 = getMarkedSpanFor(first, span$1.marker);\n if (!found$1) {\n span$1.from = offset;\n if (sameLine) { (first || (first = [])).push(span$1); }\n }\n } else {\n span$1.from += offset;\n if (sameLine) { (first || (first = [])).push(span$1); }\n }\n }\n }\n // Make sure we didn't create any zero-length spans\n if (first) { first = clearEmptySpans(first); }\n if (last && last != first) { last = clearEmptySpans(last); }\n\n var newMarkers = [first];\n if (!sameLine) {\n // Fill gap with whole-line-spans\n var gap = change.text.length - 2, gapMarkers;\n if (gap > 0 && first)\n { for (var i$2 = 0; i$2 < first.length; ++i$2)\n { if (first[i$2].to == null)\n { (gapMarkers || (gapMarkers = [])).push(new MarkedSpan(first[i$2].marker, null, null)); } } }\n for (var i$3 = 0; i$3 < gap; ++i$3)\n { newMarkers.push(gapMarkers); }\n newMarkers.push(last);\n }\n return newMarkers\n }\n\n // Remove spans that are empty and don't have a clearWhenEmpty\n // option of false.\n function clearEmptySpans(spans) {\n for (var i = 0; i < spans.length; ++i) {\n var span = spans[i];\n if (span.from != null && span.from == span.to && span.marker.clearWhenEmpty !== false)\n { spans.splice(i--, 1); }\n }\n if (!spans.length) { return null }\n return spans\n }\n\n // Used to 'clip' out readOnly ranges when making a change.\n function removeReadOnlyRanges(doc, from, to) {\n var markers = null;\n doc.iter(from.line, to.line + 1, function (line) {\n if (line.markedSpans) { for (var i = 0; i < line.markedSpans.length; ++i) {\n var mark = line.markedSpans[i].marker;\n if (mark.readOnly && (!markers || indexOf(markers, mark) == -1))\n { (markers || (markers = [])).push(mark); }\n } }\n });\n if (!markers) { return null }\n var parts = [{from: from, to: to}];\n for (var i = 0; i < markers.length; ++i) {\n var mk = markers[i], m = mk.find(0);\n for (var j = 0; j < parts.length; ++j) {\n var p = parts[j];\n if (cmp(p.to, m.from) < 0 || cmp(p.from, m.to) > 0) { continue }\n var newParts = [j, 1], dfrom = cmp(p.from, m.from), dto = cmp(p.to, m.to);\n if (dfrom < 0 || !mk.inclusiveLeft && !dfrom)\n { newParts.push({from: p.from, to: m.from}); }\n if (dto > 0 || !mk.inclusiveRight && !dto)\n { newParts.push({from: m.to, to: p.to}); }\n parts.splice.apply(parts, newParts);\n j += newParts.length - 3;\n }\n }\n return parts\n }\n\n // Connect or disconnect spans from a line.\n function detachMarkedSpans(line) {\n var spans = line.markedSpans;\n if (!spans) { return }\n for (var i = 0; i < spans.length; ++i)\n { spans[i].marker.detachLine(line); }\n line.markedSpans = null;\n }\n function attachMarkedSpans(line, spans) {\n if (!spans) { return }\n for (var i = 0; i < spans.length; ++i)\n { spans[i].marker.attachLine(line); }\n line.markedSpans = spans;\n }\n\n // Helpers used when computing which overlapping collapsed span\n // counts as the larger one.\n function extraLeft(marker) { return marker.inclusiveLeft ? -1 : 0 }\n function extraRight(marker) { return marker.inclusiveRight ? 1 : 0 }\n\n // Returns a number indicating which of two overlapping collapsed\n // spans is larger (and thus includes the other). Falls back to\n // comparing ids when the spans cover exactly the same range.\n function compareCollapsedMarkers(a, b) {\n var lenDiff = a.lines.length - b.lines.length;\n if (lenDiff != 0) { return lenDiff }\n var aPos = a.find(), bPos = b.find();\n var fromCmp = cmp(aPos.from, bPos.from) || extraLeft(a) - extraLeft(b);\n if (fromCmp) { return -fromCmp }\n var toCmp = cmp(aPos.to, bPos.to) || extraRight(a) - extraRight(b);\n if (toCmp) { return toCmp }\n return b.id - a.id\n }\n\n // Find out whether a line ends or starts in a collapsed span. If\n // so, return the marker for that span.\n function collapsedSpanAtSide(line, start) {\n var sps = sawCollapsedSpans && line.markedSpans, found;\n if (sps) { for (var sp = (void 0), i = 0; i < sps.length; ++i) {\n sp = sps[i];\n if (sp.marker.collapsed && (start ? sp.from : sp.to) == null &&\n (!found || compareCollapsedMarkers(found, sp.marker) < 0))\n { found = sp.marker; }\n } }\n return found\n }\n function collapsedSpanAtStart(line) { return collapsedSpanAtSide(line, true) }\n function collapsedSpanAtEnd(line) { return collapsedSpanAtSide(line, false) }\n\n function collapsedSpanAround(line, ch) {\n var sps = sawCollapsedSpans && line.markedSpans, found;\n if (sps) { for (var i = 0; i < sps.length; ++i) {\n var sp = sps[i];\n if (sp.marker.collapsed && (sp.from == null || sp.from < ch) && (sp.to == null || sp.to > ch) &&\n (!found || compareCollapsedMarkers(found, sp.marker) < 0)) { found = sp.marker; }\n } }\n return found\n }\n\n // Test whether there exists a collapsed span that partially\n // overlaps (covers the start or end, but not both) of a new span.\n // Such overlap is not allowed.\n function conflictingCollapsedRange(doc, lineNo$$1, from, to, marker) {\n var line = getLine(doc, lineNo$$1);\n var sps = sawCollapsedSpans && line.markedSpans;\n if (sps) { for (var i = 0; i < sps.length; ++i) {\n var sp = sps[i];\n if (!sp.marker.collapsed) { continue }\n var found = sp.marker.find(0);\n var fromCmp = cmp(found.from, from) || extraLeft(sp.marker) - extraLeft(marker);\n var toCmp = cmp(found.to, to) || extraRight(sp.marker) - extraRight(marker);\n if (fromCmp >= 0 && toCmp <= 0 || fromCmp <= 0 && toCmp >= 0) { continue }\n if (fromCmp <= 0 && (sp.marker.inclusiveRight && marker.inclusiveLeft ? cmp(found.to, from) >= 0 : cmp(found.to, from) > 0) ||\n fromCmp >= 0 && (sp.marker.inclusiveRight && marker.inclusiveLeft ? cmp(found.from, to) <= 0 : cmp(found.from, to) < 0))\n { return true }\n } }\n }\n\n // A visual line is a line as drawn on the screen. Folding, for\n // example, can cause multiple logical lines to appear on the same\n // visual line. This finds the start of the visual line that the\n // given line is part of (usually that is the line itself).\n function visualLine(line) {\n var merged;\n while (merged = collapsedSpanAtStart(line))\n { line = merged.find(-1, true).line; }\n return line\n }\n\n function visualLineEnd(line) {\n var merged;\n while (merged = collapsedSpanAtEnd(line))\n { line = merged.find(1, true).line; }\n return line\n }\n\n // Returns an array of logical lines that continue the visual line\n // started by the argument, or undefined if there are no such lines.\n function visualLineContinued(line) {\n var merged, lines;\n while (merged = collapsedSpanAtEnd(line)) {\n line = merged.find(1, true).line\n ;(lines || (lines = [])).push(line);\n }\n return lines\n }\n\n // Get the line number of the start of the visual line that the\n // given line number is part of.\n function visualLineNo(doc, lineN) {\n var line = getLine(doc, lineN), vis = visualLine(line);\n if (line == vis) { return lineN }\n return lineNo(vis)\n }\n\n // Get the line number of the start of the next visual line after\n // the given line.\n function visualLineEndNo(doc, lineN) {\n if (lineN > doc.lastLine()) { return lineN }\n var line = getLine(doc, lineN), merged;\n if (!lineIsHidden(doc, line)) { return lineN }\n while (merged = collapsedSpanAtEnd(line))\n { line = merged.find(1, true).line; }\n return lineNo(line) + 1\n }\n\n // Compute whether a line is hidden. Lines count as hidden when they\n // are part of a visual line that starts with another line, or when\n // they are entirely covered by collapsed, non-widget span.\n function lineIsHidden(doc, line) {\n var sps = sawCollapsedSpans && line.markedSpans;\n if (sps) { for (var sp = (void 0), i = 0; i < sps.length; ++i) {\n sp = sps[i];\n if (!sp.marker.collapsed) { continue }\n if (sp.from == null) { return true }\n if (sp.marker.widgetNode) { continue }\n if (sp.from == 0 && sp.marker.inclusiveLeft && lineIsHiddenInner(doc, line, sp))\n { return true }\n } }\n }\n function lineIsHiddenInner(doc, line, span) {\n if (span.to == null) {\n var end = span.marker.find(1, true);\n return lineIsHiddenInner(doc, end.line, getMarkedSpanFor(end.line.markedSpans, span.marker))\n }\n if (span.marker.inclusiveRight && span.to == line.text.length)\n { return true }\n for (var sp = (void 0), i = 0; i < line.markedSpans.length; ++i) {\n sp = line.markedSpans[i];\n if (sp.marker.collapsed && !sp.marker.widgetNode && sp.from == span.to &&\n (sp.to == null || sp.to != span.from) &&\n (sp.marker.inclusiveLeft || span.marker.inclusiveRight) &&\n lineIsHiddenInner(doc, line, sp)) { return true }\n }\n }\n\n // Find the height above the given line.\n function heightAtLine(lineObj) {\n lineObj = visualLine(lineObj);\n\n var h = 0, chunk = lineObj.parent;\n for (var i = 0; i < chunk.lines.length; ++i) {\n var line = chunk.lines[i];\n if (line == lineObj) { break }\n else { h += line.height; }\n }\n for (var p = chunk.parent; p; chunk = p, p = chunk.parent) {\n for (var i$1 = 0; i$1 < p.children.length; ++i$1) {\n var cur = p.children[i$1];\n if (cur == chunk) { break }\n else { h += cur.height; }\n }\n }\n return h\n }\n\n // Compute the character length of a line, taking into account\n // collapsed ranges (see markText) that might hide parts, and join\n // other lines onto it.\n function lineLength(line) {\n if (line.height == 0) { return 0 }\n var len = line.text.length, merged, cur = line;\n while (merged = collapsedSpanAtStart(cur)) {\n var found = merged.find(0, true);\n cur = found.from.line;\n len += found.from.ch - found.to.ch;\n }\n cur = line;\n while (merged = collapsedSpanAtEnd(cur)) {\n var found$1 = merged.find(0, true);\n len -= cur.text.length - found$1.from.ch;\n cur = found$1.to.line;\n len += cur.text.length - found$1.to.ch;\n }\n return len\n }\n\n // Find the longest line in the document.\n function findMaxLine(cm) {\n var d = cm.display, doc = cm.doc;\n d.maxLine = getLine(doc, doc.first);\n d.maxLineLength = lineLength(d.maxLine);\n d.maxLineChanged = true;\n doc.iter(function (line) {\n var len = lineLength(line);\n if (len > d.maxLineLength) {\n d.maxLineLength = len;\n d.maxLine = line;\n }\n });\n }\n\n // LINE DATA STRUCTURE\n\n // Line objects. These hold state related to a line, including\n // highlighting info (the styles array).\n var Line = function(text, markedSpans, estimateHeight) {\n this.text = text;\n attachMarkedSpans(this, markedSpans);\n this.height = estimateHeight ? estimateHeight(this) : 1;\n };\n\n Line.prototype.lineNo = function () { return lineNo(this) };\n eventMixin(Line);\n\n // Change the content (text, markers) of a line. Automatically\n // invalidates cached information and tries to re-estimate the\n // line's height.\n function updateLine(line, text, markedSpans, estimateHeight) {\n line.text = text;\n if (line.stateAfter) { line.stateAfter = null; }\n if (line.styles) { line.styles = null; }\n if (line.order != null) { line.order = null; }\n detachMarkedSpans(line);\n attachMarkedSpans(line, markedSpans);\n var estHeight = estimateHeight ? estimateHeight(line) : 1;\n if (estHeight != line.height) { updateLineHeight(line, estHeight); }\n }\n\n // Detach a line from the document tree and its markers.\n function cleanUpLine(line) {\n line.parent = null;\n detachMarkedSpans(line);\n }\n\n // Convert a style as returned by a mode (either null, or a string\n // containing one or more styles) to a CSS style. This is cached,\n // and also looks for line-wide styles.\n var styleToClassCache = {}, styleToClassCacheWithMode = {};\n function interpretTokenStyle(style, options) {\n if (!style || /^\\s*$/.test(style)) { return null }\n var cache = options.addModeClass ? styleToClassCacheWithMode : styleToClassCache;\n return cache[style] ||\n (cache[style] = style.replace(/\\S+/g, \"cm-$&\"))\n }\n\n // Render the DOM representation of the text of a line. Also builds\n // up a 'line map', which points at the DOM nodes that represent\n // specific stretches of text, and is used by the measuring code.\n // The returned object contains the DOM node, this map, and\n // information about line-wide styles that were set by the mode.\n function buildLineContent(cm, lineView) {\n // The padding-right forces the element to have a 'border', which\n // is needed on Webkit to be able to get line-level bounding\n // rectangles for it (in measureChar).\n var content = eltP(\"span\", null, null, webkit ? \"padding-right: .1px\" : null);\n var builder = {pre: eltP(\"pre\", [content], \"CodeMirror-line\"), content: content,\n col: 0, pos: 0, cm: cm,\n trailingSpace: false,\n splitSpaces: cm.getOption(\"lineWrapping\")};\n lineView.measure = {};\n\n // Iterate over the logical lines that make up this visual line.\n for (var i = 0; i <= (lineView.rest ? lineView.rest.length : 0); i++) {\n var line = i ? lineView.rest[i - 1] : lineView.line, order = (void 0);\n builder.pos = 0;\n builder.addToken = buildToken;\n // Optionally wire in some hacks into the token-rendering\n // algorithm, to deal with browser quirks.\n if (hasBadBidiRects(cm.display.measure) && (order = getOrder(line, cm.doc.direction)))\n { builder.addToken = buildTokenBadBidi(builder.addToken, order); }\n builder.map = [];\n var allowFrontierUpdate = lineView != cm.display.externalMeasured && lineNo(line);\n insertLineContent(line, builder, getLineStyles(cm, line, allowFrontierUpdate));\n if (line.styleClasses) {\n if (line.styleClasses.bgClass)\n { builder.bgClass = joinClasses(line.styleClasses.bgClass, builder.bgClass || \"\"); }\n if (line.styleClasses.textClass)\n { builder.textClass = joinClasses(line.styleClasses.textClass, builder.textClass || \"\"); }\n }\n\n // Ensure at least a single node is present, for measuring.\n if (builder.map.length == 0)\n { builder.map.push(0, 0, builder.content.appendChild(zeroWidthElement(cm.display.measure))); }\n\n // Store the map and a cache object for the current logical line\n if (i == 0) {\n lineView.measure.map = builder.map;\n lineView.measure.cache = {};\n } else {\n (lineView.measure.maps || (lineView.measure.maps = [])).push(builder.map)\n ;(lineView.measure.caches || (lineView.measure.caches = [])).push({});\n }\n }\n\n // See issue #2901\n if (webkit) {\n var last = builder.content.lastChild;\n if (/\\bcm-tab\\b/.test(last.className) || (last.querySelector && last.querySelector(\".cm-tab\")))\n { builder.content.className = \"cm-tab-wrap-hack\"; }\n }\n\n signal(cm, \"renderLine\", cm, lineView.line, builder.pre);\n if (builder.pre.className)\n { builder.textClass = joinClasses(builder.pre.className, builder.textClass || \"\"); }\n\n return builder\n }\n\n function defaultSpecialCharPlaceholder(ch) {\n var token = elt(\"span\", \"\\u2022\", \"cm-invalidchar\");\n token.title = \"\\\\u\" + ch.charCodeAt(0).toString(16);\n token.setAttribute(\"aria-label\", token.title);\n return token\n }\n\n // Build up the DOM representation for a single token, and add it to\n // the line map. Takes care to render special characters separately.\n function buildToken(builder, text, style, startStyle, endStyle, css, attributes) {\n if (!text) { return }\n var displayText = builder.splitSpaces ? splitSpaces(text, builder.trailingSpace) : text;\n var special = builder.cm.state.specialChars, mustWrap = false;\n var content;\n if (!special.test(text)) {\n builder.col += text.length;\n content = document.createTextNode(displayText);\n builder.map.push(builder.pos, builder.pos + text.length, content);\n if (ie && ie_version < 9) { mustWrap = true; }\n builder.pos += text.length;\n } else {\n content = document.createDocumentFragment();\n var pos = 0;\n while (true) {\n special.lastIndex = pos;\n var m = special.exec(text);\n var skipped = m ? m.index - pos : text.length - pos;\n if (skipped) {\n var txt = document.createTextNode(displayText.slice(pos, pos + skipped));\n if (ie && ie_version < 9) { content.appendChild(elt(\"span\", [txt])); }\n else { content.appendChild(txt); }\n builder.map.push(builder.pos, builder.pos + skipped, txt);\n builder.col += skipped;\n builder.pos += skipped;\n }\n if (!m) { break }\n pos += skipped + 1;\n var txt$1 = (void 0);\n if (m[0] == \"\\t\") {\n var tabSize = builder.cm.options.tabSize, tabWidth = tabSize - builder.col % tabSize;\n txt$1 = content.appendChild(elt(\"span\", spaceStr(tabWidth), \"cm-tab\"));\n txt$1.setAttribute(\"role\", \"presentation\");\n txt$1.setAttribute(\"cm-text\", \"\\t\");\n builder.col += tabWidth;\n } else if (m[0] == \"\\r\" || m[0] == \"\\n\") {\n txt$1 = content.appendChild(elt(\"span\", m[0] == \"\\r\" ? \"\\u240d\" : \"\\u2424\", \"cm-invalidchar\"));\n txt$1.setAttribute(\"cm-text\", m[0]);\n builder.col += 1;\n } else {\n txt$1 = builder.cm.options.specialCharPlaceholder(m[0]);\n txt$1.setAttribute(\"cm-text\", m[0]);\n if (ie && ie_version < 9) { content.appendChild(elt(\"span\", [txt$1])); }\n else { content.appendChild(txt$1); }\n builder.col += 1;\n }\n builder.map.push(builder.pos, builder.pos + 1, txt$1);\n builder.pos++;\n }\n }\n builder.trailingSpace = displayText.charCodeAt(text.length - 1) == 32;\n if (style || startStyle || endStyle || mustWrap || css) {\n var fullStyle = style || \"\";\n if (startStyle) { fullStyle += startStyle; }\n if (endStyle) { fullStyle += endStyle; }\n var token = elt(\"span\", [content], fullStyle, css);\n if (attributes) {\n for (var attr in attributes) { if (attributes.hasOwnProperty(attr) && attr != \"style\" && attr != \"class\")\n { token.setAttribute(attr, attributes[attr]); } }\n }\n return builder.content.appendChild(token)\n }\n builder.content.appendChild(content);\n }\n\n // Change some spaces to NBSP to prevent the browser from collapsing\n // trailing spaces at the end of a line when rendering text (issue #1362).\n function splitSpaces(text, trailingBefore) {\n if (text.length > 1 && !/ /.test(text)) { return text }\n var spaceBefore = trailingBefore, result = \"\";\n for (var i = 0; i < text.length; i++) {\n var ch = text.charAt(i);\n if (ch == \" \" && spaceBefore && (i == text.length - 1 || text.charCodeAt(i + 1) == 32))\n { ch = \"\\u00a0\"; }\n result += ch;\n spaceBefore = ch == \" \";\n }\n return result\n }\n\n // Work around nonsense dimensions being reported for stretches of\n // right-to-left text.\n function buildTokenBadBidi(inner, order) {\n return function (builder, text, style, startStyle, endStyle, css, attributes) {\n style = style ? style + \" cm-force-border\" : \"cm-force-border\";\n var start = builder.pos, end = start + text.length;\n for (;;) {\n // Find the part that overlaps with the start of this text\n var part = (void 0);\n for (var i = 0; i < order.length; i++) {\n part = order[i];\n if (part.to > start && part.from <= start) { break }\n }\n if (part.to >= end) { return inner(builder, text, style, startStyle, endStyle, css, attributes) }\n inner(builder, text.slice(0, part.to - start), style, startStyle, null, css, attributes);\n startStyle = null;\n text = text.slice(part.to - start);\n start = part.to;\n }\n }\n }\n\n function buildCollapsedSpan(builder, size, marker, ignoreWidget) {\n var widget = !ignoreWidget && marker.widgetNode;\n if (widget) { builder.map.push(builder.pos, builder.pos + size, widget); }\n if (!ignoreWidget && builder.cm.display.input.needsContentAttribute) {\n if (!widget)\n { widget = builder.content.appendChild(document.createElement(\"span\")); }\n widget.setAttribute(\"cm-marker\", marker.id);\n }\n if (widget) {\n builder.cm.display.input.setUneditable(widget);\n builder.content.appendChild(widget);\n }\n builder.pos += size;\n builder.trailingSpace = false;\n }\n\n // Outputs a number of spans to make up a line, taking highlighting\n // and marked text into account.\n function insertLineContent(line, builder, styles) {\n var spans = line.markedSpans, allText = line.text, at = 0;\n if (!spans) {\n for (var i$1 = 1; i$1 < styles.length; i$1+=2)\n { builder.addToken(builder, allText.slice(at, at = styles[i$1]), interpretTokenStyle(styles[i$1+1], builder.cm.options)); }\n return\n }\n\n var len = allText.length, pos = 0, i = 1, text = \"\", style, css;\n var nextChange = 0, spanStyle, spanEndStyle, spanStartStyle, collapsed, attributes;\n for (;;) {\n if (nextChange == pos) { // Update current marker set\n spanStyle = spanEndStyle = spanStartStyle = css = \"\";\n attributes = null;\n collapsed = null; nextChange = Infinity;\n var foundBookmarks = [], endStyles = (void 0);\n for (var j = 0; j < spans.length; ++j) {\n var sp = spans[j], m = sp.marker;\n if (m.type == \"bookmark\" && sp.from == pos && m.widgetNode) {\n foundBookmarks.push(m);\n } else if (sp.from <= pos && (sp.to == null || sp.to > pos || m.collapsed && sp.to == pos && sp.from == pos)) {\n if (sp.to != null && sp.to != pos && nextChange > sp.to) {\n nextChange = sp.to;\n spanEndStyle = \"\";\n }\n if (m.className) { spanStyle += \" \" + m.className; }\n if (m.css) { css = (css ? css + \";\" : \"\") + m.css; }\n if (m.startStyle && sp.from == pos) { spanStartStyle += \" \" + m.startStyle; }\n if (m.endStyle && sp.to == nextChange) { (endStyles || (endStyles = [])).push(m.endStyle, sp.to); }\n // support for the old title property\n // https://github.com/codemirror/CodeMirror/pull/5673\n if (m.title) { (attributes || (attributes = {})).title = m.title; }\n if (m.attributes) {\n for (var attr in m.attributes)\n { (attributes || (attributes = {}))[attr] = m.attributes[attr]; }\n }\n if (m.collapsed && (!collapsed || compareCollapsedMarkers(collapsed.marker, m) < 0))\n { collapsed = sp; }\n } else if (sp.from > pos && nextChange > sp.from) {\n nextChange = sp.from;\n }\n }\n if (endStyles) { for (var j$1 = 0; j$1 < endStyles.length; j$1 += 2)\n { if (endStyles[j$1 + 1] == nextChange) { spanEndStyle += \" \" + endStyles[j$1]; } } }\n\n if (!collapsed || collapsed.from == pos) { for (var j$2 = 0; j$2 < foundBookmarks.length; ++j$2)\n { buildCollapsedSpan(builder, 0, foundBookmarks[j$2]); } }\n if (collapsed && (collapsed.from || 0) == pos) {\n buildCollapsedSpan(builder, (collapsed.to == null ? len + 1 : collapsed.to) - pos,\n collapsed.marker, collapsed.from == null);\n if (collapsed.to == null) { return }\n if (collapsed.to == pos) { collapsed = false; }\n }\n }\n if (pos >= len) { break }\n\n var upto = Math.min(len, nextChange);\n while (true) {\n if (text) {\n var end = pos + text.length;\n if (!collapsed) {\n var tokenText = end > upto ? text.slice(0, upto - pos) : text;\n builder.addToken(builder, tokenText, style ? style + spanStyle : spanStyle,\n spanStartStyle, pos + tokenText.length == nextChange ? spanEndStyle : \"\", css, attributes);\n }\n if (end >= upto) {text = text.slice(upto - pos); pos = upto; break}\n pos = end;\n spanStartStyle = \"\";\n }\n text = allText.slice(at, at = styles[i++]);\n style = interpretTokenStyle(styles[i++], builder.cm.options);\n }\n }\n }\n\n\n // These objects are used to represent the visible (currently drawn)\n // part of the document. A LineView may correspond to multiple\n // logical lines, if those are connected by collapsed ranges.\n function LineView(doc, line, lineN) {\n // The starting line\n this.line = line;\n // Continuing lines, if any\n this.rest = visualLineContinued(line);\n // Number of logical lines in this visual line\n this.size = this.rest ? lineNo(lst(this.rest)) - lineN + 1 : 1;\n this.node = this.text = null;\n this.hidden = lineIsHidden(doc, line);\n }\n\n // Create a range of LineView objects for the given lines.\n function buildViewArray(cm, from, to) {\n var array = [], nextPos;\n for (var pos = from; pos < to; pos = nextPos) {\n var view = new LineView(cm.doc, getLine(cm.doc, pos), pos);\n nextPos = pos + view.size;\n array.push(view);\n }\n return array\n }\n\n var operationGroup = null;\n\n function pushOperation(op) {\n if (operationGroup) {\n operationGroup.ops.push(op);\n } else {\n op.ownsGroup = operationGroup = {\n ops: [op],\n delayedCallbacks: []\n };\n }\n }\n\n function fireCallbacksForOps(group) {\n // Calls delayed callbacks and cursorActivity handlers until no\n // new ones appear\n var callbacks = group.delayedCallbacks, i = 0;\n do {\n for (; i < callbacks.length; i++)\n { callbacks[i].call(null); }\n for (var j = 0; j < group.ops.length; j++) {\n var op = group.ops[j];\n if (op.cursorActivityHandlers)\n { while (op.cursorActivityCalled < op.cursorActivityHandlers.length)\n { op.cursorActivityHandlers[op.cursorActivityCalled++].call(null, op.cm); } }\n }\n } while (i < callbacks.length)\n }\n\n function finishOperation(op, endCb) {\n var group = op.ownsGroup;\n if (!group) { return }\n\n try { fireCallbacksForOps(group); }\n finally {\n operationGroup = null;\n endCb(group);\n }\n }\n\n var orphanDelayedCallbacks = null;\n\n // Often, we want to signal events at a point where we are in the\n // middle of some work, but don't want the handler to start calling\n // other methods on the editor, which might be in an inconsistent\n // state or simply not expect any other events to happen.\n // signalLater looks whether there are any handlers, and schedules\n // them to be executed when the last operation ends, or, if no\n // operation is active, when a timeout fires.\n function signalLater(emitter, type /*, values...*/) {\n var arr = getHandlers(emitter, type);\n if (!arr.length) { return }\n var args = Array.prototype.slice.call(arguments, 2), list;\n if (operationGroup) {\n list = operationGroup.delayedCallbacks;\n } else if (orphanDelayedCallbacks) {\n list = orphanDelayedCallbacks;\n } else {\n list = orphanDelayedCallbacks = [];\n setTimeout(fireOrphanDelayed, 0);\n }\n var loop = function ( i ) {\n list.push(function () { return arr[i].apply(null, args); });\n };\n\n for (var i = 0; i < arr.length; ++i)\n loop( i );\n }\n\n function fireOrphanDelayed() {\n var delayed = orphanDelayedCallbacks;\n orphanDelayedCallbacks = null;\n for (var i = 0; i < delayed.length; ++i) { delayed[i](); }\n }\n\n // When an aspect of a line changes, a string is added to\n // lineView.changes. This updates the relevant part of the line's\n // DOM structure.\n function updateLineForChanges(cm, lineView, lineN, dims) {\n for (var j = 0; j < lineView.changes.length; j++) {\n var type = lineView.changes[j];\n if (type == \"text\") { updateLineText(cm, lineView); }\n else if (type == \"gutter\") { updateLineGutter(cm, lineView, lineN, dims); }\n else if (type == \"class\") { updateLineClasses(cm, lineView); }\n else if (type == \"widget\") { updateLineWidgets(cm, lineView, dims); }\n }\n lineView.changes = null;\n }\n\n // Lines with gutter elements, widgets or a background class need to\n // be wrapped, and have the extra elements added to the wrapper div\n function ensureLineWrapped(lineView) {\n if (lineView.node == lineView.text) {\n lineView.node = elt(\"div\", null, null, \"position: relative\");\n if (lineView.text.parentNode)\n { lineView.text.parentNode.replaceChild(lineView.node, lineView.text); }\n lineView.node.appendChild(lineView.text);\n if (ie && ie_version < 8) { lineView.node.style.zIndex = 2; }\n }\n return lineView.node\n }\n\n function updateLineBackground(cm, lineView) {\n var cls = lineView.bgClass ? lineView.bgClass + \" \" + (lineView.line.bgClass || \"\") : lineView.line.bgClass;\n if (cls) { cls += \" CodeMirror-linebackground\"; }\n if (lineView.background) {\n if (cls) { lineView.background.className = cls; }\n else { lineView.background.parentNode.removeChild(lineView.background); lineView.background = null; }\n } else if (cls) {\n var wrap = ensureLineWrapped(lineView);\n lineView.background = wrap.insertBefore(elt(\"div\", null, cls), wrap.firstChild);\n cm.display.input.setUneditable(lineView.background);\n }\n }\n\n // Wrapper around buildLineContent which will reuse the structure\n // in display.externalMeasured when possible.\n function getLineContent(cm, lineView) {\n var ext = cm.display.externalMeasured;\n if (ext && ext.line == lineView.line) {\n cm.display.externalMeasured = null;\n lineView.measure = ext.measure;\n return ext.built\n }\n return buildLineContent(cm, lineView)\n }\n\n // Redraw the line's text. Interacts with the background and text\n // classes because the mode may output tokens that influence these\n // classes.\n function updateLineText(cm, lineView) {\n var cls = lineView.text.className;\n var built = getLineContent(cm, lineView);\n if (lineView.text == lineView.node) { lineView.node = built.pre; }\n lineView.text.parentNode.replaceChild(built.pre, lineView.text);\n lineView.text = built.pre;\n if (built.bgClass != lineView.bgClass || built.textClass != lineView.textClass) {\n lineView.bgClass = built.bgClass;\n lineView.textClass = built.textClass;\n updateLineClasses(cm, lineView);\n } else if (cls) {\n lineView.text.className = cls;\n }\n }\n\n function updateLineClasses(cm, lineView) {\n updateLineBackground(cm, lineView);\n if (lineView.line.wrapClass)\n { ensureLineWrapped(lineView).className = lineView.line.wrapClass; }\n else if (lineView.node != lineView.text)\n { lineView.node.className = \"\"; }\n var textClass = lineView.textClass ? lineView.textClass + \" \" + (lineView.line.textClass || \"\") : lineView.line.textClass;\n lineView.text.className = textClass || \"\";\n }\n\n function updateLineGutter(cm, lineView, lineN, dims) {\n if (lineView.gutter) {\n lineView.node.removeChild(lineView.gutter);\n lineView.gutter = null;\n }\n if (lineView.gutterBackground) {\n lineView.node.removeChild(lineView.gutterBackground);\n lineView.gutterBackground = null;\n }\n if (lineView.line.gutterClass) {\n var wrap = ensureLineWrapped(lineView);\n lineView.gutterBackground = elt(\"div\", null, \"CodeMirror-gutter-background \" + lineView.line.gutterClass,\n (\"left: \" + (cm.options.fixedGutter ? dims.fixedPos : -dims.gutterTotalWidth) + \"px; width: \" + (dims.gutterTotalWidth) + \"px\"));\n cm.display.input.setUneditable(lineView.gutterBackground);\n wrap.insertBefore(lineView.gutterBackground, lineView.text);\n }\n var markers = lineView.line.gutterMarkers;\n if (cm.options.lineNumbers || markers) {\n var wrap$1 = ensureLineWrapped(lineView);\n var gutterWrap = lineView.gutter = elt(\"div\", null, \"CodeMirror-gutter-wrapper\", (\"left: \" + (cm.options.fixedGutter ? dims.fixedPos : -dims.gutterTotalWidth) + \"px\"));\n cm.display.input.setUneditable(gutterWrap);\n wrap$1.insertBefore(gutterWrap, lineView.text);\n if (lineView.line.gutterClass)\n { gutterWrap.className += \" \" + lineView.line.gutterClass; }\n if (cm.options.lineNumbers && (!markers || !markers[\"CodeMirror-linenumbers\"]))\n { lineView.lineNumber = gutterWrap.appendChild(\n elt(\"div\", lineNumberFor(cm.options, lineN),\n \"CodeMirror-linenumber CodeMirror-gutter-elt\",\n (\"left: \" + (dims.gutterLeft[\"CodeMirror-linenumbers\"]) + \"px; width: \" + (cm.display.lineNumInnerWidth) + \"px\"))); }\n if (markers) { for (var k = 0; k < cm.display.gutterSpecs.length; ++k) {\n var id = cm.display.gutterSpecs[k].className, found = markers.hasOwnProperty(id) && markers[id];\n if (found)\n { gutterWrap.appendChild(elt(\"div\", [found], \"CodeMirror-gutter-elt\",\n (\"left: \" + (dims.gutterLeft[id]) + \"px; width: \" + (dims.gutterWidth[id]) + \"px\"))); }\n } }\n }\n }\n\n function updateLineWidgets(cm, lineView, dims) {\n if (lineView.alignable) { lineView.alignable = null; }\n for (var node = lineView.node.firstChild, next = (void 0); node; node = next) {\n next = node.nextSibling;\n if (node.className == \"CodeMirror-linewidget\")\n { lineView.node.removeChild(node); }\n }\n insertLineWidgets(cm, lineView, dims);\n }\n\n // Build a line's DOM representation from scratch\n function buildLineElement(cm, lineView, lineN, dims) {\n var built = getLineContent(cm, lineView);\n lineView.text = lineView.node = built.pre;\n if (built.bgClass) { lineView.bgClass = built.bgClass; }\n if (built.textClass) { lineView.textClass = built.textClass; }\n\n updateLineClasses(cm, lineView);\n updateLineGutter(cm, lineView, lineN, dims);\n insertLineWidgets(cm, lineView, dims);\n return lineView.node\n }\n\n // A lineView may contain multiple logical lines (when merged by\n // collapsed spans). The widgets for all of them need to be drawn.\n function insertLineWidgets(cm, lineView, dims) {\n insertLineWidgetsFor(cm, lineView.line, lineView, dims, true);\n if (lineView.rest) { for (var i = 0; i < lineView.rest.length; i++)\n { insertLineWidgetsFor(cm, lineView.rest[i], lineView, dims, false); } }\n }\n\n function insertLineWidgetsFor(cm, line, lineView, dims, allowAbove) {\n if (!line.widgets) { return }\n var wrap = ensureLineWrapped(lineView);\n for (var i = 0, ws = line.widgets; i < ws.length; ++i) {\n var widget = ws[i], node = elt(\"div\", [widget.node], \"CodeMirror-linewidget\");\n if (!widget.handleMouseEvents) { node.setAttribute(\"cm-ignore-events\", \"true\"); }\n positionLineWidget(widget, node, lineView, dims);\n cm.display.input.setUneditable(node);\n if (allowAbove && widget.above)\n { wrap.insertBefore(node, lineView.gutter || lineView.text); }\n else\n { wrap.appendChild(node); }\n signalLater(widget, \"redraw\");\n }\n }\n\n function positionLineWidget(widget, node, lineView, dims) {\n if (widget.noHScroll) {\n (lineView.alignable || (lineView.alignable = [])).push(node);\n var width = dims.wrapperWidth;\n node.style.left = dims.fixedPos + \"px\";\n if (!widget.coverGutter) {\n width -= dims.gutterTotalWidth;\n node.style.paddingLeft = dims.gutterTotalWidth + \"px\";\n }\n node.style.width = width + \"px\";\n }\n if (widget.coverGutter) {\n node.style.zIndex = 5;\n node.style.position = \"relative\";\n if (!widget.noHScroll) { node.style.marginLeft = -dims.gutterTotalWidth + \"px\"; }\n }\n }\n\n function widgetHeight(widget) {\n if (widget.height != null) { return widget.height }\n var cm = widget.doc.cm;\n if (!cm) { return 0 }\n if (!contains(document.body, widget.node)) {\n var parentStyle = \"position: relative;\";\n if (widget.coverGutter)\n { parentStyle += \"margin-left: -\" + cm.display.gutters.offsetWidth + \"px;\"; }\n if (widget.noHScroll)\n { parentStyle += \"width: \" + cm.display.wrapper.clientWidth + \"px;\"; }\n removeChildrenAndAdd(cm.display.measure, elt(\"div\", [widget.node], null, parentStyle));\n }\n return widget.height = widget.node.parentNode.offsetHeight\n }\n\n // Return true when the given mouse event happened in a widget\n function eventInWidget(display, e) {\n for (var n = e_target(e); n != display.wrapper; n = n.parentNode) {\n if (!n || (n.nodeType == 1 && n.getAttribute(\"cm-ignore-events\") == \"true\") ||\n (n.parentNode == display.sizer && n != display.mover))\n { return true }\n }\n }\n\n // POSITION MEASUREMENT\n\n function paddingTop(display) {return display.lineSpace.offsetTop}\n function paddingVert(display) {return display.mover.offsetHeight - display.lineSpace.offsetHeight}\n function paddingH(display) {\n if (display.cachedPaddingH) { return display.cachedPaddingH }\n var e = removeChildrenAndAdd(display.measure, elt(\"pre\", \"x\", \"CodeMirror-line-like\"));\n var style = window.getComputedStyle ? window.getComputedStyle(e) : e.currentStyle;\n var data = {left: parseInt(style.paddingLeft), right: parseInt(style.paddingRight)};\n if (!isNaN(data.left) && !isNaN(data.right)) { display.cachedPaddingH = data; }\n return data\n }\n\n function scrollGap(cm) { return scrollerGap - cm.display.nativeBarWidth }\n function displayWidth(cm) {\n return cm.display.scroller.clientWidth - scrollGap(cm) - cm.display.barWidth\n }\n function displayHeight(cm) {\n return cm.display.scroller.clientHeight - scrollGap(cm) - cm.display.barHeight\n }\n\n // Ensure the lineView.wrapping.heights array is populated. This is\n // an array of bottom offsets for the lines that make up a drawn\n // line. When lineWrapping is on, there might be more than one\n // height.\n function ensureLineHeights(cm, lineView, rect) {\n var wrapping = cm.options.lineWrapping;\n var curWidth = wrapping && displayWidth(cm);\n if (!lineView.measure.heights || wrapping && lineView.measure.width != curWidth) {\n var heights = lineView.measure.heights = [];\n if (wrapping) {\n lineView.measure.width = curWidth;\n var rects = lineView.text.firstChild.getClientRects();\n for (var i = 0; i < rects.length - 1; i++) {\n var cur = rects[i], next = rects[i + 1];\n if (Math.abs(cur.bottom - next.bottom) > 2)\n { heights.push((cur.bottom + next.top) / 2 - rect.top); }\n }\n }\n heights.push(rect.bottom - rect.top);\n }\n }\n\n // Find a line map (mapping character offsets to text nodes) and a\n // measurement cache for the given line number. (A line view might\n // contain multiple lines when collapsed ranges are present.)\n function mapFromLineView(lineView, line, lineN) {\n if (lineView.line == line)\n { return {map: lineView.measure.map, cache: lineView.measure.cache} }\n for (var i = 0; i < lineView.rest.length; i++)\n { if (lineView.rest[i] == line)\n { return {map: lineView.measure.maps[i], cache: lineView.measure.caches[i]} } }\n for (var i$1 = 0; i$1 < lineView.rest.length; i$1++)\n { if (lineNo(lineView.rest[i$1]) > lineN)\n { return {map: lineView.measure.maps[i$1], cache: lineView.measure.caches[i$1], before: true} } }\n }\n\n // Render a line into the hidden node display.externalMeasured. Used\n // when measurement is needed for a line that's not in the viewport.\n function updateExternalMeasurement(cm, line) {\n line = visualLine(line);\n var lineN = lineNo(line);\n var view = cm.display.externalMeasured = new LineView(cm.doc, line, lineN);\n view.lineN = lineN;\n var built = view.built = buildLineContent(cm, view);\n view.text = built.pre;\n removeChildrenAndAdd(cm.display.lineMeasure, built.pre);\n return view\n }\n\n // Get a {top, bottom, left, right} box (in line-local coordinates)\n // for a given character.\n function measureChar(cm, line, ch, bias) {\n return measureCharPrepared(cm, prepareMeasureForLine(cm, line), ch, bias)\n }\n\n // Find a line view that corresponds to the given line number.\n function findViewForLine(cm, lineN) {\n if (lineN >= cm.display.viewFrom && lineN < cm.display.viewTo)\n { return cm.display.view[findViewIndex(cm, lineN)] }\n var ext = cm.display.externalMeasured;\n if (ext && lineN >= ext.lineN && lineN < ext.lineN + ext.size)\n { return ext }\n }\n\n // Measurement can be split in two steps, the set-up work that\n // applies to the whole line, and the measurement of the actual\n // character. Functions like coordsChar, that need to do a lot of\n // measurements in a row, can thus ensure that the set-up work is\n // only done once.\n function prepareMeasureForLine(cm, line) {\n var lineN = lineNo(line);\n var view = findViewForLine(cm, lineN);\n if (view && !view.text) {\n view = null;\n } else if (view && view.changes) {\n updateLineForChanges(cm, view, lineN, getDimensions(cm));\n cm.curOp.forceUpdate = true;\n }\n if (!view)\n { view = updateExternalMeasurement(cm, line); }\n\n var info = mapFromLineView(view, line, lineN);\n return {\n line: line, view: view, rect: null,\n map: info.map, cache: info.cache, before: info.before,\n hasHeights: false\n }\n }\n\n // Given a prepared measurement object, measures the position of an\n // actual character (or fetches it from the cache).\n function measureCharPrepared(cm, prepared, ch, bias, varHeight) {\n if (prepared.before) { ch = -1; }\n var key = ch + (bias || \"\"), found;\n if (prepared.cache.hasOwnProperty(key)) {\n found = prepared.cache[key];\n } else {\n if (!prepared.rect)\n { prepared.rect = prepared.view.text.getBoundingClientRect(); }\n if (!prepared.hasHeights) {\n ensureLineHeights(cm, prepared.view, prepared.rect);\n prepared.hasHeights = true;\n }\n found = measureCharInner(cm, prepared, ch, bias);\n if (!found.bogus) { prepared.cache[key] = found; }\n }\n return {left: found.left, right: found.right,\n top: varHeight ? found.rtop : found.top,\n bottom: varHeight ? found.rbottom : found.bottom}\n }\n\n var nullRect = {left: 0, right: 0, top: 0, bottom: 0};\n\n function nodeAndOffsetInLineMap(map$$1, ch, bias) {\n var node, start, end, collapse, mStart, mEnd;\n // First, search the line map for the text node corresponding to,\n // or closest to, the target character.\n for (var i = 0; i < map$$1.length; i += 3) {\n mStart = map$$1[i];\n mEnd = map$$1[i + 1];\n if (ch < mStart) {\n start = 0; end = 1;\n collapse = \"left\";\n } else if (ch < mEnd) {\n start = ch - mStart;\n end = start + 1;\n } else if (i == map$$1.length - 3 || ch == mEnd && map$$1[i + 3] > ch) {\n end = mEnd - mStart;\n start = end - 1;\n if (ch >= mEnd) { collapse = \"right\"; }\n }\n if (start != null) {\n node = map$$1[i + 2];\n if (mStart == mEnd && bias == (node.insertLeft ? \"left\" : \"right\"))\n { collapse = bias; }\n if (bias == \"left\" && start == 0)\n { while (i && map$$1[i - 2] == map$$1[i - 3] && map$$1[i - 1].insertLeft) {\n node = map$$1[(i -= 3) + 2];\n collapse = \"left\";\n } }\n if (bias == \"right\" && start == mEnd - mStart)\n { while (i < map$$1.length - 3 && map$$1[i + 3] == map$$1[i + 4] && !map$$1[i + 5].insertLeft) {\n node = map$$1[(i += 3) + 2];\n collapse = \"right\";\n } }\n break\n }\n }\n return {node: node, start: start, end: end, collapse: collapse, coverStart: mStart, coverEnd: mEnd}\n }\n\n function getUsefulRect(rects, bias) {\n var rect = nullRect;\n if (bias == \"left\") { for (var i = 0; i < rects.length; i++) {\n if ((rect = rects[i]).left != rect.right) { break }\n } } else { for (var i$1 = rects.length - 1; i$1 >= 0; i$1--) {\n if ((rect = rects[i$1]).left != rect.right) { break }\n } }\n return rect\n }\n\n function measureCharInner(cm, prepared, ch, bias) {\n var place = nodeAndOffsetInLineMap(prepared.map, ch, bias);\n var node = place.node, start = place.start, end = place.end, collapse = place.collapse;\n\n var rect;\n if (node.nodeType == 3) { // If it is a text node, use a range to retrieve the coordinates.\n for (var i$1 = 0; i$1 < 4; i$1++) { // Retry a maximum of 4 times when nonsense rectangles are returned\n while (start && isExtendingChar(prepared.line.text.charAt(place.coverStart + start))) { --start; }\n while (place.coverStart + end < place.coverEnd && isExtendingChar(prepared.line.text.charAt(place.coverStart + end))) { ++end; }\n if (ie && ie_version < 9 && start == 0 && end == place.coverEnd - place.coverStart)\n { rect = node.parentNode.getBoundingClientRect(); }\n else\n { rect = getUsefulRect(range(node, start, end).getClientRects(), bias); }\n if (rect.left || rect.right || start == 0) { break }\n end = start;\n start = start - 1;\n collapse = \"right\";\n }\n if (ie && ie_version < 11) { rect = maybeUpdateRectForZooming(cm.display.measure, rect); }\n } else { // If it is a widget, simply get the box for the whole widget.\n if (start > 0) { collapse = bias = \"right\"; }\n var rects;\n if (cm.options.lineWrapping && (rects = node.getClientRects()).length > 1)\n { rect = rects[bias == \"right\" ? rects.length - 1 : 0]; }\n else\n { rect = node.getBoundingClientRect(); }\n }\n if (ie && ie_version < 9 && !start && (!rect || !rect.left && !rect.right)) {\n var rSpan = node.parentNode.getClientRects()[0];\n if (rSpan)\n { rect = {left: rSpan.left, right: rSpan.left + charWidth(cm.display), top: rSpan.top, bottom: rSpan.bottom}; }\n else\n { rect = nullRect; }\n }\n\n var rtop = rect.top - prepared.rect.top, rbot = rect.bottom - prepared.rect.top;\n var mid = (rtop + rbot) / 2;\n var heights = prepared.view.measure.heights;\n var i = 0;\n for (; i < heights.length - 1; i++)\n { if (mid < heights[i]) { break } }\n var top = i ? heights[i - 1] : 0, bot = heights[i];\n var result = {left: (collapse == \"right\" ? rect.right : rect.left) - prepared.rect.left,\n right: (collapse == \"left\" ? rect.left : rect.right) - prepared.rect.left,\n top: top, bottom: bot};\n if (!rect.left && !rect.right) { result.bogus = true; }\n if (!cm.options.singleCursorHeightPerLine) { result.rtop = rtop; result.rbottom = rbot; }\n\n return result\n }\n\n // Work around problem with bounding client rects on ranges being\n // returned incorrectly when zoomed on IE10 and below.\n function maybeUpdateRectForZooming(measure, rect) {\n if (!window.screen || screen.logicalXDPI == null ||\n screen.logicalXDPI == screen.deviceXDPI || !hasBadZoomedRects(measure))\n { return rect }\n var scaleX = screen.logicalXDPI / screen.deviceXDPI;\n var scaleY = screen.logicalYDPI / screen.deviceYDPI;\n return {left: rect.left * scaleX, right: rect.right * scaleX,\n top: rect.top * scaleY, bottom: rect.bottom * scaleY}\n }\n\n function clearLineMeasurementCacheFor(lineView) {\n if (lineView.measure) {\n lineView.measure.cache = {};\n lineView.measure.heights = null;\n if (lineView.rest) { for (var i = 0; i < lineView.rest.length; i++)\n { lineView.measure.caches[i] = {}; } }\n }\n }\n\n function clearLineMeasurementCache(cm) {\n cm.display.externalMeasure = null;\n removeChildren(cm.display.lineMeasure);\n for (var i = 0; i < cm.display.view.length; i++)\n { clearLineMeasurementCacheFor(cm.display.view[i]); }\n }\n\n function clearCaches(cm) {\n clearLineMeasurementCache(cm);\n cm.display.cachedCharWidth = cm.display.cachedTextHeight = cm.display.cachedPaddingH = null;\n if (!cm.options.lineWrapping) { cm.display.maxLineChanged = true; }\n cm.display.lineNumChars = null;\n }\n\n function pageScrollX() {\n // Work around https://bugs.chromium.org/p/chromium/issues/detail?id=489206\n // which causes page_Offset and bounding client rects to use\n // different reference viewports and invalidate our calculations.\n if (chrome && android) { return -(document.body.getBoundingClientRect().left - parseInt(getComputedStyle(document.body).marginLeft)) }\n return window.pageXOffset || (document.documentElement || document.body).scrollLeft\n }\n function pageScrollY() {\n if (chrome && android) { return -(document.body.getBoundingClientRect().top - parseInt(getComputedStyle(document.body).marginTop)) }\n return window.pageYOffset || (document.documentElement || document.body).scrollTop\n }\n\n function widgetTopHeight(lineObj) {\n var height = 0;\n if (lineObj.widgets) { for (var i = 0; i < lineObj.widgets.length; ++i) { if (lineObj.widgets[i].above)\n { height += widgetHeight(lineObj.widgets[i]); } } }\n return height\n }\n\n // Converts a {top, bottom, left, right} box from line-local\n // coordinates into another coordinate system. Context may be one of\n // \"line\", \"div\" (display.lineDiv), \"local\"./null (editor), \"window\",\n // or \"page\".\n function intoCoordSystem(cm, lineObj, rect, context, includeWidgets) {\n if (!includeWidgets) {\n var height = widgetTopHeight(lineObj);\n rect.top += height; rect.bottom += height;\n }\n if (context == \"line\") { return rect }\n if (!context) { context = \"local\"; }\n var yOff = heightAtLine(lineObj);\n if (context == \"local\") { yOff += paddingTop(cm.display); }\n else { yOff -= cm.display.viewOffset; }\n if (context == \"page\" || context == \"window\") {\n var lOff = cm.display.lineSpace.getBoundingClientRect();\n yOff += lOff.top + (context == \"window\" ? 0 : pageScrollY());\n var xOff = lOff.left + (context == \"window\" ? 0 : pageScrollX());\n rect.left += xOff; rect.right += xOff;\n }\n rect.top += yOff; rect.bottom += yOff;\n return rect\n }\n\n // Coverts a box from \"div\" coords to another coordinate system.\n // Context may be \"window\", \"page\", \"div\", or \"local\"./null.\n function fromCoordSystem(cm, coords, context) {\n if (context == \"div\") { return coords }\n var left = coords.left, top = coords.top;\n // First move into \"page\" coordinate system\n if (context == \"page\") {\n left -= pageScrollX();\n top -= pageScrollY();\n } else if (context == \"local\" || !context) {\n var localBox = cm.display.sizer.getBoundingClientRect();\n left += localBox.left;\n top += localBox.top;\n }\n\n var lineSpaceBox = cm.display.lineSpace.getBoundingClientRect();\n return {left: left - lineSpaceBox.left, top: top - lineSpaceBox.top}\n }\n\n function charCoords(cm, pos, context, lineObj, bias) {\n if (!lineObj) { lineObj = getLine(cm.doc, pos.line); }\n return intoCoordSystem(cm, lineObj, measureChar(cm, lineObj, pos.ch, bias), context)\n }\n\n // Returns a box for a given cursor position, which may have an\n // 'other' property containing the position of the secondary cursor\n // on a bidi boundary.\n // A cursor Pos(line, char, \"before\") is on the same visual line as `char - 1`\n // and after `char - 1` in writing order of `char - 1`\n // A cursor Pos(line, char, \"after\") is on the same visual line as `char`\n // and before `char` in writing order of `char`\n // Examples (upper-case letters are RTL, lower-case are LTR):\n // Pos(0, 1, ...)\n // before after\n // ab a|b a|b\n // aB a|B aB|\n // Ab |Ab A|b\n // AB B|A B|A\n // Every position after the last character on a line is considered to stick\n // to the last character on the line.\n function cursorCoords(cm, pos, context, lineObj, preparedMeasure, varHeight) {\n lineObj = lineObj || getLine(cm.doc, pos.line);\n if (!preparedMeasure) { preparedMeasure = prepareMeasureForLine(cm, lineObj); }\n function get(ch, right) {\n var m = measureCharPrepared(cm, preparedMeasure, ch, right ? \"right\" : \"left\", varHeight);\n if (right) { m.left = m.right; } else { m.right = m.left; }\n return intoCoordSystem(cm, lineObj, m, context)\n }\n var order = getOrder(lineObj, cm.doc.direction), ch = pos.ch, sticky = pos.sticky;\n if (ch >= lineObj.text.length) {\n ch = lineObj.text.length;\n sticky = \"before\";\n } else if (ch <= 0) {\n ch = 0;\n sticky = \"after\";\n }\n if (!order) { return get(sticky == \"before\" ? ch - 1 : ch, sticky == \"before\") }\n\n function getBidi(ch, partPos, invert) {\n var part = order[partPos], right = part.level == 1;\n return get(invert ? ch - 1 : ch, right != invert)\n }\n var partPos = getBidiPartAt(order, ch, sticky);\n var other = bidiOther;\n var val = getBidi(ch, partPos, sticky == \"before\");\n if (other != null) { val.other = getBidi(ch, other, sticky != \"before\"); }\n return val\n }\n\n // Used to cheaply estimate the coordinates for a position. Used for\n // intermediate scroll updates.\n function estimateCoords(cm, pos) {\n var left = 0;\n pos = clipPos(cm.doc, pos);\n if (!cm.options.lineWrapping) { left = charWidth(cm.display) * pos.ch; }\n var lineObj = getLine(cm.doc, pos.line);\n var top = heightAtLine(lineObj) + paddingTop(cm.display);\n return {left: left, right: left, top: top, bottom: top + lineObj.height}\n }\n\n // Positions returned by coordsChar contain some extra information.\n // xRel is the relative x position of the input coordinates compared\n // to the found position (so xRel > 0 means the coordinates are to\n // the right of the character position, for example). When outside\n // is true, that means the coordinates lie outside the line's\n // vertical range.\n function PosWithInfo(line, ch, sticky, outside, xRel) {\n var pos = Pos(line, ch, sticky);\n pos.xRel = xRel;\n if (outside) { pos.outside = outside; }\n return pos\n }\n\n // Compute the character position closest to the given coordinates.\n // Input must be lineSpace-local (\"div\" coordinate system).\n function coordsChar(cm, x, y) {\n var doc = cm.doc;\n y += cm.display.viewOffset;\n if (y < 0) { return PosWithInfo(doc.first, 0, null, -1, -1) }\n var lineN = lineAtHeight(doc, y), last = doc.first + doc.size - 1;\n if (lineN > last)\n { return PosWithInfo(doc.first + doc.size - 1, getLine(doc, last).text.length, null, 1, 1) }\n if (x < 0) { x = 0; }\n\n var lineObj = getLine(doc, lineN);\n for (;;) {\n var found = coordsCharInner(cm, lineObj, lineN, x, y);\n var collapsed = collapsedSpanAround(lineObj, found.ch + (found.xRel > 0 || found.outside > 0 ? 1 : 0));\n if (!collapsed) { return found }\n var rangeEnd = collapsed.find(1);\n if (rangeEnd.line == lineN) { return rangeEnd }\n lineObj = getLine(doc, lineN = rangeEnd.line);\n }\n }\n\n function wrappedLineExtent(cm, lineObj, preparedMeasure, y) {\n y -= widgetTopHeight(lineObj);\n var end = lineObj.text.length;\n var begin = findFirst(function (ch) { return measureCharPrepared(cm, preparedMeasure, ch - 1).bottom <= y; }, end, 0);\n end = findFirst(function (ch) { return measureCharPrepared(cm, preparedMeasure, ch).top > y; }, begin, end);\n return {begin: begin, end: end}\n }\n\n function wrappedLineExtentChar(cm, lineObj, preparedMeasure, target) {\n if (!preparedMeasure) { preparedMeasure = prepareMeasureForLine(cm, lineObj); }\n var targetTop = intoCoordSystem(cm, lineObj, measureCharPrepared(cm, preparedMeasure, target), \"line\").top;\n return wrappedLineExtent(cm, lineObj, preparedMeasure, targetTop)\n }\n\n // Returns true if the given side of a box is after the given\n // coordinates, in top-to-bottom, left-to-right order.\n function boxIsAfter(box, x, y, left) {\n return box.bottom <= y ? false : box.top > y ? true : (left ? box.left : box.right) > x\n }\n\n function coordsCharInner(cm, lineObj, lineNo$$1, x, y) {\n // Move y into line-local coordinate space\n y -= heightAtLine(lineObj);\n var preparedMeasure = prepareMeasureForLine(cm, lineObj);\n // When directly calling `measureCharPrepared`, we have to adjust\n // for the widgets at this line.\n var widgetHeight$$1 = widgetTopHeight(lineObj);\n var begin = 0, end = lineObj.text.length, ltr = true;\n\n var order = getOrder(lineObj, cm.doc.direction);\n // If the line isn't plain left-to-right text, first figure out\n // which bidi section the coordinates fall into.\n if (order) {\n var part = (cm.options.lineWrapping ? coordsBidiPartWrapped : coordsBidiPart)\n (cm, lineObj, lineNo$$1, preparedMeasure, order, x, y);\n ltr = part.level != 1;\n // The awkward -1 offsets are needed because findFirst (called\n // on these below) will treat its first bound as inclusive,\n // second as exclusive, but we want to actually address the\n // characters in the part's range\n begin = ltr ? part.from : part.to - 1;\n end = ltr ? part.to : part.from - 1;\n }\n\n // A binary search to find the first character whose bounding box\n // starts after the coordinates. If we run across any whose box wrap\n // the coordinates, store that.\n var chAround = null, boxAround = null;\n var ch = findFirst(function (ch) {\n var box = measureCharPrepared(cm, preparedMeasure, ch);\n box.top += widgetHeight$$1; box.bottom += widgetHeight$$1;\n if (!boxIsAfter(box, x, y, false)) { return false }\n if (box.top <= y && box.left <= x) {\n chAround = ch;\n boxAround = box;\n }\n return true\n }, begin, end);\n\n var baseX, sticky, outside = false;\n // If a box around the coordinates was found, use that\n if (boxAround) {\n // Distinguish coordinates nearer to the left or right side of the box\n var atLeft = x - boxAround.left < boxAround.right - x, atStart = atLeft == ltr;\n ch = chAround + (atStart ? 0 : 1);\n sticky = atStart ? \"after\" : \"before\";\n baseX = atLeft ? boxAround.left : boxAround.right;\n } else {\n // (Adjust for extended bound, if necessary.)\n if (!ltr && (ch == end || ch == begin)) { ch++; }\n // To determine which side to associate with, get the box to the\n // left of the character and compare it's vertical position to the\n // coordinates\n sticky = ch == 0 ? \"after\" : ch == lineObj.text.length ? \"before\" :\n (measureCharPrepared(cm, preparedMeasure, ch - (ltr ? 1 : 0)).bottom + widgetHeight$$1 <= y) == ltr ?\n \"after\" : \"before\";\n // Now get accurate coordinates for this place, in order to get a\n // base X position\n var coords = cursorCoords(cm, Pos(lineNo$$1, ch, sticky), \"line\", lineObj, preparedMeasure);\n baseX = coords.left;\n outside = y < coords.top ? -1 : y >= coords.bottom ? 1 : 0;\n }\n\n ch = skipExtendingChars(lineObj.text, ch, 1);\n return PosWithInfo(lineNo$$1, ch, sticky, outside, x - baseX)\n }\n\n function coordsBidiPart(cm, lineObj, lineNo$$1, preparedMeasure, order, x, y) {\n // Bidi parts are sorted left-to-right, and in a non-line-wrapping\n // situation, we can take this ordering to correspond to the visual\n // ordering. This finds the first part whose end is after the given\n // coordinates.\n var index = findFirst(function (i) {\n var part = order[i], ltr = part.level != 1;\n return boxIsAfter(cursorCoords(cm, Pos(lineNo$$1, ltr ? part.to : part.from, ltr ? \"before\" : \"after\"),\n \"line\", lineObj, preparedMeasure), x, y, true)\n }, 0, order.length - 1);\n var part = order[index];\n // If this isn't the first part, the part's start is also after\n // the coordinates, and the coordinates aren't on the same line as\n // that start, move one part back.\n if (index > 0) {\n var ltr = part.level != 1;\n var start = cursorCoords(cm, Pos(lineNo$$1, ltr ? part.from : part.to, ltr ? \"after\" : \"before\"),\n \"line\", lineObj, preparedMeasure);\n if (boxIsAfter(start, x, y, true) && start.top > y)\n { part = order[index - 1]; }\n }\n return part\n }\n\n function coordsBidiPartWrapped(cm, lineObj, _lineNo, preparedMeasure, order, x, y) {\n // In a wrapped line, rtl text on wrapping boundaries can do things\n // that don't correspond to the ordering in our `order` array at\n // all, so a binary search doesn't work, and we want to return a\n // part that only spans one line so that the binary search in\n // coordsCharInner is safe. As such, we first find the extent of the\n // wrapped line, and then do a flat search in which we discard any\n // spans that aren't on the line.\n var ref = wrappedLineExtent(cm, lineObj, preparedMeasure, y);\n var begin = ref.begin;\n var end = ref.end;\n if (/\\s/.test(lineObj.text.charAt(end - 1))) { end--; }\n var part = null, closestDist = null;\n for (var i = 0; i < order.length; i++) {\n var p = order[i];\n if (p.from >= end || p.to <= begin) { continue }\n var ltr = p.level != 1;\n var endX = measureCharPrepared(cm, preparedMeasure, ltr ? Math.min(end, p.to) - 1 : Math.max(begin, p.from)).right;\n // Weigh against spans ending before this, so that they are only\n // picked if nothing ends after\n var dist = endX < x ? x - endX + 1e9 : endX - x;\n if (!part || closestDist > dist) {\n part = p;\n closestDist = dist;\n }\n }\n if (!part) { part = order[order.length - 1]; }\n // Clip the part to the wrapped line.\n if (part.from < begin) { part = {from: begin, to: part.to, level: part.level}; }\n if (part.to > end) { part = {from: part.from, to: end, level: part.level}; }\n return part\n }\n\n var measureText;\n // Compute the default text height.\n function textHeight(display) {\n if (display.cachedTextHeight != null) { return display.cachedTextHeight }\n if (measureText == null) {\n measureText = elt(\"pre\", null, \"CodeMirror-line-like\");\n // Measure a bunch of lines, for browsers that compute\n // fractional heights.\n for (var i = 0; i < 49; ++i) {\n measureText.appendChild(document.createTextNode(\"x\"));\n measureText.appendChild(elt(\"br\"));\n }\n measureText.appendChild(document.createTextNode(\"x\"));\n }\n removeChildrenAndAdd(display.measure, measureText);\n var height = measureText.offsetHeight / 50;\n if (height > 3) { display.cachedTextHeight = height; }\n removeChildren(display.measure);\n return height || 1\n }\n\n // Compute the default character width.\n function charWidth(display) {\n if (display.cachedCharWidth != null) { return display.cachedCharWidth }\n var anchor = elt(\"span\", \"xxxxxxxxxx\");\n var pre = elt(\"pre\", [anchor], \"CodeMirror-line-like\");\n removeChildrenAndAdd(display.measure, pre);\n var rect = anchor.getBoundingClientRect(), width = (rect.right - rect.left) / 10;\n if (width > 2) { display.cachedCharWidth = width; }\n return width || 10\n }\n\n // Do a bulk-read of the DOM positions and sizes needed to draw the\n // view, so that we don't interleave reading and writing to the DOM.\n function getDimensions(cm) {\n var d = cm.display, left = {}, width = {};\n var gutterLeft = d.gutters.clientLeft;\n for (var n = d.gutters.firstChild, i = 0; n; n = n.nextSibling, ++i) {\n var id = cm.display.gutterSpecs[i].className;\n left[id] = n.offsetLeft + n.clientLeft + gutterLeft;\n width[id] = n.clientWidth;\n }\n return {fixedPos: compensateForHScroll(d),\n gutterTotalWidth: d.gutters.offsetWidth,\n gutterLeft: left,\n gutterWidth: width,\n wrapperWidth: d.wrapper.clientWidth}\n }\n\n // Computes display.scroller.scrollLeft + display.gutters.offsetWidth,\n // but using getBoundingClientRect to get a sub-pixel-accurate\n // result.\n function compensateForHScroll(display) {\n return display.scroller.getBoundingClientRect().left - display.sizer.getBoundingClientRect().left\n }\n\n // Returns a function that estimates the height of a line, to use as\n // first approximation until the line becomes visible (and is thus\n // properly measurable).\n function estimateHeight(cm) {\n var th = textHeight(cm.display), wrapping = cm.options.lineWrapping;\n var perLine = wrapping && Math.max(5, cm.display.scroller.clientWidth / charWidth(cm.display) - 3);\n return function (line) {\n if (lineIsHidden(cm.doc, line)) { return 0 }\n\n var widgetsHeight = 0;\n if (line.widgets) { for (var i = 0; i < line.widgets.length; i++) {\n if (line.widgets[i].height) { widgetsHeight += line.widgets[i].height; }\n } }\n\n if (wrapping)\n { return widgetsHeight + (Math.ceil(line.text.length / perLine) || 1) * th }\n else\n { return widgetsHeight + th }\n }\n }\n\n function estimateLineHeights(cm) {\n var doc = cm.doc, est = estimateHeight(cm);\n doc.iter(function (line) {\n var estHeight = est(line);\n if (estHeight != line.height) { updateLineHeight(line, estHeight); }\n });\n }\n\n // Given a mouse event, find the corresponding position. If liberal\n // is false, it checks whether a gutter or scrollbar was clicked,\n // and returns null if it was. forRect is used by rectangular\n // selections, and tries to estimate a character position even for\n // coordinates beyond the right of the text.\n function posFromMouse(cm, e, liberal, forRect) {\n var display = cm.display;\n if (!liberal && e_target(e).getAttribute(\"cm-not-content\") == \"true\") { return null }\n\n var x, y, space = display.lineSpace.getBoundingClientRect();\n // Fails unpredictably on IE[67] when mouse is dragged around quickly.\n try { x = e.clientX - space.left; y = e.clientY - space.top; }\n catch (e) { return null }\n var coords = coordsChar(cm, x, y), line;\n if (forRect && coords.xRel == 1 && (line = getLine(cm.doc, coords.line).text).length == coords.ch) {\n var colDiff = countColumn(line, line.length, cm.options.tabSize) - line.length;\n coords = Pos(coords.line, Math.max(0, Math.round((x - paddingH(cm.display).left) / charWidth(cm.display)) - colDiff));\n }\n return coords\n }\n\n // Find the view element corresponding to a given line. Return null\n // when the line isn't visible.\n function findViewIndex(cm, n) {\n if (n >= cm.display.viewTo) { return null }\n n -= cm.display.viewFrom;\n if (n < 0) { return null }\n var view = cm.display.view;\n for (var i = 0; i < view.length; i++) {\n n -= view[i].size;\n if (n < 0) { return i }\n }\n }\n\n // Updates the display.view data structure for a given change to the\n // document. From and to are in pre-change coordinates. Lendiff is\n // the amount of lines added or subtracted by the change. This is\n // used for changes that span multiple lines, or change the way\n // lines are divided into visual lines. regLineChange (below)\n // registers single-line changes.\n function regChange(cm, from, to, lendiff) {\n if (from == null) { from = cm.doc.first; }\n if (to == null) { to = cm.doc.first + cm.doc.size; }\n if (!lendiff) { lendiff = 0; }\n\n var display = cm.display;\n if (lendiff && to < display.viewTo &&\n (display.updateLineNumbers == null || display.updateLineNumbers > from))\n { display.updateLineNumbers = from; }\n\n cm.curOp.viewChanged = true;\n\n if (from >= display.viewTo) { // Change after\n if (sawCollapsedSpans && visualLineNo(cm.doc, from) < display.viewTo)\n { resetView(cm); }\n } else if (to <= display.viewFrom) { // Change before\n if (sawCollapsedSpans && visualLineEndNo(cm.doc, to + lendiff) > display.viewFrom) {\n resetView(cm);\n } else {\n display.viewFrom += lendiff;\n display.viewTo += lendiff;\n }\n } else if (from <= display.viewFrom && to >= display.viewTo) { // Full overlap\n resetView(cm);\n } else if (from <= display.viewFrom) { // Top overlap\n var cut = viewCuttingPoint(cm, to, to + lendiff, 1);\n if (cut) {\n display.view = display.view.slice(cut.index);\n display.viewFrom = cut.lineN;\n display.viewTo += lendiff;\n } else {\n resetView(cm);\n }\n } else if (to >= display.viewTo) { // Bottom overlap\n var cut$1 = viewCuttingPoint(cm, from, from, -1);\n if (cut$1) {\n display.view = display.view.slice(0, cut$1.index);\n display.viewTo = cut$1.lineN;\n } else {\n resetView(cm);\n }\n } else { // Gap in the middle\n var cutTop = viewCuttingPoint(cm, from, from, -1);\n var cutBot = viewCuttingPoint(cm, to, to + lendiff, 1);\n if (cutTop && cutBot) {\n display.view = display.view.slice(0, cutTop.index)\n .concat(buildViewArray(cm, cutTop.lineN, cutBot.lineN))\n .concat(display.view.slice(cutBot.index));\n display.viewTo += lendiff;\n } else {\n resetView(cm);\n }\n }\n\n var ext = display.externalMeasured;\n if (ext) {\n if (to < ext.lineN)\n { ext.lineN += lendiff; }\n else if (from < ext.lineN + ext.size)\n { display.externalMeasured = null; }\n }\n }\n\n // Register a change to a single line. Type must be one of \"text\",\n // \"gutter\", \"class\", \"widget\"\n function regLineChange(cm, line, type) {\n cm.curOp.viewChanged = true;\n var display = cm.display, ext = cm.display.externalMeasured;\n if (ext && line >= ext.lineN && line < ext.lineN + ext.size)\n { display.externalMeasured = null; }\n\n if (line < display.viewFrom || line >= display.viewTo) { return }\n var lineView = display.view[findViewIndex(cm, line)];\n if (lineView.node == null) { return }\n var arr = lineView.changes || (lineView.changes = []);\n if (indexOf(arr, type) == -1) { arr.push(type); }\n }\n\n // Clear the view.\n function resetView(cm) {\n cm.display.viewFrom = cm.display.viewTo = cm.doc.first;\n cm.display.view = [];\n cm.display.viewOffset = 0;\n }\n\n function viewCuttingPoint(cm, oldN, newN, dir) {\n var index = findViewIndex(cm, oldN), diff, view = cm.display.view;\n if (!sawCollapsedSpans || newN == cm.doc.first + cm.doc.size)\n { return {index: index, lineN: newN} }\n var n = cm.display.viewFrom;\n for (var i = 0; i < index; i++)\n { n += view[i].size; }\n if (n != oldN) {\n if (dir > 0) {\n if (index == view.length - 1) { return null }\n diff = (n + view[index].size) - oldN;\n index++;\n } else {\n diff = n - oldN;\n }\n oldN += diff; newN += diff;\n }\n while (visualLineNo(cm.doc, newN) != newN) {\n if (index == (dir < 0 ? 0 : view.length - 1)) { return null }\n newN += dir * view[index - (dir < 0 ? 1 : 0)].size;\n index += dir;\n }\n return {index: index, lineN: newN}\n }\n\n // Force the view to cover a given range, adding empty view element\n // or clipping off existing ones as needed.\n function adjustView(cm, from, to) {\n var display = cm.display, view = display.view;\n if (view.length == 0 || from >= display.viewTo || to <= display.viewFrom) {\n display.view = buildViewArray(cm, from, to);\n display.viewFrom = from;\n } else {\n if (display.viewFrom > from)\n { display.view = buildViewArray(cm, from, display.viewFrom).concat(display.view); }\n else if (display.viewFrom < from)\n { display.view = display.view.slice(findViewIndex(cm, from)); }\n display.viewFrom = from;\n if (display.viewTo < to)\n { display.view = display.view.concat(buildViewArray(cm, display.viewTo, to)); }\n else if (display.viewTo > to)\n { display.view = display.view.slice(0, findViewIndex(cm, to)); }\n }\n display.viewTo = to;\n }\n\n // Count the number of lines in the view whose DOM representation is\n // out of date (or nonexistent).\n function countDirtyView(cm) {\n var view = cm.display.view, dirty = 0;\n for (var i = 0; i < view.length; i++) {\n var lineView = view[i];\n if (!lineView.hidden && (!lineView.node || lineView.changes)) { ++dirty; }\n }\n return dirty\n }\n\n function updateSelection(cm) {\n cm.display.input.showSelection(cm.display.input.prepareSelection());\n }\n\n function prepareSelection(cm, primary) {\n if ( primary === void 0 ) primary = true;\n\n var doc = cm.doc, result = {};\n var curFragment = result.cursors = document.createDocumentFragment();\n var selFragment = result.selection = document.createDocumentFragment();\n\n for (var i = 0; i < doc.sel.ranges.length; i++) {\n if (!primary && i == doc.sel.primIndex) { continue }\n var range$$1 = doc.sel.ranges[i];\n if (range$$1.from().line >= cm.display.viewTo || range$$1.to().line < cm.display.viewFrom) { continue }\n var collapsed = range$$1.empty();\n if (collapsed || cm.options.showCursorWhenSelecting)\n { drawSelectionCursor(cm, range$$1.head, curFragment); }\n if (!collapsed)\n { drawSelectionRange(cm, range$$1, selFragment); }\n }\n return result\n }\n\n // Draws a cursor for the given range\n function drawSelectionCursor(cm, head, output) {\n var pos = cursorCoords(cm, head, \"div\", null, null, !cm.options.singleCursorHeightPerLine);\n\n var cursor = output.appendChild(elt(\"div\", \"\\u00a0\", \"CodeMirror-cursor\"));\n cursor.style.left = pos.left + \"px\";\n cursor.style.top = pos.top + \"px\";\n cursor.style.height = Math.max(0, pos.bottom - pos.top) * cm.options.cursorHeight + \"px\";\n\n if (pos.other) {\n // Secondary cursor, shown when on a 'jump' in bi-directional text\n var otherCursor = output.appendChild(elt(\"div\", \"\\u00a0\", \"CodeMirror-cursor CodeMirror-secondarycursor\"));\n otherCursor.style.display = \"\";\n otherCursor.style.left = pos.other.left + \"px\";\n otherCursor.style.top = pos.other.top + \"px\";\n otherCursor.style.height = (pos.other.bottom - pos.other.top) * .85 + \"px\";\n }\n }\n\n function cmpCoords(a, b) { return a.top - b.top || a.left - b.left }\n\n // Draws the given range as a highlighted selection\n function drawSelectionRange(cm, range$$1, output) {\n var display = cm.display, doc = cm.doc;\n var fragment = document.createDocumentFragment();\n var padding = paddingH(cm.display), leftSide = padding.left;\n var rightSide = Math.max(display.sizerWidth, displayWidth(cm) - display.sizer.offsetLeft) - padding.right;\n var docLTR = doc.direction == \"ltr\";\n\n function add(left, top, width, bottom) {\n if (top < 0) { top = 0; }\n top = Math.round(top);\n bottom = Math.round(bottom);\n fragment.appendChild(elt(\"div\", null, \"CodeMirror-selected\", (\"position: absolute; left: \" + left + \"px;\\n top: \" + top + \"px; width: \" + (width == null ? rightSide - left : width) + \"px;\\n height: \" + (bottom - top) + \"px\")));\n }\n\n function drawForLine(line, fromArg, toArg) {\n var lineObj = getLine(doc, line);\n var lineLen = lineObj.text.length;\n var start, end;\n function coords(ch, bias) {\n return charCoords(cm, Pos(line, ch), \"div\", lineObj, bias)\n }\n\n function wrapX(pos, dir, side) {\n var extent = wrappedLineExtentChar(cm, lineObj, null, pos);\n var prop = (dir == \"ltr\") == (side == \"after\") ? \"left\" : \"right\";\n var ch = side == \"after\" ? extent.begin : extent.end - (/\\s/.test(lineObj.text.charAt(extent.end - 1)) ? 2 : 1);\n return coords(ch, prop)[prop]\n }\n\n var order = getOrder(lineObj, doc.direction);\n iterateBidiSections(order, fromArg || 0, toArg == null ? lineLen : toArg, function (from, to, dir, i) {\n var ltr = dir == \"ltr\";\n var fromPos = coords(from, ltr ? \"left\" : \"right\");\n var toPos = coords(to - 1, ltr ? \"right\" : \"left\");\n\n var openStart = fromArg == null && from == 0, openEnd = toArg == null && to == lineLen;\n var first = i == 0, last = !order || i == order.length - 1;\n if (toPos.top - fromPos.top <= 3) { // Single line\n var openLeft = (docLTR ? openStart : openEnd) && first;\n var openRight = (docLTR ? openEnd : openStart) && last;\n var left = openLeft ? leftSide : (ltr ? fromPos : toPos).left;\n var right = openRight ? rightSide : (ltr ? toPos : fromPos).right;\n add(left, fromPos.top, right - left, fromPos.bottom);\n } else { // Multiple lines\n var topLeft, topRight, botLeft, botRight;\n if (ltr) {\n topLeft = docLTR && openStart && first ? leftSide : fromPos.left;\n topRight = docLTR ? rightSide : wrapX(from, dir, \"before\");\n botLeft = docLTR ? leftSide : wrapX(to, dir, \"after\");\n botRight = docLTR && openEnd && last ? rightSide : toPos.right;\n } else {\n topLeft = !docLTR ? leftSide : wrapX(from, dir, \"before\");\n topRight = !docLTR && openStart && first ? rightSide : fromPos.right;\n botLeft = !docLTR && openEnd && last ? leftSide : toPos.left;\n botRight = !docLTR ? rightSide : wrapX(to, dir, \"after\");\n }\n add(topLeft, fromPos.top, topRight - topLeft, fromPos.bottom);\n if (fromPos.bottom < toPos.top) { add(leftSide, fromPos.bottom, null, toPos.top); }\n add(botLeft, toPos.top, botRight - botLeft, toPos.bottom);\n }\n\n if (!start || cmpCoords(fromPos, start) < 0) { start = fromPos; }\n if (cmpCoords(toPos, start) < 0) { start = toPos; }\n if (!end || cmpCoords(fromPos, end) < 0) { end = fromPos; }\n if (cmpCoords(toPos, end) < 0) { end = toPos; }\n });\n return {start: start, end: end}\n }\n\n var sFrom = range$$1.from(), sTo = range$$1.to();\n if (sFrom.line == sTo.line) {\n drawForLine(sFrom.line, sFrom.ch, sTo.ch);\n } else {\n var fromLine = getLine(doc, sFrom.line), toLine = getLine(doc, sTo.line);\n var singleVLine = visualLine(fromLine) == visualLine(toLine);\n var leftEnd = drawForLine(sFrom.line, sFrom.ch, singleVLine ? fromLine.text.length + 1 : null).end;\n var rightStart = drawForLine(sTo.line, singleVLine ? 0 : null, sTo.ch).start;\n if (singleVLine) {\n if (leftEnd.top < rightStart.top - 2) {\n add(leftEnd.right, leftEnd.top, null, leftEnd.bottom);\n add(leftSide, rightStart.top, rightStart.left, rightStart.bottom);\n } else {\n add(leftEnd.right, leftEnd.top, rightStart.left - leftEnd.right, leftEnd.bottom);\n }\n }\n if (leftEnd.bottom < rightStart.top)\n { add(leftSide, leftEnd.bottom, null, rightStart.top); }\n }\n\n output.appendChild(fragment);\n }\n\n // Cursor-blinking\n function restartBlink(cm) {\n if (!cm.state.focused) { return }\n var display = cm.display;\n clearInterval(display.blinker);\n var on = true;\n display.cursorDiv.style.visibility = \"\";\n if (cm.options.cursorBlinkRate > 0)\n { display.blinker = setInterval(function () { return display.cursorDiv.style.visibility = (on = !on) ? \"\" : \"hidden\"; },\n cm.options.cursorBlinkRate); }\n else if (cm.options.cursorBlinkRate < 0)\n { display.cursorDiv.style.visibility = \"hidden\"; }\n }\n\n function ensureFocus(cm) {\n if (!cm.state.focused) { cm.display.input.focus(); onFocus(cm); }\n }\n\n function delayBlurEvent(cm) {\n cm.state.delayingBlurEvent = true;\n setTimeout(function () { if (cm.state.delayingBlurEvent) {\n cm.state.delayingBlurEvent = false;\n onBlur(cm);\n } }, 100);\n }\n\n function onFocus(cm, e) {\n if (cm.state.delayingBlurEvent) { cm.state.delayingBlurEvent = false; }\n\n if (cm.options.readOnly == \"nocursor\") { return }\n if (!cm.state.focused) {\n signal(cm, \"focus\", cm, e);\n cm.state.focused = true;\n addClass(cm.display.wrapper, \"CodeMirror-focused\");\n // This test prevents this from firing when a context\n // menu is closed (since the input reset would kill the\n // select-all detection hack)\n if (!cm.curOp && cm.display.selForContextMenu != cm.doc.sel) {\n cm.display.input.reset();\n if (webkit) { setTimeout(function () { return cm.display.input.reset(true); }, 20); } // Issue #1730\n }\n cm.display.input.receivedFocus();\n }\n restartBlink(cm);\n }\n function onBlur(cm, e) {\n if (cm.state.delayingBlurEvent) { return }\n\n if (cm.state.focused) {\n signal(cm, \"blur\", cm, e);\n cm.state.focused = false;\n rmClass(cm.display.wrapper, \"CodeMirror-focused\");\n }\n clearInterval(cm.display.blinker);\n setTimeout(function () { if (!cm.state.focused) { cm.display.shift = false; } }, 150);\n }\n\n // Read the actual heights of the rendered lines, and update their\n // stored heights to match.\n function updateHeightsInViewport(cm) {\n var display = cm.display;\n var prevBottom = display.lineDiv.offsetTop;\n for (var i = 0; i < display.view.length; i++) {\n var cur = display.view[i], wrapping = cm.options.lineWrapping;\n var height = (void 0), width = 0;\n if (cur.hidden) { continue }\n if (ie && ie_version < 8) {\n var bot = cur.node.offsetTop + cur.node.offsetHeight;\n height = bot - prevBottom;\n prevBottom = bot;\n } else {\n var box = cur.node.getBoundingClientRect();\n height = box.bottom - box.top;\n // Check that lines don't extend past the right of the current\n // editor width\n if (!wrapping && cur.text.firstChild)\n { width = cur.text.firstChild.getBoundingClientRect().right - box.left - 1; }\n }\n var diff = cur.line.height - height;\n if (diff > .005 || diff < -.005) {\n updateLineHeight(cur.line, height);\n updateWidgetHeight(cur.line);\n if (cur.rest) { for (var j = 0; j < cur.rest.length; j++)\n { updateWidgetHeight(cur.rest[j]); } }\n }\n if (width > cm.display.sizerWidth) {\n var chWidth = Math.ceil(width / charWidth(cm.display));\n if (chWidth > cm.display.maxLineLength) {\n cm.display.maxLineLength = chWidth;\n cm.display.maxLine = cur.line;\n cm.display.maxLineChanged = true;\n }\n }\n }\n }\n\n // Read and store the height of line widgets associated with the\n // given line.\n function updateWidgetHeight(line) {\n if (line.widgets) { for (var i = 0; i < line.widgets.length; ++i) {\n var w = line.widgets[i], parent = w.node.parentNode;\n if (parent) { w.height = parent.offsetHeight; }\n } }\n }\n\n // Compute the lines that are visible in a given viewport (defaults\n // the the current scroll position). viewport may contain top,\n // height, and ensure (see op.scrollToPos) properties.\n function visibleLines(display, doc, viewport) {\n var top = viewport && viewport.top != null ? Math.max(0, viewport.top) : display.scroller.scrollTop;\n top = Math.floor(top - paddingTop(display));\n var bottom = viewport && viewport.bottom != null ? viewport.bottom : top + display.wrapper.clientHeight;\n\n var from = lineAtHeight(doc, top), to = lineAtHeight(doc, bottom);\n // Ensure is a {from: {line, ch}, to: {line, ch}} object, and\n // forces those lines into the viewport (if possible).\n if (viewport && viewport.ensure) {\n var ensureFrom = viewport.ensure.from.line, ensureTo = viewport.ensure.to.line;\n if (ensureFrom < from) {\n from = ensureFrom;\n to = lineAtHeight(doc, heightAtLine(getLine(doc, ensureFrom)) + display.wrapper.clientHeight);\n } else if (Math.min(ensureTo, doc.lastLine()) >= to) {\n from = lineAtHeight(doc, heightAtLine(getLine(doc, ensureTo)) - display.wrapper.clientHeight);\n to = ensureTo;\n }\n }\n return {from: from, to: Math.max(to, from + 1)}\n }\n\n // SCROLLING THINGS INTO VIEW\n\n // If an editor sits on the top or bottom of the window, partially\n // scrolled out of view, this ensures that the cursor is visible.\n function maybeScrollWindow(cm, rect) {\n if (signalDOMEvent(cm, \"scrollCursorIntoView\")) { return }\n\n var display = cm.display, box = display.sizer.getBoundingClientRect(), doScroll = null;\n if (rect.top + box.top < 0) { doScroll = true; }\n else if (rect.bottom + box.top > (window.innerHeight || document.documentElement.clientHeight)) { doScroll = false; }\n if (doScroll != null && !phantom) {\n var scrollNode = elt(\"div\", \"\\u200b\", null, (\"position: absolute;\\n top: \" + (rect.top - display.viewOffset - paddingTop(cm.display)) + \"px;\\n height: \" + (rect.bottom - rect.top + scrollGap(cm) + display.barHeight) + \"px;\\n left: \" + (rect.left) + \"px; width: \" + (Math.max(2, rect.right - rect.left)) + \"px;\"));\n cm.display.lineSpace.appendChild(scrollNode);\n scrollNode.scrollIntoView(doScroll);\n cm.display.lineSpace.removeChild(scrollNode);\n }\n }\n\n // Scroll a given position into view (immediately), verifying that\n // it actually became visible (as line heights are accurately\n // measured, the position of something may 'drift' during drawing).\n function scrollPosIntoView(cm, pos, end, margin) {\n if (margin == null) { margin = 0; }\n var rect;\n if (!cm.options.lineWrapping && pos == end) {\n // Set pos and end to the cursor positions around the character pos sticks to\n // If pos.sticky == \"before\", that is around pos.ch - 1, otherwise around pos.ch\n // If pos == Pos(_, 0, \"before\"), pos and end are unchanged\n pos = pos.ch ? Pos(pos.line, pos.sticky == \"before\" ? pos.ch - 1 : pos.ch, \"after\") : pos;\n end = pos.sticky == \"before\" ? Pos(pos.line, pos.ch + 1, \"before\") : pos;\n }\n for (var limit = 0; limit < 5; limit++) {\n var changed = false;\n var coords = cursorCoords(cm, pos);\n var endCoords = !end || end == pos ? coords : cursorCoords(cm, end);\n rect = {left: Math.min(coords.left, endCoords.left),\n top: Math.min(coords.top, endCoords.top) - margin,\n right: Math.max(coords.left, endCoords.left),\n bottom: Math.max(coords.bottom, endCoords.bottom) + margin};\n var scrollPos = calculateScrollPos(cm, rect);\n var startTop = cm.doc.scrollTop, startLeft = cm.doc.scrollLeft;\n if (scrollPos.scrollTop != null) {\n updateScrollTop(cm, scrollPos.scrollTop);\n if (Math.abs(cm.doc.scrollTop - startTop) > 1) { changed = true; }\n }\n if (scrollPos.scrollLeft != null) {\n setScrollLeft(cm, scrollPos.scrollLeft);\n if (Math.abs(cm.doc.scrollLeft - startLeft) > 1) { changed = true; }\n }\n if (!changed) { break }\n }\n return rect\n }\n\n // Scroll a given set of coordinates into view (immediately).\n function scrollIntoView(cm, rect) {\n var scrollPos = calculateScrollPos(cm, rect);\n if (scrollPos.scrollTop != null) { updateScrollTop(cm, scrollPos.scrollTop); }\n if (scrollPos.scrollLeft != null) { setScrollLeft(cm, scrollPos.scrollLeft); }\n }\n\n // Calculate a new scroll position needed to scroll the given\n // rectangle into view. Returns an object with scrollTop and\n // scrollLeft properties. When these are undefined, the\n // vertical/horizontal position does not need to be adjusted.\n function calculateScrollPos(cm, rect) {\n var display = cm.display, snapMargin = textHeight(cm.display);\n if (rect.top < 0) { rect.top = 0; }\n var screentop = cm.curOp && cm.curOp.scrollTop != null ? cm.curOp.scrollTop : display.scroller.scrollTop;\n var screen = displayHeight(cm), result = {};\n if (rect.bottom - rect.top > screen) { rect.bottom = rect.top + screen; }\n var docBottom = cm.doc.height + paddingVert(display);\n var atTop = rect.top < snapMargin, atBottom = rect.bottom > docBottom - snapMargin;\n if (rect.top < screentop) {\n result.scrollTop = atTop ? 0 : rect.top;\n } else if (rect.bottom > screentop + screen) {\n var newTop = Math.min(rect.top, (atBottom ? docBottom : rect.bottom) - screen);\n if (newTop != screentop) { result.scrollTop = newTop; }\n }\n\n var screenleft = cm.curOp && cm.curOp.scrollLeft != null ? cm.curOp.scrollLeft : display.scroller.scrollLeft;\n var screenw = displayWidth(cm) - (cm.options.fixedGutter ? display.gutters.offsetWidth : 0);\n var tooWide = rect.right - rect.left > screenw;\n if (tooWide) { rect.right = rect.left + screenw; }\n if (rect.left < 10)\n { result.scrollLeft = 0; }\n else if (rect.left < screenleft)\n { result.scrollLeft = Math.max(0, rect.left - (tooWide ? 0 : 10)); }\n else if (rect.right > screenw + screenleft - 3)\n { result.scrollLeft = rect.right + (tooWide ? 0 : 10) - screenw; }\n return result\n }\n\n // Store a relative adjustment to the scroll position in the current\n // operation (to be applied when the operation finishes).\n function addToScrollTop(cm, top) {\n if (top == null) { return }\n resolveScrollToPos(cm);\n cm.curOp.scrollTop = (cm.curOp.scrollTop == null ? cm.doc.scrollTop : cm.curOp.scrollTop) + top;\n }\n\n // Make sure that at the end of the operation the current cursor is\n // shown.\n function ensureCursorVisible(cm) {\n resolveScrollToPos(cm);\n var cur = cm.getCursor();\n cm.curOp.scrollToPos = {from: cur, to: cur, margin: cm.options.cursorScrollMargin};\n }\n\n function scrollToCoords(cm, x, y) {\n if (x != null || y != null) { resolveScrollToPos(cm); }\n if (x != null) { cm.curOp.scrollLeft = x; }\n if (y != null) { cm.curOp.scrollTop = y; }\n }\n\n function scrollToRange(cm, range$$1) {\n resolveScrollToPos(cm);\n cm.curOp.scrollToPos = range$$1;\n }\n\n // When an operation has its scrollToPos property set, and another\n // scroll action is applied before the end of the operation, this\n // 'simulates' scrolling that position into view in a cheap way, so\n // that the effect of intermediate scroll commands is not ignored.\n function resolveScrollToPos(cm) {\n var range$$1 = cm.curOp.scrollToPos;\n if (range$$1) {\n cm.curOp.scrollToPos = null;\n var from = estimateCoords(cm, range$$1.from), to = estimateCoords(cm, range$$1.to);\n scrollToCoordsRange(cm, from, to, range$$1.margin);\n }\n }\n\n function scrollToCoordsRange(cm, from, to, margin) {\n var sPos = calculateScrollPos(cm, {\n left: Math.min(from.left, to.left),\n top: Math.min(from.top, to.top) - margin,\n right: Math.max(from.right, to.right),\n bottom: Math.max(from.bottom, to.bottom) + margin\n });\n scrollToCoords(cm, sPos.scrollLeft, sPos.scrollTop);\n }\n\n // Sync the scrollable area and scrollbars, ensure the viewport\n // covers the visible area.\n function updateScrollTop(cm, val) {\n if (Math.abs(cm.doc.scrollTop - val) < 2) { return }\n if (!gecko) { updateDisplaySimple(cm, {top: val}); }\n setScrollTop(cm, val, true);\n if (gecko) { updateDisplaySimple(cm); }\n startWorker(cm, 100);\n }\n\n function setScrollTop(cm, val, forceScroll) {\n val = Math.min(cm.display.scroller.scrollHeight - cm.display.scroller.clientHeight, val);\n if (cm.display.scroller.scrollTop == val && !forceScroll) { return }\n cm.doc.scrollTop = val;\n cm.display.scrollbars.setScrollTop(val);\n if (cm.display.scroller.scrollTop != val) { cm.display.scroller.scrollTop = val; }\n }\n\n // Sync scroller and scrollbar, ensure the gutter elements are\n // aligned.\n function setScrollLeft(cm, val, isScroller, forceScroll) {\n val = Math.min(val, cm.display.scroller.scrollWidth - cm.display.scroller.clientWidth);\n if ((isScroller ? val == cm.doc.scrollLeft : Math.abs(cm.doc.scrollLeft - val) < 2) && !forceScroll) { return }\n cm.doc.scrollLeft = val;\n alignHorizontally(cm);\n if (cm.display.scroller.scrollLeft != val) { cm.display.scroller.scrollLeft = val; }\n cm.display.scrollbars.setScrollLeft(val);\n }\n\n // SCROLLBARS\n\n // Prepare DOM reads needed to update the scrollbars. Done in one\n // shot to minimize update/measure roundtrips.\n function measureForScrollbars(cm) {\n var d = cm.display, gutterW = d.gutters.offsetWidth;\n var docH = Math.round(cm.doc.height + paddingVert(cm.display));\n return {\n clientHeight: d.scroller.clientHeight,\n viewHeight: d.wrapper.clientHeight,\n scrollWidth: d.scroller.scrollWidth, clientWidth: d.scroller.clientWidth,\n viewWidth: d.wrapper.clientWidth,\n barLeft: cm.options.fixedGutter ? gutterW : 0,\n docHeight: docH,\n scrollHeight: docH + scrollGap(cm) + d.barHeight,\n nativeBarWidth: d.nativeBarWidth,\n gutterWidth: gutterW\n }\n }\n\n var NativeScrollbars = function(place, scroll, cm) {\n this.cm = cm;\n var vert = this.vert = elt(\"div\", [elt(\"div\", null, null, \"min-width: 1px\")], \"CodeMirror-vscrollbar\");\n var horiz = this.horiz = elt(\"div\", [elt(\"div\", null, null, \"height: 100%; min-height: 1px\")], \"CodeMirror-hscrollbar\");\n vert.tabIndex = horiz.tabIndex = -1;\n place(vert); place(horiz);\n\n on(vert, \"scroll\", function () {\n if (vert.clientHeight) { scroll(vert.scrollTop, \"vertical\"); }\n });\n on(horiz, \"scroll\", function () {\n if (horiz.clientWidth) { scroll(horiz.scrollLeft, \"horizontal\"); }\n });\n\n this.checkedZeroWidth = false;\n // Need to set a minimum width to see the scrollbar on IE7 (but must not set it on IE8).\n if (ie && ie_version < 8) { this.horiz.style.minHeight = this.vert.style.minWidth = \"18px\"; }\n };\n\n NativeScrollbars.prototype.update = function (measure) {\n var needsH = measure.scrollWidth > measure.clientWidth + 1;\n var needsV = measure.scrollHeight > measure.clientHeight + 1;\n var sWidth = measure.nativeBarWidth;\n\n if (needsV) {\n this.vert.style.display = \"block\";\n this.vert.style.bottom = needsH ? sWidth + \"px\" : \"0\";\n var totalHeight = measure.viewHeight - (needsH ? sWidth : 0);\n // A bug in IE8 can cause this value to be negative, so guard it.\n this.vert.firstChild.style.height =\n Math.max(0, measure.scrollHeight - measure.clientHeight + totalHeight) + \"px\";\n } else {\n this.vert.style.display = \"\";\n this.vert.firstChild.style.height = \"0\";\n }\n\n if (needsH) {\n this.horiz.style.display = \"block\";\n this.horiz.style.right = needsV ? sWidth + \"px\" : \"0\";\n this.horiz.style.left = measure.barLeft + \"px\";\n var totalWidth = measure.viewWidth - measure.barLeft - (needsV ? sWidth : 0);\n this.horiz.firstChild.style.width =\n Math.max(0, measure.scrollWidth - measure.clientWidth + totalWidth) + \"px\";\n } else {\n this.horiz.style.display = \"\";\n this.horiz.firstChild.style.width = \"0\";\n }\n\n if (!this.checkedZeroWidth && measure.clientHeight > 0) {\n if (sWidth == 0) { this.zeroWidthHack(); }\n this.checkedZeroWidth = true;\n }\n\n return {right: needsV ? sWidth : 0, bottom: needsH ? sWidth : 0}\n };\n\n NativeScrollbars.prototype.setScrollLeft = function (pos) {\n if (this.horiz.scrollLeft != pos) { this.horiz.scrollLeft = pos; }\n if (this.disableHoriz) { this.enableZeroWidthBar(this.horiz, this.disableHoriz, \"horiz\"); }\n };\n\n NativeScrollbars.prototype.setScrollTop = function (pos) {\n if (this.vert.scrollTop != pos) { this.vert.scrollTop = pos; }\n if (this.disableVert) { this.enableZeroWidthBar(this.vert, this.disableVert, \"vert\"); }\n };\n\n NativeScrollbars.prototype.zeroWidthHack = function () {\n var w = mac && !mac_geMountainLion ? \"12px\" : \"18px\";\n this.horiz.style.height = this.vert.style.width = w;\n this.horiz.style.pointerEvents = this.vert.style.pointerEvents = \"none\";\n this.disableHoriz = new Delayed;\n this.disableVert = new Delayed;\n };\n\n NativeScrollbars.prototype.enableZeroWidthBar = function (bar, delay, type) {\n bar.style.pointerEvents = \"auto\";\n function maybeDisable() {\n // To find out whether the scrollbar is still visible, we\n // check whether the element under the pixel in the bottom\n // right corner of the scrollbar box is the scrollbar box\n // itself (when the bar is still visible) or its filler child\n // (when the bar is hidden). If it is still visible, we keep\n // it enabled, if it's hidden, we disable pointer events.\n var box = bar.getBoundingClientRect();\n var elt$$1 = type == \"vert\" ? document.elementFromPoint(box.right - 1, (box.top + box.bottom) / 2)\n : document.elementFromPoint((box.right + box.left) / 2, box.bottom - 1);\n if (elt$$1 != bar) { bar.style.pointerEvents = \"none\"; }\n else { delay.set(1000, maybeDisable); }\n }\n delay.set(1000, maybeDisable);\n };\n\n NativeScrollbars.prototype.clear = function () {\n var parent = this.horiz.parentNode;\n parent.removeChild(this.horiz);\n parent.removeChild(this.vert);\n };\n\n var NullScrollbars = function () {};\n\n NullScrollbars.prototype.update = function () { return {bottom: 0, right: 0} };\n NullScrollbars.prototype.setScrollLeft = function () {};\n NullScrollbars.prototype.setScrollTop = function () {};\n NullScrollbars.prototype.clear = function () {};\n\n function updateScrollbars(cm, measure) {\n if (!measure) { measure = measureForScrollbars(cm); }\n var startWidth = cm.display.barWidth, startHeight = cm.display.barHeight;\n updateScrollbarsInner(cm, measure);\n for (var i = 0; i < 4 && startWidth != cm.display.barWidth || startHeight != cm.display.barHeight; i++) {\n if (startWidth != cm.display.barWidth && cm.options.lineWrapping)\n { updateHeightsInViewport(cm); }\n updateScrollbarsInner(cm, measureForScrollbars(cm));\n startWidth = cm.display.barWidth; startHeight = cm.display.barHeight;\n }\n }\n\n // Re-synchronize the fake scrollbars with the actual size of the\n // content.\n function updateScrollbarsInner(cm, measure) {\n var d = cm.display;\n var sizes = d.scrollbars.update(measure);\n\n d.sizer.style.paddingRight = (d.barWidth = sizes.right) + \"px\";\n d.sizer.style.paddingBottom = (d.barHeight = sizes.bottom) + \"px\";\n d.heightForcer.style.borderBottom = sizes.bottom + \"px solid transparent\";\n\n if (sizes.right && sizes.bottom) {\n d.scrollbarFiller.style.display = \"block\";\n d.scrollbarFiller.style.height = sizes.bottom + \"px\";\n d.scrollbarFiller.style.width = sizes.right + \"px\";\n } else { d.scrollbarFiller.style.display = \"\"; }\n if (sizes.bottom && cm.options.coverGutterNextToScrollbar && cm.options.fixedGutter) {\n d.gutterFiller.style.display = \"block\";\n d.gutterFiller.style.height = sizes.bottom + \"px\";\n d.gutterFiller.style.width = measure.gutterWidth + \"px\";\n } else { d.gutterFiller.style.display = \"\"; }\n }\n\n var scrollbarModel = {\"native\": NativeScrollbars, \"null\": NullScrollbars};\n\n function initScrollbars(cm) {\n if (cm.display.scrollbars) {\n cm.display.scrollbars.clear();\n if (cm.display.scrollbars.addClass)\n { rmClass(cm.display.wrapper, cm.display.scrollbars.addClass); }\n }\n\n cm.display.scrollbars = new scrollbarModel[cm.options.scrollbarStyle](function (node) {\n cm.display.wrapper.insertBefore(node, cm.display.scrollbarFiller);\n // Prevent clicks in the scrollbars from killing focus\n on(node, \"mousedown\", function () {\n if (cm.state.focused) { setTimeout(function () { return cm.display.input.focus(); }, 0); }\n });\n node.setAttribute(\"cm-not-content\", \"true\");\n }, function (pos, axis) {\n if (axis == \"horizontal\") { setScrollLeft(cm, pos); }\n else { updateScrollTop(cm, pos); }\n }, cm);\n if (cm.display.scrollbars.addClass)\n { addClass(cm.display.wrapper, cm.display.scrollbars.addClass); }\n }\n\n // Operations are used to wrap a series of changes to the editor\n // state in such a way that each change won't have to update the\n // cursor and display (which would be awkward, slow, and\n // error-prone). Instead, display updates are batched and then all\n // combined and executed at once.\n\n var nextOpId = 0;\n // Start a new operation.\n function startOperation(cm) {\n cm.curOp = {\n cm: cm,\n viewChanged: false, // Flag that indicates that lines might need to be redrawn\n startHeight: cm.doc.height, // Used to detect need to update scrollbar\n forceUpdate: false, // Used to force a redraw\n updateInput: 0, // Whether to reset the input textarea\n typing: false, // Whether this reset should be careful to leave existing text (for compositing)\n changeObjs: null, // Accumulated changes, for firing change events\n cursorActivityHandlers: null, // Set of handlers to fire cursorActivity on\n cursorActivityCalled: 0, // Tracks which cursorActivity handlers have been called already\n selectionChanged: false, // Whether the selection needs to be redrawn\n updateMaxLine: false, // Set when the widest line needs to be determined anew\n scrollLeft: null, scrollTop: null, // Intermediate scroll position, not pushed to DOM yet\n scrollToPos: null, // Used to scroll to a specific position\n focus: false,\n id: ++nextOpId // Unique ID\n };\n pushOperation(cm.curOp);\n }\n\n // Finish an operation, updating the display and signalling delayed events\n function endOperation(cm) {\n var op = cm.curOp;\n if (op) { finishOperation(op, function (group) {\n for (var i = 0; i < group.ops.length; i++)\n { group.ops[i].cm.curOp = null; }\n endOperations(group);\n }); }\n }\n\n // The DOM updates done when an operation finishes are batched so\n // that the minimum number of relayouts are required.\n function endOperations(group) {\n var ops = group.ops;\n for (var i = 0; i < ops.length; i++) // Read DOM\n { endOperation_R1(ops[i]); }\n for (var i$1 = 0; i$1 < ops.length; i$1++) // Write DOM (maybe)\n { endOperation_W1(ops[i$1]); }\n for (var i$2 = 0; i$2 < ops.length; i$2++) // Read DOM\n { endOperation_R2(ops[i$2]); }\n for (var i$3 = 0; i$3 < ops.length; i$3++) // Write DOM (maybe)\n { endOperation_W2(ops[i$3]); }\n for (var i$4 = 0; i$4 < ops.length; i$4++) // Read DOM\n { endOperation_finish(ops[i$4]); }\n }\n\n function endOperation_R1(op) {\n var cm = op.cm, display = cm.display;\n maybeClipScrollbars(cm);\n if (op.updateMaxLine) { findMaxLine(cm); }\n\n op.mustUpdate = op.viewChanged || op.forceUpdate || op.scrollTop != null ||\n op.scrollToPos && (op.scrollToPos.from.line < display.viewFrom ||\n op.scrollToPos.to.line >= display.viewTo) ||\n display.maxLineChanged && cm.options.lineWrapping;\n op.update = op.mustUpdate &&\n new DisplayUpdate(cm, op.mustUpdate && {top: op.scrollTop, ensure: op.scrollToPos}, op.forceUpdate);\n }\n\n function endOperation_W1(op) {\n op.updatedDisplay = op.mustUpdate && updateDisplayIfNeeded(op.cm, op.update);\n }\n\n function endOperation_R2(op) {\n var cm = op.cm, display = cm.display;\n if (op.updatedDisplay) { updateHeightsInViewport(cm); }\n\n op.barMeasure = measureForScrollbars(cm);\n\n // If the max line changed since it was last measured, measure it,\n // and ensure the document's width matches it.\n // updateDisplay_W2 will use these properties to do the actual resizing\n if (display.maxLineChanged && !cm.options.lineWrapping) {\n op.adjustWidthTo = measureChar(cm, display.maxLine, display.maxLine.text.length).left + 3;\n cm.display.sizerWidth = op.adjustWidthTo;\n op.barMeasure.scrollWidth =\n Math.max(display.scroller.clientWidth, display.sizer.offsetLeft + op.adjustWidthTo + scrollGap(cm) + cm.display.barWidth);\n op.maxScrollLeft = Math.max(0, display.sizer.offsetLeft + op.adjustWidthTo - displayWidth(cm));\n }\n\n if (op.updatedDisplay || op.selectionChanged)\n { op.preparedSelection = display.input.prepareSelection(); }\n }\n\n function endOperation_W2(op) {\n var cm = op.cm;\n\n if (op.adjustWidthTo != null) {\n cm.display.sizer.style.minWidth = op.adjustWidthTo + \"px\";\n if (op.maxScrollLeft < cm.doc.scrollLeft)\n { setScrollLeft(cm, Math.min(cm.display.scroller.scrollLeft, op.maxScrollLeft), true); }\n cm.display.maxLineChanged = false;\n }\n\n var takeFocus = op.focus && op.focus == activeElt();\n if (op.preparedSelection)\n { cm.display.input.showSelection(op.preparedSelection, takeFocus); }\n if (op.updatedDisplay || op.startHeight != cm.doc.height)\n { updateScrollbars(cm, op.barMeasure); }\n if (op.updatedDisplay)\n { setDocumentHeight(cm, op.barMeasure); }\n\n if (op.selectionChanged) { restartBlink(cm); }\n\n if (cm.state.focused && op.updateInput)\n { cm.display.input.reset(op.typing); }\n if (takeFocus) { ensureFocus(op.cm); }\n }\n\n function endOperation_finish(op) {\n var cm = op.cm, display = cm.display, doc = cm.doc;\n\n if (op.updatedDisplay) { postUpdateDisplay(cm, op.update); }\n\n // Abort mouse wheel delta measurement, when scrolling explicitly\n if (display.wheelStartX != null && (op.scrollTop != null || op.scrollLeft != null || op.scrollToPos))\n { display.wheelStartX = display.wheelStartY = null; }\n\n // Propagate the scroll position to the actual DOM scroller\n if (op.scrollTop != null) { setScrollTop(cm, op.scrollTop, op.forceScroll); }\n\n if (op.scrollLeft != null) { setScrollLeft(cm, op.scrollLeft, true, true); }\n // If we need to scroll a specific position into view, do so.\n if (op.scrollToPos) {\n var rect = scrollPosIntoView(cm, clipPos(doc, op.scrollToPos.from),\n clipPos(doc, op.scrollToPos.to), op.scrollToPos.margin);\n maybeScrollWindow(cm, rect);\n }\n\n // Fire events for markers that are hidden/unidden by editing or\n // undoing\n var hidden = op.maybeHiddenMarkers, unhidden = op.maybeUnhiddenMarkers;\n if (hidden) { for (var i = 0; i < hidden.length; ++i)\n { if (!hidden[i].lines.length) { signal(hidden[i], \"hide\"); } } }\n if (unhidden) { for (var i$1 = 0; i$1 < unhidden.length; ++i$1)\n { if (unhidden[i$1].lines.length) { signal(unhidden[i$1], \"unhide\"); } } }\n\n if (display.wrapper.offsetHeight)\n { doc.scrollTop = cm.display.scroller.scrollTop; }\n\n // Fire change events, and delayed event handlers\n if (op.changeObjs)\n { signal(cm, \"changes\", cm, op.changeObjs); }\n if (op.update)\n { op.update.finish(); }\n }\n\n // Run the given function in an operation\n function runInOp(cm, f) {\n if (cm.curOp) { return f() }\n startOperation(cm);\n try { return f() }\n finally { endOperation(cm); }\n }\n // Wraps a function in an operation. Returns the wrapped function.\n function operation(cm, f) {\n return function() {\n if (cm.curOp) { return f.apply(cm, arguments) }\n startOperation(cm);\n try { return f.apply(cm, arguments) }\n finally { endOperation(cm); }\n }\n }\n // Used to add methods to editor and doc instances, wrapping them in\n // operations.\n function methodOp(f) {\n return function() {\n if (this.curOp) { return f.apply(this, arguments) }\n startOperation(this);\n try { return f.apply(this, arguments) }\n finally { endOperation(this); }\n }\n }\n function docMethodOp(f) {\n return function() {\n var cm = this.cm;\n if (!cm || cm.curOp) { return f.apply(this, arguments) }\n startOperation(cm);\n try { return f.apply(this, arguments) }\n finally { endOperation(cm); }\n }\n }\n\n // HIGHLIGHT WORKER\n\n function startWorker(cm, time) {\n if (cm.doc.highlightFrontier < cm.display.viewTo)\n { cm.state.highlight.set(time, bind(highlightWorker, cm)); }\n }\n\n function highlightWorker(cm) {\n var doc = cm.doc;\n if (doc.highlightFrontier >= cm.display.viewTo) { return }\n var end = +new Date + cm.options.workTime;\n var context = getContextBefore(cm, doc.highlightFrontier);\n var changedLines = [];\n\n doc.iter(context.line, Math.min(doc.first + doc.size, cm.display.viewTo + 500), function (line) {\n if (context.line >= cm.display.viewFrom) { // Visible\n var oldStyles = line.styles;\n var resetState = line.text.length > cm.options.maxHighlightLength ? copyState(doc.mode, context.state) : null;\n var highlighted = highlightLine(cm, line, context, true);\n if (resetState) { context.state = resetState; }\n line.styles = highlighted.styles;\n var oldCls = line.styleClasses, newCls = highlighted.classes;\n if (newCls) { line.styleClasses = newCls; }\n else if (oldCls) { line.styleClasses = null; }\n var ischange = !oldStyles || oldStyles.length != line.styles.length ||\n oldCls != newCls && (!oldCls || !newCls || oldCls.bgClass != newCls.bgClass || oldCls.textClass != newCls.textClass);\n for (var i = 0; !ischange && i < oldStyles.length; ++i) { ischange = oldStyles[i] != line.styles[i]; }\n if (ischange) { changedLines.push(context.line); }\n line.stateAfter = context.save();\n context.nextLine();\n } else {\n if (line.text.length <= cm.options.maxHighlightLength)\n { processLine(cm, line.text, context); }\n line.stateAfter = context.line % 5 == 0 ? context.save() : null;\n context.nextLine();\n }\n if (+new Date > end) {\n startWorker(cm, cm.options.workDelay);\n return true\n }\n });\n doc.highlightFrontier = context.line;\n doc.modeFrontier = Math.max(doc.modeFrontier, context.line);\n if (changedLines.length) { runInOp(cm, function () {\n for (var i = 0; i < changedLines.length; i++)\n { regLineChange(cm, changedLines[i], \"text\"); }\n }); }\n }\n\n // DISPLAY DRAWING\n\n var DisplayUpdate = function(cm, viewport, force) {\n var display = cm.display;\n\n this.viewport = viewport;\n // Store some values that we'll need later (but don't want to force a relayout for)\n this.visible = visibleLines(display, cm.doc, viewport);\n this.editorIsHidden = !display.wrapper.offsetWidth;\n this.wrapperHeight = display.wrapper.clientHeight;\n this.wrapperWidth = display.wrapper.clientWidth;\n this.oldDisplayWidth = displayWidth(cm);\n this.force = force;\n this.dims = getDimensions(cm);\n this.events = [];\n };\n\n DisplayUpdate.prototype.signal = function (emitter, type) {\n if (hasHandler(emitter, type))\n { this.events.push(arguments); }\n };\n DisplayUpdate.prototype.finish = function () {\n var this$1 = this;\n\n for (var i = 0; i < this.events.length; i++)\n { signal.apply(null, this$1.events[i]); }\n };\n\n function maybeClipScrollbars(cm) {\n var display = cm.display;\n if (!display.scrollbarsClipped && display.scroller.offsetWidth) {\n display.nativeBarWidth = display.scroller.offsetWidth - display.scroller.clientWidth;\n display.heightForcer.style.height = scrollGap(cm) + \"px\";\n display.sizer.style.marginBottom = -display.nativeBarWidth + \"px\";\n display.sizer.style.borderRightWidth = scrollGap(cm) + \"px\";\n display.scrollbarsClipped = true;\n }\n }\n\n function selectionSnapshot(cm) {\n if (cm.hasFocus()) { return null }\n var active = activeElt();\n if (!active || !contains(cm.display.lineDiv, active)) { return null }\n var result = {activeElt: active};\n if (window.getSelection) {\n var sel = window.getSelection();\n if (sel.anchorNode && sel.extend && contains(cm.display.lineDiv, sel.anchorNode)) {\n result.anchorNode = sel.anchorNode;\n result.anchorOffset = sel.anchorOffset;\n result.focusNode = sel.focusNode;\n result.focusOffset = sel.focusOffset;\n }\n }\n return result\n }\n\n function restoreSelection(snapshot) {\n if (!snapshot || !snapshot.activeElt || snapshot.activeElt == activeElt()) { return }\n snapshot.activeElt.focus();\n if (snapshot.anchorNode && contains(document.body, snapshot.anchorNode) && contains(document.body, snapshot.focusNode)) {\n var sel = window.getSelection(), range$$1 = document.createRange();\n range$$1.setEnd(snapshot.anchorNode, snapshot.anchorOffset);\n range$$1.collapse(false);\n sel.removeAllRanges();\n sel.addRange(range$$1);\n sel.extend(snapshot.focusNode, snapshot.focusOffset);\n }\n }\n\n // Does the actual updating of the line display. Bails out\n // (returning false) when there is nothing to be done and forced is\n // false.\n function updateDisplayIfNeeded(cm, update) {\n var display = cm.display, doc = cm.doc;\n\n if (update.editorIsHidden) {\n resetView(cm);\n return false\n }\n\n // Bail out if the visible area is already rendered and nothing changed.\n if (!update.force &&\n update.visible.from >= display.viewFrom && update.visible.to <= display.viewTo &&\n (display.updateLineNumbers == null || display.updateLineNumbers >= display.viewTo) &&\n display.renderedView == display.view && countDirtyView(cm) == 0)\n { return false }\n\n if (maybeUpdateLineNumberWidth(cm)) {\n resetView(cm);\n update.dims = getDimensions(cm);\n }\n\n // Compute a suitable new viewport (from & to)\n var end = doc.first + doc.size;\n var from = Math.max(update.visible.from - cm.options.viewportMargin, doc.first);\n var to = Math.min(end, update.visible.to + cm.options.viewportMargin);\n if (display.viewFrom < from && from - display.viewFrom < 20) { from = Math.max(doc.first, display.viewFrom); }\n if (display.viewTo > to && display.viewTo - to < 20) { to = Math.min(end, display.viewTo); }\n if (sawCollapsedSpans) {\n from = visualLineNo(cm.doc, from);\n to = visualLineEndNo(cm.doc, to);\n }\n\n var different = from != display.viewFrom || to != display.viewTo ||\n display.lastWrapHeight != update.wrapperHeight || display.lastWrapWidth != update.wrapperWidth;\n adjustView(cm, from, to);\n\n display.viewOffset = heightAtLine(getLine(cm.doc, display.viewFrom));\n // Position the mover div to align with the current scroll position\n cm.display.mover.style.top = display.viewOffset + \"px\";\n\n var toUpdate = countDirtyView(cm);\n if (!different && toUpdate == 0 && !update.force && display.renderedView == display.view &&\n (display.updateLineNumbers == null || display.updateLineNumbers >= display.viewTo))\n { return false }\n\n // For big changes, we hide the enclosing element during the\n // update, since that speeds up the operations on most browsers.\n var selSnapshot = selectionSnapshot(cm);\n if (toUpdate > 4) { display.lineDiv.style.display = \"none\"; }\n patchDisplay(cm, display.updateLineNumbers, update.dims);\n if (toUpdate > 4) { display.lineDiv.style.display = \"\"; }\n display.renderedView = display.view;\n // There might have been a widget with a focused element that got\n // hidden or updated, if so re-focus it.\n restoreSelection(selSnapshot);\n\n // Prevent selection and cursors from interfering with the scroll\n // width and height.\n removeChildren(display.cursorDiv);\n removeChildren(display.selectionDiv);\n display.gutters.style.height = display.sizer.style.minHeight = 0;\n\n if (different) {\n display.lastWrapHeight = update.wrapperHeight;\n display.lastWrapWidth = update.wrapperWidth;\n startWorker(cm, 400);\n }\n\n display.updateLineNumbers = null;\n\n return true\n }\n\n function postUpdateDisplay(cm, update) {\n var viewport = update.viewport;\n\n for (var first = true;; first = false) {\n if (!first || !cm.options.lineWrapping || update.oldDisplayWidth == displayWidth(cm)) {\n // Clip forced viewport to actual scrollable area.\n if (viewport && viewport.top != null)\n { viewport = {top: Math.min(cm.doc.height + paddingVert(cm.display) - displayHeight(cm), viewport.top)}; }\n // Updated line heights might result in the drawn area not\n // actually covering the viewport. Keep looping until it does.\n update.visible = visibleLines(cm.display, cm.doc, viewport);\n if (update.visible.from >= cm.display.viewFrom && update.visible.to <= cm.display.viewTo)\n { break }\n }\n if (!updateDisplayIfNeeded(cm, update)) { break }\n updateHeightsInViewport(cm);\n var barMeasure = measureForScrollbars(cm);\n updateSelection(cm);\n updateScrollbars(cm, barMeasure);\n setDocumentHeight(cm, barMeasure);\n update.force = false;\n }\n\n update.signal(cm, \"update\", cm);\n if (cm.display.viewFrom != cm.display.reportedViewFrom || cm.display.viewTo != cm.display.reportedViewTo) {\n update.signal(cm, \"viewportChange\", cm, cm.display.viewFrom, cm.display.viewTo);\n cm.display.reportedViewFrom = cm.display.viewFrom; cm.display.reportedViewTo = cm.display.viewTo;\n }\n }\n\n function updateDisplaySimple(cm, viewport) {\n var update = new DisplayUpdate(cm, viewport);\n if (updateDisplayIfNeeded(cm, update)) {\n updateHeightsInViewport(cm);\n postUpdateDisplay(cm, update);\n var barMeasure = measureForScrollbars(cm);\n updateSelection(cm);\n updateScrollbars(cm, barMeasure);\n setDocumentHeight(cm, barMeasure);\n update.finish();\n }\n }\n\n // Sync the actual display DOM structure with display.view, removing\n // nodes for lines that are no longer in view, and creating the ones\n // that are not there yet, and updating the ones that are out of\n // date.\n function patchDisplay(cm, updateNumbersFrom, dims) {\n var display = cm.display, lineNumbers = cm.options.lineNumbers;\n var container = display.lineDiv, cur = container.firstChild;\n\n function rm(node) {\n var next = node.nextSibling;\n // Works around a throw-scroll bug in OS X Webkit\n if (webkit && mac && cm.display.currentWheelTarget == node)\n { node.style.display = \"none\"; }\n else\n { node.parentNode.removeChild(node); }\n return next\n }\n\n var view = display.view, lineN = display.viewFrom;\n // Loop over the elements in the view, syncing cur (the DOM nodes\n // in display.lineDiv) with the view as we go.\n for (var i = 0; i < view.length; i++) {\n var lineView = view[i];\n if (lineView.hidden) ; else if (!lineView.node || lineView.node.parentNode != container) { // Not drawn yet\n var node = buildLineElement(cm, lineView, lineN, dims);\n container.insertBefore(node, cur);\n } else { // Already drawn\n while (cur != lineView.node) { cur = rm(cur); }\n var updateNumber = lineNumbers && updateNumbersFrom != null &&\n updateNumbersFrom <= lineN && lineView.lineNumber;\n if (lineView.changes) {\n if (indexOf(lineView.changes, \"gutter\") > -1) { updateNumber = false; }\n updateLineForChanges(cm, lineView, lineN, dims);\n }\n if (updateNumber) {\n removeChildren(lineView.lineNumber);\n lineView.lineNumber.appendChild(document.createTextNode(lineNumberFor(cm.options, lineN)));\n }\n cur = lineView.node.nextSibling;\n }\n lineN += lineView.size;\n }\n while (cur) { cur = rm(cur); }\n }\n\n function updateGutterSpace(display) {\n var width = display.gutters.offsetWidth;\n display.sizer.style.marginLeft = width + \"px\";\n }\n\n function setDocumentHeight(cm, measure) {\n cm.display.sizer.style.minHeight = measure.docHeight + \"px\";\n cm.display.heightForcer.style.top = measure.docHeight + \"px\";\n cm.display.gutters.style.height = (measure.docHeight + cm.display.barHeight + scrollGap(cm)) + \"px\";\n }\n\n // Re-align line numbers and gutter marks to compensate for\n // horizontal scrolling.\n function alignHorizontally(cm) {\n var display = cm.display, view = display.view;\n if (!display.alignWidgets && (!display.gutters.firstChild || !cm.options.fixedGutter)) { return }\n var comp = compensateForHScroll(display) - display.scroller.scrollLeft + cm.doc.scrollLeft;\n var gutterW = display.gutters.offsetWidth, left = comp + \"px\";\n for (var i = 0; i < view.length; i++) { if (!view[i].hidden) {\n if (cm.options.fixedGutter) {\n if (view[i].gutter)\n { view[i].gutter.style.left = left; }\n if (view[i].gutterBackground)\n { view[i].gutterBackground.style.left = left; }\n }\n var align = view[i].alignable;\n if (align) { for (var j = 0; j < align.length; j++)\n { align[j].style.left = left; } }\n } }\n if (cm.options.fixedGutter)\n { display.gutters.style.left = (comp + gutterW) + \"px\"; }\n }\n\n // Used to ensure that the line number gutter is still the right\n // size for the current document size. Returns true when an update\n // is needed.\n function maybeUpdateLineNumberWidth(cm) {\n if (!cm.options.lineNumbers) { return false }\n var doc = cm.doc, last = lineNumberFor(cm.options, doc.first + doc.size - 1), display = cm.display;\n if (last.length != display.lineNumChars) {\n var test = display.measure.appendChild(elt(\"div\", [elt(\"div\", last)],\n \"CodeMirror-linenumber CodeMirror-gutter-elt\"));\n var innerW = test.firstChild.offsetWidth, padding = test.offsetWidth - innerW;\n display.lineGutter.style.width = \"\";\n display.lineNumInnerWidth = Math.max(innerW, display.lineGutter.offsetWidth - padding) + 1;\n display.lineNumWidth = display.lineNumInnerWidth + padding;\n display.lineNumChars = display.lineNumInnerWidth ? last.length : -1;\n display.lineGutter.style.width = display.lineNumWidth + \"px\";\n updateGutterSpace(cm.display);\n return true\n }\n return false\n }\n\n function getGutters(gutters, lineNumbers) {\n var result = [], sawLineNumbers = false;\n for (var i = 0; i < gutters.length; i++) {\n var name = gutters[i], style = null;\n if (typeof name != \"string\") { style = name.style; name = name.className; }\n if (name == \"CodeMirror-linenumbers\") {\n if (!lineNumbers) { continue }\n else { sawLineNumbers = true; }\n }\n result.push({className: name, style: style});\n }\n if (lineNumbers && !sawLineNumbers) { result.push({className: \"CodeMirror-linenumbers\", style: null}); }\n return result\n }\n\n // Rebuild the gutter elements, ensure the margin to the left of the\n // code matches their width.\n function renderGutters(display) {\n var gutters = display.gutters, specs = display.gutterSpecs;\n removeChildren(gutters);\n display.lineGutter = null;\n for (var i = 0; i < specs.length; ++i) {\n var ref = specs[i];\n var className = ref.className;\n var style = ref.style;\n var gElt = gutters.appendChild(elt(\"div\", null, \"CodeMirror-gutter \" + className));\n if (style) { gElt.style.cssText = style; }\n if (className == \"CodeMirror-linenumbers\") {\n display.lineGutter = gElt;\n gElt.style.width = (display.lineNumWidth || 1) + \"px\";\n }\n }\n gutters.style.display = specs.length ? \"\" : \"none\";\n updateGutterSpace(display);\n }\n\n function updateGutters(cm) {\n renderGutters(cm.display);\n regChange(cm);\n alignHorizontally(cm);\n }\n\n // The display handles the DOM integration, both for input reading\n // and content drawing. It holds references to DOM nodes and\n // display-related state.\n\n function Display(place, doc, input, options) {\n var d = this;\n this.input = input;\n\n // Covers bottom-right square when both scrollbars are present.\n d.scrollbarFiller = elt(\"div\", null, \"CodeMirror-scrollbar-filler\");\n d.scrollbarFiller.setAttribute(\"cm-not-content\", \"true\");\n // Covers bottom of gutter when coverGutterNextToScrollbar is on\n // and h scrollbar is present.\n d.gutterFiller = elt(\"div\", null, \"CodeMirror-gutter-filler\");\n d.gutterFiller.setAttribute(\"cm-not-content\", \"true\");\n // Will contain the actual code, positioned to cover the viewport.\n d.lineDiv = eltP(\"div\", null, \"CodeMirror-code\");\n // Elements are added to these to represent selection and cursors.\n d.selectionDiv = elt(\"div\", null, null, \"position: relative; z-index: 1\");\n d.cursorDiv = elt(\"div\", null, \"CodeMirror-cursors\");\n // A visibility: hidden element used to find the size of things.\n d.measure = elt(\"div\", null, \"CodeMirror-measure\");\n // When lines outside of the viewport are measured, they are drawn in this.\n d.lineMeasure = elt(\"div\", null, \"CodeMirror-measure\");\n // Wraps everything that needs to exist inside the vertically-padded coordinate system\n d.lineSpace = eltP(\"div\", [d.measure, d.lineMeasure, d.selectionDiv, d.cursorDiv, d.lineDiv],\n null, \"position: relative; outline: none\");\n var lines = eltP(\"div\", [d.lineSpace], \"CodeMirror-lines\");\n // Moved around its parent to cover visible view.\n d.mover = elt(\"div\", [lines], null, \"position: relative\");\n // Set to the height of the document, allowing scrolling.\n d.sizer = elt(\"div\", [d.mover], \"CodeMirror-sizer\");\n d.sizerWidth = null;\n // Behavior of elts with overflow: auto and padding is\n // inconsistent across browsers. This is used to ensure the\n // scrollable area is big enough.\n d.heightForcer = elt(\"div\", null, null, \"position: absolute; height: \" + scrollerGap + \"px; width: 1px;\");\n // Will contain the gutters, if any.\n d.gutters = elt(\"div\", null, \"CodeMirror-gutters\");\n d.lineGutter = null;\n // Actual scrollable element.\n d.scroller = elt(\"div\", [d.sizer, d.heightForcer, d.gutters], \"CodeMirror-scroll\");\n d.scroller.setAttribute(\"tabIndex\", \"-1\");\n // The element in which the editor lives.\n d.wrapper = elt(\"div\", [d.scrollbarFiller, d.gutterFiller, d.scroller], \"CodeMirror\");\n\n // Work around IE7 z-index bug (not perfect, hence IE7 not really being supported)\n if (ie && ie_version < 8) { d.gutters.style.zIndex = -1; d.scroller.style.paddingRight = 0; }\n if (!webkit && !(gecko && mobile)) { d.scroller.draggable = true; }\n\n if (place) {\n if (place.appendChild) { place.appendChild(d.wrapper); }\n else { place(d.wrapper); }\n }\n\n // Current rendered range (may be bigger than the view window).\n d.viewFrom = d.viewTo = doc.first;\n d.reportedViewFrom = d.reportedViewTo = doc.first;\n // Information about the rendered lines.\n d.view = [];\n d.renderedView = null;\n // Holds info about a single rendered line when it was rendered\n // for measurement, while not in view.\n d.externalMeasured = null;\n // Empty space (in pixels) above the view\n d.viewOffset = 0;\n d.lastWrapHeight = d.lastWrapWidth = 0;\n d.updateLineNumbers = null;\n\n d.nativeBarWidth = d.barHeight = d.barWidth = 0;\n d.scrollbarsClipped = false;\n\n // Used to only resize the line number gutter when necessary (when\n // the amount of lines crosses a boundary that makes its width change)\n d.lineNumWidth = d.lineNumInnerWidth = d.lineNumChars = null;\n // Set to true when a non-horizontal-scrolling line widget is\n // added. As an optimization, line widget aligning is skipped when\n // this is false.\n d.alignWidgets = false;\n\n d.cachedCharWidth = d.cachedTextHeight = d.cachedPaddingH = null;\n\n // Tracks the maximum line length so that the horizontal scrollbar\n // can be kept static when scrolling.\n d.maxLine = null;\n d.maxLineLength = 0;\n d.maxLineChanged = false;\n\n // Used for measuring wheel scrolling granularity\n d.wheelDX = d.wheelDY = d.wheelStartX = d.wheelStartY = null;\n\n // True when shift is held down.\n d.shift = false;\n\n // Used to track whether anything happened since the context menu\n // was opened.\n d.selForContextMenu = null;\n\n d.activeTouch = null;\n\n d.gutterSpecs = getGutters(options.gutters, options.lineNumbers);\n renderGutters(d);\n\n input.init(d);\n }\n\n // Since the delta values reported on mouse wheel events are\n // unstandardized between browsers and even browser versions, and\n // generally horribly unpredictable, this code starts by measuring\n // the scroll effect that the first few mouse wheel events have,\n // and, from that, detects the way it can convert deltas to pixel\n // offsets afterwards.\n //\n // The reason we want to know the amount a wheel event will scroll\n // is that it gives us a chance to update the display before the\n // actual scrolling happens, reducing flickering.\n\n var wheelSamples = 0, wheelPixelsPerUnit = null;\n // Fill in a browser-detected starting value on browsers where we\n // know one. These don't have to be accurate -- the result of them\n // being wrong would just be a slight flicker on the first wheel\n // scroll (if it is large enough).\n if (ie) { wheelPixelsPerUnit = -.53; }\n else if (gecko) { wheelPixelsPerUnit = 15; }\n else if (chrome) { wheelPixelsPerUnit = -.7; }\n else if (safari) { wheelPixelsPerUnit = -1/3; }\n\n function wheelEventDelta(e) {\n var dx = e.wheelDeltaX, dy = e.wheelDeltaY;\n if (dx == null && e.detail && e.axis == e.HORIZONTAL_AXIS) { dx = e.detail; }\n if (dy == null && e.detail && e.axis == e.VERTICAL_AXIS) { dy = e.detail; }\n else if (dy == null) { dy = e.wheelDelta; }\n return {x: dx, y: dy}\n }\n function wheelEventPixels(e) {\n var delta = wheelEventDelta(e);\n delta.x *= wheelPixelsPerUnit;\n delta.y *= wheelPixelsPerUnit;\n return delta\n }\n\n function onScrollWheel(cm, e) {\n var delta = wheelEventDelta(e), dx = delta.x, dy = delta.y;\n\n var display = cm.display, scroll = display.scroller;\n // Quit if there's nothing to scroll here\n var canScrollX = scroll.scrollWidth > scroll.clientWidth;\n var canScrollY = scroll.scrollHeight > scroll.clientHeight;\n if (!(dx && canScrollX || dy && canScrollY)) { return }\n\n // Webkit browsers on OS X abort momentum scrolls when the target\n // of the scroll event is removed from the scrollable element.\n // This hack (see related code in patchDisplay) makes sure the\n // element is kept around.\n if (dy && mac && webkit) {\n outer: for (var cur = e.target, view = display.view; cur != scroll; cur = cur.parentNode) {\n for (var i = 0; i < view.length; i++) {\n if (view[i].node == cur) {\n cm.display.currentWheelTarget = cur;\n break outer\n }\n }\n }\n }\n\n // On some browsers, horizontal scrolling will cause redraws to\n // happen before the gutter has been realigned, causing it to\n // wriggle around in a most unseemly way. When we have an\n // estimated pixels/delta value, we just handle horizontal\n // scrolling entirely here. It'll be slightly off from native, but\n // better than glitching out.\n if (dx && !gecko && !presto && wheelPixelsPerUnit != null) {\n if (dy && canScrollY)\n { updateScrollTop(cm, Math.max(0, scroll.scrollTop + dy * wheelPixelsPerUnit)); }\n setScrollLeft(cm, Math.max(0, scroll.scrollLeft + dx * wheelPixelsPerUnit));\n // Only prevent default scrolling if vertical scrolling is\n // actually possible. Otherwise, it causes vertical scroll\n // jitter on OSX trackpads when deltaX is small and deltaY\n // is large (issue #3579)\n if (!dy || (dy && canScrollY))\n { e_preventDefault(e); }\n display.wheelStartX = null; // Abort measurement, if in progress\n return\n }\n\n // 'Project' the visible viewport to cover the area that is being\n // scrolled into view (if we know enough to estimate it).\n if (dy && wheelPixelsPerUnit != null) {\n var pixels = dy * wheelPixelsPerUnit;\n var top = cm.doc.scrollTop, bot = top + display.wrapper.clientHeight;\n if (pixels < 0) { top = Math.max(0, top + pixels - 50); }\n else { bot = Math.min(cm.doc.height, bot + pixels + 50); }\n updateDisplaySimple(cm, {top: top, bottom: bot});\n }\n\n if (wheelSamples < 20) {\n if (display.wheelStartX == null) {\n display.wheelStartX = scroll.scrollLeft; display.wheelStartY = scroll.scrollTop;\n display.wheelDX = dx; display.wheelDY = dy;\n setTimeout(function () {\n if (display.wheelStartX == null) { return }\n var movedX = scroll.scrollLeft - display.wheelStartX;\n var movedY = scroll.scrollTop - display.wheelStartY;\n var sample = (movedY && display.wheelDY && movedY / display.wheelDY) ||\n (movedX && display.wheelDX && movedX / display.wheelDX);\n display.wheelStartX = display.wheelStartY = null;\n if (!sample) { return }\n wheelPixelsPerUnit = (wheelPixelsPerUnit * wheelSamples + sample) / (wheelSamples + 1);\n ++wheelSamples;\n }, 200);\n } else {\n display.wheelDX += dx; display.wheelDY += dy;\n }\n }\n }\n\n // Selection objects are immutable. A new one is created every time\n // the selection changes. A selection is one or more non-overlapping\n // (and non-touching) ranges, sorted, and an integer that indicates\n // which one is the primary selection (the one that's scrolled into\n // view, that getCursor returns, etc).\n var Selection = function(ranges, primIndex) {\n this.ranges = ranges;\n this.primIndex = primIndex;\n };\n\n Selection.prototype.primary = function () { return this.ranges[this.primIndex] };\n\n Selection.prototype.equals = function (other) {\n var this$1 = this;\n\n if (other == this) { return true }\n if (other.primIndex != this.primIndex || other.ranges.length != this.ranges.length) { return false }\n for (var i = 0; i < this.ranges.length; i++) {\n var here = this$1.ranges[i], there = other.ranges[i];\n if (!equalCursorPos(here.anchor, there.anchor) || !equalCursorPos(here.head, there.head)) { return false }\n }\n return true\n };\n\n Selection.prototype.deepCopy = function () {\n var this$1 = this;\n\n var out = [];\n for (var i = 0; i < this.ranges.length; i++)\n { out[i] = new Range(copyPos(this$1.ranges[i].anchor), copyPos(this$1.ranges[i].head)); }\n return new Selection(out, this.primIndex)\n };\n\n Selection.prototype.somethingSelected = function () {\n var this$1 = this;\n\n for (var i = 0; i < this.ranges.length; i++)\n { if (!this$1.ranges[i].empty()) { return true } }\n return false\n };\n\n Selection.prototype.contains = function (pos, end) {\n var this$1 = this;\n\n if (!end) { end = pos; }\n for (var i = 0; i < this.ranges.length; i++) {\n var range = this$1.ranges[i];\n if (cmp(end, range.from()) >= 0 && cmp(pos, range.to()) <= 0)\n { return i }\n }\n return -1\n };\n\n var Range = function(anchor, head) {\n this.anchor = anchor; this.head = head;\n };\n\n Range.prototype.from = function () { return minPos(this.anchor, this.head) };\n Range.prototype.to = function () { return maxPos(this.anchor, this.head) };\n Range.prototype.empty = function () { return this.head.line == this.anchor.line && this.head.ch == this.anchor.ch };\n\n // Take an unsorted, potentially overlapping set of ranges, and\n // build a selection out of it. 'Consumes' ranges array (modifying\n // it).\n function normalizeSelection(cm, ranges, primIndex) {\n var mayTouch = cm && cm.options.selectionsMayTouch;\n var prim = ranges[primIndex];\n ranges.sort(function (a, b) { return cmp(a.from(), b.from()); });\n primIndex = indexOf(ranges, prim);\n for (var i = 1; i < ranges.length; i++) {\n var cur = ranges[i], prev = ranges[i - 1];\n var diff = cmp(prev.to(), cur.from());\n if (mayTouch && !cur.empty() ? diff > 0 : diff >= 0) {\n var from = minPos(prev.from(), cur.from()), to = maxPos(prev.to(), cur.to());\n var inv = prev.empty() ? cur.from() == cur.head : prev.from() == prev.head;\n if (i <= primIndex) { --primIndex; }\n ranges.splice(--i, 2, new Range(inv ? to : from, inv ? from : to));\n }\n }\n return new Selection(ranges, primIndex)\n }\n\n function simpleSelection(anchor, head) {\n return new Selection([new Range(anchor, head || anchor)], 0)\n }\n\n // Compute the position of the end of a change (its 'to' property\n // refers to the pre-change end).\n function changeEnd(change) {\n if (!change.text) { return change.to }\n return Pos(change.from.line + change.text.length - 1,\n lst(change.text).length + (change.text.length == 1 ? change.from.ch : 0))\n }\n\n // Adjust a position to refer to the post-change position of the\n // same text, or the end of the change if the change covers it.\n function adjustForChange(pos, change) {\n if (cmp(pos, change.from) < 0) { return pos }\n if (cmp(pos, change.to) <= 0) { return changeEnd(change) }\n\n var line = pos.line + change.text.length - (change.to.line - change.from.line) - 1, ch = pos.ch;\n if (pos.line == change.to.line) { ch += changeEnd(change).ch - change.to.ch; }\n return Pos(line, ch)\n }\n\n function computeSelAfterChange(doc, change) {\n var out = [];\n for (var i = 0; i < doc.sel.ranges.length; i++) {\n var range = doc.sel.ranges[i];\n out.push(new Range(adjustForChange(range.anchor, change),\n adjustForChange(range.head, change)));\n }\n return normalizeSelection(doc.cm, out, doc.sel.primIndex)\n }\n\n function offsetPos(pos, old, nw) {\n if (pos.line == old.line)\n { return Pos(nw.line, pos.ch - old.ch + nw.ch) }\n else\n { return Pos(nw.line + (pos.line - old.line), pos.ch) }\n }\n\n // Used by replaceSelections to allow moving the selection to the\n // start or around the replaced test. Hint may be \"start\" or \"around\".\n function computeReplacedSel(doc, changes, hint) {\n var out = [];\n var oldPrev = Pos(doc.first, 0), newPrev = oldPrev;\n for (var i = 0; i < changes.length; i++) {\n var change = changes[i];\n var from = offsetPos(change.from, oldPrev, newPrev);\n var to = offsetPos(changeEnd(change), oldPrev, newPrev);\n oldPrev = change.to;\n newPrev = to;\n if (hint == \"around\") {\n var range = doc.sel.ranges[i], inv = cmp(range.head, range.anchor) < 0;\n out[i] = new Range(inv ? to : from, inv ? from : to);\n } else {\n out[i] = new Range(from, from);\n }\n }\n return new Selection(out, doc.sel.primIndex)\n }\n\n // Used to get the editor into a consistent state again when options change.\n\n function loadMode(cm) {\n cm.doc.mode = getMode(cm.options, cm.doc.modeOption);\n resetModeState(cm);\n }\n\n function resetModeState(cm) {\n cm.doc.iter(function (line) {\n if (line.stateAfter) { line.stateAfter = null; }\n if (line.styles) { line.styles = null; }\n });\n cm.doc.modeFrontier = cm.doc.highlightFrontier = cm.doc.first;\n startWorker(cm, 100);\n cm.state.modeGen++;\n if (cm.curOp) { regChange(cm); }\n }\n\n // DOCUMENT DATA STRUCTURE\n\n // By default, updates that start and end at the beginning of a line\n // are treated specially, in order to make the association of line\n // widgets and marker elements with the text behave more intuitive.\n function isWholeLineUpdate(doc, change) {\n return change.from.ch == 0 && change.to.ch == 0 && lst(change.text) == \"\" &&\n (!doc.cm || doc.cm.options.wholeLineUpdateBefore)\n }\n\n // Perform a change on the document data structure.\n function updateDoc(doc, change, markedSpans, estimateHeight$$1) {\n function spansFor(n) {return markedSpans ? markedSpans[n] : null}\n function update(line, text, spans) {\n updateLine(line, text, spans, estimateHeight$$1);\n signalLater(line, \"change\", line, change);\n }\n function linesFor(start, end) {\n var result = [];\n for (var i = start; i < end; ++i)\n { result.push(new Line(text[i], spansFor(i), estimateHeight$$1)); }\n return result\n }\n\n var from = change.from, to = change.to, text = change.text;\n var firstLine = getLine(doc, from.line), lastLine = getLine(doc, to.line);\n var lastText = lst(text), lastSpans = spansFor(text.length - 1), nlines = to.line - from.line;\n\n // Adjust the line structure\n if (change.full) {\n doc.insert(0, linesFor(0, text.length));\n doc.remove(text.length, doc.size - text.length);\n } else if (isWholeLineUpdate(doc, change)) {\n // This is a whole-line replace. Treated specially to make\n // sure line objects move the way they are supposed to.\n var added = linesFor(0, text.length - 1);\n update(lastLine, lastLine.text, lastSpans);\n if (nlines) { doc.remove(from.line, nlines); }\n if (added.length) { doc.insert(from.line, added); }\n } else if (firstLine == lastLine) {\n if (text.length == 1) {\n update(firstLine, firstLine.text.slice(0, from.ch) + lastText + firstLine.text.slice(to.ch), lastSpans);\n } else {\n var added$1 = linesFor(1, text.length - 1);\n added$1.push(new Line(lastText + firstLine.text.slice(to.ch), lastSpans, estimateHeight$$1));\n update(firstLine, firstLine.text.slice(0, from.ch) + text[0], spansFor(0));\n doc.insert(from.line + 1, added$1);\n }\n } else if (text.length == 1) {\n update(firstLine, firstLine.text.slice(0, from.ch) + text[0] + lastLine.text.slice(to.ch), spansFor(0));\n doc.remove(from.line + 1, nlines);\n } else {\n update(firstLine, firstLine.text.slice(0, from.ch) + text[0], spansFor(0));\n update(lastLine, lastText + lastLine.text.slice(to.ch), lastSpans);\n var added$2 = linesFor(1, text.length - 1);\n if (nlines > 1) { doc.remove(from.line + 1, nlines - 1); }\n doc.insert(from.line + 1, added$2);\n }\n\n signalLater(doc, \"change\", doc, change);\n }\n\n // Call f for all linked documents.\n function linkedDocs(doc, f, sharedHistOnly) {\n function propagate(doc, skip, sharedHist) {\n if (doc.linked) { for (var i = 0; i < doc.linked.length; ++i) {\n var rel = doc.linked[i];\n if (rel.doc == skip) { continue }\n var shared = sharedHist && rel.sharedHist;\n if (sharedHistOnly && !shared) { continue }\n f(rel.doc, shared);\n propagate(rel.doc, doc, shared);\n } }\n }\n propagate(doc, null, true);\n }\n\n // Attach a document to an editor.\n function attachDoc(cm, doc) {\n if (doc.cm) { throw new Error(\"This document is already in use.\") }\n cm.doc = doc;\n doc.cm = cm;\n estimateLineHeights(cm);\n loadMode(cm);\n setDirectionClass(cm);\n if (!cm.options.lineWrapping) { findMaxLine(cm); }\n cm.options.mode = doc.modeOption;\n regChange(cm);\n }\n\n function setDirectionClass(cm) {\n (cm.doc.direction == \"rtl\" ? addClass : rmClass)(cm.display.lineDiv, \"CodeMirror-rtl\");\n }\n\n function directionChanged(cm) {\n runInOp(cm, function () {\n setDirectionClass(cm);\n regChange(cm);\n });\n }\n\n function History(startGen) {\n // Arrays of change events and selections. Doing something adds an\n // event to done and clears undo. Undoing moves events from done\n // to undone, redoing moves them in the other direction.\n this.done = []; this.undone = [];\n this.undoDepth = Infinity;\n // Used to track when changes can be merged into a single undo\n // event\n this.lastModTime = this.lastSelTime = 0;\n this.lastOp = this.lastSelOp = null;\n this.lastOrigin = this.lastSelOrigin = null;\n // Used by the isClean() method\n this.generation = this.maxGeneration = startGen || 1;\n }\n\n // Create a history change event from an updateDoc-style change\n // object.\n function historyChangeFromChange(doc, change) {\n var histChange = {from: copyPos(change.from), to: changeEnd(change), text: getBetween(doc, change.from, change.to)};\n attachLocalSpans(doc, histChange, change.from.line, change.to.line + 1);\n linkedDocs(doc, function (doc) { return attachLocalSpans(doc, histChange, change.from.line, change.to.line + 1); }, true);\n return histChange\n }\n\n // Pop all selection events off the end of a history array. Stop at\n // a change event.\n function clearSelectionEvents(array) {\n while (array.length) {\n var last = lst(array);\n if (last.ranges) { array.pop(); }\n else { break }\n }\n }\n\n // Find the top change event in the history. Pop off selection\n // events that are in the way.\n function lastChangeEvent(hist, force) {\n if (force) {\n clearSelectionEvents(hist.done);\n return lst(hist.done)\n } else if (hist.done.length && !lst(hist.done).ranges) {\n return lst(hist.done)\n } else if (hist.done.length > 1 && !hist.done[hist.done.length - 2].ranges) {\n hist.done.pop();\n return lst(hist.done)\n }\n }\n\n // Register a change in the history. Merges changes that are within\n // a single operation, or are close together with an origin that\n // allows merging (starting with \"+\") into a single event.\n function addChangeToHistory(doc, change, selAfter, opId) {\n var hist = doc.history;\n hist.undone.length = 0;\n var time = +new Date, cur;\n var last;\n\n if ((hist.lastOp == opId ||\n hist.lastOrigin == change.origin && change.origin &&\n ((change.origin.charAt(0) == \"+\" && hist.lastModTime > time - (doc.cm ? doc.cm.options.historyEventDelay : 500)) ||\n change.origin.charAt(0) == \"*\")) &&\n (cur = lastChangeEvent(hist, hist.lastOp == opId))) {\n // Merge this change into the last event\n last = lst(cur.changes);\n if (cmp(change.from, change.to) == 0 && cmp(change.from, last.to) == 0) {\n // Optimized case for simple insertion -- don't want to add\n // new changesets for every character typed\n last.to = changeEnd(change);\n } else {\n // Add new sub-event\n cur.changes.push(historyChangeFromChange(doc, change));\n }\n } else {\n // Can not be merged, start a new event.\n var before = lst(hist.done);\n if (!before || !before.ranges)\n { pushSelectionToHistory(doc.sel, hist.done); }\n cur = {changes: [historyChangeFromChange(doc, change)],\n generation: hist.generation};\n hist.done.push(cur);\n while (hist.done.length > hist.undoDepth) {\n hist.done.shift();\n if (!hist.done[0].ranges) { hist.done.shift(); }\n }\n }\n hist.done.push(selAfter);\n hist.generation = ++hist.maxGeneration;\n hist.lastModTime = hist.lastSelTime = time;\n hist.lastOp = hist.lastSelOp = opId;\n hist.lastOrigin = hist.lastSelOrigin = change.origin;\n\n if (!last) { signal(doc, \"historyAdded\"); }\n }\n\n function selectionEventCanBeMerged(doc, origin, prev, sel) {\n var ch = origin.charAt(0);\n return ch == \"*\" ||\n ch == \"+\" &&\n prev.ranges.length == sel.ranges.length &&\n prev.somethingSelected() == sel.somethingSelected() &&\n new Date - doc.history.lastSelTime <= (doc.cm ? doc.cm.options.historyEventDelay : 500)\n }\n\n // Called whenever the selection changes, sets the new selection as\n // the pending selection in the history, and pushes the old pending\n // selection into the 'done' array when it was significantly\n // different (in number of selected ranges, emptiness, or time).\n function addSelectionToHistory(doc, sel, opId, options) {\n var hist = doc.history, origin = options && options.origin;\n\n // A new event is started when the previous origin does not match\n // the current, or the origins don't allow matching. Origins\n // starting with * are always merged, those starting with + are\n // merged when similar and close together in time.\n if (opId == hist.lastSelOp ||\n (origin && hist.lastSelOrigin == origin &&\n (hist.lastModTime == hist.lastSelTime && hist.lastOrigin == origin ||\n selectionEventCanBeMerged(doc, origin, lst(hist.done), sel))))\n { hist.done[hist.done.length - 1] = sel; }\n else\n { pushSelectionToHistory(sel, hist.done); }\n\n hist.lastSelTime = +new Date;\n hist.lastSelOrigin = origin;\n hist.lastSelOp = opId;\n if (options && options.clearRedo !== false)\n { clearSelectionEvents(hist.undone); }\n }\n\n function pushSelectionToHistory(sel, dest) {\n var top = lst(dest);\n if (!(top && top.ranges && top.equals(sel)))\n { dest.push(sel); }\n }\n\n // Used to store marked span information in the history.\n function attachLocalSpans(doc, change, from, to) {\n var existing = change[\"spans_\" + doc.id], n = 0;\n doc.iter(Math.max(doc.first, from), Math.min(doc.first + doc.size, to), function (line) {\n if (line.markedSpans)\n { (existing || (existing = change[\"spans_\" + doc.id] = {}))[n] = line.markedSpans; }\n ++n;\n });\n }\n\n // When un/re-doing restores text containing marked spans, those\n // that have been explicitly cleared should not be restored.\n function removeClearedSpans(spans) {\n if (!spans) { return null }\n var out;\n for (var i = 0; i < spans.length; ++i) {\n if (spans[i].marker.explicitlyCleared) { if (!out) { out = spans.slice(0, i); } }\n else if (out) { out.push(spans[i]); }\n }\n return !out ? spans : out.length ? out : null\n }\n\n // Retrieve and filter the old marked spans stored in a change event.\n function getOldSpans(doc, change) {\n var found = change[\"spans_\" + doc.id];\n if (!found) { return null }\n var nw = [];\n for (var i = 0; i < change.text.length; ++i)\n { nw.push(removeClearedSpans(found[i])); }\n return nw\n }\n\n // Used for un/re-doing changes from the history. Combines the\n // result of computing the existing spans with the set of spans that\n // existed in the history (so that deleting around a span and then\n // undoing brings back the span).\n function mergeOldSpans(doc, change) {\n var old = getOldSpans(doc, change);\n var stretched = stretchSpansOverChange(doc, change);\n if (!old) { return stretched }\n if (!stretched) { return old }\n\n for (var i = 0; i < old.length; ++i) {\n var oldCur = old[i], stretchCur = stretched[i];\n if (oldCur && stretchCur) {\n spans: for (var j = 0; j < stretchCur.length; ++j) {\n var span = stretchCur[j];\n for (var k = 0; k < oldCur.length; ++k)\n { if (oldCur[k].marker == span.marker) { continue spans } }\n oldCur.push(span);\n }\n } else if (stretchCur) {\n old[i] = stretchCur;\n }\n }\n return old\n }\n\n // Used both to provide a JSON-safe object in .getHistory, and, when\n // detaching a document, to split the history in two\n function copyHistoryArray(events, newGroup, instantiateSel) {\n var copy = [];\n for (var i = 0; i < events.length; ++i) {\n var event = events[i];\n if (event.ranges) {\n copy.push(instantiateSel ? Selection.prototype.deepCopy.call(event) : event);\n continue\n }\n var changes = event.changes, newChanges = [];\n copy.push({changes: newChanges});\n for (var j = 0; j < changes.length; ++j) {\n var change = changes[j], m = (void 0);\n newChanges.push({from: change.from, to: change.to, text: change.text});\n if (newGroup) { for (var prop in change) { if (m = prop.match(/^spans_(\\d+)$/)) {\n if (indexOf(newGroup, Number(m[1])) > -1) {\n lst(newChanges)[prop] = change[prop];\n delete change[prop];\n }\n } } }\n }\n }\n return copy\n }\n\n // The 'scroll' parameter given to many of these indicated whether\n // the new cursor position should be scrolled into view after\n // modifying the selection.\n\n // If shift is held or the extend flag is set, extends a range to\n // include a given position (and optionally a second position).\n // Otherwise, simply returns the range between the given positions.\n // Used for cursor motion and such.\n function extendRange(range, head, other, extend) {\n if (extend) {\n var anchor = range.anchor;\n if (other) {\n var posBefore = cmp(head, anchor) < 0;\n if (posBefore != (cmp(other, anchor) < 0)) {\n anchor = head;\n head = other;\n } else if (posBefore != (cmp(head, other) < 0)) {\n head = other;\n }\n }\n return new Range(anchor, head)\n } else {\n return new Range(other || head, head)\n }\n }\n\n // Extend the primary selection range, discard the rest.\n function extendSelection(doc, head, other, options, extend) {\n if (extend == null) { extend = doc.cm && (doc.cm.display.shift || doc.extend); }\n setSelection(doc, new Selection([extendRange(doc.sel.primary(), head, other, extend)], 0), options);\n }\n\n // Extend all selections (pos is an array of selections with length\n // equal the number of selections)\n function extendSelections(doc, heads, options) {\n var out = [];\n var extend = doc.cm && (doc.cm.display.shift || doc.extend);\n for (var i = 0; i < doc.sel.ranges.length; i++)\n { out[i] = extendRange(doc.sel.ranges[i], heads[i], null, extend); }\n var newSel = normalizeSelection(doc.cm, out, doc.sel.primIndex);\n setSelection(doc, newSel, options);\n }\n\n // Updates a single range in the selection.\n function replaceOneSelection(doc, i, range, options) {\n var ranges = doc.sel.ranges.slice(0);\n ranges[i] = range;\n setSelection(doc, normalizeSelection(doc.cm, ranges, doc.sel.primIndex), options);\n }\n\n // Reset the selection to a single range.\n function setSimpleSelection(doc, anchor, head, options) {\n setSelection(doc, simpleSelection(anchor, head), options);\n }\n\n // Give beforeSelectionChange handlers a change to influence a\n // selection update.\n function filterSelectionChange(doc, sel, options) {\n var obj = {\n ranges: sel.ranges,\n update: function(ranges) {\n var this$1 = this;\n\n this.ranges = [];\n for (var i = 0; i < ranges.length; i++)\n { this$1.ranges[i] = new Range(clipPos(doc, ranges[i].anchor),\n clipPos(doc, ranges[i].head)); }\n },\n origin: options && options.origin\n };\n signal(doc, \"beforeSelectionChange\", doc, obj);\n if (doc.cm) { signal(doc.cm, \"beforeSelectionChange\", doc.cm, obj); }\n if (obj.ranges != sel.ranges) { return normalizeSelection(doc.cm, obj.ranges, obj.ranges.length - 1) }\n else { return sel }\n }\n\n function setSelectionReplaceHistory(doc, sel, options) {\n var done = doc.history.done, last = lst(done);\n if (last && last.ranges) {\n done[done.length - 1] = sel;\n setSelectionNoUndo(doc, sel, options);\n } else {\n setSelection(doc, sel, options);\n }\n }\n\n // Set a new selection.\n function setSelection(doc, sel, options) {\n setSelectionNoUndo(doc, sel, options);\n addSelectionToHistory(doc, doc.sel, doc.cm ? doc.cm.curOp.id : NaN, options);\n }\n\n function setSelectionNoUndo(doc, sel, options) {\n if (hasHandler(doc, \"beforeSelectionChange\") || doc.cm && hasHandler(doc.cm, \"beforeSelectionChange\"))\n { sel = filterSelectionChange(doc, sel, options); }\n\n var bias = options && options.bias ||\n (cmp(sel.primary().head, doc.sel.primary().head) < 0 ? -1 : 1);\n setSelectionInner(doc, skipAtomicInSelection(doc, sel, bias, true));\n\n if (!(options && options.scroll === false) && doc.cm)\n { ensureCursorVisible(doc.cm); }\n }\n\n function setSelectionInner(doc, sel) {\n if (sel.equals(doc.sel)) { return }\n\n doc.sel = sel;\n\n if (doc.cm) {\n doc.cm.curOp.updateInput = 1;\n doc.cm.curOp.selectionChanged = true;\n signalCursorActivity(doc.cm);\n }\n signalLater(doc, \"cursorActivity\", doc);\n }\n\n // Verify that the selection does not partially select any atomic\n // marked ranges.\n function reCheckSelection(doc) {\n setSelectionInner(doc, skipAtomicInSelection(doc, doc.sel, null, false));\n }\n\n // Return a selection that does not partially select any atomic\n // ranges.\n function skipAtomicInSelection(doc, sel, bias, mayClear) {\n var out;\n for (var i = 0; i < sel.ranges.length; i++) {\n var range = sel.ranges[i];\n var old = sel.ranges.length == doc.sel.ranges.length && doc.sel.ranges[i];\n var newAnchor = skipAtomic(doc, range.anchor, old && old.anchor, bias, mayClear);\n var newHead = skipAtomic(doc, range.head, old && old.head, bias, mayClear);\n if (out || newAnchor != range.anchor || newHead != range.head) {\n if (!out) { out = sel.ranges.slice(0, i); }\n out[i] = new Range(newAnchor, newHead);\n }\n }\n return out ? normalizeSelection(doc.cm, out, sel.primIndex) : sel\n }\n\n function skipAtomicInner(doc, pos, oldPos, dir, mayClear) {\n var line = getLine(doc, pos.line);\n if (line.markedSpans) { for (var i = 0; i < line.markedSpans.length; ++i) {\n var sp = line.markedSpans[i], m = sp.marker;\n\n // Determine if we should prevent the cursor being placed to the left/right of an atomic marker\n // Historically this was determined using the inclusiveLeft/Right option, but the new way to control it\n // is with selectLeft/Right\n var preventCursorLeft = (\"selectLeft\" in m) ? !m.selectLeft : m.inclusiveLeft;\n var preventCursorRight = (\"selectRight\" in m) ? !m.selectRight : m.inclusiveRight;\n\n if ((sp.from == null || (preventCursorLeft ? sp.from <= pos.ch : sp.from < pos.ch)) &&\n (sp.to == null || (preventCursorRight ? sp.to >= pos.ch : sp.to > pos.ch))) {\n if (mayClear) {\n signal(m, \"beforeCursorEnter\");\n if (m.explicitlyCleared) {\n if (!line.markedSpans) { break }\n else {--i; continue}\n }\n }\n if (!m.atomic) { continue }\n\n if (oldPos) {\n var near = m.find(dir < 0 ? 1 : -1), diff = (void 0);\n if (dir < 0 ? preventCursorRight : preventCursorLeft)\n { near = movePos(doc, near, -dir, near && near.line == pos.line ? line : null); }\n if (near && near.line == pos.line && (diff = cmp(near, oldPos)) && (dir < 0 ? diff < 0 : diff > 0))\n { return skipAtomicInner(doc, near, pos, dir, mayClear) }\n }\n\n var far = m.find(dir < 0 ? -1 : 1);\n if (dir < 0 ? preventCursorLeft : preventCursorRight)\n { far = movePos(doc, far, dir, far.line == pos.line ? line : null); }\n return far ? skipAtomicInner(doc, far, pos, dir, mayClear) : null\n }\n } }\n return pos\n }\n\n // Ensure a given position is not inside an atomic range.\n function skipAtomic(doc, pos, oldPos, bias, mayClear) {\n var dir = bias || 1;\n var found = skipAtomicInner(doc, pos, oldPos, dir, mayClear) ||\n (!mayClear && skipAtomicInner(doc, pos, oldPos, dir, true)) ||\n skipAtomicInner(doc, pos, oldPos, -dir, mayClear) ||\n (!mayClear && skipAtomicInner(doc, pos, oldPos, -dir, true));\n if (!found) {\n doc.cantEdit = true;\n return Pos(doc.first, 0)\n }\n return found\n }\n\n function movePos(doc, pos, dir, line) {\n if (dir < 0 && pos.ch == 0) {\n if (pos.line > doc.first) { return clipPos(doc, Pos(pos.line - 1)) }\n else { return null }\n } else if (dir > 0 && pos.ch == (line || getLine(doc, pos.line)).text.length) {\n if (pos.line < doc.first + doc.size - 1) { return Pos(pos.line + 1, 0) }\n else { return null }\n } else {\n return new Pos(pos.line, pos.ch + dir)\n }\n }\n\n function selectAll(cm) {\n cm.setSelection(Pos(cm.firstLine(), 0), Pos(cm.lastLine()), sel_dontScroll);\n }\n\n // UPDATING\n\n // Allow \"beforeChange\" event handlers to influence a change\n function filterChange(doc, change, update) {\n var obj = {\n canceled: false,\n from: change.from,\n to: change.to,\n text: change.text,\n origin: change.origin,\n cancel: function () { return obj.canceled = true; }\n };\n if (update) { obj.update = function (from, to, text, origin) {\n if (from) { obj.from = clipPos(doc, from); }\n if (to) { obj.to = clipPos(doc, to); }\n if (text) { obj.text = text; }\n if (origin !== undefined) { obj.origin = origin; }\n }; }\n signal(doc, \"beforeChange\", doc, obj);\n if (doc.cm) { signal(doc.cm, \"beforeChange\", doc.cm, obj); }\n\n if (obj.canceled) {\n if (doc.cm) { doc.cm.curOp.updateInput = 2; }\n return null\n }\n return {from: obj.from, to: obj.to, text: obj.text, origin: obj.origin}\n }\n\n // Apply a change to a document, and add it to the document's\n // history, and propagating it to all linked documents.\n function makeChange(doc, change, ignoreReadOnly) {\n if (doc.cm) {\n if (!doc.cm.curOp) { return operation(doc.cm, makeChange)(doc, change, ignoreReadOnly) }\n if (doc.cm.state.suppressEdits) { return }\n }\n\n if (hasHandler(doc, \"beforeChange\") || doc.cm && hasHandler(doc.cm, \"beforeChange\")) {\n change = filterChange(doc, change, true);\n if (!change) { return }\n }\n\n // Possibly split or suppress the update based on the presence\n // of read-only spans in its range.\n var split = sawReadOnlySpans && !ignoreReadOnly && removeReadOnlyRanges(doc, change.from, change.to);\n if (split) {\n for (var i = split.length - 1; i >= 0; --i)\n { makeChangeInner(doc, {from: split[i].from, to: split[i].to, text: i ? [\"\"] : change.text, origin: change.origin}); }\n } else {\n makeChangeInner(doc, change);\n }\n }\n\n function makeChangeInner(doc, change) {\n if (change.text.length == 1 && change.text[0] == \"\" && cmp(change.from, change.to) == 0) { return }\n var selAfter = computeSelAfterChange(doc, change);\n addChangeToHistory(doc, change, selAfter, doc.cm ? doc.cm.curOp.id : NaN);\n\n makeChangeSingleDoc(doc, change, selAfter, stretchSpansOverChange(doc, change));\n var rebased = [];\n\n linkedDocs(doc, function (doc, sharedHist) {\n if (!sharedHist && indexOf(rebased, doc.history) == -1) {\n rebaseHist(doc.history, change);\n rebased.push(doc.history);\n }\n makeChangeSingleDoc(doc, change, null, stretchSpansOverChange(doc, change));\n });\n }\n\n // Revert a change stored in a document's history.\n function makeChangeFromHistory(doc, type, allowSelectionOnly) {\n var suppress = doc.cm && doc.cm.state.suppressEdits;\n if (suppress && !allowSelectionOnly) { return }\n\n var hist = doc.history, event, selAfter = doc.sel;\n var source = type == \"undo\" ? hist.done : hist.undone, dest = type == \"undo\" ? hist.undone : hist.done;\n\n // Verify that there is a useable event (so that ctrl-z won't\n // needlessly clear selection events)\n var i = 0;\n for (; i < source.length; i++) {\n event = source[i];\n if (allowSelectionOnly ? event.ranges && !event.equals(doc.sel) : !event.ranges)\n { break }\n }\n if (i == source.length) { return }\n hist.lastOrigin = hist.lastSelOrigin = null;\n\n for (;;) {\n event = source.pop();\n if (event.ranges) {\n pushSelectionToHistory(event, dest);\n if (allowSelectionOnly && !event.equals(doc.sel)) {\n setSelection(doc, event, {clearRedo: false});\n return\n }\n selAfter = event;\n } else if (suppress) {\n source.push(event);\n return\n } else { break }\n }\n\n // Build up a reverse change object to add to the opposite history\n // stack (redo when undoing, and vice versa).\n var antiChanges = [];\n pushSelectionToHistory(selAfter, dest);\n dest.push({changes: antiChanges, generation: hist.generation});\n hist.generation = event.generation || ++hist.maxGeneration;\n\n var filter = hasHandler(doc, \"beforeChange\") || doc.cm && hasHandler(doc.cm, \"beforeChange\");\n\n var loop = function ( i ) {\n var change = event.changes[i];\n change.origin = type;\n if (filter && !filterChange(doc, change, false)) {\n source.length = 0;\n return {}\n }\n\n antiChanges.push(historyChangeFromChange(doc, change));\n\n var after = i ? computeSelAfterChange(doc, change) : lst(source);\n makeChangeSingleDoc(doc, change, after, mergeOldSpans(doc, change));\n if (!i && doc.cm) { doc.cm.scrollIntoView({from: change.from, to: changeEnd(change)}); }\n var rebased = [];\n\n // Propagate to the linked documents\n linkedDocs(doc, function (doc, sharedHist) {\n if (!sharedHist && indexOf(rebased, doc.history) == -1) {\n rebaseHist(doc.history, change);\n rebased.push(doc.history);\n }\n makeChangeSingleDoc(doc, change, null, mergeOldSpans(doc, change));\n });\n };\n\n for (var i$1 = event.changes.length - 1; i$1 >= 0; --i$1) {\n var returned = loop( i$1 );\n\n if ( returned ) return returned.v;\n }\n }\n\n // Sub-views need their line numbers shifted when text is added\n // above or below them in the parent document.\n function shiftDoc(doc, distance) {\n if (distance == 0) { return }\n doc.first += distance;\n doc.sel = new Selection(map(doc.sel.ranges, function (range) { return new Range(\n Pos(range.anchor.line + distance, range.anchor.ch),\n Pos(range.head.line + distance, range.head.ch)\n ); }), doc.sel.primIndex);\n if (doc.cm) {\n regChange(doc.cm, doc.first, doc.first - distance, distance);\n for (var d = doc.cm.display, l = d.viewFrom; l < d.viewTo; l++)\n { regLineChange(doc.cm, l, \"gutter\"); }\n }\n }\n\n // More lower-level change function, handling only a single document\n // (not linked ones).\n function makeChangeSingleDoc(doc, change, selAfter, spans) {\n if (doc.cm && !doc.cm.curOp)\n { return operation(doc.cm, makeChangeSingleDoc)(doc, change, selAfter, spans) }\n\n if (change.to.line < doc.first) {\n shiftDoc(doc, change.text.length - 1 - (change.to.line - change.from.line));\n return\n }\n if (change.from.line > doc.lastLine()) { return }\n\n // Clip the change to the size of this doc\n if (change.from.line < doc.first) {\n var shift = change.text.length - 1 - (doc.first - change.from.line);\n shiftDoc(doc, shift);\n change = {from: Pos(doc.first, 0), to: Pos(change.to.line + shift, change.to.ch),\n text: [lst(change.text)], origin: change.origin};\n }\n var last = doc.lastLine();\n if (change.to.line > last) {\n change = {from: change.from, to: Pos(last, getLine(doc, last).text.length),\n text: [change.text[0]], origin: change.origin};\n }\n\n change.removed = getBetween(doc, change.from, change.to);\n\n if (!selAfter) { selAfter = computeSelAfterChange(doc, change); }\n if (doc.cm) { makeChangeSingleDocInEditor(doc.cm, change, spans); }\n else { updateDoc(doc, change, spans); }\n setSelectionNoUndo(doc, selAfter, sel_dontScroll);\n\n if (doc.cantEdit && skipAtomic(doc, Pos(doc.firstLine(), 0)))\n { doc.cantEdit = false; }\n }\n\n // Handle the interaction of a change to a document with the editor\n // that this document is part of.\n function makeChangeSingleDocInEditor(cm, change, spans) {\n var doc = cm.doc, display = cm.display, from = change.from, to = change.to;\n\n var recomputeMaxLength = false, checkWidthStart = from.line;\n if (!cm.options.lineWrapping) {\n checkWidthStart = lineNo(visualLine(getLine(doc, from.line)));\n doc.iter(checkWidthStart, to.line + 1, function (line) {\n if (line == display.maxLine) {\n recomputeMaxLength = true;\n return true\n }\n });\n }\n\n if (doc.sel.contains(change.from, change.to) > -1)\n { signalCursorActivity(cm); }\n\n updateDoc(doc, change, spans, estimateHeight(cm));\n\n if (!cm.options.lineWrapping) {\n doc.iter(checkWidthStart, from.line + change.text.length, function (line) {\n var len = lineLength(line);\n if (len > display.maxLineLength) {\n display.maxLine = line;\n display.maxLineLength = len;\n display.maxLineChanged = true;\n recomputeMaxLength = false;\n }\n });\n if (recomputeMaxLength) { cm.curOp.updateMaxLine = true; }\n }\n\n retreatFrontier(doc, from.line);\n startWorker(cm, 400);\n\n var lendiff = change.text.length - (to.line - from.line) - 1;\n // Remember that these lines changed, for updating the display\n if (change.full)\n { regChange(cm); }\n else if (from.line == to.line && change.text.length == 1 && !isWholeLineUpdate(cm.doc, change))\n { regLineChange(cm, from.line, \"text\"); }\n else\n { regChange(cm, from.line, to.line + 1, lendiff); }\n\n var changesHandler = hasHandler(cm, \"changes\"), changeHandler = hasHandler(cm, \"change\");\n if (changeHandler || changesHandler) {\n var obj = {\n from: from, to: to,\n text: change.text,\n removed: change.removed,\n origin: change.origin\n };\n if (changeHandler) { signalLater(cm, \"change\", cm, obj); }\n if (changesHandler) { (cm.curOp.changeObjs || (cm.curOp.changeObjs = [])).push(obj); }\n }\n cm.display.selForContextMenu = null;\n }\n\n function replaceRange(doc, code, from, to, origin) {\n var assign;\n\n if (!to) { to = from; }\n if (cmp(to, from) < 0) { (assign = [to, from], from = assign[0], to = assign[1]); }\n if (typeof code == \"string\") { code = doc.splitLines(code); }\n makeChange(doc, {from: from, to: to, text: code, origin: origin});\n }\n\n // Rebasing/resetting history to deal with externally-sourced changes\n\n function rebaseHistSelSingle(pos, from, to, diff) {\n if (to < pos.line) {\n pos.line += diff;\n } else if (from < pos.line) {\n pos.line = from;\n pos.ch = 0;\n }\n }\n\n // Tries to rebase an array of history events given a change in the\n // document. If the change touches the same lines as the event, the\n // event, and everything 'behind' it, is discarded. If the change is\n // before the event, the event's positions are updated. Uses a\n // copy-on-write scheme for the positions, to avoid having to\n // reallocate them all on every rebase, but also avoid problems with\n // shared position objects being unsafely updated.\n function rebaseHistArray(array, from, to, diff) {\n for (var i = 0; i < array.length; ++i) {\n var sub = array[i], ok = true;\n if (sub.ranges) {\n if (!sub.copied) { sub = array[i] = sub.deepCopy(); sub.copied = true; }\n for (var j = 0; j < sub.ranges.length; j++) {\n rebaseHistSelSingle(sub.ranges[j].anchor, from, to, diff);\n rebaseHistSelSingle(sub.ranges[j].head, from, to, diff);\n }\n continue\n }\n for (var j$1 = 0; j$1 < sub.changes.length; ++j$1) {\n var cur = sub.changes[j$1];\n if (to < cur.from.line) {\n cur.from = Pos(cur.from.line + diff, cur.from.ch);\n cur.to = Pos(cur.to.line + diff, cur.to.ch);\n } else if (from <= cur.to.line) {\n ok = false;\n break\n }\n }\n if (!ok) {\n array.splice(0, i + 1);\n i = 0;\n }\n }\n }\n\n function rebaseHist(hist, change) {\n var from = change.from.line, to = change.to.line, diff = change.text.length - (to - from) - 1;\n rebaseHistArray(hist.done, from, to, diff);\n rebaseHistArray(hist.undone, from, to, diff);\n }\n\n // Utility for applying a change to a line by handle or number,\n // returning the number and optionally registering the line as\n // changed.\n function changeLine(doc, handle, changeType, op) {\n var no = handle, line = handle;\n if (typeof handle == \"number\") { line = getLine(doc, clipLine(doc, handle)); }\n else { no = lineNo(handle); }\n if (no == null) { return null }\n if (op(line, no) && doc.cm) { regLineChange(doc.cm, no, changeType); }\n return line\n }\n\n // The document is represented as a BTree consisting of leaves, with\n // chunk of lines in them, and branches, with up to ten leaves or\n // other branch nodes below them. The top node is always a branch\n // node, and is the document object itself (meaning it has\n // additional methods and properties).\n //\n // All nodes have parent links. The tree is used both to go from\n // line numbers to line objects, and to go from objects to numbers.\n // It also indexes by height, and is used to convert between height\n // and line object, and to find the total height of the document.\n //\n // See also http://marijnhaverbeke.nl/blog/codemirror-line-tree.html\n\n function LeafChunk(lines) {\n var this$1 = this;\n\n this.lines = lines;\n this.parent = null;\n var height = 0;\n for (var i = 0; i < lines.length; ++i) {\n lines[i].parent = this$1;\n height += lines[i].height;\n }\n this.height = height;\n }\n\n LeafChunk.prototype = {\n chunkSize: function() { return this.lines.length },\n\n // Remove the n lines at offset 'at'.\n removeInner: function(at, n) {\n var this$1 = this;\n\n for (var i = at, e = at + n; i < e; ++i) {\n var line = this$1.lines[i];\n this$1.height -= line.height;\n cleanUpLine(line);\n signalLater(line, \"delete\");\n }\n this.lines.splice(at, n);\n },\n\n // Helper used to collapse a small branch into a single leaf.\n collapse: function(lines) {\n lines.push.apply(lines, this.lines);\n },\n\n // Insert the given array of lines at offset 'at', count them as\n // having the given height.\n insertInner: function(at, lines, height) {\n var this$1 = this;\n\n this.height += height;\n this.lines = this.lines.slice(0, at).concat(lines).concat(this.lines.slice(at));\n for (var i = 0; i < lines.length; ++i) { lines[i].parent = this$1; }\n },\n\n // Used to iterate over a part of the tree.\n iterN: function(at, n, op) {\n var this$1 = this;\n\n for (var e = at + n; at < e; ++at)\n { if (op(this$1.lines[at])) { return true } }\n }\n };\n\n function BranchChunk(children) {\n var this$1 = this;\n\n this.children = children;\n var size = 0, height = 0;\n for (var i = 0; i < children.length; ++i) {\n var ch = children[i];\n size += ch.chunkSize(); height += ch.height;\n ch.parent = this$1;\n }\n this.size = size;\n this.height = height;\n this.parent = null;\n }\n\n BranchChunk.prototype = {\n chunkSize: function() { return this.size },\n\n removeInner: function(at, n) {\n var this$1 = this;\n\n this.size -= n;\n for (var i = 0; i < this.children.length; ++i) {\n var child = this$1.children[i], sz = child.chunkSize();\n if (at < sz) {\n var rm = Math.min(n, sz - at), oldHeight = child.height;\n child.removeInner(at, rm);\n this$1.height -= oldHeight - child.height;\n if (sz == rm) { this$1.children.splice(i--, 1); child.parent = null; }\n if ((n -= rm) == 0) { break }\n at = 0;\n } else { at -= sz; }\n }\n // If the result is smaller than 25 lines, ensure that it is a\n // single leaf node.\n if (this.size - n < 25 &&\n (this.children.length > 1 || !(this.children[0] instanceof LeafChunk))) {\n var lines = [];\n this.collapse(lines);\n this.children = [new LeafChunk(lines)];\n this.children[0].parent = this;\n }\n },\n\n collapse: function(lines) {\n var this$1 = this;\n\n for (var i = 0; i < this.children.length; ++i) { this$1.children[i].collapse(lines); }\n },\n\n insertInner: function(at, lines, height) {\n var this$1 = this;\n\n this.size += lines.length;\n this.height += height;\n for (var i = 0; i < this.children.length; ++i) {\n var child = this$1.children[i], sz = child.chunkSize();\n if (at <= sz) {\n child.insertInner(at, lines, height);\n if (child.lines && child.lines.length > 50) {\n // To avoid memory thrashing when child.lines is huge (e.g. first view of a large file), it's never spliced.\n // Instead, small slices are taken. They're taken in order because sequential memory accesses are fastest.\n var remaining = child.lines.length % 25 + 25;\n for (var pos = remaining; pos < child.lines.length;) {\n var leaf = new LeafChunk(child.lines.slice(pos, pos += 25));\n child.height -= leaf.height;\n this$1.children.splice(++i, 0, leaf);\n leaf.parent = this$1;\n }\n child.lines = child.lines.slice(0, remaining);\n this$1.maybeSpill();\n }\n break\n }\n at -= sz;\n }\n },\n\n // When a node has grown, check whether it should be split.\n maybeSpill: function() {\n if (this.children.length <= 10) { return }\n var me = this;\n do {\n var spilled = me.children.splice(me.children.length - 5, 5);\n var sibling = new BranchChunk(spilled);\n if (!me.parent) { // Become the parent node\n var copy = new BranchChunk(me.children);\n copy.parent = me;\n me.children = [copy, sibling];\n me = copy;\n } else {\n me.size -= sibling.size;\n me.height -= sibling.height;\n var myIndex = indexOf(me.parent.children, me);\n me.parent.children.splice(myIndex + 1, 0, sibling);\n }\n sibling.parent = me.parent;\n } while (me.children.length > 10)\n me.parent.maybeSpill();\n },\n\n iterN: function(at, n, op) {\n var this$1 = this;\n\n for (var i = 0; i < this.children.length; ++i) {\n var child = this$1.children[i], sz = child.chunkSize();\n if (at < sz) {\n var used = Math.min(n, sz - at);\n if (child.iterN(at, used, op)) { return true }\n if ((n -= used) == 0) { break }\n at = 0;\n } else { at -= sz; }\n }\n }\n };\n\n // Line widgets are block elements displayed above or below a line.\n\n var LineWidget = function(doc, node, options) {\n var this$1 = this;\n\n if (options) { for (var opt in options) { if (options.hasOwnProperty(opt))\n { this$1[opt] = options[opt]; } } }\n this.doc = doc;\n this.node = node;\n };\n\n LineWidget.prototype.clear = function () {\n var this$1 = this;\n\n var cm = this.doc.cm, ws = this.line.widgets, line = this.line, no = lineNo(line);\n if (no == null || !ws) { return }\n for (var i = 0; i < ws.length; ++i) { if (ws[i] == this$1) { ws.splice(i--, 1); } }\n if (!ws.length) { line.widgets = null; }\n var height = widgetHeight(this);\n updateLineHeight(line, Math.max(0, line.height - height));\n if (cm) {\n runInOp(cm, function () {\n adjustScrollWhenAboveVisible(cm, line, -height);\n regLineChange(cm, no, \"widget\");\n });\n signalLater(cm, \"lineWidgetCleared\", cm, this, no);\n }\n };\n\n LineWidget.prototype.changed = function () {\n var this$1 = this;\n\n var oldH = this.height, cm = this.doc.cm, line = this.line;\n this.height = null;\n var diff = widgetHeight(this) - oldH;\n if (!diff) { return }\n if (!lineIsHidden(this.doc, line)) { updateLineHeight(line, line.height + diff); }\n if (cm) {\n runInOp(cm, function () {\n cm.curOp.forceUpdate = true;\n adjustScrollWhenAboveVisible(cm, line, diff);\n signalLater(cm, \"lineWidgetChanged\", cm, this$1, lineNo(line));\n });\n }\n };\n eventMixin(LineWidget);\n\n function adjustScrollWhenAboveVisible(cm, line, diff) {\n if (heightAtLine(line) < ((cm.curOp && cm.curOp.scrollTop) || cm.doc.scrollTop))\n { addToScrollTop(cm, diff); }\n }\n\n function addLineWidget(doc, handle, node, options) {\n var widget = new LineWidget(doc, node, options);\n var cm = doc.cm;\n if (cm && widget.noHScroll) { cm.display.alignWidgets = true; }\n changeLine(doc, handle, \"widget\", function (line) {\n var widgets = line.widgets || (line.widgets = []);\n if (widget.insertAt == null) { widgets.push(widget); }\n else { widgets.splice(Math.min(widgets.length - 1, Math.max(0, widget.insertAt)), 0, widget); }\n widget.line = line;\n if (cm && !lineIsHidden(doc, line)) {\n var aboveVisible = heightAtLine(line) < doc.scrollTop;\n updateLineHeight(line, line.height + widgetHeight(widget));\n if (aboveVisible) { addToScrollTop(cm, widget.height); }\n cm.curOp.forceUpdate = true;\n }\n return true\n });\n if (cm) { signalLater(cm, \"lineWidgetAdded\", cm, widget, typeof handle == \"number\" ? handle : lineNo(handle)); }\n return widget\n }\n\n // TEXTMARKERS\n\n // Created with markText and setBookmark methods. A TextMarker is a\n // handle that can be used to clear or find a marked position in the\n // document. Line objects hold arrays (markedSpans) containing\n // {from, to, marker} object pointing to such marker objects, and\n // indicating that such a marker is present on that line. Multiple\n // lines may point to the same marker when it spans across lines.\n // The spans will have null for their from/to properties when the\n // marker continues beyond the start/end of the line. Markers have\n // links back to the lines they currently touch.\n\n // Collapsed markers have unique ids, in order to be able to order\n // them, which is needed for uniquely determining an outer marker\n // when they overlap (they may nest, but not partially overlap).\n var nextMarkerId = 0;\n\n var TextMarker = function(doc, type) {\n this.lines = [];\n this.type = type;\n this.doc = doc;\n this.id = ++nextMarkerId;\n };\n\n // Clear the marker.\n TextMarker.prototype.clear = function () {\n var this$1 = this;\n\n if (this.explicitlyCleared) { return }\n var cm = this.doc.cm, withOp = cm && !cm.curOp;\n if (withOp) { startOperation(cm); }\n if (hasHandler(this, \"clear\")) {\n var found = this.find();\n if (found) { signalLater(this, \"clear\", found.from, found.to); }\n }\n var min = null, max = null;\n for (var i = 0; i < this.lines.length; ++i) {\n var line = this$1.lines[i];\n var span = getMarkedSpanFor(line.markedSpans, this$1);\n if (cm && !this$1.collapsed) { regLineChange(cm, lineNo(line), \"text\"); }\n else if (cm) {\n if (span.to != null) { max = lineNo(line); }\n if (span.from != null) { min = lineNo(line); }\n }\n line.markedSpans = removeMarkedSpan(line.markedSpans, span);\n if (span.from == null && this$1.collapsed && !lineIsHidden(this$1.doc, line) && cm)\n { updateLineHeight(line, textHeight(cm.display)); }\n }\n if (cm && this.collapsed && !cm.options.lineWrapping) { for (var i$1 = 0; i$1 < this.lines.length; ++i$1) {\n var visual = visualLine(this$1.lines[i$1]), len = lineLength(visual);\n if (len > cm.display.maxLineLength) {\n cm.display.maxLine = visual;\n cm.display.maxLineLength = len;\n cm.display.maxLineChanged = true;\n }\n } }\n\n if (min != null && cm && this.collapsed) { regChange(cm, min, max + 1); }\n this.lines.length = 0;\n this.explicitlyCleared = true;\n if (this.atomic && this.doc.cantEdit) {\n this.doc.cantEdit = false;\n if (cm) { reCheckSelection(cm.doc); }\n }\n if (cm) { signalLater(cm, \"markerCleared\", cm, this, min, max); }\n if (withOp) { endOperation(cm); }\n if (this.parent) { this.parent.clear(); }\n };\n\n // Find the position of the marker in the document. Returns a {from,\n // to} object by default. Side can be passed to get a specific side\n // -- 0 (both), -1 (left), or 1 (right). When lineObj is true, the\n // Pos objects returned contain a line object, rather than a line\n // number (used to prevent looking up the same line twice).\n TextMarker.prototype.find = function (side, lineObj) {\n var this$1 = this;\n\n if (side == null && this.type == \"bookmark\") { side = 1; }\n var from, to;\n for (var i = 0; i < this.lines.length; ++i) {\n var line = this$1.lines[i];\n var span = getMarkedSpanFor(line.markedSpans, this$1);\n if (span.from != null) {\n from = Pos(lineObj ? line : lineNo(line), span.from);\n if (side == -1) { return from }\n }\n if (span.to != null) {\n to = Pos(lineObj ? line : lineNo(line), span.to);\n if (side == 1) { return to }\n }\n }\n return from && {from: from, to: to}\n };\n\n // Signals that the marker's widget changed, and surrounding layout\n // should be recomputed.\n TextMarker.prototype.changed = function () {\n var this$1 = this;\n\n var pos = this.find(-1, true), widget = this, cm = this.doc.cm;\n if (!pos || !cm) { return }\n runInOp(cm, function () {\n var line = pos.line, lineN = lineNo(pos.line);\n var view = findViewForLine(cm, lineN);\n if (view) {\n clearLineMeasurementCacheFor(view);\n cm.curOp.selectionChanged = cm.curOp.forceUpdate = true;\n }\n cm.curOp.updateMaxLine = true;\n if (!lineIsHidden(widget.doc, line) && widget.height != null) {\n var oldHeight = widget.height;\n widget.height = null;\n var dHeight = widgetHeight(widget) - oldHeight;\n if (dHeight)\n { updateLineHeight(line, line.height + dHeight); }\n }\n signalLater(cm, \"markerChanged\", cm, this$1);\n });\n };\n\n TextMarker.prototype.attachLine = function (line) {\n if (!this.lines.length && this.doc.cm) {\n var op = this.doc.cm.curOp;\n if (!op.maybeHiddenMarkers || indexOf(op.maybeHiddenMarkers, this) == -1)\n { (op.maybeUnhiddenMarkers || (op.maybeUnhiddenMarkers = [])).push(this); }\n }\n this.lines.push(line);\n };\n\n TextMarker.prototype.detachLine = function (line) {\n this.lines.splice(indexOf(this.lines, line), 1);\n if (!this.lines.length && this.doc.cm) {\n var op = this.doc.cm.curOp\n ;(op.maybeHiddenMarkers || (op.maybeHiddenMarkers = [])).push(this);\n }\n };\n eventMixin(TextMarker);\n\n // Create a marker, wire it up to the right lines, and\n function markText(doc, from, to, options, type) {\n // Shared markers (across linked documents) are handled separately\n // (markTextShared will call out to this again, once per\n // document).\n if (options && options.shared) { return markTextShared(doc, from, to, options, type) }\n // Ensure we are in an operation.\n if (doc.cm && !doc.cm.curOp) { return operation(doc.cm, markText)(doc, from, to, options, type) }\n\n var marker = new TextMarker(doc, type), diff = cmp(from, to);\n if (options) { copyObj(options, marker, false); }\n // Don't connect empty markers unless clearWhenEmpty is false\n if (diff > 0 || diff == 0 && marker.clearWhenEmpty !== false)\n { return marker }\n if (marker.replacedWith) {\n // Showing up as a widget implies collapsed (widget replaces text)\n marker.collapsed = true;\n marker.widgetNode = eltP(\"span\", [marker.replacedWith], \"CodeMirror-widget\");\n if (!options.handleMouseEvents) { marker.widgetNode.setAttribute(\"cm-ignore-events\", \"true\"); }\n if (options.insertLeft) { marker.widgetNode.insertLeft = true; }\n }\n if (marker.collapsed) {\n if (conflictingCollapsedRange(doc, from.line, from, to, marker) ||\n from.line != to.line && conflictingCollapsedRange(doc, to.line, from, to, marker))\n { throw new Error(\"Inserting collapsed marker partially overlapping an existing one\") }\n seeCollapsedSpans();\n }\n\n if (marker.addToHistory)\n { addChangeToHistory(doc, {from: from, to: to, origin: \"markText\"}, doc.sel, NaN); }\n\n var curLine = from.line, cm = doc.cm, updateMaxLine;\n doc.iter(curLine, to.line + 1, function (line) {\n if (cm && marker.collapsed && !cm.options.lineWrapping && visualLine(line) == cm.display.maxLine)\n { updateMaxLine = true; }\n if (marker.collapsed && curLine != from.line) { updateLineHeight(line, 0); }\n addMarkedSpan(line, new MarkedSpan(marker,\n curLine == from.line ? from.ch : null,\n curLine == to.line ? to.ch : null));\n ++curLine;\n });\n // lineIsHidden depends on the presence of the spans, so needs a second pass\n if (marker.collapsed) { doc.iter(from.line, to.line + 1, function (line) {\n if (lineIsHidden(doc, line)) { updateLineHeight(line, 0); }\n }); }\n\n if (marker.clearOnEnter) { on(marker, \"beforeCursorEnter\", function () { return marker.clear(); }); }\n\n if (marker.readOnly) {\n seeReadOnlySpans();\n if (doc.history.done.length || doc.history.undone.length)\n { doc.clearHistory(); }\n }\n if (marker.collapsed) {\n marker.id = ++nextMarkerId;\n marker.atomic = true;\n }\n if (cm) {\n // Sync editor state\n if (updateMaxLine) { cm.curOp.updateMaxLine = true; }\n if (marker.collapsed)\n { regChange(cm, from.line, to.line + 1); }\n else if (marker.className || marker.startStyle || marker.endStyle || marker.css ||\n marker.attributes || marker.title)\n { for (var i = from.line; i <= to.line; i++) { regLineChange(cm, i, \"text\"); } }\n if (marker.atomic) { reCheckSelection(cm.doc); }\n signalLater(cm, \"markerAdded\", cm, marker);\n }\n return marker\n }\n\n // SHARED TEXTMARKERS\n\n // A shared marker spans multiple linked documents. It is\n // implemented as a meta-marker-object controlling multiple normal\n // markers.\n var SharedTextMarker = function(markers, primary) {\n var this$1 = this;\n\n this.markers = markers;\n this.primary = primary;\n for (var i = 0; i < markers.length; ++i)\n { markers[i].parent = this$1; }\n };\n\n SharedTextMarker.prototype.clear = function () {\n var this$1 = this;\n\n if (this.explicitlyCleared) { return }\n this.explicitlyCleared = true;\n for (var i = 0; i < this.markers.length; ++i)\n { this$1.markers[i].clear(); }\n signalLater(this, \"clear\");\n };\n\n SharedTextMarker.prototype.find = function (side, lineObj) {\n return this.primary.find(side, lineObj)\n };\n eventMixin(SharedTextMarker);\n\n function markTextShared(doc, from, to, options, type) {\n options = copyObj(options);\n options.shared = false;\n var markers = [markText(doc, from, to, options, type)], primary = markers[0];\n var widget = options.widgetNode;\n linkedDocs(doc, function (doc) {\n if (widget) { options.widgetNode = widget.cloneNode(true); }\n markers.push(markText(doc, clipPos(doc, from), clipPos(doc, to), options, type));\n for (var i = 0; i < doc.linked.length; ++i)\n { if (doc.linked[i].isParent) { return } }\n primary = lst(markers);\n });\n return new SharedTextMarker(markers, primary)\n }\n\n function findSharedMarkers(doc) {\n return doc.findMarks(Pos(doc.first, 0), doc.clipPos(Pos(doc.lastLine())), function (m) { return m.parent; })\n }\n\n function copySharedMarkers(doc, markers) {\n for (var i = 0; i < markers.length; i++) {\n var marker = markers[i], pos = marker.find();\n var mFrom = doc.clipPos(pos.from), mTo = doc.clipPos(pos.to);\n if (cmp(mFrom, mTo)) {\n var subMark = markText(doc, mFrom, mTo, marker.primary, marker.primary.type);\n marker.markers.push(subMark);\n subMark.parent = marker;\n }\n }\n }\n\n function detachSharedMarkers(markers) {\n var loop = function ( i ) {\n var marker = markers[i], linked = [marker.primary.doc];\n linkedDocs(marker.primary.doc, function (d) { return linked.push(d); });\n for (var j = 0; j < marker.markers.length; j++) {\n var subMarker = marker.markers[j];\n if (indexOf(linked, subMarker.doc) == -1) {\n subMarker.parent = null;\n marker.markers.splice(j--, 1);\n }\n }\n };\n\n for (var i = 0; i < markers.length; i++) loop( i );\n }\n\n var nextDocId = 0;\n var Doc = function(text, mode, firstLine, lineSep, direction) {\n if (!(this instanceof Doc)) { return new Doc(text, mode, firstLine, lineSep, direction) }\n if (firstLine == null) { firstLine = 0; }\n\n BranchChunk.call(this, [new LeafChunk([new Line(\"\", null)])]);\n this.first = firstLine;\n this.scrollTop = this.scrollLeft = 0;\n this.cantEdit = false;\n this.cleanGeneration = 1;\n this.modeFrontier = this.highlightFrontier = firstLine;\n var start = Pos(firstLine, 0);\n this.sel = simpleSelection(start);\n this.history = new History(null);\n this.id = ++nextDocId;\n this.modeOption = mode;\n this.lineSep = lineSep;\n this.direction = (direction == \"rtl\") ? \"rtl\" : \"ltr\";\n this.extend = false;\n\n if (typeof text == \"string\") { text = this.splitLines(text); }\n updateDoc(this, {from: start, to: start, text: text});\n setSelection(this, simpleSelection(start), sel_dontScroll);\n };\n\n Doc.prototype = createObj(BranchChunk.prototype, {\n constructor: Doc,\n // Iterate over the document. Supports two forms -- with only one\n // argument, it calls that for each line in the document. With\n // three, it iterates over the range given by the first two (with\n // the second being non-inclusive).\n iter: function(from, to, op) {\n if (op) { this.iterN(from - this.first, to - from, op); }\n else { this.iterN(this.first, this.first + this.size, from); }\n },\n\n // Non-public interface for adding and removing lines.\n insert: function(at, lines) {\n var height = 0;\n for (var i = 0; i < lines.length; ++i) { height += lines[i].height; }\n this.insertInner(at - this.first, lines, height);\n },\n remove: function(at, n) { this.removeInner(at - this.first, n); },\n\n // From here, the methods are part of the public interface. Most\n // are also available from CodeMirror (editor) instances.\n\n getValue: function(lineSep) {\n var lines = getLines(this, this.first, this.first + this.size);\n if (lineSep === false) { return lines }\n return lines.join(lineSep || this.lineSeparator())\n },\n setValue: docMethodOp(function(code) {\n var top = Pos(this.first, 0), last = this.first + this.size - 1;\n makeChange(this, {from: top, to: Pos(last, getLine(this, last).text.length),\n text: this.splitLines(code), origin: \"setValue\", full: true}, true);\n if (this.cm) { scrollToCoords(this.cm, 0, 0); }\n setSelection(this, simpleSelection(top), sel_dontScroll);\n }),\n replaceRange: function(code, from, to, origin) {\n from = clipPos(this, from);\n to = to ? clipPos(this, to) : from;\n replaceRange(this, code, from, to, origin);\n },\n getRange: function(from, to, lineSep) {\n var lines = getBetween(this, clipPos(this, from), clipPos(this, to));\n if (lineSep === false) { return lines }\n return lines.join(lineSep || this.lineSeparator())\n },\n\n getLine: function(line) {var l = this.getLineHandle(line); return l && l.text},\n\n getLineHandle: function(line) {if (isLine(this, line)) { return getLine(this, line) }},\n getLineNumber: function(line) {return lineNo(line)},\n\n getLineHandleVisualStart: function(line) {\n if (typeof line == \"number\") { line = getLine(this, line); }\n return visualLine(line)\n },\n\n lineCount: function() {return this.size},\n firstLine: function() {return this.first},\n lastLine: function() {return this.first + this.size - 1},\n\n clipPos: function(pos) {return clipPos(this, pos)},\n\n getCursor: function(start) {\n var range$$1 = this.sel.primary(), pos;\n if (start == null || start == \"head\") { pos = range$$1.head; }\n else if (start == \"anchor\") { pos = range$$1.anchor; }\n else if (start == \"end\" || start == \"to\" || start === false) { pos = range$$1.to(); }\n else { pos = range$$1.from(); }\n return pos\n },\n listSelections: function() { return this.sel.ranges },\n somethingSelected: function() {return this.sel.somethingSelected()},\n\n setCursor: docMethodOp(function(line, ch, options) {\n setSimpleSelection(this, clipPos(this, typeof line == \"number\" ? Pos(line, ch || 0) : line), null, options);\n }),\n setSelection: docMethodOp(function(anchor, head, options) {\n setSimpleSelection(this, clipPos(this, anchor), clipPos(this, head || anchor), options);\n }),\n extendSelection: docMethodOp(function(head, other, options) {\n extendSelection(this, clipPos(this, head), other && clipPos(this, other), options);\n }),\n extendSelections: docMethodOp(function(heads, options) {\n extendSelections(this, clipPosArray(this, heads), options);\n }),\n extendSelectionsBy: docMethodOp(function(f, options) {\n var heads = map(this.sel.ranges, f);\n extendSelections(this, clipPosArray(this, heads), options);\n }),\n setSelections: docMethodOp(function(ranges, primary, options) {\n var this$1 = this;\n\n if (!ranges.length) { return }\n var out = [];\n for (var i = 0; i < ranges.length; i++)\n { out[i] = new Range(clipPos(this$1, ranges[i].anchor),\n clipPos(this$1, ranges[i].head)); }\n if (primary == null) { primary = Math.min(ranges.length - 1, this.sel.primIndex); }\n setSelection(this, normalizeSelection(this.cm, out, primary), options);\n }),\n addSelection: docMethodOp(function(anchor, head, options) {\n var ranges = this.sel.ranges.slice(0);\n ranges.push(new Range(clipPos(this, anchor), clipPos(this, head || anchor)));\n setSelection(this, normalizeSelection(this.cm, ranges, ranges.length - 1), options);\n }),\n\n getSelection: function(lineSep) {\n var this$1 = this;\n\n var ranges = this.sel.ranges, lines;\n for (var i = 0; i < ranges.length; i++) {\n var sel = getBetween(this$1, ranges[i].from(), ranges[i].to());\n lines = lines ? lines.concat(sel) : sel;\n }\n if (lineSep === false) { return lines }\n else { return lines.join(lineSep || this.lineSeparator()) }\n },\n getSelections: function(lineSep) {\n var this$1 = this;\n\n var parts = [], ranges = this.sel.ranges;\n for (var i = 0; i < ranges.length; i++) {\n var sel = getBetween(this$1, ranges[i].from(), ranges[i].to());\n if (lineSep !== false) { sel = sel.join(lineSep || this$1.lineSeparator()); }\n parts[i] = sel;\n }\n return parts\n },\n replaceSelection: function(code, collapse, origin) {\n var dup = [];\n for (var i = 0; i < this.sel.ranges.length; i++)\n { dup[i] = code; }\n this.replaceSelections(dup, collapse, origin || \"+input\");\n },\n replaceSelections: docMethodOp(function(code, collapse, origin) {\n var this$1 = this;\n\n var changes = [], sel = this.sel;\n for (var i = 0; i < sel.ranges.length; i++) {\n var range$$1 = sel.ranges[i];\n changes[i] = {from: range$$1.from(), to: range$$1.to(), text: this$1.splitLines(code[i]), origin: origin};\n }\n var newSel = collapse && collapse != \"end\" && computeReplacedSel(this, changes, collapse);\n for (var i$1 = changes.length - 1; i$1 >= 0; i$1--)\n { makeChange(this$1, changes[i$1]); }\n if (newSel) { setSelectionReplaceHistory(this, newSel); }\n else if (this.cm) { ensureCursorVisible(this.cm); }\n }),\n undo: docMethodOp(function() {makeChangeFromHistory(this, \"undo\");}),\n redo: docMethodOp(function() {makeChangeFromHistory(this, \"redo\");}),\n undoSelection: docMethodOp(function() {makeChangeFromHistory(this, \"undo\", true);}),\n redoSelection: docMethodOp(function() {makeChangeFromHistory(this, \"redo\", true);}),\n\n setExtending: function(val) {this.extend = val;},\n getExtending: function() {return this.extend},\n\n historySize: function() {\n var hist = this.history, done = 0, undone = 0;\n for (var i = 0; i < hist.done.length; i++) { if (!hist.done[i].ranges) { ++done; } }\n for (var i$1 = 0; i$1 < hist.undone.length; i$1++) { if (!hist.undone[i$1].ranges) { ++undone; } }\n return {undo: done, redo: undone}\n },\n clearHistory: function() {this.history = new History(this.history.maxGeneration);},\n\n markClean: function() {\n this.cleanGeneration = this.changeGeneration(true);\n },\n changeGeneration: function(forceSplit) {\n if (forceSplit)\n { this.history.lastOp = this.history.lastSelOp = this.history.lastOrigin = null; }\n return this.history.generation\n },\n isClean: function (gen) {\n return this.history.generation == (gen || this.cleanGeneration)\n },\n\n getHistory: function() {\n return {done: copyHistoryArray(this.history.done),\n undone: copyHistoryArray(this.history.undone)}\n },\n setHistory: function(histData) {\n var hist = this.history = new History(this.history.maxGeneration);\n hist.done = copyHistoryArray(histData.done.slice(0), null, true);\n hist.undone = copyHistoryArray(histData.undone.slice(0), null, true);\n },\n\n setGutterMarker: docMethodOp(function(line, gutterID, value) {\n return changeLine(this, line, \"gutter\", function (line) {\n var markers = line.gutterMarkers || (line.gutterMarkers = {});\n markers[gutterID] = value;\n if (!value && isEmpty(markers)) { line.gutterMarkers = null; }\n return true\n })\n }),\n\n clearGutter: docMethodOp(function(gutterID) {\n var this$1 = this;\n\n this.iter(function (line) {\n if (line.gutterMarkers && line.gutterMarkers[gutterID]) {\n changeLine(this$1, line, \"gutter\", function () {\n line.gutterMarkers[gutterID] = null;\n if (isEmpty(line.gutterMarkers)) { line.gutterMarkers = null; }\n return true\n });\n }\n });\n }),\n\n lineInfo: function(line) {\n var n;\n if (typeof line == \"number\") {\n if (!isLine(this, line)) { return null }\n n = line;\n line = getLine(this, line);\n if (!line) { return null }\n } else {\n n = lineNo(line);\n if (n == null) { return null }\n }\n return {line: n, handle: line, text: line.text, gutterMarkers: line.gutterMarkers,\n textClass: line.textClass, bgClass: line.bgClass, wrapClass: line.wrapClass,\n widgets: line.widgets}\n },\n\n addLineClass: docMethodOp(function(handle, where, cls) {\n return changeLine(this, handle, where == \"gutter\" ? \"gutter\" : \"class\", function (line) {\n var prop = where == \"text\" ? \"textClass\"\n : where == \"background\" ? \"bgClass\"\n : where == \"gutter\" ? \"gutterClass\" : \"wrapClass\";\n if (!line[prop]) { line[prop] = cls; }\n else if (classTest(cls).test(line[prop])) { return false }\n else { line[prop] += \" \" + cls; }\n return true\n })\n }),\n removeLineClass: docMethodOp(function(handle, where, cls) {\n return changeLine(this, handle, where == \"gutter\" ? \"gutter\" : \"class\", function (line) {\n var prop = where == \"text\" ? \"textClass\"\n : where == \"background\" ? \"bgClass\"\n : where == \"gutter\" ? \"gutterClass\" : \"wrapClass\";\n var cur = line[prop];\n if (!cur) { return false }\n else if (cls == null) { line[prop] = null; }\n else {\n var found = cur.match(classTest(cls));\n if (!found) { return false }\n var end = found.index + found[0].length;\n line[prop] = cur.slice(0, found.index) + (!found.index || end == cur.length ? \"\" : \" \") + cur.slice(end) || null;\n }\n return true\n })\n }),\n\n addLineWidget: docMethodOp(function(handle, node, options) {\n return addLineWidget(this, handle, node, options)\n }),\n removeLineWidget: function(widget) { widget.clear(); },\n\n markText: function(from, to, options) {\n return markText(this, clipPos(this, from), clipPos(this, to), options, options && options.type || \"range\")\n },\n setBookmark: function(pos, options) {\n var realOpts = {replacedWith: options && (options.nodeType == null ? options.widget : options),\n insertLeft: options && options.insertLeft,\n clearWhenEmpty: false, shared: options && options.shared,\n handleMouseEvents: options && options.handleMouseEvents};\n pos = clipPos(this, pos);\n return markText(this, pos, pos, realOpts, \"bookmark\")\n },\n findMarksAt: function(pos) {\n pos = clipPos(this, pos);\n var markers = [], spans = getLine(this, pos.line).markedSpans;\n if (spans) { for (var i = 0; i < spans.length; ++i) {\n var span = spans[i];\n if ((span.from == null || span.from <= pos.ch) &&\n (span.to == null || span.to >= pos.ch))\n { markers.push(span.marker.parent || span.marker); }\n } }\n return markers\n },\n findMarks: function(from, to, filter) {\n from = clipPos(this, from); to = clipPos(this, to);\n var found = [], lineNo$$1 = from.line;\n this.iter(from.line, to.line + 1, function (line) {\n var spans = line.markedSpans;\n if (spans) { for (var i = 0; i < spans.length; i++) {\n var span = spans[i];\n if (!(span.to != null && lineNo$$1 == from.line && from.ch >= span.to ||\n span.from == null && lineNo$$1 != from.line ||\n span.from != null && lineNo$$1 == to.line && span.from >= to.ch) &&\n (!filter || filter(span.marker)))\n { found.push(span.marker.parent || span.marker); }\n } }\n ++lineNo$$1;\n });\n return found\n },\n getAllMarks: function() {\n var markers = [];\n this.iter(function (line) {\n var sps = line.markedSpans;\n if (sps) { for (var i = 0; i < sps.length; ++i)\n { if (sps[i].from != null) { markers.push(sps[i].marker); } } }\n });\n return markers\n },\n\n posFromIndex: function(off) {\n var ch, lineNo$$1 = this.first, sepSize = this.lineSeparator().length;\n this.iter(function (line) {\n var sz = line.text.length + sepSize;\n if (sz > off) { ch = off; return true }\n off -= sz;\n ++lineNo$$1;\n });\n return clipPos(this, Pos(lineNo$$1, ch))\n },\n indexFromPos: function (coords) {\n coords = clipPos(this, coords);\n var index = coords.ch;\n if (coords.line < this.first || coords.ch < 0) { return 0 }\n var sepSize = this.lineSeparator().length;\n this.iter(this.first, coords.line, function (line) { // iter aborts when callback returns a truthy value\n index += line.text.length + sepSize;\n });\n return index\n },\n\n copy: function(copyHistory) {\n var doc = new Doc(getLines(this, this.first, this.first + this.size),\n this.modeOption, this.first, this.lineSep, this.direction);\n doc.scrollTop = this.scrollTop; doc.scrollLeft = this.scrollLeft;\n doc.sel = this.sel;\n doc.extend = false;\n if (copyHistory) {\n doc.history.undoDepth = this.history.undoDepth;\n doc.setHistory(this.getHistory());\n }\n return doc\n },\n\n linkedDoc: function(options) {\n if (!options) { options = {}; }\n var from = this.first, to = this.first + this.size;\n if (options.from != null && options.from > from) { from = options.from; }\n if (options.to != null && options.to < to) { to = options.to; }\n var copy = new Doc(getLines(this, from, to), options.mode || this.modeOption, from, this.lineSep, this.direction);\n if (options.sharedHist) { copy.history = this.history\n ; }(this.linked || (this.linked = [])).push({doc: copy, sharedHist: options.sharedHist});\n copy.linked = [{doc: this, isParent: true, sharedHist: options.sharedHist}];\n copySharedMarkers(copy, findSharedMarkers(this));\n return copy\n },\n unlinkDoc: function(other) {\n var this$1 = this;\n\n if (other instanceof CodeMirror) { other = other.doc; }\n if (this.linked) { for (var i = 0; i < this.linked.length; ++i) {\n var link = this$1.linked[i];\n if (link.doc != other) { continue }\n this$1.linked.splice(i, 1);\n other.unlinkDoc(this$1);\n detachSharedMarkers(findSharedMarkers(this$1));\n break\n } }\n // If the histories were shared, split them again\n if (other.history == this.history) {\n var splitIds = [other.id];\n linkedDocs(other, function (doc) { return splitIds.push(doc.id); }, true);\n other.history = new History(null);\n other.history.done = copyHistoryArray(this.history.done, splitIds);\n other.history.undone = copyHistoryArray(this.history.undone, splitIds);\n }\n },\n iterLinkedDocs: function(f) {linkedDocs(this, f);},\n\n getMode: function() {return this.mode},\n getEditor: function() {return this.cm},\n\n splitLines: function(str) {\n if (this.lineSep) { return str.split(this.lineSep) }\n return splitLinesAuto(str)\n },\n lineSeparator: function() { return this.lineSep || \"\\n\" },\n\n setDirection: docMethodOp(function (dir) {\n if (dir != \"rtl\") { dir = \"ltr\"; }\n if (dir == this.direction) { return }\n this.direction = dir;\n this.iter(function (line) { return line.order = null; });\n if (this.cm) { directionChanged(this.cm); }\n })\n });\n\n // Public alias.\n Doc.prototype.eachLine = Doc.prototype.iter;\n\n // Kludge to work around strange IE behavior where it'll sometimes\n // re-fire a series of drag-related events right after the drop (#1551)\n var lastDrop = 0;\n\n function onDrop(e) {\n var cm = this;\n clearDragCursor(cm);\n if (signalDOMEvent(cm, e) || eventInWidget(cm.display, e))\n { return }\n e_preventDefault(e);\n if (ie) { lastDrop = +new Date; }\n var pos = posFromMouse(cm, e, true), files = e.dataTransfer.files;\n if (!pos || cm.isReadOnly()) { return }\n // Might be a file drop, in which case we simply extract the text\n // and insert it.\n if (files && files.length && window.FileReader && window.File) {\n var n = files.length, text = Array(n), read = 0;\n var loadFile = function (file, i) {\n if (cm.options.allowDropFileTypes &&\n indexOf(cm.options.allowDropFileTypes, file.type) == -1)\n { return }\n\n var reader = new FileReader;\n reader.onload = operation(cm, function () {\n var content = reader.result;\n if (/[\\x00-\\x08\\x0e-\\x1f]{2}/.test(content)) { content = \"\"; }\n text[i] = content;\n if (++read == n) {\n pos = clipPos(cm.doc, pos);\n var change = {from: pos, to: pos,\n text: cm.doc.splitLines(text.join(cm.doc.lineSeparator())),\n origin: \"paste\"};\n makeChange(cm.doc, change);\n setSelectionReplaceHistory(cm.doc, simpleSelection(pos, changeEnd(change)));\n }\n });\n reader.readAsText(file);\n };\n for (var i = 0; i < n; ++i) { loadFile(files[i], i); }\n } else { // Normal drop\n // Don't do a replace if the drop happened inside of the selected text.\n if (cm.state.draggingText && cm.doc.sel.contains(pos) > -1) {\n cm.state.draggingText(e);\n // Ensure the editor is re-focused\n setTimeout(function () { return cm.display.input.focus(); }, 20);\n return\n }\n try {\n var text$1 = e.dataTransfer.getData(\"Text\");\n if (text$1) {\n var selected;\n if (cm.state.draggingText && !cm.state.draggingText.copy)\n { selected = cm.listSelections(); }\n setSelectionNoUndo(cm.doc, simpleSelection(pos, pos));\n if (selected) { for (var i$1 = 0; i$1 < selected.length; ++i$1)\n { replaceRange(cm.doc, \"\", selected[i$1].anchor, selected[i$1].head, \"drag\"); } }\n cm.replaceSelection(text$1, \"around\", \"paste\");\n cm.display.input.focus();\n }\n }\n catch(e){}\n }\n }\n\n function onDragStart(cm, e) {\n if (ie && (!cm.state.draggingText || +new Date - lastDrop < 100)) { e_stop(e); return }\n if (signalDOMEvent(cm, e) || eventInWidget(cm.display, e)) { return }\n\n e.dataTransfer.setData(\"Text\", cm.getSelection());\n e.dataTransfer.effectAllowed = \"copyMove\";\n\n // Use dummy image instead of default browsers image.\n // Recent Safari (~6.0.2) have a tendency to segfault when this happens, so we don't do it there.\n if (e.dataTransfer.setDragImage && !safari) {\n var img = elt(\"img\", null, null, \"position: fixed; left: 0; top: 0;\");\n img.src = \"data:image/gif;base64,R0lGODlhAQABAAAAACH5BAEKAAEALAAAAAABAAEAAAICTAEAOw==\";\n if (presto) {\n img.width = img.height = 1;\n cm.display.wrapper.appendChild(img);\n // Force a relayout, or Opera won't use our image for some obscure reason\n img._top = img.offsetTop;\n }\n e.dataTransfer.setDragImage(img, 0, 0);\n if (presto) { img.parentNode.removeChild(img); }\n }\n }\n\n function onDragOver(cm, e) {\n var pos = posFromMouse(cm, e);\n if (!pos) { return }\n var frag = document.createDocumentFragment();\n drawSelectionCursor(cm, pos, frag);\n if (!cm.display.dragCursor) {\n cm.display.dragCursor = elt(\"div\", null, \"CodeMirror-cursors CodeMirror-dragcursors\");\n cm.display.lineSpace.insertBefore(cm.display.dragCursor, cm.display.cursorDiv);\n }\n removeChildrenAndAdd(cm.display.dragCursor, frag);\n }\n\n function clearDragCursor(cm) {\n if (cm.display.dragCursor) {\n cm.display.lineSpace.removeChild(cm.display.dragCursor);\n cm.display.dragCursor = null;\n }\n }\n\n // These must be handled carefully, because naively registering a\n // handler for each editor will cause the editors to never be\n // garbage collected.\n\n function forEachCodeMirror(f) {\n if (!document.getElementsByClassName) { return }\n var byClass = document.getElementsByClassName(\"CodeMirror\"), editors = [];\n for (var i = 0; i < byClass.length; i++) {\n var cm = byClass[i].CodeMirror;\n if (cm) { editors.push(cm); }\n }\n if (editors.length) { editors[0].operation(function () {\n for (var i = 0; i < editors.length; i++) { f(editors[i]); }\n }); }\n }\n\n var globalsRegistered = false;\n function ensureGlobalHandlers() {\n if (globalsRegistered) { return }\n registerGlobalHandlers();\n globalsRegistered = true;\n }\n function registerGlobalHandlers() {\n // When the window resizes, we need to refresh active editors.\n var resizeTimer;\n on(window, \"resize\", function () {\n if (resizeTimer == null) { resizeTimer = setTimeout(function () {\n resizeTimer = null;\n forEachCodeMirror(onResize);\n }, 100); }\n });\n // When the window loses focus, we want to show the editor as blurred\n on(window, \"blur\", function () { return forEachCodeMirror(onBlur); });\n }\n // Called when the window resizes\n function onResize(cm) {\n var d = cm.display;\n // Might be a text scaling operation, clear size caches.\n d.cachedCharWidth = d.cachedTextHeight = d.cachedPaddingH = null;\n d.scrollbarsClipped = false;\n cm.setSize();\n }\n\n var keyNames = {\n 3: \"Pause\", 8: \"Backspace\", 9: \"Tab\", 13: \"Enter\", 16: \"Shift\", 17: \"Ctrl\", 18: \"Alt\",\n 19: \"Pause\", 20: \"CapsLock\", 27: \"Esc\", 32: \"Space\", 33: \"PageUp\", 34: \"PageDown\", 35: \"End\",\n 36: \"Home\", 37: \"Left\", 38: \"Up\", 39: \"Right\", 40: \"Down\", 44: \"PrintScrn\", 45: \"Insert\",\n 46: \"Delete\", 59: \";\", 61: \"=\", 91: \"Mod\", 92: \"Mod\", 93: \"Mod\",\n 106: \"*\", 107: \"=\", 109: \"-\", 110: \".\", 111: \"/\", 145: \"ScrollLock\",\n 173: \"-\", 186: \";\", 187: \"=\", 188: \",\", 189: \"-\", 190: \".\", 191: \"/\", 192: \"`\", 219: \"[\", 220: \"\\\\\",\n 221: \"]\", 222: \"'\", 63232: \"Up\", 63233: \"Down\", 63234: \"Left\", 63235: \"Right\", 63272: \"Delete\",\n 63273: \"Home\", 63275: \"End\", 63276: \"PageUp\", 63277: \"PageDown\", 63302: \"Insert\"\n };\n\n // Number keys\n for (var i = 0; i < 10; i++) { keyNames[i + 48] = keyNames[i + 96] = String(i); }\n // Alphabetic keys\n for (var i$1 = 65; i$1 <= 90; i$1++) { keyNames[i$1] = String.fromCharCode(i$1); }\n // Function keys\n for (var i$2 = 1; i$2 <= 12; i$2++) { keyNames[i$2 + 111] = keyNames[i$2 + 63235] = \"F\" + i$2; }\n\n var keyMap = {};\n\n keyMap.basic = {\n \"Left\": \"goCharLeft\", \"Right\": \"goCharRight\", \"Up\": \"goLineUp\", \"Down\": \"goLineDown\",\n \"End\": \"goLineEnd\", \"Home\": \"goLineStartSmart\", \"PageUp\": \"goPageUp\", \"PageDown\": \"goPageDown\",\n \"Delete\": \"delCharAfter\", \"Backspace\": \"delCharBefore\", \"Shift-Backspace\": \"delCharBefore\",\n \"Tab\": \"defaultTab\", \"Shift-Tab\": \"indentAuto\",\n \"Enter\": \"newlineAndIndent\", \"Insert\": \"toggleOverwrite\",\n \"Esc\": \"singleSelection\"\n };\n // Note that the save and find-related commands aren't defined by\n // default. User code or addons can define them. Unknown commands\n // are simply ignored.\n keyMap.pcDefault = {\n \"Ctrl-A\": \"selectAll\", \"Ctrl-D\": \"deleteLine\", \"Ctrl-Z\": \"undo\", \"Shift-Ctrl-Z\": \"redo\", \"Ctrl-Y\": \"redo\",\n \"Ctrl-Home\": \"goDocStart\", \"Ctrl-End\": \"goDocEnd\", \"Ctrl-Up\": \"goLineUp\", \"Ctrl-Down\": \"goLineDown\",\n \"Ctrl-Left\": \"goGroupLeft\", \"Ctrl-Right\": \"goGroupRight\", \"Alt-Left\": \"goLineStart\", \"Alt-Right\": \"goLineEnd\",\n \"Ctrl-Backspace\": \"delGroupBefore\", \"Ctrl-Delete\": \"delGroupAfter\", \"Ctrl-S\": \"save\", \"Ctrl-F\": \"find\",\n \"Ctrl-G\": \"findNext\", \"Shift-Ctrl-G\": \"findPrev\", \"Shift-Ctrl-F\": \"replace\", \"Shift-Ctrl-R\": \"replaceAll\",\n \"Ctrl-[\": \"indentLess\", \"Ctrl-]\": \"indentMore\",\n \"Ctrl-U\": \"undoSelection\", \"Shift-Ctrl-U\": \"redoSelection\", \"Alt-U\": \"redoSelection\",\n \"fallthrough\": \"basic\"\n };\n // Very basic readline/emacs-style bindings, which are standard on Mac.\n keyMap.emacsy = {\n \"Ctrl-F\": \"goCharRight\", \"Ctrl-B\": \"goCharLeft\", \"Ctrl-P\": \"goLineUp\", \"Ctrl-N\": \"goLineDown\",\n \"Alt-F\": \"goWordRight\", \"Alt-B\": \"goWordLeft\", \"Ctrl-A\": \"goLineStart\", \"Ctrl-E\": \"goLineEnd\",\n \"Ctrl-V\": \"goPageDown\", \"Shift-Ctrl-V\": \"goPageUp\", \"Ctrl-D\": \"delCharAfter\", \"Ctrl-H\": \"delCharBefore\",\n \"Alt-D\": \"delWordAfter\", \"Alt-Backspace\": \"delWordBefore\", \"Ctrl-K\": \"killLine\", \"Ctrl-T\": \"transposeChars\",\n \"Ctrl-O\": \"openLine\"\n };\n keyMap.macDefault = {\n \"Cmd-A\": \"selectAll\", \"Cmd-D\": \"deleteLine\", \"Cmd-Z\": \"undo\", \"Shift-Cmd-Z\": \"redo\", \"Cmd-Y\": \"redo\",\n \"Cmd-Home\": \"goDocStart\", \"Cmd-Up\": \"goDocStart\", \"Cmd-End\": \"goDocEnd\", \"Cmd-Down\": \"goDocEnd\", \"Alt-Left\": \"goGroupLeft\",\n \"Alt-Right\": \"goGroupRight\", \"Cmd-Left\": \"goLineLeft\", \"Cmd-Right\": \"goLineRight\", \"Alt-Backspace\": \"delGroupBefore\",\n \"Ctrl-Alt-Backspace\": \"delGroupAfter\", \"Alt-Delete\": \"delGroupAfter\", \"Cmd-S\": \"save\", \"Cmd-F\": \"find\",\n \"Cmd-G\": \"findNext\", \"Shift-Cmd-G\": \"findPrev\", \"Cmd-Alt-F\": \"replace\", \"Shift-Cmd-Alt-F\": \"replaceAll\",\n \"Cmd-[\": \"indentLess\", \"Cmd-]\": \"indentMore\", \"Cmd-Backspace\": \"delWrappedLineLeft\", \"Cmd-Delete\": \"delWrappedLineRight\",\n \"Cmd-U\": \"undoSelection\", \"Shift-Cmd-U\": \"redoSelection\", \"Ctrl-Up\": \"goDocStart\", \"Ctrl-Down\": \"goDocEnd\",\n \"fallthrough\": [\"basic\", \"emacsy\"]\n };\n keyMap[\"default\"] = mac ? keyMap.macDefault : keyMap.pcDefault;\n\n // KEYMAP DISPATCH\n\n function normalizeKeyName(name) {\n var parts = name.split(/-(?!$)/);\n name = parts[parts.length - 1];\n var alt, ctrl, shift, cmd;\n for (var i = 0; i < parts.length - 1; i++) {\n var mod = parts[i];\n if (/^(cmd|meta|m)$/i.test(mod)) { cmd = true; }\n else if (/^a(lt)?$/i.test(mod)) { alt = true; }\n else if (/^(c|ctrl|control)$/i.test(mod)) { ctrl = true; }\n else if (/^s(hift)?$/i.test(mod)) { shift = true; }\n else { throw new Error(\"Unrecognized modifier name: \" + mod) }\n }\n if (alt) { name = \"Alt-\" + name; }\n if (ctrl) { name = \"Ctrl-\" + name; }\n if (cmd) { name = \"Cmd-\" + name; }\n if (shift) { name = \"Shift-\" + name; }\n return name\n }\n\n // This is a kludge to keep keymaps mostly working as raw objects\n // (backwards compatibility) while at the same time support features\n // like normalization and multi-stroke key bindings. It compiles a\n // new normalized keymap, and then updates the old object to reflect\n // this.\n function normalizeKeyMap(keymap) {\n var copy = {};\n for (var keyname in keymap) { if (keymap.hasOwnProperty(keyname)) {\n var value = keymap[keyname];\n if (/^(name|fallthrough|(de|at)tach)$/.test(keyname)) { continue }\n if (value == \"...\") { delete keymap[keyname]; continue }\n\n var keys = map(keyname.split(\" \"), normalizeKeyName);\n for (var i = 0; i < keys.length; i++) {\n var val = (void 0), name = (void 0);\n if (i == keys.length - 1) {\n name = keys.join(\" \");\n val = value;\n } else {\n name = keys.slice(0, i + 1).join(\" \");\n val = \"...\";\n }\n var prev = copy[name];\n if (!prev) { copy[name] = val; }\n else if (prev != val) { throw new Error(\"Inconsistent bindings for \" + name) }\n }\n delete keymap[keyname];\n } }\n for (var prop in copy) { keymap[prop] = copy[prop]; }\n return keymap\n }\n\n function lookupKey(key, map$$1, handle, context) {\n map$$1 = getKeyMap(map$$1);\n var found = map$$1.call ? map$$1.call(key, context) : map$$1[key];\n if (found === false) { return \"nothing\" }\n if (found === \"...\") { return \"multi\" }\n if (found != null && handle(found)) { return \"handled\" }\n\n if (map$$1.fallthrough) {\n if (Object.prototype.toString.call(map$$1.fallthrough) != \"[object Array]\")\n { return lookupKey(key, map$$1.fallthrough, handle, context) }\n for (var i = 0; i < map$$1.fallthrough.length; i++) {\n var result = lookupKey(key, map$$1.fallthrough[i], handle, context);\n if (result) { return result }\n }\n }\n }\n\n // Modifier key presses don't count as 'real' key presses for the\n // purpose of keymap fallthrough.\n function isModifierKey(value) {\n var name = typeof value == \"string\" ? value : keyNames[value.keyCode];\n return name == \"Ctrl\" || name == \"Alt\" || name == \"Shift\" || name == \"Mod\"\n }\n\n function addModifierNames(name, event, noShift) {\n var base = name;\n if (event.altKey && base != \"Alt\") { name = \"Alt-\" + name; }\n if ((flipCtrlCmd ? event.metaKey : event.ctrlKey) && base != \"Ctrl\") { name = \"Ctrl-\" + name; }\n if ((flipCtrlCmd ? event.ctrlKey : event.metaKey) && base != \"Cmd\") { name = \"Cmd-\" + name; }\n if (!noShift && event.shiftKey && base != \"Shift\") { name = \"Shift-\" + name; }\n return name\n }\n\n // Look up the name of a key as indicated by an event object.\n function keyName(event, noShift) {\n if (presto && event.keyCode == 34 && event[\"char\"]) { return false }\n var name = keyNames[event.keyCode];\n if (name == null || event.altGraphKey) { return false }\n // Ctrl-ScrollLock has keyCode 3, same as Ctrl-Pause,\n // so we'll use event.code when available (Chrome 48+, FF 38+, Safari 10.1+)\n if (event.keyCode == 3 && event.code) { name = event.code; }\n return addModifierNames(name, event, noShift)\n }\n\n function getKeyMap(val) {\n return typeof val == \"string\" ? keyMap[val] : val\n }\n\n // Helper for deleting text near the selection(s), used to implement\n // backspace, delete, and similar functionality.\n function deleteNearSelection(cm, compute) {\n var ranges = cm.doc.sel.ranges, kill = [];\n // Build up a set of ranges to kill first, merging overlapping\n // ranges.\n for (var i = 0; i < ranges.length; i++) {\n var toKill = compute(ranges[i]);\n while (kill.length && cmp(toKill.from, lst(kill).to) <= 0) {\n var replaced = kill.pop();\n if (cmp(replaced.from, toKill.from) < 0) {\n toKill.from = replaced.from;\n break\n }\n }\n kill.push(toKill);\n }\n // Next, remove those actual ranges.\n runInOp(cm, function () {\n for (var i = kill.length - 1; i >= 0; i--)\n { replaceRange(cm.doc, \"\", kill[i].from, kill[i].to, \"+delete\"); }\n ensureCursorVisible(cm);\n });\n }\n\n function moveCharLogically(line, ch, dir) {\n var target = skipExtendingChars(line.text, ch + dir, dir);\n return target < 0 || target > line.text.length ? null : target\n }\n\n function moveLogically(line, start, dir) {\n var ch = moveCharLogically(line, start.ch, dir);\n return ch == null ? null : new Pos(start.line, ch, dir < 0 ? \"after\" : \"before\")\n }\n\n function endOfLine(visually, cm, lineObj, lineNo, dir) {\n if (visually) {\n var order = getOrder(lineObj, cm.doc.direction);\n if (order) {\n var part = dir < 0 ? lst(order) : order[0];\n var moveInStorageOrder = (dir < 0) == (part.level == 1);\n var sticky = moveInStorageOrder ? \"after\" : \"before\";\n var ch;\n // With a wrapped rtl chunk (possibly spanning multiple bidi parts),\n // it could be that the last bidi part is not on the last visual line,\n // since visual lines contain content order-consecutive chunks.\n // Thus, in rtl, we are looking for the first (content-order) character\n // in the rtl chunk that is on the last line (that is, the same line\n // as the last (content-order) character).\n if (part.level > 0 || cm.doc.direction == \"rtl\") {\n var prep = prepareMeasureForLine(cm, lineObj);\n ch = dir < 0 ? lineObj.text.length - 1 : 0;\n var targetTop = measureCharPrepared(cm, prep, ch).top;\n ch = findFirst(function (ch) { return measureCharPrepared(cm, prep, ch).top == targetTop; }, (dir < 0) == (part.level == 1) ? part.from : part.to - 1, ch);\n if (sticky == \"before\") { ch = moveCharLogically(lineObj, ch, 1); }\n } else { ch = dir < 0 ? part.to : part.from; }\n return new Pos(lineNo, ch, sticky)\n }\n }\n return new Pos(lineNo, dir < 0 ? lineObj.text.length : 0, dir < 0 ? \"before\" : \"after\")\n }\n\n function moveVisually(cm, line, start, dir) {\n var bidi = getOrder(line, cm.doc.direction);\n if (!bidi) { return moveLogically(line, start, dir) }\n if (start.ch >= line.text.length) {\n start.ch = line.text.length;\n start.sticky = \"before\";\n } else if (start.ch <= 0) {\n start.ch = 0;\n start.sticky = \"after\";\n }\n var partPos = getBidiPartAt(bidi, start.ch, start.sticky), part = bidi[partPos];\n if (cm.doc.direction == \"ltr\" && part.level % 2 == 0 && (dir > 0 ? part.to > start.ch : part.from < start.ch)) {\n // Case 1: We move within an ltr part in an ltr editor. Even with wrapped lines,\n // nothing interesting happens.\n return moveLogically(line, start, dir)\n }\n\n var mv = function (pos, dir) { return moveCharLogically(line, pos instanceof Pos ? pos.ch : pos, dir); };\n var prep;\n var getWrappedLineExtent = function (ch) {\n if (!cm.options.lineWrapping) { return {begin: 0, end: line.text.length} }\n prep = prep || prepareMeasureForLine(cm, line);\n return wrappedLineExtentChar(cm, line, prep, ch)\n };\n var wrappedLineExtent = getWrappedLineExtent(start.sticky == \"before\" ? mv(start, -1) : start.ch);\n\n if (cm.doc.direction == \"rtl\" || part.level == 1) {\n var moveInStorageOrder = (part.level == 1) == (dir < 0);\n var ch = mv(start, moveInStorageOrder ? 1 : -1);\n if (ch != null && (!moveInStorageOrder ? ch >= part.from && ch >= wrappedLineExtent.begin : ch <= part.to && ch <= wrappedLineExtent.end)) {\n // Case 2: We move within an rtl part or in an rtl editor on the same visual line\n var sticky = moveInStorageOrder ? \"before\" : \"after\";\n return new Pos(start.line, ch, sticky)\n }\n }\n\n // Case 3: Could not move within this bidi part in this visual line, so leave\n // the current bidi part\n\n var searchInVisualLine = function (partPos, dir, wrappedLineExtent) {\n var getRes = function (ch, moveInStorageOrder) { return moveInStorageOrder\n ? new Pos(start.line, mv(ch, 1), \"before\")\n : new Pos(start.line, ch, \"after\"); };\n\n for (; partPos >= 0 && partPos < bidi.length; partPos += dir) {\n var part = bidi[partPos];\n var moveInStorageOrder = (dir > 0) == (part.level != 1);\n var ch = moveInStorageOrder ? wrappedLineExtent.begin : mv(wrappedLineExtent.end, -1);\n if (part.from <= ch && ch < part.to) { return getRes(ch, moveInStorageOrder) }\n ch = moveInStorageOrder ? part.from : mv(part.to, -1);\n if (wrappedLineExtent.begin <= ch && ch < wrappedLineExtent.end) { return getRes(ch, moveInStorageOrder) }\n }\n };\n\n // Case 3a: Look for other bidi parts on the same visual line\n var res = searchInVisualLine(partPos + dir, dir, wrappedLineExtent);\n if (res) { return res }\n\n // Case 3b: Look for other bidi parts on the next visual line\n var nextCh = dir > 0 ? wrappedLineExtent.end : mv(wrappedLineExtent.begin, -1);\n if (nextCh != null && !(dir > 0 && nextCh == line.text.length)) {\n res = searchInVisualLine(dir > 0 ? 0 : bidi.length - 1, dir, getWrappedLineExtent(nextCh));\n if (res) { return res }\n }\n\n // Case 4: Nowhere to move\n return null\n }\n\n // Commands are parameter-less actions that can be performed on an\n // editor, mostly used for keybindings.\n var commands = {\n selectAll: selectAll,\n singleSelection: function (cm) { return cm.setSelection(cm.getCursor(\"anchor\"), cm.getCursor(\"head\"), sel_dontScroll); },\n killLine: function (cm) { return deleteNearSelection(cm, function (range) {\n if (range.empty()) {\n var len = getLine(cm.doc, range.head.line).text.length;\n if (range.head.ch == len && range.head.line < cm.lastLine())\n { return {from: range.head, to: Pos(range.head.line + 1, 0)} }\n else\n { return {from: range.head, to: Pos(range.head.line, len)} }\n } else {\n return {from: range.from(), to: range.to()}\n }\n }); },\n deleteLine: function (cm) { return deleteNearSelection(cm, function (range) { return ({\n from: Pos(range.from().line, 0),\n to: clipPos(cm.doc, Pos(range.to().line + 1, 0))\n }); }); },\n delLineLeft: function (cm) { return deleteNearSelection(cm, function (range) { return ({\n from: Pos(range.from().line, 0), to: range.from()\n }); }); },\n delWrappedLineLeft: function (cm) { return deleteNearSelection(cm, function (range) {\n var top = cm.charCoords(range.head, \"div\").top + 5;\n var leftPos = cm.coordsChar({left: 0, top: top}, \"div\");\n return {from: leftPos, to: range.from()}\n }); },\n delWrappedLineRight: function (cm) { return deleteNearSelection(cm, function (range) {\n var top = cm.charCoords(range.head, \"div\").top + 5;\n var rightPos = cm.coordsChar({left: cm.display.lineDiv.offsetWidth + 100, top: top}, \"div\");\n return {from: range.from(), to: rightPos }\n }); },\n undo: function (cm) { return cm.undo(); },\n redo: function (cm) { return cm.redo(); },\n undoSelection: function (cm) { return cm.undoSelection(); },\n redoSelection: function (cm) { return cm.redoSelection(); },\n goDocStart: function (cm) { return cm.extendSelection(Pos(cm.firstLine(), 0)); },\n goDocEnd: function (cm) { return cm.extendSelection(Pos(cm.lastLine())); },\n goLineStart: function (cm) { return cm.extendSelectionsBy(function (range) { return lineStart(cm, range.head.line); },\n {origin: \"+move\", bias: 1}\n ); },\n goLineStartSmart: function (cm) { return cm.extendSelectionsBy(function (range) { return lineStartSmart(cm, range.head); },\n {origin: \"+move\", bias: 1}\n ); },\n goLineEnd: function (cm) { return cm.extendSelectionsBy(function (range) { return lineEnd(cm, range.head.line); },\n {origin: \"+move\", bias: -1}\n ); },\n goLineRight: function (cm) { return cm.extendSelectionsBy(function (range) {\n var top = cm.cursorCoords(range.head, \"div\").top + 5;\n return cm.coordsChar({left: cm.display.lineDiv.offsetWidth + 100, top: top}, \"div\")\n }, sel_move); },\n goLineLeft: function (cm) { return cm.extendSelectionsBy(function (range) {\n var top = cm.cursorCoords(range.head, \"div\").top + 5;\n return cm.coordsChar({left: 0, top: top}, \"div\")\n }, sel_move); },\n goLineLeftSmart: function (cm) { return cm.extendSelectionsBy(function (range) {\n var top = cm.cursorCoords(range.head, \"div\").top + 5;\n var pos = cm.coordsChar({left: 0, top: top}, \"div\");\n if (pos.ch < cm.getLine(pos.line).search(/\\S/)) { return lineStartSmart(cm, range.head) }\n return pos\n }, sel_move); },\n goLineUp: function (cm) { return cm.moveV(-1, \"line\"); },\n goLineDown: function (cm) { return cm.moveV(1, \"line\"); },\n goPageUp: function (cm) { return cm.moveV(-1, \"page\"); },\n goPageDown: function (cm) { return cm.moveV(1, \"page\"); },\n goCharLeft: function (cm) { return cm.moveH(-1, \"char\"); },\n goCharRight: function (cm) { return cm.moveH(1, \"char\"); },\n goColumnLeft: function (cm) { return cm.moveH(-1, \"column\"); },\n goColumnRight: function (cm) { return cm.moveH(1, \"column\"); },\n goWordLeft: function (cm) { return cm.moveH(-1, \"word\"); },\n goGroupRight: function (cm) { return cm.moveH(1, \"group\"); },\n goGroupLeft: function (cm) { return cm.moveH(-1, \"group\"); },\n goWordRight: function (cm) { return cm.moveH(1, \"word\"); },\n delCharBefore: function (cm) { return cm.deleteH(-1, \"char\"); },\n delCharAfter: function (cm) { return cm.deleteH(1, \"char\"); },\n delWordBefore: function (cm) { return cm.deleteH(-1, \"word\"); },\n delWordAfter: function (cm) { return cm.deleteH(1, \"word\"); },\n delGroupBefore: function (cm) { return cm.deleteH(-1, \"group\"); },\n delGroupAfter: function (cm) { return cm.deleteH(1, \"group\"); },\n indentAuto: function (cm) { return cm.indentSelection(\"smart\"); },\n indentMore: function (cm) { return cm.indentSelection(\"add\"); },\n indentLess: function (cm) { return cm.indentSelection(\"subtract\"); },\n insertTab: function (cm) { return cm.replaceSelection(\"\\t\"); },\n insertSoftTab: function (cm) {\n var spaces = [], ranges = cm.listSelections(), tabSize = cm.options.tabSize;\n for (var i = 0; i < ranges.length; i++) {\n var pos = ranges[i].from();\n var col = countColumn(cm.getLine(pos.line), pos.ch, tabSize);\n spaces.push(spaceStr(tabSize - col % tabSize));\n }\n cm.replaceSelections(spaces);\n },\n defaultTab: function (cm) {\n if (cm.somethingSelected()) { cm.indentSelection(\"add\"); }\n else { cm.execCommand(\"insertTab\"); }\n },\n // Swap the two chars left and right of each selection's head.\n // Move cursor behind the two swapped characters afterwards.\n //\n // Doesn't consider line feeds a character.\n // Doesn't scan more than one line above to find a character.\n // Doesn't do anything on an empty line.\n // Doesn't do anything with non-empty selections.\n transposeChars: function (cm) { return runInOp(cm, function () {\n var ranges = cm.listSelections(), newSel = [];\n for (var i = 0; i < ranges.length; i++) {\n if (!ranges[i].empty()) { continue }\n var cur = ranges[i].head, line = getLine(cm.doc, cur.line).text;\n if (line) {\n if (cur.ch == line.length) { cur = new Pos(cur.line, cur.ch - 1); }\n if (cur.ch > 0) {\n cur = new Pos(cur.line, cur.ch + 1);\n cm.replaceRange(line.charAt(cur.ch - 1) + line.charAt(cur.ch - 2),\n Pos(cur.line, cur.ch - 2), cur, \"+transpose\");\n } else if (cur.line > cm.doc.first) {\n var prev = getLine(cm.doc, cur.line - 1).text;\n if (prev) {\n cur = new Pos(cur.line, 1);\n cm.replaceRange(line.charAt(0) + cm.doc.lineSeparator() +\n prev.charAt(prev.length - 1),\n Pos(cur.line - 1, prev.length - 1), cur, \"+transpose\");\n }\n }\n }\n newSel.push(new Range(cur, cur));\n }\n cm.setSelections(newSel);\n }); },\n newlineAndIndent: function (cm) { return runInOp(cm, function () {\n var sels = cm.listSelections();\n for (var i = sels.length - 1; i >= 0; i--)\n { cm.replaceRange(cm.doc.lineSeparator(), sels[i].anchor, sels[i].head, \"+input\"); }\n sels = cm.listSelections();\n for (var i$1 = 0; i$1 < sels.length; i$1++)\n { cm.indentLine(sels[i$1].from().line, null, true); }\n ensureCursorVisible(cm);\n }); },\n openLine: function (cm) { return cm.replaceSelection(\"\\n\", \"start\"); },\n toggleOverwrite: function (cm) { return cm.toggleOverwrite(); }\n };\n\n\n function lineStart(cm, lineN) {\n var line = getLine(cm.doc, lineN);\n var visual = visualLine(line);\n if (visual != line) { lineN = lineNo(visual); }\n return endOfLine(true, cm, visual, lineN, 1)\n }\n function lineEnd(cm, lineN) {\n var line = getLine(cm.doc, lineN);\n var visual = visualLineEnd(line);\n if (visual != line) { lineN = lineNo(visual); }\n return endOfLine(true, cm, line, lineN, -1)\n }\n function lineStartSmart(cm, pos) {\n var start = lineStart(cm, pos.line);\n var line = getLine(cm.doc, start.line);\n var order = getOrder(line, cm.doc.direction);\n if (!order || order[0].level == 0) {\n var firstNonWS = Math.max(0, line.text.search(/\\S/));\n var inWS = pos.line == start.line && pos.ch <= firstNonWS && pos.ch;\n return Pos(start.line, inWS ? 0 : firstNonWS, start.sticky)\n }\n return start\n }\n\n // Run a handler that was bound to a key.\n function doHandleBinding(cm, bound, dropShift) {\n if (typeof bound == \"string\") {\n bound = commands[bound];\n if (!bound) { return false }\n }\n // Ensure previous input has been read, so that the handler sees a\n // consistent view of the document\n cm.display.input.ensurePolled();\n var prevShift = cm.display.shift, done = false;\n try {\n if (cm.isReadOnly()) { cm.state.suppressEdits = true; }\n if (dropShift) { cm.display.shift = false; }\n done = bound(cm) != Pass;\n } finally {\n cm.display.shift = prevShift;\n cm.state.suppressEdits = false;\n }\n return done\n }\n\n function lookupKeyForEditor(cm, name, handle) {\n for (var i = 0; i < cm.state.keyMaps.length; i++) {\n var result = lookupKey(name, cm.state.keyMaps[i], handle, cm);\n if (result) { return result }\n }\n return (cm.options.extraKeys && lookupKey(name, cm.options.extraKeys, handle, cm))\n || lookupKey(name, cm.options.keyMap, handle, cm)\n }\n\n // Note that, despite the name, this function is also used to check\n // for bound mouse clicks.\n\n var stopSeq = new Delayed;\n\n function dispatchKey(cm, name, e, handle) {\n var seq = cm.state.keySeq;\n if (seq) {\n if (isModifierKey(name)) { return \"handled\" }\n if (/\\'$/.test(name))\n { cm.state.keySeq = null; }\n else\n { stopSeq.set(50, function () {\n if (cm.state.keySeq == seq) {\n cm.state.keySeq = null;\n cm.display.input.reset();\n }\n }); }\n if (dispatchKeyInner(cm, seq + \" \" + name, e, handle)) { return true }\n }\n return dispatchKeyInner(cm, name, e, handle)\n }\n\n function dispatchKeyInner(cm, name, e, handle) {\n var result = lookupKeyForEditor(cm, name, handle);\n\n if (result == \"multi\")\n { cm.state.keySeq = name; }\n if (result == \"handled\")\n { signalLater(cm, \"keyHandled\", cm, name, e); }\n\n if (result == \"handled\" || result == \"multi\") {\n e_preventDefault(e);\n restartBlink(cm);\n }\n\n return !!result\n }\n\n // Handle a key from the keydown event.\n function handleKeyBinding(cm, e) {\n var name = keyName(e, true);\n if (!name) { return false }\n\n if (e.shiftKey && !cm.state.keySeq) {\n // First try to resolve full name (including 'Shift-'). Failing\n // that, see if there is a cursor-motion command (starting with\n // 'go') bound to the keyname without 'Shift-'.\n return dispatchKey(cm, \"Shift-\" + name, e, function (b) { return doHandleBinding(cm, b, true); })\n || dispatchKey(cm, name, e, function (b) {\n if (typeof b == \"string\" ? /^go[A-Z]/.test(b) : b.motion)\n { return doHandleBinding(cm, b) }\n })\n } else {\n return dispatchKey(cm, name, e, function (b) { return doHandleBinding(cm, b); })\n }\n }\n\n // Handle a key from the keypress event\n function handleCharBinding(cm, e, ch) {\n return dispatchKey(cm, \"'\" + ch + \"'\", e, function (b) { return doHandleBinding(cm, b, true); })\n }\n\n var lastStoppedKey = null;\n function onKeyDown(e) {\n var cm = this;\n cm.curOp.focus = activeElt();\n if (signalDOMEvent(cm, e)) { return }\n // IE does strange things with escape.\n if (ie && ie_version < 11 && e.keyCode == 27) { e.returnValue = false; }\n var code = e.keyCode;\n cm.display.shift = code == 16 || e.shiftKey;\n var handled = handleKeyBinding(cm, e);\n if (presto) {\n lastStoppedKey = handled ? code : null;\n // Opera has no cut event... we try to at least catch the key combo\n if (!handled && code == 88 && !hasCopyEvent && (mac ? e.metaKey : e.ctrlKey))\n { cm.replaceSelection(\"\", null, \"cut\"); }\n }\n\n // Turn mouse into crosshair when Alt is held on Mac.\n if (code == 18 && !/\\bCodeMirror-crosshair\\b/.test(cm.display.lineDiv.className))\n { showCrossHair(cm); }\n }\n\n function showCrossHair(cm) {\n var lineDiv = cm.display.lineDiv;\n addClass(lineDiv, \"CodeMirror-crosshair\");\n\n function up(e) {\n if (e.keyCode == 18 || !e.altKey) {\n rmClass(lineDiv, \"CodeMirror-crosshair\");\n off(document, \"keyup\", up);\n off(document, \"mouseover\", up);\n }\n }\n on(document, \"keyup\", up);\n on(document, \"mouseover\", up);\n }\n\n function onKeyUp(e) {\n if (e.keyCode == 16) { this.doc.sel.shift = false; }\n signalDOMEvent(this, e);\n }\n\n function onKeyPress(e) {\n var cm = this;\n if (eventInWidget(cm.display, e) || signalDOMEvent(cm, e) || e.ctrlKey && !e.altKey || mac && e.metaKey) { return }\n var keyCode = e.keyCode, charCode = e.charCode;\n if (presto && keyCode == lastStoppedKey) {lastStoppedKey = null; e_preventDefault(e); return}\n if ((presto && (!e.which || e.which < 10)) && handleKeyBinding(cm, e)) { return }\n var ch = String.fromCharCode(charCode == null ? keyCode : charCode);\n // Some browsers fire keypress events for backspace\n if (ch == \"\\x08\") { return }\n if (handleCharBinding(cm, e, ch)) { return }\n cm.display.input.onKeyPress(e);\n }\n\n var DOUBLECLICK_DELAY = 400;\n\n var PastClick = function(time, pos, button) {\n this.time = time;\n this.pos = pos;\n this.button = button;\n };\n\n PastClick.prototype.compare = function (time, pos, button) {\n return this.time + DOUBLECLICK_DELAY > time &&\n cmp(pos, this.pos) == 0 && button == this.button\n };\n\n var lastClick, lastDoubleClick;\n function clickRepeat(pos, button) {\n var now = +new Date;\n if (lastDoubleClick && lastDoubleClick.compare(now, pos, button)) {\n lastClick = lastDoubleClick = null;\n return \"triple\"\n } else if (lastClick && lastClick.compare(now, pos, button)) {\n lastDoubleClick = new PastClick(now, pos, button);\n lastClick = null;\n return \"double\"\n } else {\n lastClick = new PastClick(now, pos, button);\n lastDoubleClick = null;\n return \"single\"\n }\n }\n\n // A mouse down can be a single click, double click, triple click,\n // start of selection drag, start of text drag, new cursor\n // (ctrl-click), rectangle drag (alt-drag), or xwin\n // middle-click-paste. Or it might be a click on something we should\n // not interfere with, such as a scrollbar or widget.\n function onMouseDown(e) {\n var cm = this, display = cm.display;\n if (signalDOMEvent(cm, e) || display.activeTouch && display.input.supportsTouch()) { return }\n display.input.ensurePolled();\n display.shift = e.shiftKey;\n\n if (eventInWidget(display, e)) {\n if (!webkit) {\n // Briefly turn off draggability, to allow widgets to do\n // normal dragging things.\n display.scroller.draggable = false;\n setTimeout(function () { return display.scroller.draggable = true; }, 100);\n }\n return\n }\n if (clickInGutter(cm, e)) { return }\n var pos = posFromMouse(cm, e), button = e_button(e), repeat = pos ? clickRepeat(pos, button) : \"single\";\n window.focus();\n\n // #3261: make sure, that we're not starting a second selection\n if (button == 1 && cm.state.selectingText)\n { cm.state.selectingText(e); }\n\n if (pos && handleMappedButton(cm, button, pos, repeat, e)) { return }\n\n if (button == 1) {\n if (pos) { leftButtonDown(cm, pos, repeat, e); }\n else if (e_target(e) == display.scroller) { e_preventDefault(e); }\n } else if (button == 2) {\n if (pos) { extendSelection(cm.doc, pos); }\n setTimeout(function () { return display.input.focus(); }, 20);\n } else if (button == 3) {\n if (captureRightClick) { cm.display.input.onContextMenu(e); }\n else { delayBlurEvent(cm); }\n }\n }\n\n function handleMappedButton(cm, button, pos, repeat, event) {\n var name = \"Click\";\n if (repeat == \"double\") { name = \"Double\" + name; }\n else if (repeat == \"triple\") { name = \"Triple\" + name; }\n name = (button == 1 ? \"Left\" : button == 2 ? \"Middle\" : \"Right\") + name;\n\n return dispatchKey(cm, addModifierNames(name, event), event, function (bound) {\n if (typeof bound == \"string\") { bound = commands[bound]; }\n if (!bound) { return false }\n var done = false;\n try {\n if (cm.isReadOnly()) { cm.state.suppressEdits = true; }\n done = bound(cm, pos) != Pass;\n } finally {\n cm.state.suppressEdits = false;\n }\n return done\n })\n }\n\n function configureMouse(cm, repeat, event) {\n var option = cm.getOption(\"configureMouse\");\n var value = option ? option(cm, repeat, event) : {};\n if (value.unit == null) {\n var rect = chromeOS ? event.shiftKey && event.metaKey : event.altKey;\n value.unit = rect ? \"rectangle\" : repeat == \"single\" ? \"char\" : repeat == \"double\" ? \"word\" : \"line\";\n }\n if (value.extend == null || cm.doc.extend) { value.extend = cm.doc.extend || event.shiftKey; }\n if (value.addNew == null) { value.addNew = mac ? event.metaKey : event.ctrlKey; }\n if (value.moveOnDrag == null) { value.moveOnDrag = !(mac ? event.altKey : event.ctrlKey); }\n return value\n }\n\n function leftButtonDown(cm, pos, repeat, event) {\n if (ie) { setTimeout(bind(ensureFocus, cm), 0); }\n else { cm.curOp.focus = activeElt(); }\n\n var behavior = configureMouse(cm, repeat, event);\n\n var sel = cm.doc.sel, contained;\n if (cm.options.dragDrop && dragAndDrop && !cm.isReadOnly() &&\n repeat == \"single\" && (contained = sel.contains(pos)) > -1 &&\n (cmp((contained = sel.ranges[contained]).from(), pos) < 0 || pos.xRel > 0) &&\n (cmp(contained.to(), pos) > 0 || pos.xRel < 0))\n { leftButtonStartDrag(cm, event, pos, behavior); }\n else\n { leftButtonSelect(cm, event, pos, behavior); }\n }\n\n // Start a text drag. When it ends, see if any dragging actually\n // happen, and treat as a click if it didn't.\n function leftButtonStartDrag(cm, event, pos, behavior) {\n var display = cm.display, moved = false;\n var dragEnd = operation(cm, function (e) {\n if (webkit) { display.scroller.draggable = false; }\n cm.state.draggingText = false;\n off(display.wrapper.ownerDocument, \"mouseup\", dragEnd);\n off(display.wrapper.ownerDocument, \"mousemove\", mouseMove);\n off(display.scroller, \"dragstart\", dragStart);\n off(display.scroller, \"drop\", dragEnd);\n if (!moved) {\n e_preventDefault(e);\n if (!behavior.addNew)\n { extendSelection(cm.doc, pos, null, null, behavior.extend); }\n // Work around unexplainable focus problem in IE9 (#2127) and Chrome (#3081)\n if (webkit || ie && ie_version == 9)\n { setTimeout(function () {display.wrapper.ownerDocument.body.focus(); display.input.focus();}, 20); }\n else\n { display.input.focus(); }\n }\n });\n var mouseMove = function(e2) {\n moved = moved || Math.abs(event.clientX - e2.clientX) + Math.abs(event.clientY - e2.clientY) >= 10;\n };\n var dragStart = function () { return moved = true; };\n // Let the drag handler handle this.\n if (webkit) { display.scroller.draggable = true; }\n cm.state.draggingText = dragEnd;\n dragEnd.copy = !behavior.moveOnDrag;\n // IE's approach to draggable\n if (display.scroller.dragDrop) { display.scroller.dragDrop(); }\n on(display.wrapper.ownerDocument, \"mouseup\", dragEnd);\n on(display.wrapper.ownerDocument, \"mousemove\", mouseMove);\n on(display.scroller, \"dragstart\", dragStart);\n on(display.scroller, \"drop\", dragEnd);\n\n delayBlurEvent(cm);\n setTimeout(function () { return display.input.focus(); }, 20);\n }\n\n function rangeForUnit(cm, pos, unit) {\n if (unit == \"char\") { return new Range(pos, pos) }\n if (unit == \"word\") { return cm.findWordAt(pos) }\n if (unit == \"line\") { return new Range(Pos(pos.line, 0), clipPos(cm.doc, Pos(pos.line + 1, 0))) }\n var result = unit(cm, pos);\n return new Range(result.from, result.to)\n }\n\n // Normal selection, as opposed to text dragging.\n function leftButtonSelect(cm, event, start, behavior) {\n var display = cm.display, doc = cm.doc;\n e_preventDefault(event);\n\n var ourRange, ourIndex, startSel = doc.sel, ranges = startSel.ranges;\n if (behavior.addNew && !behavior.extend) {\n ourIndex = doc.sel.contains(start);\n if (ourIndex > -1)\n { ourRange = ranges[ourIndex]; }\n else\n { ourRange = new Range(start, start); }\n } else {\n ourRange = doc.sel.primary();\n ourIndex = doc.sel.primIndex;\n }\n\n if (behavior.unit == \"rectangle\") {\n if (!behavior.addNew) { ourRange = new Range(start, start); }\n start = posFromMouse(cm, event, true, true);\n ourIndex = -1;\n } else {\n var range$$1 = rangeForUnit(cm, start, behavior.unit);\n if (behavior.extend)\n { ourRange = extendRange(ourRange, range$$1.anchor, range$$1.head, behavior.extend); }\n else\n { ourRange = range$$1; }\n }\n\n if (!behavior.addNew) {\n ourIndex = 0;\n setSelection(doc, new Selection([ourRange], 0), sel_mouse);\n startSel = doc.sel;\n } else if (ourIndex == -1) {\n ourIndex = ranges.length;\n setSelection(doc, normalizeSelection(cm, ranges.concat([ourRange]), ourIndex),\n {scroll: false, origin: \"*mouse\"});\n } else if (ranges.length > 1 && ranges[ourIndex].empty() && behavior.unit == \"char\" && !behavior.extend) {\n setSelection(doc, normalizeSelection(cm, ranges.slice(0, ourIndex).concat(ranges.slice(ourIndex + 1)), 0),\n {scroll: false, origin: \"*mouse\"});\n startSel = doc.sel;\n } else {\n replaceOneSelection(doc, ourIndex, ourRange, sel_mouse);\n }\n\n var lastPos = start;\n function extendTo(pos) {\n if (cmp(lastPos, pos) == 0) { return }\n lastPos = pos;\n\n if (behavior.unit == \"rectangle\") {\n var ranges = [], tabSize = cm.options.tabSize;\n var startCol = countColumn(getLine(doc, start.line).text, start.ch, tabSize);\n var posCol = countColumn(getLine(doc, pos.line).text, pos.ch, tabSize);\n var left = Math.min(startCol, posCol), right = Math.max(startCol, posCol);\n for (var line = Math.min(start.line, pos.line), end = Math.min(cm.lastLine(), Math.max(start.line, pos.line));\n line <= end; line++) {\n var text = getLine(doc, line).text, leftPos = findColumn(text, left, tabSize);\n if (left == right)\n { ranges.push(new Range(Pos(line, leftPos), Pos(line, leftPos))); }\n else if (text.length > leftPos)\n { ranges.push(new Range(Pos(line, leftPos), Pos(line, findColumn(text, right, tabSize)))); }\n }\n if (!ranges.length) { ranges.push(new Range(start, start)); }\n setSelection(doc, normalizeSelection(cm, startSel.ranges.slice(0, ourIndex).concat(ranges), ourIndex),\n {origin: \"*mouse\", scroll: false});\n cm.scrollIntoView(pos);\n } else {\n var oldRange = ourRange;\n var range$$1 = rangeForUnit(cm, pos, behavior.unit);\n var anchor = oldRange.anchor, head;\n if (cmp(range$$1.anchor, anchor) > 0) {\n head = range$$1.head;\n anchor = minPos(oldRange.from(), range$$1.anchor);\n } else {\n head = range$$1.anchor;\n anchor = maxPos(oldRange.to(), range$$1.head);\n }\n var ranges$1 = startSel.ranges.slice(0);\n ranges$1[ourIndex] = bidiSimplify(cm, new Range(clipPos(doc, anchor), head));\n setSelection(doc, normalizeSelection(cm, ranges$1, ourIndex), sel_mouse);\n }\n }\n\n var editorSize = display.wrapper.getBoundingClientRect();\n // Used to ensure timeout re-tries don't fire when another extend\n // happened in the meantime (clearTimeout isn't reliable -- at\n // least on Chrome, the timeouts still happen even when cleared,\n // if the clear happens after their scheduled firing time).\n var counter = 0;\n\n function extend(e) {\n var curCount = ++counter;\n var cur = posFromMouse(cm, e, true, behavior.unit == \"rectangle\");\n if (!cur) { return }\n if (cmp(cur, lastPos) != 0) {\n cm.curOp.focus = activeElt();\n extendTo(cur);\n var visible = visibleLines(display, doc);\n if (cur.line >= visible.to || cur.line < visible.from)\n { setTimeout(operation(cm, function () {if (counter == curCount) { extend(e); }}), 150); }\n } else {\n var outside = e.clientY < editorSize.top ? -20 : e.clientY > editorSize.bottom ? 20 : 0;\n if (outside) { setTimeout(operation(cm, function () {\n if (counter != curCount) { return }\n display.scroller.scrollTop += outside;\n extend(e);\n }), 50); }\n }\n }\n\n function done(e) {\n cm.state.selectingText = false;\n counter = Infinity;\n // If e is null or undefined we interpret this as someone trying\n // to explicitly cancel the selection rather than the user\n // letting go of the mouse button.\n if (e) {\n e_preventDefault(e);\n display.input.focus();\n }\n off(display.wrapper.ownerDocument, \"mousemove\", move);\n off(display.wrapper.ownerDocument, \"mouseup\", up);\n doc.history.lastSelOrigin = null;\n }\n\n var move = operation(cm, function (e) {\n if (e.buttons === 0 || !e_button(e)) { done(e); }\n else { extend(e); }\n });\n var up = operation(cm, done);\n cm.state.selectingText = up;\n on(display.wrapper.ownerDocument, \"mousemove\", move);\n on(display.wrapper.ownerDocument, \"mouseup\", up);\n }\n\n // Used when mouse-selecting to adjust the anchor to the proper side\n // of a bidi jump depending on the visual position of the head.\n function bidiSimplify(cm, range$$1) {\n var anchor = range$$1.anchor;\n var head = range$$1.head;\n var anchorLine = getLine(cm.doc, anchor.line);\n if (cmp(anchor, head) == 0 && anchor.sticky == head.sticky) { return range$$1 }\n var order = getOrder(anchorLine);\n if (!order) { return range$$1 }\n var index = getBidiPartAt(order, anchor.ch, anchor.sticky), part = order[index];\n if (part.from != anchor.ch && part.to != anchor.ch) { return range$$1 }\n var boundary = index + ((part.from == anchor.ch) == (part.level != 1) ? 0 : 1);\n if (boundary == 0 || boundary == order.length) { return range$$1 }\n\n // Compute the relative visual position of the head compared to the\n // anchor (<0 is to the left, >0 to the right)\n var leftSide;\n if (head.line != anchor.line) {\n leftSide = (head.line - anchor.line) * (cm.doc.direction == \"ltr\" ? 1 : -1) > 0;\n } else {\n var headIndex = getBidiPartAt(order, head.ch, head.sticky);\n var dir = headIndex - index || (head.ch - anchor.ch) * (part.level == 1 ? -1 : 1);\n if (headIndex == boundary - 1 || headIndex == boundary)\n { leftSide = dir < 0; }\n else\n { leftSide = dir > 0; }\n }\n\n var usePart = order[boundary + (leftSide ? -1 : 0)];\n var from = leftSide == (usePart.level == 1);\n var ch = from ? usePart.from : usePart.to, sticky = from ? \"after\" : \"before\";\n return anchor.ch == ch && anchor.sticky == sticky ? range$$1 : new Range(new Pos(anchor.line, ch, sticky), head)\n }\n\n\n // Determines whether an event happened in the gutter, and fires the\n // handlers for the corresponding event.\n function gutterEvent(cm, e, type, prevent) {\n var mX, mY;\n if (e.touches) {\n mX = e.touches[0].clientX;\n mY = e.touches[0].clientY;\n } else {\n try { mX = e.clientX; mY = e.clientY; }\n catch(e) { return false }\n }\n if (mX >= Math.floor(cm.display.gutters.getBoundingClientRect().right)) { return false }\n if (prevent) { e_preventDefault(e); }\n\n var display = cm.display;\n var lineBox = display.lineDiv.getBoundingClientRect();\n\n if (mY > lineBox.bottom || !hasHandler(cm, type)) { return e_defaultPrevented(e) }\n mY -= lineBox.top - display.viewOffset;\n\n for (var i = 0; i < cm.display.gutterSpecs.length; ++i) {\n var g = display.gutters.childNodes[i];\n if (g && g.getBoundingClientRect().right >= mX) {\n var line = lineAtHeight(cm.doc, mY);\n var gutter = cm.display.gutterSpecs[i];\n signal(cm, type, cm, line, gutter.className, e);\n return e_defaultPrevented(e)\n }\n }\n }\n\n function clickInGutter(cm, e) {\n return gutterEvent(cm, e, \"gutterClick\", true)\n }\n\n // CONTEXT MENU HANDLING\n\n // To make the context menu work, we need to briefly unhide the\n // textarea (making it as unobtrusive as possible) to let the\n // right-click take effect on it.\n function onContextMenu(cm, e) {\n if (eventInWidget(cm.display, e) || contextMenuInGutter(cm, e)) { return }\n if (signalDOMEvent(cm, e, \"contextmenu\")) { return }\n if (!captureRightClick) { cm.display.input.onContextMenu(e); }\n }\n\n function contextMenuInGutter(cm, e) {\n if (!hasHandler(cm, \"gutterContextMenu\")) { return false }\n return gutterEvent(cm, e, \"gutterContextMenu\", false)\n }\n\n function themeChanged(cm) {\n cm.display.wrapper.className = cm.display.wrapper.className.replace(/\\s*cm-s-\\S+/g, \"\") +\n cm.options.theme.replace(/(^|\\s)\\s*/g, \" cm-s-\");\n clearCaches(cm);\n }\n\n var Init = {toString: function(){return \"CodeMirror.Init\"}};\n\n var defaults = {};\n var optionHandlers = {};\n\n function defineOptions(CodeMirror) {\n var optionHandlers = CodeMirror.optionHandlers;\n\n function option(name, deflt, handle, notOnInit) {\n CodeMirror.defaults[name] = deflt;\n if (handle) { optionHandlers[name] =\n notOnInit ? function (cm, val, old) {if (old != Init) { handle(cm, val, old); }} : handle; }\n }\n\n CodeMirror.defineOption = option;\n\n // Passed to option handlers when there is no old value.\n CodeMirror.Init = Init;\n\n // These two are, on init, called from the constructor because they\n // have to be initialized before the editor can start at all.\n option(\"value\", \"\", function (cm, val) { return cm.setValue(val); }, true);\n option(\"mode\", null, function (cm, val) {\n cm.doc.modeOption = val;\n loadMode(cm);\n }, true);\n\n option(\"indentUnit\", 2, loadMode, true);\n option(\"indentWithTabs\", false);\n option(\"smartIndent\", true);\n option(\"tabSize\", 4, function (cm) {\n resetModeState(cm);\n clearCaches(cm);\n regChange(cm);\n }, true);\n\n option(\"lineSeparator\", null, function (cm, val) {\n cm.doc.lineSep = val;\n if (!val) { return }\n var newBreaks = [], lineNo = cm.doc.first;\n cm.doc.iter(function (line) {\n for (var pos = 0;;) {\n var found = line.text.indexOf(val, pos);\n if (found == -1) { break }\n pos = found + val.length;\n newBreaks.push(Pos(lineNo, found));\n }\n lineNo++;\n });\n for (var i = newBreaks.length - 1; i >= 0; i--)\n { replaceRange(cm.doc, val, newBreaks[i], Pos(newBreaks[i].line, newBreaks[i].ch + val.length)); }\n });\n option(\"specialChars\", /[\\u0000-\\u001f\\u007f-\\u009f\\u00ad\\u061c\\u200b-\\u200f\\u2028\\u2029\\ufeff\\ufff9-\\ufffc]/g, function (cm, val, old) {\n cm.state.specialChars = new RegExp(val.source + (val.test(\"\\t\") ? \"\" : \"|\\t\"), \"g\");\n if (old != Init) { cm.refresh(); }\n });\n option(\"specialCharPlaceholder\", defaultSpecialCharPlaceholder, function (cm) { return cm.refresh(); }, true);\n option(\"electricChars\", true);\n option(\"inputStyle\", mobile ? \"contenteditable\" : \"textarea\", function () {\n throw new Error(\"inputStyle can not (yet) be changed in a running editor\") // FIXME\n }, true);\n option(\"spellcheck\", false, function (cm, val) { return cm.getInputField().spellcheck = val; }, true);\n option(\"autocorrect\", false, function (cm, val) { return cm.getInputField().autocorrect = val; }, true);\n option(\"autocapitalize\", false, function (cm, val) { return cm.getInputField().autocapitalize = val; }, true);\n option(\"rtlMoveVisually\", !windows);\n option(\"wholeLineUpdateBefore\", true);\n\n option(\"theme\", \"default\", function (cm) {\n themeChanged(cm);\n updateGutters(cm);\n }, true);\n option(\"keyMap\", \"default\", function (cm, val, old) {\n var next = getKeyMap(val);\n var prev = old != Init && getKeyMap(old);\n if (prev && prev.detach) { prev.detach(cm, next); }\n if (next.attach) { next.attach(cm, prev || null); }\n });\n option(\"extraKeys\", null);\n option(\"configureMouse\", null);\n\n option(\"lineWrapping\", false, wrappingChanged, true);\n option(\"gutters\", [], function (cm, val) {\n cm.display.gutterSpecs = getGutters(val, cm.options.lineNumbers);\n updateGutters(cm);\n }, true);\n option(\"fixedGutter\", true, function (cm, val) {\n cm.display.gutters.style.left = val ? compensateForHScroll(cm.display) + \"px\" : \"0\";\n cm.refresh();\n }, true);\n option(\"coverGutterNextToScrollbar\", false, function (cm) { return updateScrollbars(cm); }, true);\n option(\"scrollbarStyle\", \"native\", function (cm) {\n initScrollbars(cm);\n updateScrollbars(cm);\n cm.display.scrollbars.setScrollTop(cm.doc.scrollTop);\n cm.display.scrollbars.setScrollLeft(cm.doc.scrollLeft);\n }, true);\n option(\"lineNumbers\", false, function (cm, val) {\n cm.display.gutterSpecs = getGutters(cm.options.gutters, val);\n updateGutters(cm);\n }, true);\n option(\"firstLineNumber\", 1, updateGutters, true);\n option(\"lineNumberFormatter\", function (integer) { return integer; }, updateGutters, true);\n option(\"showCursorWhenSelecting\", false, updateSelection, true);\n\n option(\"resetSelectionOnContextMenu\", true);\n option(\"lineWiseCopyCut\", true);\n option(\"pasteLinesPerSelection\", true);\n option(\"selectionsMayTouch\", false);\n\n option(\"readOnly\", false, function (cm, val) {\n if (val == \"nocursor\") {\n onBlur(cm);\n cm.display.input.blur();\n }\n cm.display.input.readOnlyChanged(val);\n });\n option(\"disableInput\", false, function (cm, val) {if (!val) { cm.display.input.reset(); }}, true);\n option(\"dragDrop\", true, dragDropChanged);\n option(\"allowDropFileTypes\", null);\n\n option(\"cursorBlinkRate\", 530);\n option(\"cursorScrollMargin\", 0);\n option(\"cursorHeight\", 1, updateSelection, true);\n option(\"singleCursorHeightPerLine\", true, updateSelection, true);\n option(\"workTime\", 100);\n option(\"workDelay\", 100);\n option(\"flattenSpans\", true, resetModeState, true);\n option(\"addModeClass\", false, resetModeState, true);\n option(\"pollInterval\", 100);\n option(\"undoDepth\", 200, function (cm, val) { return cm.doc.history.undoDepth = val; });\n option(\"historyEventDelay\", 1250);\n option(\"viewportMargin\", 10, function (cm) { return cm.refresh(); }, true);\n option(\"maxHighlightLength\", 10000, resetModeState, true);\n option(\"moveInputWithCursor\", true, function (cm, val) {\n if (!val) { cm.display.input.resetPosition(); }\n });\n\n option(\"tabindex\", null, function (cm, val) { return cm.display.input.getField().tabIndex = val || \"\"; });\n option(\"autofocus\", null);\n option(\"direction\", \"ltr\", function (cm, val) { return cm.doc.setDirection(val); }, true);\n option(\"phrases\", null);\n }\n\n function dragDropChanged(cm, value, old) {\n var wasOn = old && old != Init;\n if (!value != !wasOn) {\n var funcs = cm.display.dragFunctions;\n var toggle = value ? on : off;\n toggle(cm.display.scroller, \"dragstart\", funcs.start);\n toggle(cm.display.scroller, \"dragenter\", funcs.enter);\n toggle(cm.display.scroller, \"dragover\", funcs.over);\n toggle(cm.display.scroller, \"dragleave\", funcs.leave);\n toggle(cm.display.scroller, \"drop\", funcs.drop);\n }\n }\n\n function wrappingChanged(cm) {\n if (cm.options.lineWrapping) {\n addClass(cm.display.wrapper, \"CodeMirror-wrap\");\n cm.display.sizer.style.minWidth = \"\";\n cm.display.sizerWidth = null;\n } else {\n rmClass(cm.display.wrapper, \"CodeMirror-wrap\");\n findMaxLine(cm);\n }\n estimateLineHeights(cm);\n regChange(cm);\n clearCaches(cm);\n setTimeout(function () { return updateScrollbars(cm); }, 100);\n }\n\n // A CodeMirror instance represents an editor. This is the object\n // that user code is usually dealing with.\n\n function CodeMirror(place, options) {\n var this$1 = this;\n\n if (!(this instanceof CodeMirror)) { return new CodeMirror(place, options) }\n\n this.options = options = options ? copyObj(options) : {};\n // Determine effective options based on given values and defaults.\n copyObj(defaults, options, false);\n\n var doc = options.value;\n if (typeof doc == \"string\") { doc = new Doc(doc, options.mode, null, options.lineSeparator, options.direction); }\n else if (options.mode) { doc.modeOption = options.mode; }\n this.doc = doc;\n\n var input = new CodeMirror.inputStyles[options.inputStyle](this);\n var display = this.display = new Display(place, doc, input, options);\n display.wrapper.CodeMirror = this;\n themeChanged(this);\n if (options.lineWrapping)\n { this.display.wrapper.className += \" CodeMirror-wrap\"; }\n initScrollbars(this);\n\n this.state = {\n keyMaps: [], // stores maps added by addKeyMap\n overlays: [], // highlighting overlays, as added by addOverlay\n modeGen: 0, // bumped when mode/overlay changes, used to invalidate highlighting info\n overwrite: false,\n delayingBlurEvent: false,\n focused: false,\n suppressEdits: false, // used to disable editing during key handlers when in readOnly mode\n pasteIncoming: -1, cutIncoming: -1, // help recognize paste/cut edits in input.poll\n selectingText: false,\n draggingText: false,\n highlight: new Delayed(), // stores highlight worker timeout\n keySeq: null, // Unfinished key sequence\n specialChars: null\n };\n\n if (options.autofocus && !mobile) { display.input.focus(); }\n\n // Override magic textarea content restore that IE sometimes does\n // on our hidden textarea on reload\n if (ie && ie_version < 11) { setTimeout(function () { return this$1.display.input.reset(true); }, 20); }\n\n registerEventHandlers(this);\n ensureGlobalHandlers();\n\n startOperation(this);\n this.curOp.forceUpdate = true;\n attachDoc(this, doc);\n\n if ((options.autofocus && !mobile) || this.hasFocus())\n { setTimeout(bind(onFocus, this), 20); }\n else\n { onBlur(this); }\n\n for (var opt in optionHandlers) { if (optionHandlers.hasOwnProperty(opt))\n { optionHandlers[opt](this$1, options[opt], Init); } }\n maybeUpdateLineNumberWidth(this);\n if (options.finishInit) { options.finishInit(this); }\n for (var i = 0; i < initHooks.length; ++i) { initHooks[i](this$1); }\n endOperation(this);\n // Suppress optimizelegibility in Webkit, since it breaks text\n // measuring on line wrapping boundaries.\n if (webkit && options.lineWrapping &&\n getComputedStyle(display.lineDiv).textRendering == \"optimizelegibility\")\n { display.lineDiv.style.textRendering = \"auto\"; }\n }\n\n // The default configuration options.\n CodeMirror.defaults = defaults;\n // Functions to run when options are changed.\n CodeMirror.optionHandlers = optionHandlers;\n\n // Attach the necessary event handlers when initializing the editor\n function registerEventHandlers(cm) {\n var d = cm.display;\n on(d.scroller, \"mousedown\", operation(cm, onMouseDown));\n // Older IE's will not fire a second mousedown for a double click\n if (ie && ie_version < 11)\n { on(d.scroller, \"dblclick\", operation(cm, function (e) {\n if (signalDOMEvent(cm, e)) { return }\n var pos = posFromMouse(cm, e);\n if (!pos || clickInGutter(cm, e) || eventInWidget(cm.display, e)) { return }\n e_preventDefault(e);\n var word = cm.findWordAt(pos);\n extendSelection(cm.doc, word.anchor, word.head);\n })); }\n else\n { on(d.scroller, \"dblclick\", function (e) { return signalDOMEvent(cm, e) || e_preventDefault(e); }); }\n // Some browsers fire contextmenu *after* opening the menu, at\n // which point we can't mess with it anymore. Context menu is\n // handled in onMouseDown for these browsers.\n on(d.scroller, \"contextmenu\", function (e) { return onContextMenu(cm, e); });\n\n // Used to suppress mouse event handling when a touch happens\n var touchFinished, prevTouch = {end: 0};\n function finishTouch() {\n if (d.activeTouch) {\n touchFinished = setTimeout(function () { return d.activeTouch = null; }, 1000);\n prevTouch = d.activeTouch;\n prevTouch.end = +new Date;\n }\n }\n function isMouseLikeTouchEvent(e) {\n if (e.touches.length != 1) { return false }\n var touch = e.touches[0];\n return touch.radiusX <= 1 && touch.radiusY <= 1\n }\n function farAway(touch, other) {\n if (other.left == null) { return true }\n var dx = other.left - touch.left, dy = other.top - touch.top;\n return dx * dx + dy * dy > 20 * 20\n }\n on(d.scroller, \"touchstart\", function (e) {\n if (!signalDOMEvent(cm, e) && !isMouseLikeTouchEvent(e) && !clickInGutter(cm, e)) {\n d.input.ensurePolled();\n clearTimeout(touchFinished);\n var now = +new Date;\n d.activeTouch = {start: now, moved: false,\n prev: now - prevTouch.end <= 300 ? prevTouch : null};\n if (e.touches.length == 1) {\n d.activeTouch.left = e.touches[0].pageX;\n d.activeTouch.top = e.touches[0].pageY;\n }\n }\n });\n on(d.scroller, \"touchmove\", function () {\n if (d.activeTouch) { d.activeTouch.moved = true; }\n });\n on(d.scroller, \"touchend\", function (e) {\n var touch = d.activeTouch;\n if (touch && !eventInWidget(d, e) && touch.left != null &&\n !touch.moved && new Date - touch.start < 300) {\n var pos = cm.coordsChar(d.activeTouch, \"page\"), range;\n if (!touch.prev || farAway(touch, touch.prev)) // Single tap\n { range = new Range(pos, pos); }\n else if (!touch.prev.prev || farAway(touch, touch.prev.prev)) // Double tap\n { range = cm.findWordAt(pos); }\n else // Triple tap\n { range = new Range(Pos(pos.line, 0), clipPos(cm.doc, Pos(pos.line + 1, 0))); }\n cm.setSelection(range.anchor, range.head);\n cm.focus();\n e_preventDefault(e);\n }\n finishTouch();\n });\n on(d.scroller, \"touchcancel\", finishTouch);\n\n // Sync scrolling between fake scrollbars and real scrollable\n // area, ensure viewport is updated when scrolling.\n on(d.scroller, \"scroll\", function () {\n if (d.scroller.clientHeight) {\n updateScrollTop(cm, d.scroller.scrollTop);\n setScrollLeft(cm, d.scroller.scrollLeft, true);\n signal(cm, \"scroll\", cm);\n }\n });\n\n // Listen to wheel events in order to try and update the viewport on time.\n on(d.scroller, \"mousewheel\", function (e) { return onScrollWheel(cm, e); });\n on(d.scroller, \"DOMMouseScroll\", function (e) { return onScrollWheel(cm, e); });\n\n // Prevent wrapper from ever scrolling\n on(d.wrapper, \"scroll\", function () { return d.wrapper.scrollTop = d.wrapper.scrollLeft = 0; });\n\n d.dragFunctions = {\n enter: function (e) {if (!signalDOMEvent(cm, e)) { e_stop(e); }},\n over: function (e) {if (!signalDOMEvent(cm, e)) { onDragOver(cm, e); e_stop(e); }},\n start: function (e) { return onDragStart(cm, e); },\n drop: operation(cm, onDrop),\n leave: function (e) {if (!signalDOMEvent(cm, e)) { clearDragCursor(cm); }}\n };\n\n var inp = d.input.getField();\n on(inp, \"keyup\", function (e) { return onKeyUp.call(cm, e); });\n on(inp, \"keydown\", operation(cm, onKeyDown));\n on(inp, \"keypress\", operation(cm, onKeyPress));\n on(inp, \"focus\", function (e) { return onFocus(cm, e); });\n on(inp, \"blur\", function (e) { return onBlur(cm, e); });\n }\n\n var initHooks = [];\n CodeMirror.defineInitHook = function (f) { return initHooks.push(f); };\n\n // Indent the given line. The how parameter can be \"smart\",\n // \"add\"/null, \"subtract\", or \"prev\". When aggressive is false\n // (typically set to true for forced single-line indents), empty\n // lines are not indented, and places where the mode returns Pass\n // are left alone.\n function indentLine(cm, n, how, aggressive) {\n var doc = cm.doc, state;\n if (how == null) { how = \"add\"; }\n if (how == \"smart\") {\n // Fall back to \"prev\" when the mode doesn't have an indentation\n // method.\n if (!doc.mode.indent) { how = \"prev\"; }\n else { state = getContextBefore(cm, n).state; }\n }\n\n var tabSize = cm.options.tabSize;\n var line = getLine(doc, n), curSpace = countColumn(line.text, null, tabSize);\n if (line.stateAfter) { line.stateAfter = null; }\n var curSpaceString = line.text.match(/^\\s*/)[0], indentation;\n if (!aggressive && !/\\S/.test(line.text)) {\n indentation = 0;\n how = \"not\";\n } else if (how == \"smart\") {\n indentation = doc.mode.indent(state, line.text.slice(curSpaceString.length), line.text);\n if (indentation == Pass || indentation > 150) {\n if (!aggressive) { return }\n how = \"prev\";\n }\n }\n if (how == \"prev\") {\n if (n > doc.first) { indentation = countColumn(getLine(doc, n-1).text, null, tabSize); }\n else { indentation = 0; }\n } else if (how == \"add\") {\n indentation = curSpace + cm.options.indentUnit;\n } else if (how == \"subtract\") {\n indentation = curSpace - cm.options.indentUnit;\n } else if (typeof how == \"number\") {\n indentation = curSpace + how;\n }\n indentation = Math.max(0, indentation);\n\n var indentString = \"\", pos = 0;\n if (cm.options.indentWithTabs)\n { for (var i = Math.floor(indentation / tabSize); i; --i) {pos += tabSize; indentString += \"\\t\";} }\n if (pos < indentation) { indentString += spaceStr(indentation - pos); }\n\n if (indentString != curSpaceString) {\n replaceRange(doc, indentString, Pos(n, 0), Pos(n, curSpaceString.length), \"+input\");\n line.stateAfter = null;\n return true\n } else {\n // Ensure that, if the cursor was in the whitespace at the start\n // of the line, it is moved to the end of that space.\n for (var i$1 = 0; i$1 < doc.sel.ranges.length; i$1++) {\n var range = doc.sel.ranges[i$1];\n if (range.head.line == n && range.head.ch < curSpaceString.length) {\n var pos$1 = Pos(n, curSpaceString.length);\n replaceOneSelection(doc, i$1, new Range(pos$1, pos$1));\n break\n }\n }\n }\n }\n\n // This will be set to a {lineWise: bool, text: [string]} object, so\n // that, when pasting, we know what kind of selections the copied\n // text was made out of.\n var lastCopied = null;\n\n function setLastCopied(newLastCopied) {\n lastCopied = newLastCopied;\n }\n\n function applyTextInput(cm, inserted, deleted, sel, origin) {\n var doc = cm.doc;\n cm.display.shift = false;\n if (!sel) { sel = doc.sel; }\n\n var recent = +new Date - 200;\n var paste = origin == \"paste\" || cm.state.pasteIncoming > recent;\n var textLines = splitLinesAuto(inserted), multiPaste = null;\n // When pasting N lines into N selections, insert one line per selection\n if (paste && sel.ranges.length > 1) {\n if (lastCopied && lastCopied.text.join(\"\\n\") == inserted) {\n if (sel.ranges.length % lastCopied.text.length == 0) {\n multiPaste = [];\n for (var i = 0; i < lastCopied.text.length; i++)\n { multiPaste.push(doc.splitLines(lastCopied.text[i])); }\n }\n } else if (textLines.length == sel.ranges.length && cm.options.pasteLinesPerSelection) {\n multiPaste = map(textLines, function (l) { return [l]; });\n }\n }\n\n var updateInput = cm.curOp.updateInput;\n // Normal behavior is to insert the new text into every selection\n for (var i$1 = sel.ranges.length - 1; i$1 >= 0; i$1--) {\n var range$$1 = sel.ranges[i$1];\n var from = range$$1.from(), to = range$$1.to();\n if (range$$1.empty()) {\n if (deleted && deleted > 0) // Handle deletion\n { from = Pos(from.line, from.ch - deleted); }\n else if (cm.state.overwrite && !paste) // Handle overwrite\n { to = Pos(to.line, Math.min(getLine(doc, to.line).text.length, to.ch + lst(textLines).length)); }\n else if (paste && lastCopied && lastCopied.lineWise && lastCopied.text.join(\"\\n\") == inserted)\n { from = to = Pos(from.line, 0); }\n }\n var changeEvent = {from: from, to: to, text: multiPaste ? multiPaste[i$1 % multiPaste.length] : textLines,\n origin: origin || (paste ? \"paste\" : cm.state.cutIncoming > recent ? \"cut\" : \"+input\")};\n makeChange(cm.doc, changeEvent);\n signalLater(cm, \"inputRead\", cm, changeEvent);\n }\n if (inserted && !paste)\n { triggerElectric(cm, inserted); }\n\n ensureCursorVisible(cm);\n if (cm.curOp.updateInput < 2) { cm.curOp.updateInput = updateInput; }\n cm.curOp.typing = true;\n cm.state.pasteIncoming = cm.state.cutIncoming = -1;\n }\n\n function handlePaste(e, cm) {\n var pasted = e.clipboardData && e.clipboardData.getData(\"Text\");\n if (pasted) {\n e.preventDefault();\n if (!cm.isReadOnly() && !cm.options.disableInput)\n { runInOp(cm, function () { return applyTextInput(cm, pasted, 0, null, \"paste\"); }); }\n return true\n }\n }\n\n function triggerElectric(cm, inserted) {\n // When an 'electric' character is inserted, immediately trigger a reindent\n if (!cm.options.electricChars || !cm.options.smartIndent) { return }\n var sel = cm.doc.sel;\n\n for (var i = sel.ranges.length - 1; i >= 0; i--) {\n var range$$1 = sel.ranges[i];\n if (range$$1.head.ch > 100 || (i && sel.ranges[i - 1].head.line == range$$1.head.line)) { continue }\n var mode = cm.getModeAt(range$$1.head);\n var indented = false;\n if (mode.electricChars) {\n for (var j = 0; j < mode.electricChars.length; j++)\n { if (inserted.indexOf(mode.electricChars.charAt(j)) > -1) {\n indented = indentLine(cm, range$$1.head.line, \"smart\");\n break\n } }\n } else if (mode.electricInput) {\n if (mode.electricInput.test(getLine(cm.doc, range$$1.head.line).text.slice(0, range$$1.head.ch)))\n { indented = indentLine(cm, range$$1.head.line, \"smart\"); }\n }\n if (indented) { signalLater(cm, \"electricInput\", cm, range$$1.head.line); }\n }\n }\n\n function copyableRanges(cm) {\n var text = [], ranges = [];\n for (var i = 0; i < cm.doc.sel.ranges.length; i++) {\n var line = cm.doc.sel.ranges[i].head.line;\n var lineRange = {anchor: Pos(line, 0), head: Pos(line + 1, 0)};\n ranges.push(lineRange);\n text.push(cm.getRange(lineRange.anchor, lineRange.head));\n }\n return {text: text, ranges: ranges}\n }\n\n function disableBrowserMagic(field, spellcheck, autocorrect, autocapitalize) {\n field.setAttribute(\"autocorrect\", autocorrect ? \"\" : \"off\");\n field.setAttribute(\"autocapitalize\", autocapitalize ? \"\" : \"off\");\n field.setAttribute(\"spellcheck\", !!spellcheck);\n }\n\n function hiddenTextarea() {\n var te = elt(\"textarea\", null, null, \"position: absolute; bottom: -1em; padding: 0; width: 1px; height: 1em; outline: none\");\n var div = elt(\"div\", [te], null, \"overflow: hidden; position: relative; width: 3px; height: 0px;\");\n // The textarea is kept positioned near the cursor to prevent the\n // fact that it'll be scrolled into view on input from scrolling\n // our fake cursor out of view. On webkit, when wrap=off, paste is\n // very slow. So make the area wide instead.\n if (webkit) { te.style.width = \"1000px\"; }\n else { te.setAttribute(\"wrap\", \"off\"); }\n // If border: 0; -- iOS fails to open keyboard (issue #1287)\n if (ios) { te.style.border = \"1px solid black\"; }\n disableBrowserMagic(te);\n return div\n }\n\n // The publicly visible API. Note that methodOp(f) means\n // 'wrap f in an operation, performed on its `this` parameter'.\n\n // This is not the complete set of editor methods. Most of the\n // methods defined on the Doc type are also injected into\n // CodeMirror.prototype, for backwards compatibility and\n // convenience.\n\n function addEditorMethods(CodeMirror) {\n var optionHandlers = CodeMirror.optionHandlers;\n\n var helpers = CodeMirror.helpers = {};\n\n CodeMirror.prototype = {\n constructor: CodeMirror,\n focus: function(){window.focus(); this.display.input.focus();},\n\n setOption: function(option, value) {\n var options = this.options, old = options[option];\n if (options[option] == value && option != \"mode\") { return }\n options[option] = value;\n if (optionHandlers.hasOwnProperty(option))\n { operation(this, optionHandlers[option])(this, value, old); }\n signal(this, \"optionChange\", this, option);\n },\n\n getOption: function(option) {return this.options[option]},\n getDoc: function() {return this.doc},\n\n addKeyMap: function(map$$1, bottom) {\n this.state.keyMaps[bottom ? \"push\" : \"unshift\"](getKeyMap(map$$1));\n },\n removeKeyMap: function(map$$1) {\n var maps = this.state.keyMaps;\n for (var i = 0; i < maps.length; ++i)\n { if (maps[i] == map$$1 || maps[i].name == map$$1) {\n maps.splice(i, 1);\n return true\n } }\n },\n\n addOverlay: methodOp(function(spec, options) {\n var mode = spec.token ? spec : CodeMirror.getMode(this.options, spec);\n if (mode.startState) { throw new Error(\"Overlays may not be stateful.\") }\n insertSorted(this.state.overlays,\n {mode: mode, modeSpec: spec, opaque: options && options.opaque,\n priority: (options && options.priority) || 0},\n function (overlay) { return overlay.priority; });\n this.state.modeGen++;\n regChange(this);\n }),\n removeOverlay: methodOp(function(spec) {\n var this$1 = this;\n\n var overlays = this.state.overlays;\n for (var i = 0; i < overlays.length; ++i) {\n var cur = overlays[i].modeSpec;\n if (cur == spec || typeof spec == \"string\" && cur.name == spec) {\n overlays.splice(i, 1);\n this$1.state.modeGen++;\n regChange(this$1);\n return\n }\n }\n }),\n\n indentLine: methodOp(function(n, dir, aggressive) {\n if (typeof dir != \"string\" && typeof dir != \"number\") {\n if (dir == null) { dir = this.options.smartIndent ? \"smart\" : \"prev\"; }\n else { dir = dir ? \"add\" : \"subtract\"; }\n }\n if (isLine(this.doc, n)) { indentLine(this, n, dir, aggressive); }\n }),\n indentSelection: methodOp(function(how) {\n var this$1 = this;\n\n var ranges = this.doc.sel.ranges, end = -1;\n for (var i = 0; i < ranges.length; i++) {\n var range$$1 = ranges[i];\n if (!range$$1.empty()) {\n var from = range$$1.from(), to = range$$1.to();\n var start = Math.max(end, from.line);\n end = Math.min(this$1.lastLine(), to.line - (to.ch ? 0 : 1)) + 1;\n for (var j = start; j < end; ++j)\n { indentLine(this$1, j, how); }\n var newRanges = this$1.doc.sel.ranges;\n if (from.ch == 0 && ranges.length == newRanges.length && newRanges[i].from().ch > 0)\n { replaceOneSelection(this$1.doc, i, new Range(from, newRanges[i].to()), sel_dontScroll); }\n } else if (range$$1.head.line > end) {\n indentLine(this$1, range$$1.head.line, how, true);\n end = range$$1.head.line;\n if (i == this$1.doc.sel.primIndex) { ensureCursorVisible(this$1); }\n }\n }\n }),\n\n // Fetch the parser token for a given character. Useful for hacks\n // that want to inspect the mode state (say, for completion).\n getTokenAt: function(pos, precise) {\n return takeToken(this, pos, precise)\n },\n\n getLineTokens: function(line, precise) {\n return takeToken(this, Pos(line), precise, true)\n },\n\n getTokenTypeAt: function(pos) {\n pos = clipPos(this.doc, pos);\n var styles = getLineStyles(this, getLine(this.doc, pos.line));\n var before = 0, after = (styles.length - 1) / 2, ch = pos.ch;\n var type;\n if (ch == 0) { type = styles[2]; }\n else { for (;;) {\n var mid = (before + after) >> 1;\n if ((mid ? styles[mid * 2 - 1] : 0) >= ch) { after = mid; }\n else if (styles[mid * 2 + 1] < ch) { before = mid + 1; }\n else { type = styles[mid * 2 + 2]; break }\n } }\n var cut = type ? type.indexOf(\"overlay \") : -1;\n return cut < 0 ? type : cut == 0 ? null : type.slice(0, cut - 1)\n },\n\n getModeAt: function(pos) {\n var mode = this.doc.mode;\n if (!mode.innerMode) { return mode }\n return CodeMirror.innerMode(mode, this.getTokenAt(pos).state).mode\n },\n\n getHelper: function(pos, type) {\n return this.getHelpers(pos, type)[0]\n },\n\n getHelpers: function(pos, type) {\n var this$1 = this;\n\n var found = [];\n if (!helpers.hasOwnProperty(type)) { return found }\n var help = helpers[type], mode = this.getModeAt(pos);\n if (typeof mode[type] == \"string\") {\n if (help[mode[type]]) { found.push(help[mode[type]]); }\n } else if (mode[type]) {\n for (var i = 0; i < mode[type].length; i++) {\n var val = help[mode[type][i]];\n if (val) { found.push(val); }\n }\n } else if (mode.helperType && help[mode.helperType]) {\n found.push(help[mode.helperType]);\n } else if (help[mode.name]) {\n found.push(help[mode.name]);\n }\n for (var i$1 = 0; i$1 < help._global.length; i$1++) {\n var cur = help._global[i$1];\n if (cur.pred(mode, this$1) && indexOf(found, cur.val) == -1)\n { found.push(cur.val); }\n }\n return found\n },\n\n getStateAfter: function(line, precise) {\n var doc = this.doc;\n line = clipLine(doc, line == null ? doc.first + doc.size - 1: line);\n return getContextBefore(this, line + 1, precise).state\n },\n\n cursorCoords: function(start, mode) {\n var pos, range$$1 = this.doc.sel.primary();\n if (start == null) { pos = range$$1.head; }\n else if (typeof start == \"object\") { pos = clipPos(this.doc, start); }\n else { pos = start ? range$$1.from() : range$$1.to(); }\n return cursorCoords(this, pos, mode || \"page\")\n },\n\n charCoords: function(pos, mode) {\n return charCoords(this, clipPos(this.doc, pos), mode || \"page\")\n },\n\n coordsChar: function(coords, mode) {\n coords = fromCoordSystem(this, coords, mode || \"page\");\n return coordsChar(this, coords.left, coords.top)\n },\n\n lineAtHeight: function(height, mode) {\n height = fromCoordSystem(this, {top: height, left: 0}, mode || \"page\").top;\n return lineAtHeight(this.doc, height + this.display.viewOffset)\n },\n heightAtLine: function(line, mode, includeWidgets) {\n var end = false, lineObj;\n if (typeof line == \"number\") {\n var last = this.doc.first + this.doc.size - 1;\n if (line < this.doc.first) { line = this.doc.first; }\n else if (line > last) { line = last; end = true; }\n lineObj = getLine(this.doc, line);\n } else {\n lineObj = line;\n }\n return intoCoordSystem(this, lineObj, {top: 0, left: 0}, mode || \"page\", includeWidgets || end).top +\n (end ? this.doc.height - heightAtLine(lineObj) : 0)\n },\n\n defaultTextHeight: function() { return textHeight(this.display) },\n defaultCharWidth: function() { return charWidth(this.display) },\n\n getViewport: function() { return {from: this.display.viewFrom, to: this.display.viewTo}},\n\n addWidget: function(pos, node, scroll, vert, horiz) {\n var display = this.display;\n pos = cursorCoords(this, clipPos(this.doc, pos));\n var top = pos.bottom, left = pos.left;\n node.style.position = \"absolute\";\n node.setAttribute(\"cm-ignore-events\", \"true\");\n this.display.input.setUneditable(node);\n display.sizer.appendChild(node);\n if (vert == \"over\") {\n top = pos.top;\n } else if (vert == \"above\" || vert == \"near\") {\n var vspace = Math.max(display.wrapper.clientHeight, this.doc.height),\n hspace = Math.max(display.sizer.clientWidth, display.lineSpace.clientWidth);\n // Default to positioning above (if specified and possible); otherwise default to positioning below\n if ((vert == 'above' || pos.bottom + node.offsetHeight > vspace) && pos.top > node.offsetHeight)\n { top = pos.top - node.offsetHeight; }\n else if (pos.bottom + node.offsetHeight <= vspace)\n { top = pos.bottom; }\n if (left + node.offsetWidth > hspace)\n { left = hspace - node.offsetWidth; }\n }\n node.style.top = top + \"px\";\n node.style.left = node.style.right = \"\";\n if (horiz == \"right\") {\n left = display.sizer.clientWidth - node.offsetWidth;\n node.style.right = \"0px\";\n } else {\n if (horiz == \"left\") { left = 0; }\n else if (horiz == \"middle\") { left = (display.sizer.clientWidth - node.offsetWidth) / 2; }\n node.style.left = left + \"px\";\n }\n if (scroll)\n { scrollIntoView(this, {left: left, top: top, right: left + node.offsetWidth, bottom: top + node.offsetHeight}); }\n },\n\n triggerOnKeyDown: methodOp(onKeyDown),\n triggerOnKeyPress: methodOp(onKeyPress),\n triggerOnKeyUp: onKeyUp,\n triggerOnMouseDown: methodOp(onMouseDown),\n\n execCommand: function(cmd) {\n if (commands.hasOwnProperty(cmd))\n { return commands[cmd].call(null, this) }\n },\n\n triggerElectric: methodOp(function(text) { triggerElectric(this, text); }),\n\n findPosH: function(from, amount, unit, visually) {\n var this$1 = this;\n\n var dir = 1;\n if (amount < 0) { dir = -1; amount = -amount; }\n var cur = clipPos(this.doc, from);\n for (var i = 0; i < amount; ++i) {\n cur = findPosH(this$1.doc, cur, dir, unit, visually);\n if (cur.hitSide) { break }\n }\n return cur\n },\n\n moveH: methodOp(function(dir, unit) {\n var this$1 = this;\n\n this.extendSelectionsBy(function (range$$1) {\n if (this$1.display.shift || this$1.doc.extend || range$$1.empty())\n { return findPosH(this$1.doc, range$$1.head, dir, unit, this$1.options.rtlMoveVisually) }\n else\n { return dir < 0 ? range$$1.from() : range$$1.to() }\n }, sel_move);\n }),\n\n deleteH: methodOp(function(dir, unit) {\n var sel = this.doc.sel, doc = this.doc;\n if (sel.somethingSelected())\n { doc.replaceSelection(\"\", null, \"+delete\"); }\n else\n { deleteNearSelection(this, function (range$$1) {\n var other = findPosH(doc, range$$1.head, dir, unit, false);\n return dir < 0 ? {from: other, to: range$$1.head} : {from: range$$1.head, to: other}\n }); }\n }),\n\n findPosV: function(from, amount, unit, goalColumn) {\n var this$1 = this;\n\n var dir = 1, x = goalColumn;\n if (amount < 0) { dir = -1; amount = -amount; }\n var cur = clipPos(this.doc, from);\n for (var i = 0; i < amount; ++i) {\n var coords = cursorCoords(this$1, cur, \"div\");\n if (x == null) { x = coords.left; }\n else { coords.left = x; }\n cur = findPosV(this$1, coords, dir, unit);\n if (cur.hitSide) { break }\n }\n return cur\n },\n\n moveV: methodOp(function(dir, unit) {\n var this$1 = this;\n\n var doc = this.doc, goals = [];\n var collapse = !this.display.shift && !doc.extend && doc.sel.somethingSelected();\n doc.extendSelectionsBy(function (range$$1) {\n if (collapse)\n { return dir < 0 ? range$$1.from() : range$$1.to() }\n var headPos = cursorCoords(this$1, range$$1.head, \"div\");\n if (range$$1.goalColumn != null) { headPos.left = range$$1.goalColumn; }\n goals.push(headPos.left);\n var pos = findPosV(this$1, headPos, dir, unit);\n if (unit == \"page\" && range$$1 == doc.sel.primary())\n { addToScrollTop(this$1, charCoords(this$1, pos, \"div\").top - headPos.top); }\n return pos\n }, sel_move);\n if (goals.length) { for (var i = 0; i < doc.sel.ranges.length; i++)\n { doc.sel.ranges[i].goalColumn = goals[i]; } }\n }),\n\n // Find the word at the given position (as returned by coordsChar).\n findWordAt: function(pos) {\n var doc = this.doc, line = getLine(doc, pos.line).text;\n var start = pos.ch, end = pos.ch;\n if (line) {\n var helper = this.getHelper(pos, \"wordChars\");\n if ((pos.sticky == \"before\" || end == line.length) && start) { --start; } else { ++end; }\n var startChar = line.charAt(start);\n var check = isWordChar(startChar, helper)\n ? function (ch) { return isWordChar(ch, helper); }\n : /\\s/.test(startChar) ? function (ch) { return /\\s/.test(ch); }\n : function (ch) { return (!/\\s/.test(ch) && !isWordChar(ch)); };\n while (start > 0 && check(line.charAt(start - 1))) { --start; }\n while (end < line.length && check(line.charAt(end))) { ++end; }\n }\n return new Range(Pos(pos.line, start), Pos(pos.line, end))\n },\n\n toggleOverwrite: function(value) {\n if (value != null && value == this.state.overwrite) { return }\n if (this.state.overwrite = !this.state.overwrite)\n { addClass(this.display.cursorDiv, \"CodeMirror-overwrite\"); }\n else\n { rmClass(this.display.cursorDiv, \"CodeMirror-overwrite\"); }\n\n signal(this, \"overwriteToggle\", this, this.state.overwrite);\n },\n hasFocus: function() { return this.display.input.getField() == activeElt() },\n isReadOnly: function() { return !!(this.options.readOnly || this.doc.cantEdit) },\n\n scrollTo: methodOp(function (x, y) { scrollToCoords(this, x, y); }),\n getScrollInfo: function() {\n var scroller = this.display.scroller;\n return {left: scroller.scrollLeft, top: scroller.scrollTop,\n height: scroller.scrollHeight - scrollGap(this) - this.display.barHeight,\n width: scroller.scrollWidth - scrollGap(this) - this.display.barWidth,\n clientHeight: displayHeight(this), clientWidth: displayWidth(this)}\n },\n\n scrollIntoView: methodOp(function(range$$1, margin) {\n if (range$$1 == null) {\n range$$1 = {from: this.doc.sel.primary().head, to: null};\n if (margin == null) { margin = this.options.cursorScrollMargin; }\n } else if (typeof range$$1 == \"number\") {\n range$$1 = {from: Pos(range$$1, 0), to: null};\n } else if (range$$1.from == null) {\n range$$1 = {from: range$$1, to: null};\n }\n if (!range$$1.to) { range$$1.to = range$$1.from; }\n range$$1.margin = margin || 0;\n\n if (range$$1.from.line != null) {\n scrollToRange(this, range$$1);\n } else {\n scrollToCoordsRange(this, range$$1.from, range$$1.to, range$$1.margin);\n }\n }),\n\n setSize: methodOp(function(width, height) {\n var this$1 = this;\n\n var interpret = function (val) { return typeof val == \"number\" || /^\\d+$/.test(String(val)) ? val + \"px\" : val; };\n if (width != null) { this.display.wrapper.style.width = interpret(width); }\n if (height != null) { this.display.wrapper.style.height = interpret(height); }\n if (this.options.lineWrapping) { clearLineMeasurementCache(this); }\n var lineNo$$1 = this.display.viewFrom;\n this.doc.iter(lineNo$$1, this.display.viewTo, function (line) {\n if (line.widgets) { for (var i = 0; i < line.widgets.length; i++)\n { if (line.widgets[i].noHScroll) { regLineChange(this$1, lineNo$$1, \"widget\"); break } } }\n ++lineNo$$1;\n });\n this.curOp.forceUpdate = true;\n signal(this, \"refresh\", this);\n }),\n\n operation: function(f){return runInOp(this, f)},\n startOperation: function(){return startOperation(this)},\n endOperation: function(){return endOperation(this)},\n\n refresh: methodOp(function() {\n var oldHeight = this.display.cachedTextHeight;\n regChange(this);\n this.curOp.forceUpdate = true;\n clearCaches(this);\n scrollToCoords(this, this.doc.scrollLeft, this.doc.scrollTop);\n updateGutterSpace(this.display);\n if (oldHeight == null || Math.abs(oldHeight - textHeight(this.display)) > .5)\n { estimateLineHeights(this); }\n signal(this, \"refresh\", this);\n }),\n\n swapDoc: methodOp(function(doc) {\n var old = this.doc;\n old.cm = null;\n // Cancel the current text selection if any (#5821)\n if (this.state.selectingText) { this.state.selectingText(); }\n attachDoc(this, doc);\n clearCaches(this);\n this.display.input.reset();\n scrollToCoords(this, doc.scrollLeft, doc.scrollTop);\n this.curOp.forceScroll = true;\n signalLater(this, \"swapDoc\", this, old);\n return old\n }),\n\n phrase: function(phraseText) {\n var phrases = this.options.phrases;\n return phrases && Object.prototype.hasOwnProperty.call(phrases, phraseText) ? phrases[phraseText] : phraseText\n },\n\n getInputField: function(){return this.display.input.getField()},\n getWrapperElement: function(){return this.display.wrapper},\n getScrollerElement: function(){return this.display.scroller},\n getGutterElement: function(){return this.display.gutters}\n };\n eventMixin(CodeMirror);\n\n CodeMirror.registerHelper = function(type, name, value) {\n if (!helpers.hasOwnProperty(type)) { helpers[type] = CodeMirror[type] = {_global: []}; }\n helpers[type][name] = value;\n };\n CodeMirror.registerGlobalHelper = function(type, name, predicate, value) {\n CodeMirror.registerHelper(type, name, value);\n helpers[type]._global.push({pred: predicate, val: value});\n };\n }\n\n // Used for horizontal relative motion. Dir is -1 or 1 (left or\n // right), unit can be \"char\", \"column\" (like char, but doesn't\n // cross line boundaries), \"word\" (across next word), or \"group\" (to\n // the start of next group of word or non-word-non-whitespace\n // chars). The visually param controls whether, in right-to-left\n // text, direction 1 means to move towards the next index in the\n // string, or towards the character to the right of the current\n // position. The resulting position will have a hitSide=true\n // property if it reached the end of the document.\n function findPosH(doc, pos, dir, unit, visually) {\n var oldPos = pos;\n var origDir = dir;\n var lineObj = getLine(doc, pos.line);\n function findNextLine() {\n var l = pos.line + dir;\n if (l < doc.first || l >= doc.first + doc.size) { return false }\n pos = new Pos(l, pos.ch, pos.sticky);\n return lineObj = getLine(doc, l)\n }\n function moveOnce(boundToLine) {\n var next;\n if (visually) {\n next = moveVisually(doc.cm, lineObj, pos, dir);\n } else {\n next = moveLogically(lineObj, pos, dir);\n }\n if (next == null) {\n if (!boundToLine && findNextLine())\n { pos = endOfLine(visually, doc.cm, lineObj, pos.line, dir); }\n else\n { return false }\n } else {\n pos = next;\n }\n return true\n }\n\n if (unit == \"char\") {\n moveOnce();\n } else if (unit == \"column\") {\n moveOnce(true);\n } else if (unit == \"word\" || unit == \"group\") {\n var sawType = null, group = unit == \"group\";\n var helper = doc.cm && doc.cm.getHelper(pos, \"wordChars\");\n for (var first = true;; first = false) {\n if (dir < 0 && !moveOnce(!first)) { break }\n var cur = lineObj.text.charAt(pos.ch) || \"\\n\";\n var type = isWordChar(cur, helper) ? \"w\"\n : group && cur == \"\\n\" ? \"n\"\n : !group || /\\s/.test(cur) ? null\n : \"p\";\n if (group && !first && !type) { type = \"s\"; }\n if (sawType && sawType != type) {\n if (dir < 0) {dir = 1; moveOnce(); pos.sticky = \"after\";}\n break\n }\n\n if (type) { sawType = type; }\n if (dir > 0 && !moveOnce(!first)) { break }\n }\n }\n var result = skipAtomic(doc, pos, oldPos, origDir, true);\n if (equalCursorPos(oldPos, result)) { result.hitSide = true; }\n return result\n }\n\n // For relative vertical movement. Dir may be -1 or 1. Unit can be\n // \"page\" or \"line\". The resulting position will have a hitSide=true\n // property if it reached the end of the document.\n function findPosV(cm, pos, dir, unit) {\n var doc = cm.doc, x = pos.left, y;\n if (unit == \"page\") {\n var pageSize = Math.min(cm.display.wrapper.clientHeight, window.innerHeight || document.documentElement.clientHeight);\n var moveAmount = Math.max(pageSize - .5 * textHeight(cm.display), 3);\n y = (dir > 0 ? pos.bottom : pos.top) + dir * moveAmount;\n\n } else if (unit == \"line\") {\n y = dir > 0 ? pos.bottom + 3 : pos.top - 3;\n }\n var target;\n for (;;) {\n target = coordsChar(cm, x, y);\n if (!target.outside) { break }\n if (dir < 0 ? y <= 0 : y >= doc.height) { target.hitSide = true; break }\n y += dir * 5;\n }\n return target\n }\n\n // CONTENTEDITABLE INPUT STYLE\n\n var ContentEditableInput = function(cm) {\n this.cm = cm;\n this.lastAnchorNode = this.lastAnchorOffset = this.lastFocusNode = this.lastFocusOffset = null;\n this.polling = new Delayed();\n this.composing = null;\n this.gracePeriod = false;\n this.readDOMTimeout = null;\n };\n\n ContentEditableInput.prototype.init = function (display) {\n var this$1 = this;\n\n var input = this, cm = input.cm;\n var div = input.div = display.lineDiv;\n disableBrowserMagic(div, cm.options.spellcheck, cm.options.autocorrect, cm.options.autocapitalize);\n\n on(div, \"paste\", function (e) {\n if (signalDOMEvent(cm, e) || handlePaste(e, cm)) { return }\n // IE doesn't fire input events, so we schedule a read for the pasted content in this way\n if (ie_version <= 11) { setTimeout(operation(cm, function () { return this$1.updateFromDOM(); }), 20); }\n });\n\n on(div, \"compositionstart\", function (e) {\n this$1.composing = {data: e.data, done: false};\n });\n on(div, \"compositionupdate\", function (e) {\n if (!this$1.composing) { this$1.composing = {data: e.data, done: false}; }\n });\n on(div, \"compositionend\", function (e) {\n if (this$1.composing) {\n if (e.data != this$1.composing.data) { this$1.readFromDOMSoon(); }\n this$1.composing.done = true;\n }\n });\n\n on(div, \"touchstart\", function () { return input.forceCompositionEnd(); });\n\n on(div, \"input\", function () {\n if (!this$1.composing) { this$1.readFromDOMSoon(); }\n });\n\n function onCopyCut(e) {\n if (signalDOMEvent(cm, e)) { return }\n if (cm.somethingSelected()) {\n setLastCopied({lineWise: false, text: cm.getSelections()});\n if (e.type == \"cut\") { cm.replaceSelection(\"\", null, \"cut\"); }\n } else if (!cm.options.lineWiseCopyCut) {\n return\n } else {\n var ranges = copyableRanges(cm);\n setLastCopied({lineWise: true, text: ranges.text});\n if (e.type == \"cut\") {\n cm.operation(function () {\n cm.setSelections(ranges.ranges, 0, sel_dontScroll);\n cm.replaceSelection(\"\", null, \"cut\");\n });\n }\n }\n if (e.clipboardData) {\n e.clipboardData.clearData();\n var content = lastCopied.text.join(\"\\n\");\n // iOS exposes the clipboard API, but seems to discard content inserted into it\n e.clipboardData.setData(\"Text\", content);\n if (e.clipboardData.getData(\"Text\") == content) {\n e.preventDefault();\n return\n }\n }\n // Old-fashioned briefly-focus-a-textarea hack\n var kludge = hiddenTextarea(), te = kludge.firstChild;\n cm.display.lineSpace.insertBefore(kludge, cm.display.lineSpace.firstChild);\n te.value = lastCopied.text.join(\"\\n\");\n var hadFocus = document.activeElement;\n selectInput(te);\n setTimeout(function () {\n cm.display.lineSpace.removeChild(kludge);\n hadFocus.focus();\n if (hadFocus == div) { input.showPrimarySelection(); }\n }, 50);\n }\n on(div, \"copy\", onCopyCut);\n on(div, \"cut\", onCopyCut);\n };\n\n ContentEditableInput.prototype.prepareSelection = function () {\n var result = prepareSelection(this.cm, false);\n result.focus = this.cm.state.focused;\n return result\n };\n\n ContentEditableInput.prototype.showSelection = function (info, takeFocus) {\n if (!info || !this.cm.display.view.length) { return }\n if (info.focus || takeFocus) { this.showPrimarySelection(); }\n this.showMultipleSelections(info);\n };\n\n ContentEditableInput.prototype.getSelection = function () {\n return this.cm.display.wrapper.ownerDocument.getSelection()\n };\n\n ContentEditableInput.prototype.showPrimarySelection = function () {\n var sel = this.getSelection(), cm = this.cm, prim = cm.doc.sel.primary();\n var from = prim.from(), to = prim.to();\n\n if (cm.display.viewTo == cm.display.viewFrom || from.line >= cm.display.viewTo || to.line < cm.display.viewFrom) {\n sel.removeAllRanges();\n return\n }\n\n var curAnchor = domToPos(cm, sel.anchorNode, sel.anchorOffset);\n var curFocus = domToPos(cm, sel.focusNode, sel.focusOffset);\n if (curAnchor && !curAnchor.bad && curFocus && !curFocus.bad &&\n cmp(minPos(curAnchor, curFocus), from) == 0 &&\n cmp(maxPos(curAnchor, curFocus), to) == 0)\n { return }\n\n var view = cm.display.view;\n var start = (from.line >= cm.display.viewFrom && posToDOM(cm, from)) ||\n {node: view[0].measure.map[2], offset: 0};\n var end = to.line < cm.display.viewTo && posToDOM(cm, to);\n if (!end) {\n var measure = view[view.length - 1].measure;\n var map$$1 = measure.maps ? measure.maps[measure.maps.length - 1] : measure.map;\n end = {node: map$$1[map$$1.length - 1], offset: map$$1[map$$1.length - 2] - map$$1[map$$1.length - 3]};\n }\n\n if (!start || !end) {\n sel.removeAllRanges();\n return\n }\n\n var old = sel.rangeCount && sel.getRangeAt(0), rng;\n try { rng = range(start.node, start.offset, end.offset, end.node); }\n catch(e) {} // Our model of the DOM might be outdated, in which case the range we try to set can be impossible\n if (rng) {\n if (!gecko && cm.state.focused) {\n sel.collapse(start.node, start.offset);\n if (!rng.collapsed) {\n sel.removeAllRanges();\n sel.addRange(rng);\n }\n } else {\n sel.removeAllRanges();\n sel.addRange(rng);\n }\n if (old && sel.anchorNode == null) { sel.addRange(old); }\n else if (gecko) { this.startGracePeriod(); }\n }\n this.rememberSelection();\n };\n\n ContentEditableInput.prototype.startGracePeriod = function () {\n var this$1 = this;\n\n clearTimeout(this.gracePeriod);\n this.gracePeriod = setTimeout(function () {\n this$1.gracePeriod = false;\n if (this$1.selectionChanged())\n { this$1.cm.operation(function () { return this$1.cm.curOp.selectionChanged = true; }); }\n }, 20);\n };\n\n ContentEditableInput.prototype.showMultipleSelections = function (info) {\n removeChildrenAndAdd(this.cm.display.cursorDiv, info.cursors);\n removeChildrenAndAdd(this.cm.display.selectionDiv, info.selection);\n };\n\n ContentEditableInput.prototype.rememberSelection = function () {\n var sel = this.getSelection();\n this.lastAnchorNode = sel.anchorNode; this.lastAnchorOffset = sel.anchorOffset;\n this.lastFocusNode = sel.focusNode; this.lastFocusOffset = sel.focusOffset;\n };\n\n ContentEditableInput.prototype.selectionInEditor = function () {\n var sel = this.getSelection();\n if (!sel.rangeCount) { return false }\n var node = sel.getRangeAt(0).commonAncestorContainer;\n return contains(this.div, node)\n };\n\n ContentEditableInput.prototype.focus = function () {\n if (this.cm.options.readOnly != \"nocursor\") {\n if (!this.selectionInEditor())\n { this.showSelection(this.prepareSelection(), true); }\n this.div.focus();\n }\n };\n ContentEditableInput.prototype.blur = function () { this.div.blur(); };\n ContentEditableInput.prototype.getField = function () { return this.div };\n\n ContentEditableInput.prototype.supportsTouch = function () { return true };\n\n ContentEditableInput.prototype.receivedFocus = function () {\n var input = this;\n if (this.selectionInEditor())\n { this.pollSelection(); }\n else\n { runInOp(this.cm, function () { return input.cm.curOp.selectionChanged = true; }); }\n\n function poll() {\n if (input.cm.state.focused) {\n input.pollSelection();\n input.polling.set(input.cm.options.pollInterval, poll);\n }\n }\n this.polling.set(this.cm.options.pollInterval, poll);\n };\n\n ContentEditableInput.prototype.selectionChanged = function () {\n var sel = this.getSelection();\n return sel.anchorNode != this.lastAnchorNode || sel.anchorOffset != this.lastAnchorOffset ||\n sel.focusNode != this.lastFocusNode || sel.focusOffset != this.lastFocusOffset\n };\n\n ContentEditableInput.prototype.pollSelection = function () {\n if (this.readDOMTimeout != null || this.gracePeriod || !this.selectionChanged()) { return }\n var sel = this.getSelection(), cm = this.cm;\n // On Android Chrome (version 56, at least), backspacing into an\n // uneditable block element will put the cursor in that element,\n // and then, because it's not editable, hide the virtual keyboard.\n // Because Android doesn't allow us to actually detect backspace\n // presses in a sane way, this code checks for when that happens\n // and simulates a backspace press in this case.\n if (android && chrome && this.cm.display.gutterSpecs.length && isInGutter(sel.anchorNode)) {\n this.cm.triggerOnKeyDown({type: \"keydown\", keyCode: 8, preventDefault: Math.abs});\n this.blur();\n this.focus();\n return\n }\n if (this.composing) { return }\n this.rememberSelection();\n var anchor = domToPos(cm, sel.anchorNode, sel.anchorOffset);\n var head = domToPos(cm, sel.focusNode, sel.focusOffset);\n if (anchor && head) { runInOp(cm, function () {\n setSelection(cm.doc, simpleSelection(anchor, head), sel_dontScroll);\n if (anchor.bad || head.bad) { cm.curOp.selectionChanged = true; }\n }); }\n };\n\n ContentEditableInput.prototype.pollContent = function () {\n if (this.readDOMTimeout != null) {\n clearTimeout(this.readDOMTimeout);\n this.readDOMTimeout = null;\n }\n\n var cm = this.cm, display = cm.display, sel = cm.doc.sel.primary();\n var from = sel.from(), to = sel.to();\n if (from.ch == 0 && from.line > cm.firstLine())\n { from = Pos(from.line - 1, getLine(cm.doc, from.line - 1).length); }\n if (to.ch == getLine(cm.doc, to.line).text.length && to.line < cm.lastLine())\n { to = Pos(to.line + 1, 0); }\n if (from.line < display.viewFrom || to.line > display.viewTo - 1) { return false }\n\n var fromIndex, fromLine, fromNode;\n if (from.line == display.viewFrom || (fromIndex = findViewIndex(cm, from.line)) == 0) {\n fromLine = lineNo(display.view[0].line);\n fromNode = display.view[0].node;\n } else {\n fromLine = lineNo(display.view[fromIndex].line);\n fromNode = display.view[fromIndex - 1].node.nextSibling;\n }\n var toIndex = findViewIndex(cm, to.line);\n var toLine, toNode;\n if (toIndex == display.view.length - 1) {\n toLine = display.viewTo - 1;\n toNode = display.lineDiv.lastChild;\n } else {\n toLine = lineNo(display.view[toIndex + 1].line) - 1;\n toNode = display.view[toIndex + 1].node.previousSibling;\n }\n\n if (!fromNode) { return false }\n var newText = cm.doc.splitLines(domTextBetween(cm, fromNode, toNode, fromLine, toLine));\n var oldText = getBetween(cm.doc, Pos(fromLine, 0), Pos(toLine, getLine(cm.doc, toLine).text.length));\n while (newText.length > 1 && oldText.length > 1) {\n if (lst(newText) == lst(oldText)) { newText.pop(); oldText.pop(); toLine--; }\n else if (newText[0] == oldText[0]) { newText.shift(); oldText.shift(); fromLine++; }\n else { break }\n }\n\n var cutFront = 0, cutEnd = 0;\n var newTop = newText[0], oldTop = oldText[0], maxCutFront = Math.min(newTop.length, oldTop.length);\n while (cutFront < maxCutFront && newTop.charCodeAt(cutFront) == oldTop.charCodeAt(cutFront))\n { ++cutFront; }\n var newBot = lst(newText), oldBot = lst(oldText);\n var maxCutEnd = Math.min(newBot.length - (newText.length == 1 ? cutFront : 0),\n oldBot.length - (oldText.length == 1 ? cutFront : 0));\n while (cutEnd < maxCutEnd &&\n newBot.charCodeAt(newBot.length - cutEnd - 1) == oldBot.charCodeAt(oldBot.length - cutEnd - 1))\n { ++cutEnd; }\n // Try to move start of change to start of selection if ambiguous\n if (newText.length == 1 && oldText.length == 1 && fromLine == from.line) {\n while (cutFront && cutFront > from.ch &&\n newBot.charCodeAt(newBot.length - cutEnd - 1) == oldBot.charCodeAt(oldBot.length - cutEnd - 1)) {\n cutFront--;\n cutEnd++;\n }\n }\n\n newText[newText.length - 1] = newBot.slice(0, newBot.length - cutEnd).replace(/^\\u200b+/, \"\");\n newText[0] = newText[0].slice(cutFront).replace(/\\u200b+$/, \"\");\n\n var chFrom = Pos(fromLine, cutFront);\n var chTo = Pos(toLine, oldText.length ? lst(oldText).length - cutEnd : 0);\n if (newText.length > 1 || newText[0] || cmp(chFrom, chTo)) {\n replaceRange(cm.doc, newText, chFrom, chTo, \"+input\");\n return true\n }\n };\n\n ContentEditableInput.prototype.ensurePolled = function () {\n this.forceCompositionEnd();\n };\n ContentEditableInput.prototype.reset = function () {\n this.forceCompositionEnd();\n };\n ContentEditableInput.prototype.forceCompositionEnd = function () {\n if (!this.composing) { return }\n clearTimeout(this.readDOMTimeout);\n this.composing = null;\n this.updateFromDOM();\n this.div.blur();\n this.div.focus();\n };\n ContentEditableInput.prototype.readFromDOMSoon = function () {\n var this$1 = this;\n\n if (this.readDOMTimeout != null) { return }\n this.readDOMTimeout = setTimeout(function () {\n this$1.readDOMTimeout = null;\n if (this$1.composing) {\n if (this$1.composing.done) { this$1.composing = null; }\n else { return }\n }\n this$1.updateFromDOM();\n }, 80);\n };\n\n ContentEditableInput.prototype.updateFromDOM = function () {\n var this$1 = this;\n\n if (this.cm.isReadOnly() || !this.pollContent())\n { runInOp(this.cm, function () { return regChange(this$1.cm); }); }\n };\n\n ContentEditableInput.prototype.setUneditable = function (node) {\n node.contentEditable = \"false\";\n };\n\n ContentEditableInput.prototype.onKeyPress = function (e) {\n if (e.charCode == 0 || this.composing) { return }\n e.preventDefault();\n if (!this.cm.isReadOnly())\n { operation(this.cm, applyTextInput)(this.cm, String.fromCharCode(e.charCode == null ? e.keyCode : e.charCode), 0); }\n };\n\n ContentEditableInput.prototype.readOnlyChanged = function (val) {\n this.div.contentEditable = String(val != \"nocursor\");\n };\n\n ContentEditableInput.prototype.onContextMenu = function () {};\n ContentEditableInput.prototype.resetPosition = function () {};\n\n ContentEditableInput.prototype.needsContentAttribute = true;\n\n function posToDOM(cm, pos) {\n var view = findViewForLine(cm, pos.line);\n if (!view || view.hidden) { return null }\n var line = getLine(cm.doc, pos.line);\n var info = mapFromLineView(view, line, pos.line);\n\n var order = getOrder(line, cm.doc.direction), side = \"left\";\n if (order) {\n var partPos = getBidiPartAt(order, pos.ch);\n side = partPos % 2 ? \"right\" : \"left\";\n }\n var result = nodeAndOffsetInLineMap(info.map, pos.ch, side);\n result.offset = result.collapse == \"right\" ? result.end : result.start;\n return result\n }\n\n function isInGutter(node) {\n for (var scan = node; scan; scan = scan.parentNode)\n { if (/CodeMirror-gutter-wrapper/.test(scan.className)) { return true } }\n return false\n }\n\n function badPos(pos, bad) { if (bad) { pos.bad = true; } return pos }\n\n function domTextBetween(cm, from, to, fromLine, toLine) {\n var text = \"\", closing = false, lineSep = cm.doc.lineSeparator(), extraLinebreak = false;\n function recognizeMarker(id) { return function (marker) { return marker.id == id; } }\n function close() {\n if (closing) {\n text += lineSep;\n if (extraLinebreak) { text += lineSep; }\n closing = extraLinebreak = false;\n }\n }\n function addText(str) {\n if (str) {\n close();\n text += str;\n }\n }\n function walk(node) {\n if (node.nodeType == 1) {\n var cmText = node.getAttribute(\"cm-text\");\n if (cmText) {\n addText(cmText);\n return\n }\n var markerID = node.getAttribute(\"cm-marker\"), range$$1;\n if (markerID) {\n var found = cm.findMarks(Pos(fromLine, 0), Pos(toLine + 1, 0), recognizeMarker(+markerID));\n if (found.length && (range$$1 = found[0].find(0)))\n { addText(getBetween(cm.doc, range$$1.from, range$$1.to).join(lineSep)); }\n return\n }\n if (node.getAttribute(\"contenteditable\") == \"false\") { return }\n var isBlock = /^(pre|div|p|li|table|br)$/i.test(node.nodeName);\n if (!/^br$/i.test(node.nodeName) && node.textContent.length == 0) { return }\n\n if (isBlock) { close(); }\n for (var i = 0; i < node.childNodes.length; i++)\n { walk(node.childNodes[i]); }\n\n if (/^(pre|p)$/i.test(node.nodeName)) { extraLinebreak = true; }\n if (isBlock) { closing = true; }\n } else if (node.nodeType == 3) {\n addText(node.nodeValue.replace(/\\u200b/g, \"\").replace(/\\u00a0/g, \" \"));\n }\n }\n for (;;) {\n walk(from);\n if (from == to) { break }\n from = from.nextSibling;\n extraLinebreak = false;\n }\n return text\n }\n\n function domToPos(cm, node, offset) {\n var lineNode;\n if (node == cm.display.lineDiv) {\n lineNode = cm.display.lineDiv.childNodes[offset];\n if (!lineNode) { return badPos(cm.clipPos(Pos(cm.display.viewTo - 1)), true) }\n node = null; offset = 0;\n } else {\n for (lineNode = node;; lineNode = lineNode.parentNode) {\n if (!lineNode || lineNode == cm.display.lineDiv) { return null }\n if (lineNode.parentNode && lineNode.parentNode == cm.display.lineDiv) { break }\n }\n }\n for (var i = 0; i < cm.display.view.length; i++) {\n var lineView = cm.display.view[i];\n if (lineView.node == lineNode)\n { return locateNodeInLineView(lineView, node, offset) }\n }\n }\n\n function locateNodeInLineView(lineView, node, offset) {\n var wrapper = lineView.text.firstChild, bad = false;\n if (!node || !contains(wrapper, node)) { return badPos(Pos(lineNo(lineView.line), 0), true) }\n if (node == wrapper) {\n bad = true;\n node = wrapper.childNodes[offset];\n offset = 0;\n if (!node) {\n var line = lineView.rest ? lst(lineView.rest) : lineView.line;\n return badPos(Pos(lineNo(line), line.text.length), bad)\n }\n }\n\n var textNode = node.nodeType == 3 ? node : null, topNode = node;\n if (!textNode && node.childNodes.length == 1 && node.firstChild.nodeType == 3) {\n textNode = node.firstChild;\n if (offset) { offset = textNode.nodeValue.length; }\n }\n while (topNode.parentNode != wrapper) { topNode = topNode.parentNode; }\n var measure = lineView.measure, maps = measure.maps;\n\n function find(textNode, topNode, offset) {\n for (var i = -1; i < (maps ? maps.length : 0); i++) {\n var map$$1 = i < 0 ? measure.map : maps[i];\n for (var j = 0; j < map$$1.length; j += 3) {\n var curNode = map$$1[j + 2];\n if (curNode == textNode || curNode == topNode) {\n var line = lineNo(i < 0 ? lineView.line : lineView.rest[i]);\n var ch = map$$1[j] + offset;\n if (offset < 0 || curNode != textNode) { ch = map$$1[j + (offset ? 1 : 0)]; }\n return Pos(line, ch)\n }\n }\n }\n }\n var found = find(textNode, topNode, offset);\n if (found) { return badPos(found, bad) }\n\n // FIXME this is all really shaky. might handle the few cases it needs to handle, but likely to cause problems\n for (var after = topNode.nextSibling, dist = textNode ? textNode.nodeValue.length - offset : 0; after; after = after.nextSibling) {\n found = find(after, after.firstChild, 0);\n if (found)\n { return badPos(Pos(found.line, found.ch - dist), bad) }\n else\n { dist += after.textContent.length; }\n }\n for (var before = topNode.previousSibling, dist$1 = offset; before; before = before.previousSibling) {\n found = find(before, before.firstChild, -1);\n if (found)\n { return badPos(Pos(found.line, found.ch + dist$1), bad) }\n else\n { dist$1 += before.textContent.length; }\n }\n }\n\n // TEXTAREA INPUT STYLE\n\n var TextareaInput = function(cm) {\n this.cm = cm;\n // See input.poll and input.reset\n this.prevInput = \"\";\n\n // Flag that indicates whether we expect input to appear real soon\n // now (after some event like 'keypress' or 'input') and are\n // polling intensively.\n this.pollingFast = false;\n // Self-resetting timeout for the poller\n this.polling = new Delayed();\n // Used to work around IE issue with selection being forgotten when focus moves away from textarea\n this.hasSelection = false;\n this.composing = null;\n };\n\n TextareaInput.prototype.init = function (display) {\n var this$1 = this;\n\n var input = this, cm = this.cm;\n this.createField(display);\n var te = this.textarea;\n\n display.wrapper.insertBefore(this.wrapper, display.wrapper.firstChild);\n\n // Needed to hide big blue blinking cursor on Mobile Safari (doesn't seem to work in iOS 8 anymore)\n if (ios) { te.style.width = \"0px\"; }\n\n on(te, \"input\", function () {\n if (ie && ie_version >= 9 && this$1.hasSelection) { this$1.hasSelection = null; }\n input.poll();\n });\n\n on(te, \"paste\", function (e) {\n if (signalDOMEvent(cm, e) || handlePaste(e, cm)) { return }\n\n cm.state.pasteIncoming = +new Date;\n input.fastPoll();\n });\n\n function prepareCopyCut(e) {\n if (signalDOMEvent(cm, e)) { return }\n if (cm.somethingSelected()) {\n setLastCopied({lineWise: false, text: cm.getSelections()});\n } else if (!cm.options.lineWiseCopyCut) {\n return\n } else {\n var ranges = copyableRanges(cm);\n setLastCopied({lineWise: true, text: ranges.text});\n if (e.type == \"cut\") {\n cm.setSelections(ranges.ranges, null, sel_dontScroll);\n } else {\n input.prevInput = \"\";\n te.value = ranges.text.join(\"\\n\");\n selectInput(te);\n }\n }\n if (e.type == \"cut\") { cm.state.cutIncoming = +new Date; }\n }\n on(te, \"cut\", prepareCopyCut);\n on(te, \"copy\", prepareCopyCut);\n\n on(display.scroller, \"paste\", function (e) {\n if (eventInWidget(display, e) || signalDOMEvent(cm, e)) { return }\n if (!te.dispatchEvent) {\n cm.state.pasteIncoming = +new Date;\n input.focus();\n return\n }\n\n // Pass the `paste` event to the textarea so it's handled by its event listener.\n var event = new Event(\"paste\");\n event.clipboardData = e.clipboardData;\n te.dispatchEvent(event);\n });\n\n // Prevent normal selection in the editor (we handle our own)\n on(display.lineSpace, \"selectstart\", function (e) {\n if (!eventInWidget(display, e)) { e_preventDefault(e); }\n });\n\n on(te, \"compositionstart\", function () {\n var start = cm.getCursor(\"from\");\n if (input.composing) { input.composing.range.clear(); }\n input.composing = {\n start: start,\n range: cm.markText(start, cm.getCursor(\"to\"), {className: \"CodeMirror-composing\"})\n };\n });\n on(te, \"compositionend\", function () {\n if (input.composing) {\n input.poll();\n input.composing.range.clear();\n input.composing = null;\n }\n });\n };\n\n TextareaInput.prototype.createField = function (_display) {\n // Wraps and hides input textarea\n this.wrapper = hiddenTextarea();\n // The semihidden textarea that is focused when the editor is\n // focused, and receives input.\n this.textarea = this.wrapper.firstChild;\n };\n\n TextareaInput.prototype.prepareSelection = function () {\n // Redraw the selection and/or cursor\n var cm = this.cm, display = cm.display, doc = cm.doc;\n var result = prepareSelection(cm);\n\n // Move the hidden textarea near the cursor to prevent scrolling artifacts\n if (cm.options.moveInputWithCursor) {\n var headPos = cursorCoords(cm, doc.sel.primary().head, \"div\");\n var wrapOff = display.wrapper.getBoundingClientRect(), lineOff = display.lineDiv.getBoundingClientRect();\n result.teTop = Math.max(0, Math.min(display.wrapper.clientHeight - 10,\n headPos.top + lineOff.top - wrapOff.top));\n result.teLeft = Math.max(0, Math.min(display.wrapper.clientWidth - 10,\n headPos.left + lineOff.left - wrapOff.left));\n }\n\n return result\n };\n\n TextareaInput.prototype.showSelection = function (drawn) {\n var cm = this.cm, display = cm.display;\n removeChildrenAndAdd(display.cursorDiv, drawn.cursors);\n removeChildrenAndAdd(display.selectionDiv, drawn.selection);\n if (drawn.teTop != null) {\n this.wrapper.style.top = drawn.teTop + \"px\";\n this.wrapper.style.left = drawn.teLeft + \"px\";\n }\n };\n\n // Reset the input to correspond to the selection (or to be empty,\n // when not typing and nothing is selected)\n TextareaInput.prototype.reset = function (typing) {\n if (this.contextMenuPending || this.composing) { return }\n var cm = this.cm;\n if (cm.somethingSelected()) {\n this.prevInput = \"\";\n var content = cm.getSelection();\n this.textarea.value = content;\n if (cm.state.focused) { selectInput(this.textarea); }\n if (ie && ie_version >= 9) { this.hasSelection = content; }\n } else if (!typing) {\n this.prevInput = this.textarea.value = \"\";\n if (ie && ie_version >= 9) { this.hasSelection = null; }\n }\n };\n\n TextareaInput.prototype.getField = function () { return this.textarea };\n\n TextareaInput.prototype.supportsTouch = function () { return false };\n\n TextareaInput.prototype.focus = function () {\n if (this.cm.options.readOnly != \"nocursor\" && (!mobile || activeElt() != this.textarea)) {\n try { this.textarea.focus(); }\n catch (e) {} // IE8 will throw if the textarea is display: none or not in DOM\n }\n };\n\n TextareaInput.prototype.blur = function () { this.textarea.blur(); };\n\n TextareaInput.prototype.resetPosition = function () {\n this.wrapper.style.top = this.wrapper.style.left = 0;\n };\n\n TextareaInput.prototype.receivedFocus = function () { this.slowPoll(); };\n\n // Poll for input changes, using the normal rate of polling. This\n // runs as long as the editor is focused.\n TextareaInput.prototype.slowPoll = function () {\n var this$1 = this;\n\n if (this.pollingFast) { return }\n this.polling.set(this.cm.options.pollInterval, function () {\n this$1.poll();\n if (this$1.cm.state.focused) { this$1.slowPoll(); }\n });\n };\n\n // When an event has just come in that is likely to add or change\n // something in the input textarea, we poll faster, to ensure that\n // the change appears on the screen quickly.\n TextareaInput.prototype.fastPoll = function () {\n var missed = false, input = this;\n input.pollingFast = true;\n function p() {\n var changed = input.poll();\n if (!changed && !missed) {missed = true; input.polling.set(60, p);}\n else {input.pollingFast = false; input.slowPoll();}\n }\n input.polling.set(20, p);\n };\n\n // Read input from the textarea, and update the document to match.\n // When something is selected, it is present in the textarea, and\n // selected (unless it is huge, in which case a placeholder is\n // used). When nothing is selected, the cursor sits after previously\n // seen text (can be empty), which is stored in prevInput (we must\n // not reset the textarea when typing, because that breaks IME).\n TextareaInput.prototype.poll = function () {\n var this$1 = this;\n\n var cm = this.cm, input = this.textarea, prevInput = this.prevInput;\n // Since this is called a *lot*, try to bail out as cheaply as\n // possible when it is clear that nothing happened. hasSelection\n // will be the case when there is a lot of text in the textarea,\n // in which case reading its value would be expensive.\n if (this.contextMenuPending || !cm.state.focused ||\n (hasSelection(input) && !prevInput && !this.composing) ||\n cm.isReadOnly() || cm.options.disableInput || cm.state.keySeq)\n { return false }\n\n var text = input.value;\n // If nothing changed, bail.\n if (text == prevInput && !cm.somethingSelected()) { return false }\n // Work around nonsensical selection resetting in IE9/10, and\n // inexplicable appearance of private area unicode characters on\n // some key combos in Mac (#2689).\n if (ie && ie_version >= 9 && this.hasSelection === text ||\n mac && /[\\uf700-\\uf7ff]/.test(text)) {\n cm.display.input.reset();\n return false\n }\n\n if (cm.doc.sel == cm.display.selForContextMenu) {\n var first = text.charCodeAt(0);\n if (first == 0x200b && !prevInput) { prevInput = \"\\u200b\"; }\n if (first == 0x21da) { this.reset(); return this.cm.execCommand(\"undo\") }\n }\n // Find the part of the input that is actually new\n var same = 0, l = Math.min(prevInput.length, text.length);\n while (same < l && prevInput.charCodeAt(same) == text.charCodeAt(same)) { ++same; }\n\n runInOp(cm, function () {\n applyTextInput(cm, text.slice(same), prevInput.length - same,\n null, this$1.composing ? \"*compose\" : null);\n\n // Don't leave long text in the textarea, since it makes further polling slow\n if (text.length > 1000 || text.indexOf(\"\\n\") > -1) { input.value = this$1.prevInput = \"\"; }\n else { this$1.prevInput = text; }\n\n if (this$1.composing) {\n this$1.composing.range.clear();\n this$1.composing.range = cm.markText(this$1.composing.start, cm.getCursor(\"to\"),\n {className: \"CodeMirror-composing\"});\n }\n });\n return true\n };\n\n TextareaInput.prototype.ensurePolled = function () {\n if (this.pollingFast && this.poll()) { this.pollingFast = false; }\n };\n\n TextareaInput.prototype.onKeyPress = function () {\n if (ie && ie_version >= 9) { this.hasSelection = null; }\n this.fastPoll();\n };\n\n TextareaInput.prototype.onContextMenu = function (e) {\n var input = this, cm = input.cm, display = cm.display, te = input.textarea;\n if (input.contextMenuPending) { input.contextMenuPending(); }\n var pos = posFromMouse(cm, e), scrollPos = display.scroller.scrollTop;\n if (!pos || presto) { return } // Opera is difficult.\n\n // Reset the current text selection only if the click is done outside of the selection\n // and 'resetSelectionOnContextMenu' option is true.\n var reset = cm.options.resetSelectionOnContextMenu;\n if (reset && cm.doc.sel.contains(pos) == -1)\n { operation(cm, setSelection)(cm.doc, simpleSelection(pos), sel_dontScroll); }\n\n var oldCSS = te.style.cssText, oldWrapperCSS = input.wrapper.style.cssText;\n var wrapperBox = input.wrapper.offsetParent.getBoundingClientRect();\n input.wrapper.style.cssText = \"position: static\";\n te.style.cssText = \"position: absolute; width: 30px; height: 30px;\\n top: \" + (e.clientY - wrapperBox.top - 5) + \"px; left: \" + (e.clientX - wrapperBox.left - 5) + \"px;\\n z-index: 1000; background: \" + (ie ? \"rgba(255, 255, 255, .05)\" : \"transparent\") + \";\\n outline: none; border-width: 0; outline: none; overflow: hidden; opacity: .05; filter: alpha(opacity=5);\";\n var oldScrollY;\n if (webkit) { oldScrollY = window.scrollY; } // Work around Chrome issue (#2712)\n display.input.focus();\n if (webkit) { window.scrollTo(null, oldScrollY); }\n display.input.reset();\n // Adds \"Select all\" to context menu in FF\n if (!cm.somethingSelected()) { te.value = input.prevInput = \" \"; }\n input.contextMenuPending = rehide;\n display.selForContextMenu = cm.doc.sel;\n clearTimeout(display.detectingSelectAll);\n\n // Select-all will be greyed out if there's nothing to select, so\n // this adds a zero-width space so that we can later check whether\n // it got selected.\n function prepareSelectAllHack() {\n if (te.selectionStart != null) {\n var selected = cm.somethingSelected();\n var extval = \"\\u200b\" + (selected ? te.value : \"\");\n te.value = \"\\u21da\"; // Used to catch context-menu undo\n te.value = extval;\n input.prevInput = selected ? \"\" : \"\\u200b\";\n te.selectionStart = 1; te.selectionEnd = extval.length;\n // Re-set this, in case some other handler touched the\n // selection in the meantime.\n display.selForContextMenu = cm.doc.sel;\n }\n }\n function rehide() {\n if (input.contextMenuPending != rehide) { return }\n input.contextMenuPending = false;\n input.wrapper.style.cssText = oldWrapperCSS;\n te.style.cssText = oldCSS;\n if (ie && ie_version < 9) { display.scrollbars.setScrollTop(display.scroller.scrollTop = scrollPos); }\n\n // Try to detect the user choosing select-all\n if (te.selectionStart != null) {\n if (!ie || (ie && ie_version < 9)) { prepareSelectAllHack(); }\n var i = 0, poll = function () {\n if (display.selForContextMenu == cm.doc.sel && te.selectionStart == 0 &&\n te.selectionEnd > 0 && input.prevInput == \"\\u200b\") {\n operation(cm, selectAll)(cm);\n } else if (i++ < 10) {\n display.detectingSelectAll = setTimeout(poll, 500);\n } else {\n display.selForContextMenu = null;\n display.input.reset();\n }\n };\n display.detectingSelectAll = setTimeout(poll, 200);\n }\n }\n\n if (ie && ie_version >= 9) { prepareSelectAllHack(); }\n if (captureRightClick) {\n e_stop(e);\n var mouseup = function () {\n off(window, \"mouseup\", mouseup);\n setTimeout(rehide, 20);\n };\n on(window, \"mouseup\", mouseup);\n } else {\n setTimeout(rehide, 50);\n }\n };\n\n TextareaInput.prototype.readOnlyChanged = function (val) {\n if (!val) { this.reset(); }\n this.textarea.disabled = val == \"nocursor\";\n };\n\n TextareaInput.prototype.setUneditable = function () {};\n\n TextareaInput.prototype.needsContentAttribute = false;\n\n function fromTextArea(textarea, options) {\n options = options ? copyObj(options) : {};\n options.value = textarea.value;\n if (!options.tabindex && textarea.tabIndex)\n { options.tabindex = textarea.tabIndex; }\n if (!options.placeholder && textarea.placeholder)\n { options.placeholder = textarea.placeholder; }\n // Set autofocus to true if this textarea is focused, or if it has\n // autofocus and no other element is focused.\n if (options.autofocus == null) {\n var hasFocus = activeElt();\n options.autofocus = hasFocus == textarea ||\n textarea.getAttribute(\"autofocus\") != null && hasFocus == document.body;\n }\n\n function save() {textarea.value = cm.getValue();}\n\n var realSubmit;\n if (textarea.form) {\n on(textarea.form, \"submit\", save);\n // Deplorable hack to make the submit method do the right thing.\n if (!options.leaveSubmitMethodAlone) {\n var form = textarea.form;\n realSubmit = form.submit;\n try {\n var wrappedSubmit = form.submit = function () {\n save();\n form.submit = realSubmit;\n form.submit();\n form.submit = wrappedSubmit;\n };\n } catch(e) {}\n }\n }\n\n options.finishInit = function (cm) {\n cm.save = save;\n cm.getTextArea = function () { return textarea; };\n cm.toTextArea = function () {\n cm.toTextArea = isNaN; // Prevent this from being ran twice\n save();\n textarea.parentNode.removeChild(cm.getWrapperElement());\n textarea.style.display = \"\";\n if (textarea.form) {\n off(textarea.form, \"submit\", save);\n if (typeof textarea.form.submit == \"function\")\n { textarea.form.submit = realSubmit; }\n }\n };\n };\n\n textarea.style.display = \"none\";\n var cm = CodeMirror(function (node) { return textarea.parentNode.insertBefore(node, textarea.nextSibling); },\n options);\n return cm\n }\n\n function addLegacyProps(CodeMirror) {\n CodeMirror.off = off;\n CodeMirror.on = on;\n CodeMirror.wheelEventPixels = wheelEventPixels;\n CodeMirror.Doc = Doc;\n CodeMirror.splitLines = splitLinesAuto;\n CodeMirror.countColumn = countColumn;\n CodeMirror.findColumn = findColumn;\n CodeMirror.isWordChar = isWordCharBasic;\n CodeMirror.Pass = Pass;\n CodeMirror.signal = signal;\n CodeMirror.Line = Line;\n CodeMirror.changeEnd = changeEnd;\n CodeMirror.scrollbarModel = scrollbarModel;\n CodeMirror.Pos = Pos;\n CodeMirror.cmpPos = cmp;\n CodeMirror.modes = modes;\n CodeMirror.mimeModes = mimeModes;\n CodeMirror.resolveMode = resolveMode;\n CodeMirror.getMode = getMode;\n CodeMirror.modeExtensions = modeExtensions;\n CodeMirror.extendMode = extendMode;\n CodeMirror.copyState = copyState;\n CodeMirror.startState = startState;\n CodeMirror.innerMode = innerMode;\n CodeMirror.commands = commands;\n CodeMirror.keyMap = keyMap;\n CodeMirror.keyName = keyName;\n CodeMirror.isModifierKey = isModifierKey;\n CodeMirror.lookupKey = lookupKey;\n CodeMirror.normalizeKeyMap = normalizeKeyMap;\n CodeMirror.StringStream = StringStream;\n CodeMirror.SharedTextMarker = SharedTextMarker;\n CodeMirror.TextMarker = TextMarker;\n CodeMirror.LineWidget = LineWidget;\n CodeMirror.e_preventDefault = e_preventDefault;\n CodeMirror.e_stopPropagation = e_stopPropagation;\n CodeMirror.e_stop = e_stop;\n CodeMirror.addClass = addClass;\n CodeMirror.contains = contains;\n CodeMirror.rmClass = rmClass;\n CodeMirror.keyNames = keyNames;\n }\n\n // EDITOR CONSTRUCTOR\n\n defineOptions(CodeMirror);\n\n addEditorMethods(CodeMirror);\n\n // Set up methods on CodeMirror's prototype to redirect to the editor's document.\n var dontDelegate = \"iter insert remove copy getEditor constructor\".split(\" \");\n for (var prop in Doc.prototype) { if (Doc.prototype.hasOwnProperty(prop) && indexOf(dontDelegate, prop) < 0)\n { CodeMirror.prototype[prop] = (function(method) {\n return function() {return method.apply(this.doc, arguments)}\n })(Doc.prototype[prop]); } }\n\n eventMixin(Doc);\n CodeMirror.inputStyles = {\"textarea\": TextareaInput, \"contenteditable\": ContentEditableInput};\n\n // Extra arguments are stored as the mode's dependencies, which is\n // used by (legacy) mechanisms like loadmode.js to automatically\n // load a mode. (Preferred mechanism is the require/define calls.)\n CodeMirror.defineMode = function(name/*, mode, …*/) {\n if (!CodeMirror.defaults.mode && name != \"null\") { CodeMirror.defaults.mode = name; }\n defineMode.apply(this, arguments);\n };\n\n CodeMirror.defineMIME = defineMIME;\n\n // Minimal default mode.\n CodeMirror.defineMode(\"null\", function () { return ({token: function (stream) { return stream.skipToEnd(); }}); });\n CodeMirror.defineMIME(\"text/plain\", \"null\");\n\n // EXTENSIONS\n\n CodeMirror.defineExtension = function (name, func) {\n CodeMirror.prototype[name] = func;\n };\n CodeMirror.defineDocExtension = function (name, func) {\n Doc.prototype[name] = func;\n };\n\n CodeMirror.fromTextArea = fromTextArea;\n\n addLegacyProps(CodeMirror);\n\n CodeMirror.version = \"5.48.4\";\n\n return CodeMirror;\n\n})));\n","// DOM helpers\nimport { each, isUndefined } from 'underscore';\n\nconst KEY_TAG = 'tag';\nconst KEY_ATTR = 'attributes';\nconst KEY_CHILD = 'children';\n\nexport const empty = node => {\n while (node.firstChild) node.removeChild(node.firstChild);\n};\n\nexport const replaceWith = (oldEl, newEl) => {\n oldEl.parentNode.replaceChild(newEl, oldEl);\n};\n\nexport const appendAtIndex = (parent, child, index) => {\n const { childNodes } = parent;\n const total = childNodes.length;\n const at = isUndefined(index) ? total : index;\n\n if (at >= total) {\n parent.appendChild(child);\n } else {\n parent.insertBefore(child, childNodes[at]);\n }\n};\n\n/**\n * Append an array of vNodes to an element\n * @param {HTMLElement} node HTML element\n * @param {Array} vNodes Array of node objects\n */\nexport const appendVNodes = (node, vNodes = []) => {\n const vNodesArr = Array.isArray(vNodes) ? vNodes : [vNodes];\n vNodesArr.forEach(vnode => {\n const tag = vnode[KEY_TAG] || 'div';\n const attr = vnode[KEY_ATTR] || {};\n const el = document.createElement(tag);\n\n each(attr, (value, key) => {\n el.setAttribute(key, value);\n });\n\n node.appendChild(el);\n });\n};\n","import Backbone from 'backbone';\n\nexport default Backbone.View.extend({\n events() {\n return (\n this.model.get('events') || {\n mousedown: 'handleClick'\n }\n );\n },\n\n attributes() {\n return this.model.get('attributes');\n },\n\n initialize(opts) {\n this.editor = opts.config.editor;\n },\n\n handleClick(event) {\n event.preventDefault();\n event.stopPropagation();\n this.execCommand(event);\n },\n\n execCommand(event) {\n const opts = { event };\n const command = this.model.get('command');\n const editor = this.editor;\n\n if (typeof command === 'function') {\n command(editor, null, opts);\n }\n\n if (typeof command === 'string') {\n editor.runCommand(command, opts);\n }\n },\n\n render() {\n const { editor, $el, model } = this;\n const id = model.get('id');\n const label = model.get('label');\n const pfx = editor.getConfig('stylePrefix');\n $el.addClass(`${pfx}toolbar-item`);\n id && $el.addClass(`${pfx}toolbar-item__${id}`);\n label && $el.append(label);\n return this;\n }\n});\n","import DomainViews from 'domain_abstract/view/DomainViews';\nimport ToolbarButtonView from './ToolbarButtonView';\n\nexport default DomainViews.extend({\n itemView: ToolbarButtonView,\n\n initialize(opts) {\n this.config = { editor: opts.editor || '' };\n this.listenTo(this.collection, 'reset', this.render);\n }\n});\n","import Backbone from 'backbone';\n\nexport default Backbone.Model.extend({\n defaults: {\n command: '',\n attributes: {}\n }\n});\n","import Backbone from 'backbone';\nimport ToolbarButton from './ToolbarButton';\n\nexport default Backbone.Collection.extend({ model: ToolbarButton });\n","import Backbone from 'backbone';\nimport { bindAll, isElement, isUndefined } from 'underscore';\nimport { on, off, getUnitFromValue, isTaggableNode } from 'utils/mixins';\nimport ToolbarView from 'dom_components/view/ToolbarView';\nimport Toolbar from 'dom_components/model/Toolbar';\n\nconst $ = Backbone.$;\nlet showOffsets;\n\nexport default {\n init(o) {\n bindAll(this, 'onHover', 'onOut', 'onClick', 'onFrameScroll');\n },\n\n enable() {\n this.frameOff = this.canvasOff = this.adjScroll = null;\n this.startSelectComponent();\n const { em } = this.config;\n showOffsets = 1;\n\n em.on('component:update', this.updateAttached, this);\n em.on('change:canvasOffset', this.updateAttached, this);\n },\n\n /**\n * Start select component event\n * @private\n * */\n startSelectComponent() {\n this.toggleSelectComponent(1);\n },\n\n /**\n * Stop select component event\n * @private\n * */\n stopSelectComponent() {\n this.toggleSelectComponent();\n },\n\n /**\n * Toggle select component event\n * @private\n * */\n toggleSelectComponent(enable) {\n const { em } = this;\n const method = enable ? 'on' : 'off';\n const methods = { on, off };\n const body = this.getCanvasBody();\n const win = this.getContentWindow();\n methods[method](body, 'mouseover', this.onHover);\n methods[method](body, 'mouseout', this.onOut);\n methods[method](body, 'click touchend', this.onClick);\n methods[method](win, 'scroll resize', this.onFrameScroll);\n em[method]('component:toggled', this.onSelect, this);\n em[method]('change:componentHovered', this.onHovered, this);\n },\n\n /**\n * Hover command\n * @param {Object} e\n * @private\n */\n onHover(e) {\n e.stopPropagation();\n let trg = e.target;\n let $el = $(trg);\n let model = $el.data('model');\n\n if (!model) {\n let parent = $el.parent();\n while (!model && parent.length > 0) {\n model = parent.data('model');\n parent = parent.parent();\n }\n }\n\n // Adjust tools scroll top\n if (!this.adjScroll) {\n this.adjScroll = 1;\n this.updateAttached();\n }\n\n if (model && !model.get('hoverable')) {\n let parent = model && model.parent();\n while (parent && !parent.get('hoverable')) parent = parent.parent();\n model = parent;\n }\n\n this.em.setHovered(model, { forceChange: 1 });\n },\n\n onHovered(em, component) {\n const trg = component && component.getEl();\n if (trg) {\n const pos = this.getElementPos(trg);\n this.updateBadge(trg, pos);\n this.updateHighlighter(trg, pos);\n this.showElementOffset(trg, pos);\n }\n },\n\n /**\n * Out command\n * @param {Object} e\n * @private\n */\n onOut(ev) {\n ev && ev.stopPropagation();\n this.hideBadge();\n this.hideHighlighter();\n this.hideElementOffset();\n },\n\n /**\n * Show element offset viewer\n * @param {HTMLElement} el\n * @param {Object} pos\n */\n showElementOffset(el, pos) {\n var $el = $(el);\n var model = $el.data('model');\n\n if ((model && model.get('status') == 'selected') || !showOffsets) {\n return;\n }\n\n this.editor.runCommand('show-offset', {\n el,\n elPos: pos,\n force: 1\n });\n },\n\n /**\n * Hide element offset viewer\n * @param {HTMLElement} el\n * @param {Object} pos\n */\n hideElementOffset(el, pos) {\n const { editor } = this;\n editor && editor.stopCommand('show-offset');\n },\n\n /**\n * Show fixed element offset viewer\n * @param {HTMLElement} el\n * @param {Object} pos\n */\n showFixedElementOffset(el, pos) {\n this.editor.runCommand('show-offset', {\n el,\n elPos: pos,\n state: 'Fixed'\n });\n },\n\n /**\n * Hide fixed element offset viewer\n * @param {HTMLElement} el\n * @param {Object} pos\n */\n hideFixedElementOffset(el, pos) {\n if (this.editor) this.editor.stopCommand('show-offset', { state: 'Fixed' });\n },\n\n /**\n * Hide Highlighter element\n */\n hideHighlighter() {\n this.canvas.getHighlighter().style.display = 'none';\n },\n\n /**\n * On element click\n * @param {Event} e\n * @private\n */\n onClick(e) {\n const { em } = this;\n e.stopPropagation();\n e.preventDefault();\n if (em.get('_cmpDrag')) return em.set('_cmpDrag');\n const $el = $(e.target);\n let model = $el.data('model');\n\n if (!model) {\n let parent = $el.parent();\n while (!model && parent.length > 0) {\n model = parent.data('model');\n parent = parent.parent();\n }\n }\n\n if (model) {\n if (model.get('selectable')) {\n this.select(model, e);\n } else {\n let parent = model.parent();\n while (parent && !parent.get('selectable')) parent = parent.parent();\n this.select(parent, e);\n }\n }\n },\n\n /**\n * Select component\n * @param {Component} model\n * @param {Event} event\n */\n select(model, event = {}) {\n if (!model) return;\n const ctrlKey = event.ctrlKey || event.metaKey;\n const shiftKey = event.shiftKey;\n const { editor } = this;\n const multiple = editor.getConfig('multipleSelection');\n const em = this.em;\n\n if (ctrlKey && multiple) {\n editor.selectToggle(model);\n } else if (shiftKey && multiple) {\n em.clearSelection(editor.Canvas.getWindow());\n const coll = model.collection;\n const index = coll.indexOf(model);\n const selAll = editor.getSelectedAll();\n let min, max;\n\n // Fin min and max siblings\n editor.getSelectedAll().forEach(sel => {\n const selColl = sel.collection;\n const selIndex = selColl.indexOf(sel);\n if (selColl === coll) {\n if (selIndex < index) {\n // First model BEFORE the selected one\n min = isUndefined(min) ? selIndex : Math.max(min, selIndex);\n } else if (selIndex > index) {\n // First model AFTER the selected one\n max = isUndefined(max) ? selIndex : Math.min(max, selIndex);\n }\n }\n });\n\n if (!isUndefined(min)) {\n while (min !== index) {\n editor.selectAdd(coll.at(min));\n min++;\n }\n }\n\n if (!isUndefined(max)) {\n while (max !== index) {\n editor.selectAdd(coll.at(max));\n max--;\n }\n }\n\n editor.selectAdd(model);\n } else {\n editor.select(model);\n }\n\n this.initResize(model);\n },\n\n /**\n * Update badge for the component\n * @param {Object} Component\n * @param {Object} pos Position object\n * @private\n * */\n updateBadge(el, pos) {\n var $el = $(el);\n var canvas = this.canvas;\n var config = canvas.getConfig();\n const ppfx = config.pStylePrefix || '';\n var customeLabel = config.customBadgeLabel;\n this.cacheEl = el;\n var model = $el.data('model');\n if (!model || !model.get('badgable')) return;\n var badge = this.getBadge();\n const icon = model.getIcon();\n const clsBadge = `${ppfx}badge`;\n let badgeLabel = `${\n icon ? `
${icon}
` : ''\n }\n
${model.getName()}
`;\n badgeLabel = customeLabel ? customeLabel(model) : badgeLabel;\n badge.innerHTML = badgeLabel;\n var bStyle = badge.style;\n var u = 'px';\n bStyle.display = 'block';\n var canvasPos = this.getCanvasPosition();\n\n if (canvasPos) {\n const canvasTop = canvasPos.top;\n const canvasLeft = canvasPos.left;\n const posTop = pos.top - (badge ? badge.offsetHeight : 0);\n const badgeW = badge ? badge.offsetWidth : 0;\n var top = posTop < canvasTop ? canvasTop : posTop;\n var left = pos.left + badgeW < canvasLeft ? canvasLeft : pos.left;\n bStyle.top = top + u;\n bStyle.left = left + u;\n }\n },\n\n /**\n * Update highlighter element\n * @param {HTMLElement} el\n * @param {Object} pos Position object\n * @private\n */\n updateHighlighter(el, pos) {\n var $el = $(el);\n var model = $el.data('model');\n\n if (\n !model ||\n !model.get('hoverable') ||\n model.get('status') == 'selected'\n ) {\n return;\n }\n\n var hlEl = this.canvas.getHighlighter();\n var hlStyle = hlEl.style;\n var unit = 'px';\n hlStyle.left = pos.left + unit;\n hlStyle.top = pos.top + unit;\n hlStyle.height = pos.height + unit;\n hlStyle.width = pos.width + unit;\n hlStyle.display = 'block';\n },\n\n /**\n * Say what to do after the component was selected\n * @param {Object} e\n * @param {Object} el\n * @private\n * */\n onSelect() {\n // Get the selected model directly from the Editor as the event might\n // be triggered manually without the model\n const model = this.em.getSelected();\n const view = model && model.view;\n this.updateToolbar(model);\n\n if (view) {\n const { el } = view;\n this.showFixedElementOffset(el);\n this.hideElementOffset();\n this.hideHighlighter();\n this.initResize(el);\n } else {\n this.editor.stopCommand('resize');\n }\n },\n\n /**\n * Init resizer on the element if possible\n * @param {HTMLElement|Component} elem\n * @private\n */\n initResize(elem) {\n const { em, canvas } = this;\n const editor = em ? em.get('Editor') : '';\n const config = em ? em.get('Config') : '';\n const pfx = config.stylePrefix || '';\n const resizeClass = `${pfx}resizing`;\n const model =\n !isElement(elem) && isTaggableNode(elem) ? elem : em.getSelected();\n const resizable = model.get('resizable');\n const el = isElement(elem) ? elem : model.getEl();\n let options = {};\n let modelToStyle;\n\n var toggleBodyClass = (method, e, opts) => {\n const docs = opts.docs;\n docs &&\n docs.forEach(doc => {\n const body = doc.body;\n const cls = body.className || '';\n body.className = (method == 'add'\n ? `${cls} ${resizeClass}`\n : cls.replace(resizeClass, '')\n ).trim();\n });\n };\n\n if (editor && resizable) {\n options = {\n // Here the resizer is updated with the current element height and width\n onStart(e, opts = {}) {\n const { el, config, resizer } = opts;\n const {\n keyHeight,\n keyWidth,\n currentUnit,\n keepAutoHeight,\n keepAutoWidth\n } = config;\n toggleBodyClass('add', e, opts);\n modelToStyle = em.get('StyleManager').getModelToStyle(model);\n const computedStyle = getComputedStyle(el);\n const modelStyle = modelToStyle.getStyle();\n\n let currentWidth = modelStyle[keyWidth];\n config.autoWidth = keepAutoWidth && currentWidth === 'auto';\n if (isNaN(parseFloat(currentWidth))) {\n currentWidth = computedStyle[keyWidth];\n }\n\n let currentHeight = modelStyle[keyHeight];\n config.autoHeight = keepAutoHeight && currentHeight === 'auto';\n if (isNaN(parseFloat(currentHeight))) {\n currentHeight = computedStyle[keyHeight];\n }\n\n resizer.startDim.w = parseFloat(currentWidth);\n resizer.startDim.h = parseFloat(currentHeight);\n showOffsets = 0;\n\n if (currentUnit) {\n config.unitHeight = getUnitFromValue(currentHeight);\n config.unitWidth = getUnitFromValue(currentWidth);\n }\n },\n\n // Update all positioned elements (eg. component toolbar)\n onMove() {\n editor.trigger('change:canvasOffset');\n },\n\n onEnd(e, opts) {\n toggleBodyClass('remove', e, opts);\n editor.trigger('change:canvasOffset');\n showOffsets = 1;\n },\n\n updateTarget(el, rect, options = {}) {\n if (!modelToStyle) {\n return;\n }\n\n const { store, selectedHandler, config } = options;\n const {\n keyHeight,\n keyWidth,\n autoHeight,\n autoWidth,\n unitWidth,\n unitHeight\n } = config;\n const onlyHeight = ['tc', 'bc'].indexOf(selectedHandler) >= 0;\n const onlyWidth = ['cl', 'cr'].indexOf(selectedHandler) >= 0;\n const style = modelToStyle.getStyle();\n\n if (!onlyHeight) {\n const bodyw = canvas.getBody().offsetWidth;\n const width = rect.w < bodyw ? rect.w : bodyw;\n style[keyWidth] = autoWidth ? 'auto' : `${width}${unitWidth}`;\n }\n\n if (!onlyWidth) {\n style[keyHeight] = autoHeight ? 'auto' : `${rect.h}${unitHeight}`;\n }\n\n modelToStyle.setStyle(style, { avoidStore: 1 });\n const updateEvent = `update:component:style`;\n em &&\n em.trigger(\n `${updateEvent}:${keyHeight} ${updateEvent}:${keyWidth}`\n );\n\n if (store) {\n modelToStyle.trigger('change:style', modelToStyle, style, {});\n }\n }\n };\n\n if (typeof resizable == 'object') {\n options = { ...options, ...resizable };\n }\n\n this.resizer = editor.runCommand('resize', { el, options, force: 1 });\n } else {\n editor.stopCommand('resize');\n this.resizer = null;\n }\n },\n\n /**\n * Update toolbar if the component has one\n * @param {Object} mod\n */\n updateToolbar(mod) {\n var em = this.config.em;\n var model = mod == em ? em.getSelected() : mod;\n var toolbarEl = this.canvas.getToolbarEl();\n var toolbarStyle = toolbarEl.style;\n\n if (!model) {\n // By putting `toolbarStyle.display = 'none'` will cause kind\n // of freezed effect with component selection (probably by iframe\n // switching)\n toolbarStyle.opacity = 0;\n return;\n }\n\n var toolbar = model.get('toolbar');\n var ppfx = this.ppfx;\n var showToolbar = em.get('Config').showToolbar;\n\n if (showToolbar && toolbar && toolbar.length) {\n toolbarStyle.opacity = '';\n toolbarStyle.display = '';\n if (!this.toolbar) {\n toolbarEl.innerHTML = '';\n this.toolbar = new Toolbar(toolbar);\n var toolbarView = new ToolbarView({\n collection: this.toolbar,\n editor: this.editor\n });\n toolbarEl.appendChild(toolbarView.render().el);\n }\n\n this.toolbar.reset(toolbar);\n const view = model.view;\n toolbarStyle.top = '-100px';\n toolbarStyle.left = 0;\n setTimeout(() => view && this.updateToolbarPos(view.el), 0);\n } else {\n toolbarStyle.display = 'none';\n }\n },\n\n /**\n * Update toolbar positions\n * @param {HTMLElement} el\n * @param {Object} pos\n */\n updateToolbarPos(el, elPos) {\n const { canvas } = this;\n const unit = 'px';\n const toolbarEl = canvas.getToolbarEl();\n const toolbarStyle = toolbarEl.style;\n toolbarStyle.opacity = 0;\n const pos = canvas.getTargetToElementDim(toolbarEl, el, {\n elPos,\n event: 'toolbarPosUpdate'\n });\n\n if (pos) {\n const frameOffset = canvas.getCanvasView().getFrameOffset();\n\n // Scroll with the window if the top edge is reached and the\n // element is bigger than the canvas\n if (\n pos.top <= pos.canvasTop &&\n !(pos.elementHeight + pos.targetHeight >= frameOffset.height)\n ) {\n pos.top = pos.elementTop + pos.elementHeight;\n }\n\n // Check left position of the toolbar\n const elRight = pos.elementLeft + pos.elementWidth;\n let left = elRight - pos.targetWidth;\n\n if (elRight > pos.canvasWidth) {\n left -= elRight - pos.canvasWidth;\n }\n\n left = left < 0 ? 0 : left;\n toolbarStyle.top = `${pos.top}${unit}`;\n toolbarStyle.left = `${left}${unit}`;\n toolbarStyle.opacity = '';\n }\n },\n\n /**\n * Return canvas dimensions and positions\n * @return {Object}\n */\n getCanvasPosition() {\n return this.canvas.getCanvasView().getPosition();\n },\n\n /**\n * Removes all highlighting effects on components\n * @private\n * */\n clean() {\n if (this.selEl) this.selEl.removeClass(this.hoverClass);\n },\n\n /**\n * Returns badge element\n * @return {HTMLElement}\n * @private\n */\n getBadge() {\n return this.canvas.getBadgeEl();\n },\n\n /**\n * On frame scroll callback\n * @private\n */\n onFrameScroll() {\n const el = this.cacheEl;\n\n if (el) {\n const elPos = this.getElementPos(el);\n this.updateBadge(el, elPos);\n const model = this.em.getSelected();\n const viewEl = model && model.getEl();\n viewEl && this.updateToolbarPos(viewEl);\n }\n },\n\n /**\n * Update attached elements, eg. component toolbar\n */\n updateAttached() {\n const { resizer, em } = this;\n const model = em.getSelected();\n const view = model && model.view;\n\n if (view) {\n const { el } = view;\n this.updateToolbarPos(el);\n this.showFixedElementOffset(el);\n resizer && resizer.updateContainer();\n }\n },\n\n /**\n * Returns element's data info\n * @param {HTMLElement} el\n * @return {Object}\n * @private\n */\n getElementPos(el, badge) {\n return this.canvas.getCanvasView().getElementPos(el);\n },\n\n /**\n * Hide badge\n * @private\n * */\n hideBadge() {\n this.getBadge().style.display = 'none';\n },\n\n /**\n * Clean previous model from different states\n * @param {Component} model\n * @private\n */\n cleanPrevious(model) {\n model &&\n model.set({\n status: '',\n state: ''\n });\n },\n\n /**\n * Returns content window\n * @private\n */\n getContentWindow() {\n return this.frameEl.contentWindow;\n },\n\n run(editor) {\n this.editor = editor && editor.get('Editor');\n this.enable();\n this.onSelect();\n },\n\n stop(ed, sender, opts = {}) {\n const { em, editor } = this;\n this.stopSelectComponent();\n !opts.preserveSelected && em.setSelected(null);\n this.clean();\n this.onOut();\n this.hideFixedElementOffset();\n this.canvas.getToolbarEl().style.display = 'none';\n editor && editor.stopCommand('resize');\n\n em.off('component:update', this.updateAttached, this);\n em.off('change:canvasOffset', this.updateAttached, this);\n }\n};\n","function _classCallCheck(instance, Constructor) {\n if (!(instance instanceof Constructor)) {\n throw new TypeError(\"Cannot call a class as a function\");\n }\n}\n\nmodule.exports = _classCallCheck;","function _defineProperties(target, props) {\n for (var i = 0; i < props.length; i++) {\n var descriptor = props[i];\n descriptor.enumerable = descriptor.enumerable || false;\n descriptor.configurable = true;\n if (\"value\" in descriptor) descriptor.writable = true;\n Object.defineProperty(target, descriptor.key, descriptor);\n }\n}\n\nfunction _createClass(Constructor, protoProps, staticProps) {\n if (protoProps) _defineProperties(Constructor.prototype, protoProps);\n if (staticProps) _defineProperties(Constructor, staticProps);\n return Constructor;\n}\n\nmodule.exports = _createClass;","import Backbone from 'backbone';\n\nconst $ = Backbone.$;\n\nexport default Backbone.View.extend({\n events: {\n change: 'handleChange'\n },\n\n template() {\n return ``;\n },\n\n inputClass() {\n return `${this.ppfx}field`;\n },\n\n holderClass() {\n return `${this.ppfx}input-holder`;\n },\n\n initialize(opts = {}) {\n const ppfx = opts.ppfx || '';\n this.opts = opts;\n this.ppfx = ppfx;\n this.em = opts.target || {};\n this.listenTo(this.model, 'change:value', this.handleModelChange);\n },\n\n /**\n * Fired when the element of the property is updated\n */\n elementUpdated() {\n this.model.trigger('el:change');\n },\n\n /**\n * Set value to the input element\n * @param {string} value\n */\n setValue(value) {\n const model = this.model;\n let val = value || model.get('defaults');\n const input = this.getInputEl();\n input && (input.value = val);\n },\n\n /**\n * Updates the view when the model is changed\n * */\n handleModelChange(model, value, opts) {\n this.setValue(value, opts);\n },\n\n /**\n * Handled when the view is changed\n */\n handleChange(e) {\n e.stopPropagation();\n const value = this.getInputEl().value;\n this.model.set({ value }, { fromInput: 1 });\n this.elementUpdated();\n },\n\n /**\n * Get the input element\n * @return {HTMLElement}\n */\n getInputEl() {\n if (!this.inputEl) {\n const { model } = this;\n const plh = model.get('placeholder') || model.get('defaults') || '';\n this.inputEl = $(``);\n }\n\n return this.inputEl.get(0);\n },\n\n render() {\n this.inputEl = null;\n const el = this.$el;\n el.addClass(this.inputClass());\n el.html(this.template());\n el.find(`.${this.holderClass()}`).append(this.getInputEl());\n return this;\n }\n});\n","import Backbone from 'backbone';\nimport { appendAtIndex } from 'utils/dom';\n\nexport default Backbone.View.extend({\n initialize(o) {\n this.config = o.config || {};\n this.pfx = this.config.stylePrefix || '';\n this.target = o.target || {};\n this.propTarget = o.propTarget || {};\n this.onChange = o.onChange;\n this.onInputRender = o.onInputRender || {};\n this.customValue = o.customValue || {};\n this.properties = [];\n const coll = this.collection;\n this.listenTo(coll, 'add', this.addTo);\n this.listenTo(coll, 'reset', this.render);\n },\n\n addTo(model, coll, opts) {\n this.add(model, null, opts);\n },\n\n add(model, frag, opts = {}) {\n const appendTo = frag || this.el;\n const view = new model.typeView({\n model,\n name: model.get('name'),\n id: this.pfx + model.get('property'),\n target: this.target,\n propTarget: this.propTarget,\n onChange: this.onChange,\n onInputRender: this.onInputRender,\n config: this.config\n });\n\n if (model.get('type') != 'composite') {\n view.customValue = this.customValue;\n }\n\n view.render();\n const rendered = view.el;\n this.properties.push(view);\n\n appendAtIndex(appendTo, rendered, opts.at);\n },\n\n render() {\n this.properties = [];\n const fragment = document.createDocumentFragment();\n this.collection.each(model => this.add(model, fragment));\n this.$el.append(fragment);\n this.$el.attr('class', `${this.pfx}properties`);\n return this;\n }\n});\n","import { bindAll, isFunction, result, isUndefined } from 'underscore';\nimport { on, off, isEscKey, getPointerEvent } from 'utils/mixins';\n\nconst resetPos = () => ({ x: 0, y: 0 });\n\nexport default class Dragger {\n /**\n * Init the dragger\n * @param {Object} opts\n */\n constructor(opts = {}) {\n this.opts = {\n /**\n * Element on which the drag will be executed. By default, the document will be used\n */\n container: null,\n /**\n * Callback on start\n * onStart(ev, dragger) {\n * console.log('pointer start', dragger.startPointer, 'position start', dragger.startPosition);\n * },\n */\n onStart: null,\n /**\n * Callback on drag\n * onDrag(ev, dragger) {\n * console.log('pointer', dragger.currentPointer, 'position', dragger.position, 'delta', dragger.delta);\n * },\n */\n onDrag: null,\n /**\n * Callback on drag\n * onEnd(ev, dragger) {\n * console.log('pointer', dragger.currentPointer, 'position', dragger.position, 'delta', dragger.delta);\n * },\n */\n onEnd: null,\n /**\n * Indicate a callback where to pass an object with new coordinates\n */\n setPosition: null,\n /**\n * Indicate a callback where to get initial coordinates.\n * getPosition: () => {\n * ...\n * return { x: 10, y: 100 }\n * }\n */\n getPosition: null,\n\n // Static guides to be snapped\n guidesStatic: null,\n\n // Target guides that will snap to static one\n guidesTarget: null,\n\n // Offset before snap to guides\n snapOffset: 5,\n\n // Document on which listen to pointer events\n doc: 0,\n\n // Scale result points, can also be a function\n scale: 1\n };\n bindAll(this, 'drag', 'stop', 'keyHandle', 'handleScroll');\n this.setOptions(opts);\n this.delta = resetPos();\n return this;\n }\n\n /**\n * Update options\n * @param {Object} options\n */\n setOptions(opts = {}) {\n this.opts = {\n ...this.opts,\n ...opts\n };\n }\n\n toggleDrag(enable) {\n const docs = this.getDocumentEl();\n const container = this.getContainerEl();\n const win = this.getWindowEl();\n const method = enable ? 'on' : 'off';\n const methods = { on, off };\n methods[method](container, 'mousemove dragover', this.drag);\n methods[method](docs, 'mouseup dragend touchend', this.stop);\n methods[method](docs, 'keydown', this.keyHandle);\n methods[method](win, 'scroll', this.handleScroll);\n }\n\n handleScroll() {\n const { lastScroll, delta } = this;\n const actualScroll = this.getScrollInfo();\n const scrollDiff = {\n x: actualScroll.x - lastScroll.x,\n y: actualScroll.y - lastScroll.y\n };\n this.move(delta.x + scrollDiff.x, delta.y + scrollDiff.y);\n this.lastScrollDiff = scrollDiff;\n }\n\n /**\n * Start dragging\n * @param {Event} e\n */\n start(ev) {\n const { opts } = this;\n const { onStart } = opts;\n this.toggleDrag(1);\n this.startPointer = this.getPointerPos(ev);\n this.guidesStatic = result(opts, 'guidesStatic') || [];\n this.guidesTarget = result(opts, 'guidesTarget') || [];\n isFunction(onStart) && onStart(ev, this);\n this.startPosition = this.getStartPosition();\n this.lastScrollDiff = resetPos();\n this.globScrollDiff = resetPos();\n this.drag(ev);\n }\n\n /**\n * Drag event\n * @param {Event} event\n */\n drag(ev) {\n const { opts, lastScrollDiff, globScrollDiff } = this;\n const { onDrag } = opts;\n const { startPointer } = this;\n const currentPos = this.getPointerPos(ev);\n const glDiff = {\n x: globScrollDiff.x + lastScrollDiff.x,\n y: globScrollDiff.y + lastScrollDiff.y\n };\n this.globScrollDiff = glDiff;\n const delta = {\n x: currentPos.x - startPointer.x + glDiff.x,\n y: currentPos.y - startPointer.y + glDiff.y\n };\n this.lastScrollDiff = resetPos();\n let { lockedAxis } = this;\n\n // Lock one axis\n if (ev.shiftKey) {\n lockedAxis = !lockedAxis && this.detectAxisLock(delta.x, delta.y);\n } else {\n lockedAxis = null;\n }\n\n if (lockedAxis === 'x') {\n delta.x = startPointer.x;\n } else if (lockedAxis === 'y') {\n delta.y = startPointer.y;\n }\n\n const moveDelta = delta => {\n ['x', 'y'].forEach(co => (delta[co] = delta[co] * result(opts, 'scale')));\n this.delta = delta;\n this.move(delta.x, delta.y);\n isFunction(onDrag) && onDrag(ev, this);\n };\n const deltaPre = { ...delta };\n this.currentPointer = currentPos;\n this.lockedAxis = lockedAxis;\n this.lastScroll = this.getScrollInfo();\n moveDelta(delta);\n\n if (this.guidesTarget.length) {\n const { newDelta, trgX, trgY } = this.snapGuides(deltaPre);\n (trgX || trgY) && moveDelta(newDelta);\n }\n\n // In case the mouse button was released outside of the window\n ev.which === 0 && this.stop(ev);\n }\n\n /**\n * Check if the delta hits some guide\n */\n snapGuides(delta) {\n const newDelta = delta;\n let { trgX, trgY } = this;\n\n this.guidesTarget.forEach(trg => {\n // Skip the guide if its locked axis already exists\n if ((trg.x && this.trgX) || (trg.y && this.trgY)) return;\n trg.active = 0;\n\n this.guidesStatic.forEach(stat => {\n if ((trg.y && stat.x) || (trg.x && stat.y)) return;\n const isY = trg.y && stat.y;\n const axs = isY ? 'y' : 'x';\n const trgPoint = trg[axs];\n const statPoint = stat[axs];\n const deltaPoint = delta[axs];\n const trgGuide = isY ? trgY : trgX;\n\n if (this.isPointIn(trgPoint, statPoint)) {\n if (isUndefined(trgGuide)) {\n const trgValue = deltaPoint - (trgPoint - statPoint);\n this.setGuideLock(trg, trgValue);\n }\n }\n });\n });\n\n trgX = this.trgX;\n trgY = this.trgY;\n\n ['x', 'y'].forEach(co => {\n const axis = co.toUpperCase();\n let trg = this[`trg${axis}`];\n\n if (trg && !this.isPointIn(delta[co], trg.lock)) {\n this.setGuideLock(trg, null);\n trg = null;\n }\n\n if (trg && !isUndefined(trg.lock)) {\n newDelta[co] = trg.lock;\n }\n });\n\n return {\n newDelta,\n trgX: this.trgX,\n trgY: this.trgY\n };\n }\n\n isPointIn(src, trg, { offset } = {}) {\n const ofst = offset || this.opts.snapOffset;\n return (\n (src >= trg && src <= trg + ofst) || (src <= trg && src >= trg - ofst)\n );\n }\n\n setGuideLock(guide, value) {\n const axis = !isUndefined(guide.x) ? 'X' : 'Y';\n const trgName = `trg${axis}`;\n\n if (value !== null) {\n guide.active = 1;\n guide.lock = value;\n this[trgName] = guide;\n } else {\n delete guide.active;\n delete guide.lock;\n delete this[trgName];\n }\n\n return guide;\n }\n\n /**\n * Stop dragging\n */\n stop(ev, opts = {}) {\n const { delta } = this;\n const cancelled = opts.cancel;\n const x = cancelled ? 0 : delta.x;\n const y = cancelled ? 0 : delta.y;\n this.toggleDrag();\n this.lockedAxis = null;\n this.move(x, y, 1);\n const { onEnd } = this.opts;\n isFunction(onEnd) && onEnd(ev, this, { cancelled });\n }\n\n keyHandle(ev) {\n if (isEscKey(ev)) {\n this.stop(ev, { cancel: 1 });\n }\n }\n\n /**\n * Move the element\n * @param {integer} x\n * @param {integer} y\n */\n move(x, y, end) {\n const { el, opts } = this;\n const pos = this.startPosition;\n if (!pos) return;\n const { setPosition } = opts;\n const xPos = pos.x + x;\n const yPos = pos.y + y;\n this.position = {\n x: xPos,\n y: yPos,\n end\n };\n\n isFunction(setPosition) && setPosition(this.position);\n\n if (el) {\n el.style.left = `${xPos}px`;\n el.style.top = `${yPos}px`;\n }\n }\n\n getContainerEl() {\n const { container } = this.opts;\n return container ? [container] : this.getDocumentEl();\n }\n\n getWindowEl() {\n const cont = this.getContainerEl();\n return cont.map(item => {\n const doc = item.ownerDocument || item;\n return doc.defaultView || doc.parentWindow;\n });\n }\n\n /**\n * Returns documents\n */\n getDocumentEl(el) {\n const { doc } = this.opts;\n el = el || this.el;\n\n if (!this.docs) {\n const docs = [document];\n el && docs.push(el.ownerDocument);\n doc && docs.push(doc);\n this.docs = docs;\n }\n\n return this.docs;\n }\n\n /**\n * Get mouse coordinates\n * @param {Event} event\n * @return {Object}\n */\n getPointerPos(ev) {\n const getPos = this.opts.getPointerPosition;\n const pEv = getPointerEvent(ev);\n\n return getPos\n ? getPos(ev)\n : {\n x: pEv.clientX,\n y: pEv.clientY\n };\n }\n\n getStartPosition() {\n const { el, opts } = this;\n const getPos = opts.getPosition;\n let result = resetPos();\n\n if (isFunction(getPos)) {\n result = getPos();\n } else if (el) {\n result = {\n x: parseFloat(el.style.left),\n y: parseFloat(el.style.top)\n };\n }\n\n return result;\n }\n\n getScrollInfo() {\n const { doc } = this.opts;\n const body = doc && doc.body;\n\n return {\n y: body ? body.scrollTop : 0,\n x: body ? body.scrollLeft : 0\n };\n }\n\n detectAxisLock(x, y) {\n const relX = x;\n const relY = y;\n const absX = Math.abs(relX);\n const absY = Math.abs(relY);\n\n // Vertical or Horizontal lock\n if (relY >= absX || relY <= -absX) {\n return 'x';\n } else if (relX > absY || relX < -absY) {\n return 'y';\n }\n }\n}\n","import Backbone from 'backbone';\nimport { isEmpty, isArray, isString, each, includes, extend } from 'underscore';\n\nlet Component;\n\nexport default Backbone.Collection.extend({\n initialize(models, opt = {}) {\n this.opt = opt;\n this.listenTo(this, 'add', this.onAdd);\n this.config = opt.config;\n this.em = opt.em;\n const { em } = this;\n\n this.model = (attrs, options) => {\n var model;\n var df = opt.componentTypes;\n options.em = opt.em;\n options.config = opt.config;\n options.componentTypes = df;\n options.domc = opt.domc;\n\n for (var it = 0; it < df.length; it++) {\n var dfId = df[it].id;\n if (dfId == attrs.type) {\n model = df[it].model;\n break;\n }\n }\n\n if (!model) {\n // get the last one\n model = df[df.length - 1].model;\n em &&\n attrs.type &&\n em.logWarning(`Component type '${attrs.type}' not found`, {\n attrs,\n options\n });\n }\n\n return new model(attrs, options);\n };\n },\n\n parseString(value, opt = {}) {\n const { em } = this;\n const cssc = em.get('CssComposer');\n const parsed = em.get('Parser').parseHtml(value);\n // We need this to avoid duplicate IDs\n if (!Component) Component = require('./Component').default;\n Component.checkId(parsed.html, parsed.css, this.opt.domc.componentsById);\n\n if (parsed.css && cssc && !opt.temporary) {\n cssc.addCollection(parsed.css, {\n ...opt,\n extend: 1\n });\n }\n\n return parsed.html;\n },\n\n add(models, opt = {}) {\n if (isString(models)) {\n models = this.parseString(models, opt);\n } else if (isArray(models)) {\n models.forEach((item, index) => {\n if (isString(item)) {\n models[index] = this.parseString(item, opt);\n }\n });\n }\n\n const isMult = isArray(models);\n models = (isMult ? models : [models])\n .filter(i => i)\n .map(model => this.processDef(model));\n models = isMult ? models : models[0];\n\n return Backbone.Collection.prototype.add.apply(this, [models, opt]);\n },\n\n /**\n * Process component definition.\n */\n processDef(mdl) {\n // Avoid processing Models\n if (mdl.cid && mdl.ccid) return mdl;\n const { em, config = {} } = this;\n const { processor } = config;\n let model = mdl;\n\n if (processor) {\n model = { ...model }; // Avoid 'Cannot delete property ...'\n const modelPr = processor(model);\n if (modelPr) {\n each(model, (val, key) => delete model[key]);\n extend(model, modelPr);\n }\n }\n\n // React JSX preset\n if (model.$$typeof && typeof model.props == 'object') {\n model = { ...model };\n model.props = { ...model.props };\n const domc = em.get('DomComponents');\n const parser = em.get('Parser');\n const { parserHtml } = parser;\n\n each(model, (value, key) => {\n if (!includes(['props', 'type'], key)) delete model[key];\n });\n const { props } = model;\n const comps = props.children;\n delete props.children;\n delete model.props;\n const res = parserHtml.splitPropsFromAttr(props);\n model.attributes = res.attrs;\n\n if (comps) {\n model.components = comps;\n }\n if (!model.type) {\n model.type = 'textnode';\n } else if (!domc.getType(model.type)) {\n model.tagName = model.type;\n delete model.type;\n }\n\n extend(model, res.props);\n }\n\n return model;\n },\n\n onAdd(model, c, opts = {}) {\n const em = this.em;\n const style = model.getStyle();\n const avoidInline = em && em.getConfig('avoidInlineStyle');\n\n if (\n !isEmpty(style) &&\n !avoidInline &&\n em &&\n em.get &&\n em.getConfig('forceClass') &&\n !opts.temporary\n ) {\n const name = model.cid;\n const rule = em.get('CssComposer').setClassRule(name, style);\n model.setStyle({});\n model.addClass(name);\n }\n }\n});\n","import Backbone from 'backbone';\nconst $ = Backbone.$;\n\nexport default Backbone.View.extend({\n /**\n * Initialize method that can't be removed\n * @param {Object} o Options\n * @private\n * */\n initialize(o) {\n this.config = o || {};\n this.editorModel = this.em = this.config.em || {};\n this.pfx = this.config.stylePrefix;\n this.ppfx = this.config.pStylePrefix;\n this.hoverClass = this.pfx + 'hover';\n this.badgeClass = this.pfx + 'badge';\n this.plhClass = this.pfx + 'placeholder';\n this.freezClass = this.ppfx + 'freezed';\n\n this.canvas = this.em.get && this.em.get('Canvas');\n\n if (this.em.get) this.setElement(this.getCanvas());\n\n if (this.canvas) {\n this.$canvas = this.$el;\n this.$wrapper = $(this.getCanvasWrapper());\n this.frameEl = this.canvas.getFrameEl();\n this.canvasTool = this.getCanvasTools();\n this.bodyEl = this.getCanvasBody();\n }\n\n this.init(this.config);\n },\n\n /**\n * On frame scroll callback\n * @param {[type]} e [description]\n * @return {[type]} [description]\n */\n onFrameScroll(e) {},\n\n /**\n * Returns canval element\n * @return {HTMLElement}\n */\n getCanvas() {\n return this.canvas.getElement();\n },\n\n /**\n * Get canvas body element\n * @return {HTMLElement}\n */\n getCanvasBody() {\n return this.canvas.getBody();\n },\n\n /**\n * Get canvas wrapper element\n * @return {HTMLElement}\n */\n getCanvasWrapper() {\n return this.canvas.getWrapperEl();\n },\n\n /**\n * Get canvas wrapper element\n * @return {HTMLElement}\n */\n getCanvasTools() {\n return this.canvas.getToolsEl();\n },\n\n /**\n * Get the offset of the element\n * @param {HTMLElement} el\n * @return {Object}\n */\n offset(el) {\n var rect = el.getBoundingClientRect();\n return {\n top: rect.top + el.ownerDocument.body.scrollTop,\n left: rect.left + el.ownerDocument.body.scrollLeft\n };\n },\n\n /**\n * Callback triggered after initialize\n * @param {Object} o Options\n * @private\n * */\n init(o) {},\n\n /**\n * Method that run command\n * @param {Object} editor Editor instance\n * @param {Object} [options={}] Options\n * @private\n * */\n callRun(editor, options = {}) {\n const id = this.id;\n editor.trigger(`run:${id}:before`, options);\n\n if (options && options.abort) {\n editor.trigger(`abort:${id}`, options);\n return;\n }\n\n const sender = options.sender || editor;\n const result = this.run(editor, sender, options);\n editor.trigger(`run:${id}`, result, options);\n editor.trigger('run', id, result, options);\n return result;\n },\n\n /**\n * Method that run command\n * @param {Object} editor Editor instance\n * @param {Object} [options={}] Options\n * @private\n * */\n callStop(editor, options = {}) {\n const id = this.id;\n const sender = options.sender || editor;\n editor.trigger(`stop:${id}:before`, options);\n const result = this.stop(editor, sender, options);\n editor.trigger(`stop:${id}`, result, options);\n editor.trigger('stop', id, result, options);\n return result;\n },\n\n /**\n * Stop current command\n */\n stopCommand() {\n this.em.get('Commands').stop(this.id);\n },\n\n /**\n * Method that run command\n * @param {Object} em Editor model\n * @param {Object} sender Button sender\n * @private\n * */\n run(em, sender) {},\n\n /**\n * Method that stop command\n * @param {Object} em Editor model\n * @param {Object} sender Button sender\n * @private\n * */\n stop(em, sender) {}\n});\n","import { isString, isArray, keys } from 'underscore';\nimport { shallowDiff } from 'utils/mixins';\nimport ParserHtml from 'parser/model/ParserHtml';\n\nconst parseStyle = ParserHtml().parseStyle;\n\nexport default {\n parseStyle,\n\n /**\n * To trigger the style change event on models I have to\n * pass a new object instance\n * @param {Object} prop\n * @return {Object}\n */\n extendStyle(prop) {\n return { ...this.getStyle(), ...prop };\n },\n\n /**\n * Get style object\n * @return {Object}\n */\n getStyle() {\n const style = this.get('style') || {};\n return { ...style };\n },\n\n /**\n * Set new style object\n * @param {Object|string} prop\n * @param {Object} opts\n * @return {Object} Applied properties\n */\n setStyle(prop = {}, opts = {}) {\n if (isString(prop)) {\n prop = parseStyle(prop);\n }\n\n const propOrig = this.getStyle();\n const propNew = { ...prop };\n this.set('style', propNew, opts);\n const diff = shallowDiff(propOrig, propNew);\n keys(diff).forEach(pr => {\n const em = this.em;\n this.trigger(`change:style:${pr}`);\n if (em) {\n em.trigger(`styleable:change`, this, pr);\n em.trigger(`styleable:change:${pr}`, this, pr);\n }\n });\n\n return propNew;\n },\n\n /**\n * Add style property\n * @param {Object|string} prop\n * @param {string} value\n * @example\n * this.addStyle({color: 'red'});\n * this.addStyle('color', 'blue');\n */\n addStyle(prop, value = '', opts = {}) {\n if (typeof prop == 'string') {\n prop = {\n prop: value\n };\n } else {\n opts = value || {};\n }\n\n prop = this.extendStyle(prop);\n this.setStyle(prop, opts);\n },\n\n /**\n * Remove style property\n * @param {string} prop\n */\n removeStyle(prop) {\n let style = this.getStyle();\n delete style[prop];\n this.setStyle(style);\n },\n\n /**\n * Returns string of style properties\n * @param {Object} [opts={}] Options\n * @return {String}\n */\n styleToString(opts = {}) {\n const result = [];\n const style = this.getStyle();\n\n for (let prop in style) {\n const imp = opts.important;\n const important = isArray(imp) ? imp.indexOf(prop) >= 0 : imp;\n const value = `${style[prop]}${important ? ' !important' : ''}`;\n value && result.push(`${prop}:${value};`);\n }\n\n return result.join('');\n },\n\n getSelectors() {\n return this.get('selectors') || this.get('classes');\n }\n};\n","\"use strict\";\n\n/*! cash-dom 1.3.7, https://github.com/kenwheeler/cash @license MIT */\n;(function (root, factory) {\n if (typeof define === \"function\" && define.amd) {\n define(factory);\n } else if (typeof exports !== \"undefined\") {\n module.exports = factory();\n } else {\n root.cash = root.$ = factory();\n }\n})(this, function () {\n var doc = document, win = window, ArrayProto = Array.prototype, slice = ArrayProto.slice, filter = ArrayProto.filter, push = ArrayProto.push;\n\n var noop = function () {}, isFunction = function (item) {\n // @see https://crbug.com/568448\n return typeof item === typeof noop && item.call;\n }, isString = function (item) {\n return typeof item === typeof \"\";\n };\n\n var idMatch = /^#[\\w-]*$/, classMatch = /^\\.[\\w-]*$/, htmlMatch = /<.+>/, singlet = /^\\w+$/;\n\n function find(selector, context) {\n context = context || doc;\n var elems = (classMatch.test(selector) ? context.getElementsByClassName(selector.slice(1)) : singlet.test(selector) ? context.getElementsByTagName(selector) : context.querySelectorAll(selector));\n return elems;\n }\n\n var frag;\n function parseHTML(str) {\n if (!frag) {\n frag = doc.implementation.createHTMLDocument(null);\n var base = frag.createElement(\"base\");\n base.href = doc.location.href;\n frag.head.appendChild(base);\n }\n\n frag.body.innerHTML = str;\n\n return frag.body.childNodes;\n }\n\n function onReady(fn) {\n if (doc.readyState !== \"loading\") {\n setTimeout(fn);\n } else {\n doc.addEventListener(\"DOMContentLoaded\", fn);\n }\n }\n\n function Init(selector, context) {\n if (!selector) {\n return this;\n }\n\n // If already a cash collection, don't do any further processing\n if (selector.cash && selector !== win) {\n return selector;\n }\n\n var elems = selector, i = 0, length;\n\n if (isString(selector)) {\n elems = (idMatch.test(selector) ?\n // If an ID use the faster getElementById check\n doc.getElementById(selector.slice(1)) : htmlMatch.test(selector) ?\n // If HTML, parse it into real elements\n parseHTML(selector) :\n // else use `find`\n find(selector, context));\n\n // If function, use as shortcut for DOM ready\n } else if (isFunction(selector)) {\n onReady(selector);return this;\n }\n\n if (!elems) {\n return this;\n }\n\n // If a single DOM element is passed in or received via ID, return the single element\n if (elems.nodeType || elems === win) {\n this[0] = elems;\n this.length = 1;\n } else {\n // Treat like an array and loop through each item.\n length = this.length = elems.length;\n for (; i < length; i++) {\n this[i] = elems[i];\n }\n }\n\n return this;\n }\n\n function cash(selector, context) {\n return new Init(selector, context);\n }\n\n var fn = cash.fn = cash.prototype = Init.prototype = { // jshint ignore:line\n cash: true,\n length: 0,\n push: push,\n splice: ArrayProto.splice,\n map: ArrayProto.map,\n init: Init\n };\n\n Object.defineProperty(fn, \"constructor\", { value: cash });\n\n cash.parseHTML = parseHTML;\n cash.noop = noop;\n cash.isFunction = isFunction;\n cash.isString = isString;\n\n cash.extend = fn.extend = function (target) {\n target = target || {};\n\n var args = slice.call(arguments), length = args.length, i = 1;\n\n if (args.length === 1) {\n target = this;\n i = 0;\n }\n\n for (; i < length; i++) {\n if (!args[i]) {\n continue;\n }\n for (var key in args[i]) {\n if (args[i].hasOwnProperty(key)) {\n target[key] = args[i][key];\n }\n }\n }\n\n return target;\n };\n\n function each(collection, callback) {\n var l = collection.length, i = 0;\n\n for (; i < l; i++) {\n if (callback.call(collection[i], collection[i], i, collection) === false) {\n break;\n }\n }\n }\n\n function matches(el, selector) {\n var m = el && (el.matches || el.webkitMatchesSelector || el.mozMatchesSelector || el.msMatchesSelector || el.oMatchesSelector);\n return !!m && m.call(el, selector);\n }\n\n function getCompareFunction(selector) {\n return (\n /* Use browser's `matches` function if string */\n isString(selector) ? matches :\n /* Match a cash element */\n selector.cash ? function (el) {\n return selector.is(el);\n } :\n /* Direct comparison */\n function (el, selector) {\n return el === selector;\n });\n }\n\n function unique(collection) {\n return cash(slice.call(collection).filter(function (item, index, self) {\n return self.indexOf(item) === index;\n }));\n }\n\n cash.extend({\n merge: function (first, second) {\n var len = +second.length, i = first.length, j = 0;\n\n for (; j < len; i++, j++) {\n first[i] = second[j];\n }\n\n first.length = i;\n return first;\n },\n\n each: each,\n matches: matches,\n unique: unique,\n isArray: Array.isArray,\n isNumeric: function (n) {\n return !isNaN(parseFloat(n)) && isFinite(n);\n }\n\n });\n\n var uid = cash.uid = \"_cash\" + Date.now();\n\n function getDataCache(node) {\n return (node[uid] = node[uid] || {});\n }\n\n function setData(node, key, value) {\n return (getDataCache(node)[key] = value);\n }\n\n function getData(node, key) {\n var c = getDataCache(node);\n if (c[key] === undefined) {\n c[key] = node.dataset ? node.dataset[key] : cash(node).attr(\"data-\" + key);\n }\n return c[key];\n }\n\n function removeData(node, key) {\n var c = getDataCache(node);\n if (c) {\n delete c[key];\n } else if (node.dataset) {\n delete node.dataset[key];\n } else {\n cash(node).removeAttr(\"data-\" + name);\n }\n }\n\n fn.extend({\n data: function (name, value) {\n if (isString(name)) {\n return (value === undefined ? getData(this[0], name) : this.each(function (v) {\n return setData(v, name, value);\n }));\n }\n\n for (var key in name) {\n this.data(key, name[key]);\n }\n\n return this;\n },\n\n removeData: function (key) {\n return this.each(function (v) {\n return removeData(v, key);\n });\n }\n\n });\n\n var notWhiteMatch = /\\S+/g;\n\n function getClasses(c) {\n return isString(c) && c.match(notWhiteMatch);\n }\n\n function hasClass(v, c) {\n return (v.classList ? v.classList.contains(c) : new RegExp(\"(^| )\" + c + \"( |$)\", \"gi\").test(v.className));\n }\n\n function addClass(v, c) {\n if (v.classList) {\n v.classList.add(c);\n } else if (!hasClass(v, c)) {\n v.className += \" \" + c;\n }\n }\n\n function removeClass(v, c) {\n if (v.classList) {\n v.classList.remove(c);\n } else {\n v.className = v.className.replace(c, \"\");\n }\n }\n\n fn.extend({\n addClass: function (c) {\n var classes = getClasses(c);\n\n return (classes ? this.each(function (v) {\n each(classes, function (c) {\n addClass(v, c);\n });\n }) : this);\n },\n\n attr: function (name, value) {\n if (!name) {\n return undefined;\n }\n\n if (isString(name)) {\n if (value === undefined) {\n return this[0] ? this[0].getAttribute ? this[0].getAttribute(name) : this[0][name] : undefined;\n }\n\n return this.each(function (v) {\n if (v.setAttribute) {\n v.setAttribute(name, value);\n } else {\n v[name] = value;\n }\n });\n }\n\n for (var key in name) {\n this.attr(key, name[key]);\n }\n\n return this;\n },\n\n hasClass: function (c) {\n var check = false, classes = getClasses(c);\n if (classes && classes.length) {\n this.each(function (v) {\n check = hasClass(v, classes[0]);\n return !check;\n });\n }\n return check;\n },\n\n prop: function (name, value) {\n if (isString(name)) {\n return (value === undefined ? this[0][name] : this.each(function (v) {\n v[name] = value;\n }));\n }\n\n for (var key in name) {\n this.prop(key, name[key]);\n }\n\n return this;\n },\n\n removeAttr: function (name) {\n return this.each(function (v) {\n if (v.removeAttribute) {\n v.removeAttribute(name);\n } else {\n delete v[name];\n }\n });\n },\n\n removeClass: function (c) {\n if (!arguments.length) {\n return this.attr(\"class\", \"\");\n }\n var classes = getClasses(c);\n return (classes ? this.each(function (v) {\n each(classes, function (c) {\n removeClass(v, c);\n });\n }) : this);\n },\n\n removeProp: function (name) {\n return this.each(function (v) {\n delete v[name];\n });\n },\n\n toggleClass: function (c, state) {\n if (state !== undefined) {\n return this[state ? \"addClass\" : \"removeClass\"](c);\n }\n var classes = getClasses(c);\n return (classes ? this.each(function (v) {\n each(classes, function (c) {\n if (hasClass(v, c)) {\n removeClass(v, c);\n } else {\n addClass(v, c);\n }\n });\n }) : this);\n } });\n\n fn.extend({\n add: function (selector, context) {\n return unique(cash.merge(this, cash(selector, context)));\n },\n\n each: function (callback) {\n each(this, callback);\n return this;\n },\n\n eq: function (index) {\n return cash(this.get(index));\n },\n\n filter: function (selector) {\n if (!selector) {\n return this;\n }\n\n var comparator = (isFunction(selector) ? selector : getCompareFunction(selector));\n\n return cash(filter.call(this, function (e) {\n return comparator(e, selector);\n }));\n },\n\n first: function () {\n return this.eq(0);\n },\n\n get: function (index) {\n if (index === undefined) {\n return slice.call(this);\n }\n return (index < 0 ? this[index + this.length] : this[index]);\n },\n\n index: function (elem) {\n var child = elem ? cash(elem)[0] : this[0], collection = elem ? this : cash(child).parent().children();\n return slice.call(collection).indexOf(child);\n },\n\n last: function () {\n return this.eq(-1);\n }\n\n });\n\n var camelCase = (function () {\n var camelRegex = /(?:^\\w|[A-Z]|\\b\\w)/g, whiteSpace = /[\\s-_]+/g;\n return function (str) {\n return str.replace(camelRegex, function (letter, index) {\n return letter[index === 0 ? \"toLowerCase\" : \"toUpperCase\"]();\n }).replace(whiteSpace, \"\");\n };\n }());\n\n var getPrefixedProp = (function () {\n var cache = {}, doc = document, div = doc.createElement(\"div\"), style = div.style;\n\n return function (prop) {\n prop = camelCase(prop);\n if (cache[prop]) {\n return cache[prop];\n }\n\n var ucProp = prop.charAt(0).toUpperCase() + prop.slice(1), prefixes = [\"webkit\", \"moz\", \"ms\", \"o\"], props = (prop + \" \" + (prefixes).join(ucProp + \" \") + ucProp).split(\" \");\n\n each(props, function (p) {\n if (p in style) {\n cache[p] = prop = cache[prop] = p;\n return false;\n }\n });\n\n return cache[prop];\n };\n }());\n\n cash.prefixedProp = getPrefixedProp;\n cash.camelCase = camelCase;\n\n fn.extend({\n css: function (prop, value) {\n if (isString(prop)) {\n prop = getPrefixedProp(prop);\n return (arguments.length > 1 ? this.each(function (v) {\n return v.style[prop] = value;\n }) : win.getComputedStyle(this[0])[prop]);\n }\n\n for (var key in prop) {\n this.css(key, prop[key]);\n }\n\n return this;\n }\n\n });\n\n function compute(el, prop) {\n return parseInt(win.getComputedStyle(el[0], null)[prop], 10) || 0;\n }\n\n each([\"Width\", \"Height\"], function (v) {\n var lower = v.toLowerCase();\n\n fn[lower] = function () {\n return this[0].getBoundingClientRect()[lower];\n };\n\n fn[\"inner\" + v] = function () {\n return this[0][\"client\" + v];\n };\n\n fn[\"outer\" + v] = function (margins) {\n return this[0][\"offset\" + v] + (margins ? compute(this, \"margin\" + (v === \"Width\" ? \"Left\" : \"Top\")) + compute(this, \"margin\" + (v === \"Width\" ? \"Right\" : \"Bottom\")) : 0);\n };\n });\n\n function registerEvent(node, eventName, callback) {\n var eventCache = getData(node, \"_cashEvents\") || setData(node, \"_cashEvents\", {});\n eventCache[eventName] = eventCache[eventName] || [];\n eventCache[eventName].push(callback);\n node.addEventListener(eventName, callback);\n }\n\n function removeEvent(node, eventName, callback) {\n var events = getData(node, \"_cashEvents\"), eventCache = (events && events[eventName]), index;\n\n if (!eventCache) {\n return;\n }\n\n if (callback) {\n node.removeEventListener(eventName, callback);\n index = eventCache.indexOf(callback);\n if (index >= 0) {\n eventCache.splice(index, 1);\n }\n } else {\n each(eventCache, function (event) {\n node.removeEventListener(eventName, event);\n });\n eventCache = [];\n }\n }\n\n fn.extend({\n off: function (eventName, callback) {\n return this.each(function (v) {\n return removeEvent(v, eventName, callback);\n });\n },\n\n on: function (eventName, delegate, callback, runOnce) {\n // jshint ignore:line\n\n var originalCallback;\n\n if (!isString(eventName)) {\n for (var key in eventName) {\n this.on(key, delegate, eventName[key]);\n }\n return this;\n }\n\n if (isFunction(delegate)) {\n callback = delegate;\n delegate = null;\n }\n\n if (eventName === \"ready\") {\n onReady(callback);\n return this;\n }\n\n if (delegate) {\n originalCallback = callback;\n callback = function (e) {\n var t = e.target;\n\n while (!matches(t, delegate)) {\n if (t === this) {\n return (t = false);\n }\n t = t.parentNode;\n }\n\n if (t) {\n originalCallback.call(t, e);\n }\n };\n }\n\n return this.each(function (v) {\n var finalCallback = callback;\n if (runOnce) {\n finalCallback = function () {\n callback.apply(this, arguments);\n removeEvent(v, eventName, finalCallback);\n };\n }\n registerEvent(v, eventName, finalCallback);\n });\n },\n\n one: function (eventName, delegate, callback) {\n return this.on(eventName, delegate, callback, true);\n },\n\n ready: onReady,\n\n trigger: function (eventName, data) {\n var evt = doc.createEvent(\"HTMLEvents\");\n evt.data = data;\n evt.initEvent(eventName, true, false);\n return this.each(function (v) {\n return v.dispatchEvent(evt);\n });\n }\n\n });\n\n function encode(name, value) {\n return \"&\" + encodeURIComponent(name) + \"=\" + encodeURIComponent(value).replace(/%20/g, \"+\");\n }\n\n function getSelectMultiple_(el) {\n var values = [];\n each(el.options, function (o) {\n if (o.selected) {\n values.push(o.value);\n }\n });\n return values.length ? values : null;\n }\n\n function getSelectSingle_(el) {\n var selectedIndex = el.selectedIndex;\n return selectedIndex >= 0 ? el.options[selectedIndex].value : null;\n }\n\n function getValue(el) {\n var type = el.type;\n if (!type) {\n return null;\n }\n switch (type.toLowerCase()) {\n case \"select-one\":\n return getSelectSingle_(el);\n case \"select-multiple\":\n return getSelectMultiple_(el);\n case \"radio\":\n return (el.checked) ? el.value : null;\n case \"checkbox\":\n return (el.checked) ? el.value : null;\n default:\n return el.value ? el.value : null;\n }\n }\n\n fn.extend({\n serialize: function () {\n var query = \"\";\n\n each(this[0].elements || this, function (el) {\n if (el.disabled || el.tagName === \"FIELDSET\") {\n return;\n }\n var name = el.name;\n switch (el.type.toLowerCase()) {\n case \"file\":\n case \"reset\":\n case \"submit\":\n case \"button\":\n break;\n case \"select-multiple\":\n var values = getValue(el);\n if (values !== null) {\n each(values, function (value) {\n query += encode(name, value);\n });\n }\n break;\n default:\n var value = getValue(el);\n if (value !== null) {\n query += encode(name, value);\n }\n }\n });\n\n return query.substr(1);\n },\n\n val: function (value) {\n if (value === undefined) {\n return getValue(this[0]);\n } else {\n return this.each(function (v) {\n return v.value = value;\n });\n }\n }\n\n });\n\n function insertElement(el, child, prepend) {\n if (prepend) {\n var first = el.childNodes[0];\n el.insertBefore(child, first);\n } else {\n el.appendChild(child);\n }\n }\n\n function insertContent(parent, child, prepend) {\n var str = isString(child);\n\n if (!str && child.length) {\n each(child, function (v) {\n return insertContent(parent, v, prepend);\n });\n return;\n }\n\n each(parent, str ? function (v) {\n return v.insertAdjacentHTML(prepend ? \"afterbegin\" : \"beforeend\", child);\n } : function (v, i) {\n return insertElement(v, (i === 0 ? child : child.cloneNode(true)), prepend);\n });\n }\n\n fn.extend({\n after: function (selector) {\n cash(selector).insertAfter(this);\n return this;\n },\n\n append: function (content) {\n insertContent(this, content);\n return this;\n },\n\n appendTo: function (parent) {\n insertContent(cash(parent), this);\n return this;\n },\n\n before: function (selector) {\n cash(selector).insertBefore(this);\n return this;\n },\n\n clone: function () {\n return cash(this.map(function (v) {\n return v.cloneNode(true);\n }));\n },\n\n empty: function () {\n this.html(\"\");\n return this;\n },\n\n html: function (content) {\n if (content === undefined) {\n return this[0].innerHTML;\n }\n var source = (content.nodeType ? content[0].outerHTML : content);\n return this.each(function (v) {\n return v.innerHTML = source;\n });\n },\n\n insertAfter: function (selector) {\n var _this = this;\n\n\n cash(selector).each(function (el, i) {\n var parent = el.parentNode, sibling = el.nextSibling;\n _this.each(function (v) {\n parent.insertBefore((i === 0 ? v : v.cloneNode(true)), sibling);\n });\n });\n\n return this;\n },\n\n insertBefore: function (selector) {\n var _this2 = this;\n cash(selector).each(function (el, i) {\n var parent = el.parentNode;\n _this2.each(function (v) {\n parent.insertBefore((i === 0 ? v : v.cloneNode(true)), el);\n });\n });\n return this;\n },\n\n prepend: function (content) {\n insertContent(this, content, true);\n return this;\n },\n\n prependTo: function (parent) {\n insertContent(cash(parent), this, true);\n return this;\n },\n\n remove: function () {\n return this.each(function (v) {\n return v.parentNode.removeChild(v);\n });\n },\n\n text: function (content) {\n if (content === undefined) {\n return this[0].textContent;\n }\n return this.each(function (v) {\n return v.textContent = content;\n });\n }\n\n });\n\n var docEl = doc.documentElement;\n\n fn.extend({\n position: function () {\n var el = this[0];\n return {\n left: el.offsetLeft,\n top: el.offsetTop\n };\n },\n\n offset: function () {\n var rect = this[0].getBoundingClientRect();\n return {\n top: rect.top + win.pageYOffset - docEl.clientTop,\n left: rect.left + win.pageXOffset - docEl.clientLeft\n };\n },\n\n offsetParent: function () {\n return cash(this[0].offsetParent);\n }\n\n });\n\n fn.extend({\n children: function (selector) {\n var elems = [];\n this.each(function (el) {\n push.apply(elems, el.children);\n });\n elems = unique(elems);\n\n return (!selector ? elems : elems.filter(function (v) {\n return matches(v, selector);\n }));\n },\n\n closest: function (selector) {\n if (!selector || this.length < 1) {\n return cash();\n }\n if (this.is(selector)) {\n return this.filter(selector);\n }\n return this.parent().closest(selector);\n },\n\n is: function (selector) {\n if (!selector) {\n return false;\n }\n\n var match = false, comparator = getCompareFunction(selector);\n\n this.each(function (el) {\n match = comparator(el, selector);\n return !match;\n });\n\n return match;\n },\n\n find: function (selector) {\n if (!selector || selector.nodeType) {\n return cash(selector && this.has(selector).length ? selector : null);\n }\n\n var elems = [];\n this.each(function (el) {\n push.apply(elems, find(selector, el));\n });\n\n return unique(elems);\n },\n\n has: function (selector) {\n var comparator = (isString(selector) ? function (el) {\n return find(selector, el).length !== 0;\n } : function (el) {\n return el.contains(selector);\n });\n\n return this.filter(comparator);\n },\n\n next: function () {\n return cash(this[0].nextElementSibling);\n },\n\n not: function (selector) {\n if (!selector) {\n return this;\n }\n\n var comparator = getCompareFunction(selector);\n\n return this.filter(function (el) {\n return !comparator(el, selector);\n });\n },\n\n parent: function () {\n var result = [];\n\n this.each(function (item) {\n if (item && item.parentNode) {\n result.push(item.parentNode);\n }\n });\n\n return unique(result);\n },\n\n parents: function (selector) {\n var last, result = [];\n\n this.each(function (item) {\n last = item;\n\n while (last && last.parentNode && last !== doc.body.parentNode) {\n last = last.parentNode;\n\n if (!selector || (selector && matches(last, selector))) {\n result.push(last);\n }\n }\n });\n\n return unique(result);\n },\n\n prev: function () {\n return cash(this[0].previousElementSibling);\n },\n\n siblings: function () {\n var collection = this.parent().children(), el = this[0];\n\n return collection.filter(function (i) {\n return i !== el;\n });\n }\n\n });\n\n\n return cash;\n});","import Backbone from 'backbone';\nimport { isUndefined, isString } from 'underscore';\nimport { capitalize } from 'utils/mixins';\n\nconst Property = Backbone.Model.extend(\n {\n defaults: {\n name: '',\n property: '',\n type: '',\n defaults: '',\n info: '',\n value: '',\n icon: '',\n functionName: '',\n status: '',\n visible: true,\n fixedValues: ['initial', 'inherit'],\n\n // If true, the property will be forced to be full width\n full: 0,\n\n // If true to the value will be added '!important'\n important: 0,\n\n // If true, will be hidden by default and will show up only for targets\n // which require this property (via `stylable-require`)\n // Use case:\n // you can add all SVG CSS properties with toRequire as true\n // and then require them on SVG Components\n toRequire: 0,\n\n // Specifies dependency on other properties of the selected object.\n // Property is shown only when all conditions are matched.\n //\n // example: { display: ['flex', 'block'], position: ['absolute'] };\n // in this case the property is only shown when display is\n // of value 'flex' or 'block' AND position is 'absolute'\n requires: null,\n\n // Specifies dependency on properties of the parent of the selected object.\n // Property is shown only when all conditions are matched.\n requiresParent: null\n },\n\n initialize(props = {}, opts = {}) {\n const id = this.get('id') || '';\n const name = this.get('name') || '';\n !this.get('property') &&\n this.set('property', (name || id).replace(/ /g, '-'));\n const prop = this.get('property');\n !this.get('id') && this.set('id', prop);\n !name && this.set('name', capitalize(prop).replace(/-/g, ' '));\n Property.callInit(this, props, opts);\n },\n\n init() {},\n\n /**\n * Clear the value\n * @return {this}\n */\n clearValue(opts = {}) {\n this.set({ value: undefined }, opts);\n return this;\n },\n\n /**\n * Update value\n * @param {any} value\n * @param {Boolen} [complete=true] Indicates if it's a final state\n * @param {Object} [opts={}] Options\n */\n setValue(value, complete = 1, opts = {}) {\n const parsed = this.parseValue(value);\n this.set(parsed, { ...opts, avoidStore: 1 });\n\n // It's important to set an empty value, otherwise the\n // UndoManager won't see the change\n if (complete) {\n this.set('value', '', opts);\n this.set(parsed, opts);\n }\n },\n\n /**\n * Like `setValue` but, in addition, prevents the update of the input element\n * as the changes should come from the input itself.\n * This method is useful with the definition of custom properties\n * @param {any} value\n * @param {Boolen} [complete=true] Indicates if it's a final state\n * @param {Object} [opts={}] Options\n */\n setValueFromInput(value, complete, opts = {}) {\n this.setValue(value, complete, { ...opts, fromInput: 1 });\n },\n\n /**\n * Parse a raw value, generally fetched from the target, for this property\n * @param {string} value Raw value string\n * @return {Object}\n * @example\n * // example with an Input type\n * prop.parseValue('translateX(10deg)');\n * // -> { value: 10, unit: 'deg', functionName: 'translateX' }\n *\n */\n parseValue(value, opts = {}) {\n const result = { value };\n const imp = '!important';\n\n if (isString(value) && value.indexOf(imp) !== -1) {\n result.value = value.replace(imp, '').trim();\n result.important = 1;\n }\n\n if (!this.get('functionName') && !opts.complete) {\n return result;\n }\n\n const args = [];\n let valueStr = `${result.value}`;\n let start = valueStr.indexOf('(') + 1;\n let end = valueStr.lastIndexOf(')');\n const functionName = valueStr.substring(0, start - 1);\n if (functionName) result.functionName = functionName;\n args.push(start);\n\n // Will try even if the last closing parentheses is not found\n if (end >= 0) {\n args.push(end);\n }\n\n result.value = String.prototype.substring.apply(valueStr, args);\n\n if (opts.numeric) {\n const num = parseFloat(result.value);\n result.unit = result.value.replace(num, '');\n result.value = num;\n }\n\n return result;\n },\n\n /**\n * Get the default value\n * @return {string}\n * @private\n */\n getDefaultValue() {\n return this.get('defaults');\n },\n\n /**\n * Get a complete value of the property.\n * This probably will replace the getValue when all\n * properties models will be splitted\n * @param {string} val Custom value to replace the one on the model\n * @return {string}\n * @private\n */\n getFullValue(val) {\n const fn = this.get('functionName');\n let value = isUndefined(val) ? this.get('value') : val;\n const hasValue = !isUndefined(value);\n\n if (fn && hasValue) {\n value = `${fn}(${value})`;\n }\n\n if (hasValue && this.get('important')) {\n value = `${value} !important`;\n }\n\n return value || '';\n }\n },\n {\n callParentInit(property, ctx, props, opts = {}) {\n property.prototype.initialize.apply(ctx, [\n props,\n {\n ...opts,\n skipInit: 1\n }\n ]);\n },\n\n callInit(context, props, opts = {}) {\n !opts.skipInit && context.init(props, opts);\n }\n }\n);\n\nexport default Property;\n","import Property from './Property';\n\nexport default Property.extend({\n defaults: {\n ...Property.prototype.defaults,\n // 'background' is a good example where to make a difference\n // between detached and not\n //\n // - NOT detached (default)\n // background: url(..) no-repeat center ...;\n // - Detached\n // background-image: url();\n // background-repeat: repeat;\n // ...\n detached: 0,\n\n // Array of sub properties\n properties: [],\n\n // Separator between properties\n separator: ' '\n },\n\n initialize(props = {}, opts = {}) {\n Property.callParentInit(Property, this, props, opts);\n const properties = this.get('properties') || [];\n const Properties = require('./Properties').default;\n this.set('properties', new Properties(properties));\n this.listenTo(this, 'change:value', this.updateValues);\n Property.callInit(this, props, opts);\n },\n\n /**\n * Clear the value\n * @return {this}\n */\n clearValue(opts = {}) {\n this.get('properties').each(property => property.clearValue());\n return Property.prototype.clearValue.apply(this, arguments);\n },\n\n /**\n * Update property values\n */\n updateValues() {\n const values = this.getFullValue().split(this.getSplitSeparator());\n this.get('properties').each((property, i) => {\n const len = values.length;\n // Try to get value from a shorthand:\n // 11px -> 11px 11px 11px 11xp\n // 11px 22px -> 11px 22px 11px 22xp\n const value =\n values[i] || values[(i % len) + (len != 1 && len % 2 ? 1 : 0)];\n // There some issue with UndoManager\n //property.setValue(value, 0, {fromParent: 1});\n });\n },\n\n /**\n * Split by sperator but avoid it inside parenthesis\n * @return {RegExp}\n */\n getSplitSeparator() {\n return new RegExp(`${this.get('separator')}(?![^\\\\(]*\\\\))`);\n },\n\n /**\n * Returns default value\n * @param {Boolean} defaultProps Force to get defaults from properties\n * @return {string}\n */\n getDefaultValue(defaultProps) {\n let value = this.get('defaults');\n\n if (value && !defaultProps) {\n return value;\n }\n\n value = '';\n const properties = this.get('properties');\n properties.each((prop, index) => (value += `${prop.getDefaultValue()} `));\n return value.trim();\n },\n\n getFullValue() {\n if (this.get('detached')) {\n return '';\n }\n\n return this.get('properties').getFullValue();\n },\n\n /**\n * Get property at some index\n * @param {Number} index\n * @return {Object}\n */\n getPropertyAt(index) {\n return this.get('properties').at(index);\n }\n});\n","import Backbone from 'backbone';\nimport Properties from './Properties';\n\nexport default Backbone.Model.extend({\n defaults: {\n index: '',\n value: '',\n values: {},\n active: false,\n preview: false,\n properties: []\n },\n\n initialize() {\n const properties = this.get('properties');\n var value = this.get('value');\n this.set(\n 'properties',\n properties instanceof Properties ? properties : new Properties(properties)\n );\n this.get('properties').forEach(item => {\n const { collection } = this;\n item.parent = collection && collection.property;\n });\n\n // If there is no value I'll try to get it from values\n // I need value setted to make preview working\n if (!value) {\n var val = '';\n var values = this.get('values');\n\n for (var prop in values) {\n val += ' ' + values[prop];\n }\n\n this.set('value', val.trim());\n }\n },\n\n /**\n * Get property at some index\n * @param {Number} index\n * @return {Object}\n */\n getPropertyAt(index) {\n return this.get('properties').at(index);\n },\n\n getPropertyValue(property) {\n let result = '';\n this.get('properties').each(prop => {\n if (prop.get('property') == property) {\n result = prop.getFullValue();\n }\n });\n return result;\n },\n\n getFullValue() {\n let result = [];\n this.get('properties').each(prop => result.push(prop.getFullValue()));\n return result.join(' ');\n }\n});\n","import Backbone from 'backbone';\nimport Layer from './Layer';\n\nexport default Backbone.Collection.extend({\n model: Layer,\n\n initialize() {\n this.idx = 1;\n this.on('add', this.onAdd);\n this.on('reset', this.onReset);\n },\n\n onAdd(model, c, opts) {\n if (!opts.noIncrement) model.set('index', this.idx++);\n },\n\n onReset() {\n this.idx = 1;\n },\n\n getSeparator() {\n const { property } = this;\n return property ? property.get('layerSeparator') : ', ';\n },\n\n /**\n * Get layers from a value string (for not detached properties),\n * example of input:\n * `layer1Value, layer2Value, layer3Value, ...`\n * @param {string} value\n * @return {Array}\n * @private\n */\n getLayersFromValue(value) {\n const layers = [];\n // Remove spaces inside functions, eg:\n // From: 1px 1px rgba(2px, 2px, 2px), 2px 2px rgba(3px, 3px, 3px)\n // To: 1px 1px rgba(2px,2px,2px), 2px 2px rgba(3px,3px,3px)\n value.replace(/\\(([\\w\\s,.]*)\\)/g, match => {\n var cleaned = match.replace(/,\\s*/g, ',');\n value = value.replace(match, cleaned);\n });\n const layerValues = value ? value.split(this.getSeparator()) : [];\n layerValues.forEach(layerValue => {\n layers.push({ properties: this.properties.parseValue(layerValue) });\n });\n return layers;\n },\n\n /**\n * Get layers from a style object (for detached properties),\n * example of input:\n * {\n * subPropname1: sub-propvalue11, sub-propvalue12, sub-propvalue13, ...\n * subPropname2: sub-propvalue21, sub-propvalue22, sub-propvalue23, ...\n * subPropname3: sub-propvalue31, sub-propvalue32, sub-propvalue33, ...\n * }\n * @param {Object} styleObj\n * @return {Array}\n * @private\n */\n getLayersFromStyle(styleObj) {\n const layers = [];\n const properties = this.properties;\n const propNames = properties.pluck('property');\n\n properties.each(propModel => {\n const style = styleObj[propModel.get('property')];\n const values = style ? style.split(', ') : [];\n values.forEach((value, i) => {\n value = propModel.parseValue(value.trim()).value;\n const layer = layers[i];\n const propertyObj = { ...propModel.attributes, ...{ value } };\n\n if (layer) {\n layer.properties.push(propertyObj);\n } else {\n layers[i] = {\n properties: [propertyObj]\n };\n }\n });\n });\n\n // Now whit all layers in, will check missing properties\n layers.forEach(layer => {\n const layerProprs = layer.properties.map(prop => prop.property);\n properties.each(propModel => {\n const propertyName = propModel.get('property');\n\n if (layerProprs.indexOf(propertyName) < 0) {\n layer.properties.push({ ...propModel.attributes });\n }\n });\n });\n\n return layers;\n },\n\n active(index) {\n this.each(layer => layer.set('active', 0));\n const layer = this.at(index);\n layer && layer.set('active', 1);\n },\n\n getFullValue() {\n let result = [];\n this.each(layer => result.push(layer.getFullValue()));\n return result.join(this.getSeparator());\n },\n\n getPropertyValues(property) {\n const result = [];\n this.each(layer => {\n const value = layer.getPropertyValue(property);\n value && result.push(value);\n });\n return result.join(', ');\n }\n});\n","import Property from './PropertyComposite';\nimport Layers from './Layers';\n\nexport default Property.extend({\n defaults: {\n ...Property.prototype.defaults,\n // Array of layers (which contain properties)\n layers: [],\n\n // The separator used to join layer values\n layerSeparator: ', ',\n\n // Layer preview\n preview: 0\n },\n\n initialize(props = {}, opts = {}) {\n Property.callParentInit(Property, this, props, opts);\n const layers = this.get('layers');\n const layersColl = new Layers(layers);\n layersColl.property = this;\n layersColl.properties = this.get('properties');\n this.set('layers', layersColl);\n Property.callInit(this, props, opts);\n },\n\n getLayers() {\n return this.get('layers');\n },\n\n getCurrentLayer() {\n return this.getLayers().filter(layer => layer.get('active'))[0];\n },\n\n getFullValue() {\n return this.get('detached') ? '' : this.get('layers').getFullValue();\n },\n\n /**\n * This method allows to customize layers returned from the target\n * @param {Object} target\n * @return {Array} Should return an array of layers\n * @example\n * // return example\n * [\n * {\n * properties: [\n * { property: 'width', ... }\n * { property: 'height', ... }\n * ]\n * }\n * ]\n */\n getLayersFromTarget(target) {\n return;\n }\n});\n","import Backbone from 'backbone';\nimport { bindAll, isArray, isUndefined, debounce } from 'underscore';\nimport { camelCase } from 'utils/mixins';\nimport { includes, each } from 'underscore';\n\nconst clearProp = 'data-clear-style';\n\nexport default Backbone.View.extend({\n template(model) {\n const pfx = this.pfx;\n return `\n
\n ${this.templateLabel(model)}\n
\n
\n ${this.templateInput(model)}\n
\n `;\n },\n\n templateLabel(model) {\n const { pfx } = this;\n const icon = model.get('icon') || '';\n const info = model.get('info') || '';\n const parent = model.parent;\n\n return `\n \n ${model.get('name')}\n \n ${!parent ? `` : ''}\n `;\n },\n\n templateInput(model) {\n return `\n
\n \n
\n `;\n },\n\n events: {\n change: 'inputValueChanged',\n [`click [${clearProp}]`]: 'clear'\n },\n\n initialize(o = {}) {\n bindAll(this, 'targetUpdated');\n this.config = o.config || {};\n const em = this.config.em;\n this.em = em;\n this.pfx = this.config.stylePrefix || '';\n this.ppfx = this.config.pStylePrefix || '';\n this.target = o.target || {};\n this.propTarget = o.propTarget || {};\n this.onChange = o.onChange;\n this.onInputRender = o.onInputRender || {};\n this.customValue = o.customValue || {};\n const model = this.model;\n this.property = model.get('property');\n this.input = null;\n const pfx = this.pfx;\n this.inputHolderId = '#' + pfx + 'input-holder';\n this.sector = model.collection && model.collection.sector;\n model.view = this;\n\n if (!model.get('value')) {\n model.set('value', model.getDefaultValue());\n }\n\n em && em.on(`update:component:style:${this.property}`, this.targetUpdated);\n //em && em.on(`styleable:change:${this.property}`, this.targetUpdated);\n\n // Listening to changes of properties in this.requires, so that styleable\n // changes based on other properties are propagated\n const requires = model.get('requires');\n requires &&\n Object.keys(requires).forEach(property => {\n em && em.on(`component:styleUpdate:${property}`, this.targetUpdated);\n });\n\n this.listenTo(\n this.propTarget,\n 'update styleManager:update',\n this.targetUpdated\n );\n this.listenTo(model, 'destroy remove', this.remove);\n this.listenTo(model, 'change:value', this.modelValueChanged);\n this.listenTo(model, 'targetUpdated', this.targetUpdated);\n this.listenTo(model, 'change:visible', this.updateVisibility);\n this.listenTo(model, 'change:status', this.updateStatus);\n\n const init = this.init && this.init.bind(this);\n init && init();\n },\n\n /**\n * Triggers when the status changes. The status indicates if the value of\n * the proprerty is changed or inherited\n * @private\n */\n updateStatus() {\n const { model } = this;\n const status = model.get('status');\n const parent = model.parent;\n const pfx = this.pfx;\n const ppfx = this.ppfx;\n const config = this.config;\n const updatedCls = `${ppfx}four-color`;\n const computedCls = `${ppfx}color-warn`;\n const labelEl = this.$el.children(`.${pfx}label`);\n const clearStyleEl = this.getClearEl();\n const clearStyle = clearStyleEl ? clearStyleEl.style : {};\n labelEl.removeClass(`${updatedCls} ${computedCls}`);\n clearStyle.display = 'none';\n\n switch (status) {\n case 'updated':\n !parent && labelEl.addClass(updatedCls);\n\n if (config.clearProperties) {\n clearStyle.display = 'inline';\n }\n break;\n case 'computed':\n labelEl.addClass(computedCls);\n break;\n }\n },\n\n /**\n * Clear the property from the target\n */\n clear(e) {\n e && e.stopPropagation();\n this.model.clearValue();\n // Skip one stack with setTimeout to avoid inconsistencies\n setTimeout(() => this.targetUpdated());\n },\n\n /**\n * Get clear element\n * @return {HTMLElement}\n */\n getClearEl() {\n if (!this.clearEl) {\n this.clearEl = this.el.querySelector(`[${clearProp}]`);\n }\n\n return this.clearEl;\n },\n\n /**\n * Returns selected target which should have 'style' property\n * @return {Model|null}\n */\n getTarget() {\n return this.getTargetModel();\n },\n\n /**\n * Returns Styleable model\n * @return {Model|null}\n */\n getTargetModel() {\n return this.propTarget && this.propTarget.model;\n },\n\n /**\n * Returns helper Styleable model\n * @return {Model|null}\n */\n getHelperModel() {\n return this.propTarget && this.propTarget.helper;\n },\n\n /**\n * Triggers when the value of element input/s is changed, so have to update\n * the value of the model which will propogate those changes to the target\n */\n inputValueChanged(e) {\n e && e.stopPropagation();\n this.model.setValue(this.getInputValue(), 1, { fromInput: 1 });\n this.elementUpdated();\n },\n\n /**\n * Fired when the element of the property is updated\n */\n elementUpdated() {\n this.setStatus('updated');\n },\n\n setStatus(value) {\n this.model.set('status', value);\n const parent = this.model.parent;\n parent && value && parent.set('status', value);\n },\n\n emitUpdateTarget: debounce(function() {\n const em = this.config.em;\n em && em.trigger('styleManager:update:target', this.getTarget());\n }),\n\n /**\n * Fired when the target is changed\n * */\n targetUpdated() {\n this.emitUpdateTarget();\n\n if (!this.checkVisibility()) {\n return;\n }\n\n const config = this.config;\n const em = config.em;\n const { model } = this;\n const property = model.get('property');\n let value = '';\n let status = '';\n let targetValue = this.getTargetValue({ ignoreDefault: 1 });\n let defaultValue = model.getDefaultValue();\n let computedValue = this.getComputedValue();\n\n if (targetValue) {\n value = targetValue;\n\n if (config.highlightChanged) {\n status = 'updated';\n }\n } else if (\n computedValue &&\n config.showComputed &&\n computedValue != defaultValue\n ) {\n value = computedValue;\n\n if (config.highlightComputed) {\n status = 'computed';\n }\n } else {\n value = defaultValue;\n status = '';\n }\n\n model.setValue(value, 0, { fromTarget: 1 });\n this.setStatus(status);\n\n if (em) {\n em.trigger('styleManager:change', this, property, value);\n em.trigger(`styleManager:change:${property}`, this, value);\n }\n },\n\n checkVisibility() {\n var result = 1;\n\n // Check if need to hide the property\n if (this.config.hideNotStylable) {\n if (!this.isTargetStylable() || !this.isComponentStylable()) {\n this.hide();\n result = 0;\n } else {\n this.show();\n }\n // Sector is not passed to Composite and Stack types\n if (this.sector) {\n this.sector.trigger('updateVisibility');\n }\n }\n\n return result;\n },\n\n /**\n * Get the value of this property from the target (eg, Component, CSSRule)\n * @param {Object} [opts] Options\n * @param {Boolean} [options.fetchFromFunction]\n * @param {Boolean} [options.ignoreDefault]\n * @return string\n * @private\n */\n getTargetValue(opts = {}) {\n var result;\n var model = this.model;\n var target = this.getTargetModel();\n var customFetchValue = this.customValue;\n\n if (!target) {\n return result;\n }\n\n result = target.getStyle()[model.get('property')];\n\n if (!result && !opts.ignoreDefault) {\n result = model.getDefaultValue();\n }\n\n if (typeof customFetchValue == 'function' && !opts.ignoreCustomValue) {\n let index = model.collection.indexOf(model);\n let customValue = customFetchValue(this, index);\n\n if (customValue) {\n result = customValue;\n }\n }\n\n return result;\n },\n\n /**\n * Returns computed value\n * @return {String}\n * @private\n */\n getComputedValue() {\n const target = this.propTarget;\n const computed = target.computed || {};\n const computedDef = target.computedDefault || {};\n const avoid = this.config.avoidComputed || [];\n const property = this.model.get('property');\n const notToSkip = avoid.indexOf(property) < 0;\n const value = computed[property];\n const valueDef = computedDef[camelCase(property)];\n return computed && notToSkip && valueDef !== value && value;\n },\n\n /**\n * Returns value from input\n * @return {string}\n */\n getInputValue() {\n const input = this.getInputEl();\n return input ? input.value : '';\n },\n\n /**\n * Triggers when the `value` of the model changes, so the target and\n * the input element should be updated\n * @param {Object} e Event\n * @param {Mixed} val Value\n * @param {Object} opt Options\n * */\n modelValueChanged(e, val, opt = {}) {\n const em = this.config.em;\n const model = this.model;\n const value = model.getFullValue();\n const target = this.getTarget();\n const prop = model.get('property');\n const onChange = this.onChange;\n\n // Avoid element update if the change comes from it\n if (!opt.fromInput) {\n this.setValue(value);\n }\n\n // Check if component is allowed to be styled\n if (!target || !this.isTargetStylable() || !this.isComponentStylable()) {\n return;\n }\n\n // Avoid target update if the changes comes from it\n if (!opt.fromTarget) {\n // The onChange is used by Composite/Stack properties, so I'd avoid sending\n // it back if the change comes from one of those\n if (onChange && !opt.fromParent) {\n onChange(target, this, opt);\n } else {\n this.updateTargetStyle(value, null, opt);\n }\n }\n\n const component = em && em.getSelected();\n\n if (em && component) {\n em.trigger('component:update', component);\n em.trigger('component:styleUpdate', component, prop);\n em.trigger(`component:styleUpdate:${prop}`, component);\n }\n },\n\n /**\n * Update target style\n * @param {string} value\n * @param {string} name\n * @param {Object} opts\n */\n updateTargetStyle(value, name = '', opts = {}) {\n const property = name || this.model.get('property');\n const target = this.getTarget();\n const style = target.getStyle();\n\n if (value) {\n style[property] = value;\n } else {\n delete style[property];\n }\n\n target.setStyle(style, opts);\n\n // Helper is used by `states` like ':hover' to show its preview\n const helper = this.getHelperModel();\n helper && helper.setStyle(style, opts);\n },\n\n /**\n * Check if target is stylable with this property\n * The target could be the Component as the CSS Rule\n * @return {Boolean}\n */\n isTargetStylable(target) {\n const trg = target || this.getTarget();\n const model = this.model;\n const id = model.get('id');\n const property = model.get('property');\n const toRequire = model.get('toRequire');\n const unstylable = trg.get('unstylable');\n const stylableReq = trg.get('stylable-require');\n const requires = model.get('requires');\n const requiresParent = model.get('requiresParent');\n const sectors = this.sector ? this.sector.collection : null;\n const selected = this.em ? this.em.getSelected() : null;\n let stylable = trg.get('stylable');\n\n // Stylable could also be an array indicating with which property\n // the target could be styled\n if (isArray(stylable)) {\n stylable = stylable.indexOf(property) >= 0;\n }\n\n // Check if the property was signed as unstylable\n if (isArray(unstylable)) {\n stylable = unstylable.indexOf(property) < 0;\n }\n\n // Check if the property is available only if requested\n if (toRequire) {\n stylable =\n !target ||\n (stylableReq &&\n (stylableReq.indexOf(id) >= 0 || stylableReq.indexOf(property) >= 0));\n }\n\n // Check if the property is available based on other property's values\n if (sectors && requires) {\n const properties = Object.keys(requires);\n sectors.each(sector => {\n sector.get('properties').each(model => {\n if (includes(properties, model.id)) {\n const values = requires[model.id];\n stylable = stylable && includes(values, model.get('value'));\n }\n });\n });\n }\n\n // Check if the property is available based on parent's property values\n if (requiresParent) {\n const parent = selected && selected.parent();\n const parentEl = parent && parent.getEl();\n if (parentEl) {\n const styles = window.getComputedStyle(parentEl);\n each(requiresParent, (values, property) => {\n stylable =\n stylable && styles[property] && includes(values, styles[property]);\n });\n } else {\n stylable = false;\n }\n }\n\n return stylable;\n },\n\n /**\n * Check if the selected component is stylable with this property\n * The target could be the Component as the CSS Rule\n * @return {Boolean}\n */\n isComponentStylable() {\n const em = this.em;\n const component = em && em.getSelected();\n\n if (!component) {\n return true;\n }\n\n return this.isTargetStylable(component);\n },\n\n /**\n * Passed a raw value you have to update the input element, generally\n * is the value fetched from targets, so you can receive values with\n * functions, units, etc. (eg. `rotateY(45deg)`)\n * get also\n * @param {string} value\n * @private\n */\n setRawValue(value) {\n this.setValue(this.model.parseValue(value));\n },\n\n /**\n * Update the element input.\n * Usually the value is a result of `model.getFullValue()`\n * @param {String} value The value from the model\n * */\n setValue(value) {\n const model = this.model;\n let val = isUndefined(value) ? model.getDefaultValue() : value;\n const input = this.getInputEl();\n input && (input.value = val);\n },\n\n getInputEl() {\n if (!this.input) {\n this.input = this.el.querySelector('input');\n }\n\n return this.input;\n },\n\n updateVisibility() {\n this.el.style.display = this.model.get('visible') ? 'block' : 'none';\n },\n\n show() {\n this.model.set('visible', 1);\n },\n\n hide() {\n this.model.set('visible', 0);\n },\n\n /**\n * Clean input\n * */\n cleanValue() {\n this.setValue('');\n },\n\n clearCached() {\n this.clearEl = null;\n this.input = null;\n this.$input = null;\n },\n\n render() {\n this.clearCached();\n const pfx = this.pfx;\n const model = this.model;\n const el = this.el;\n const property = model.get('property');\n const full = model.get('full');\n const className = `${pfx}property`;\n el.innerHTML = this.template(model);\n el.className = `${className} ${pfx}${model.get(\n 'type'\n )} ${className}__${property}`;\n el.className += full ? ` ${className}--full` : '';\n this.updateStatus();\n\n const onRender = this.onRender && this.onRender.bind(this);\n onRender && onRender();\n this.setValue(model.get('value'), { targetUpdate: 1 });\n }\n});\n","import Backbone from 'backbone';\nimport PropertyView from './PropertyView';\n\nconst $ = Backbone.$;\n\nexport default PropertyView.extend({\n templateInput() {\n const pfx = this.pfx;\n return `\n
\n \n
\n `;\n },\n\n inputValueChanged(...args) {\n // If it's not detached (eg. 'padding: 1px 2px 3px 4px;') it will follow\n // the same flow of PropertyView\n if (!this.model.get('detached')) {\n PropertyView.prototype.inputValueChanged.apply(this, args);\n }\n },\n\n clear(e) {\n const props = this.properties;\n props && props.forEach(propView => propView.clear());\n PropertyView.prototype.clear.apply(this, arguments);\n },\n\n /**\n * Renders input\n * */\n onRender() {\n var model = this.model;\n var props = model.get('properties') || [];\n var self = this;\n this.properties = [];\n\n if (props.length) {\n if (!this.$input) {\n this.$input = $('');\n this.input = this.$input.get(0);\n }\n\n if (!this.props) {\n this.props = model.get('properties');\n }\n\n if (!this.$props) {\n //Not yet supported nested composite\n this.props.each(function(prop, index) {\n if (prop && prop.get('type') == 'composite') {\n this.props.remove(prop);\n console.warn('Nested composite types not yet allowed.');\n }\n prop.parent = model;\n }, this);\n\n var PropertiesView = require('./PropertiesView').default;\n var propsView = new PropertiesView(this.getPropsConfig());\n this.$props = propsView.render().$el;\n this.properties = propsView.properties;\n this.$el.find(`#${this.pfx}input-holder`).append(this.$props);\n }\n }\n },\n\n /**\n * Returns configurations that should be past to properties\n * @param {Object} opts\n * @return {Object}\n */\n getPropsConfig(opts) {\n var that = this;\n const model = this.model;\n\n var result = {\n config: this.config,\n collection: this.props,\n target: this.target,\n propTarget: this.propTarget,\n // On any change made to children I need to update composite value\n onChange(el, view, opts) {\n model.set('value', model.getFullValue(), opts);\n },\n // Each child property will receive a full composite string, eg. '0px 0px 10px 0px'\n // I need to extract from that string the corresponding one to that property.\n customValue(property, mIndex) {\n return that.valueOnIndex(mIndex, property);\n }\n };\n\n // If detached let follow its standard flow\n if (model.get('detached')) {\n delete result.onChange;\n }\n\n return result;\n },\n\n /**\n * Extract string from composite value\n * @param {number} index Index\n * @param {Object} view Property view\n * @return {string}\n * */\n valueOnIndex(index, view) {\n let value;\n const targetValue = this.getTargetValue({ ignoreDefault: 1 });\n\n // If the target value of the composite is not empty I'll fetch\n // the corresponding value from the requested index, otherwise try\n // to get the value of the sub-property\n if (targetValue) {\n const values = targetValue.split(this.model.getSplitSeparator());\n value = values[index];\n } else {\n value =\n view && view.getTargetValue({ ignoreCustomValue: 1, ignoreDefault: 1 });\n }\n\n return value;\n },\n\n clearCached() {\n PropertyView.prototype.clearCached.apply(this, arguments);\n this.$input = null;\n this.props = null;\n this.$props = null;\n }\n});\n","import Backbone from 'backbone';\nimport PropertiesView from './PropertiesView';\n\nexport default Backbone.View.extend({\n events: {\n click: 'active',\n 'click [data-close-layer]': 'remove',\n 'mousedown [data-move-layer]': 'initSorter',\n 'touchstart [data-move-layer]': 'initSorter'\n },\n\n template(model) {\n const { pfx, ppfx, config } = this;\n const label = `${config.textLayer} ${model.get('index')}`;\n\n return `\n
\n \n
\n
${label}
\n
\n \t
\n
\n
\n ⨯\n
\n
\n
\n `;\n },\n\n initialize(o = {}) {\n let model = this.model;\n this.stackModel = o.stackModel || {};\n this.config = o.config || {};\n this.pfx = this.config.stylePrefix || '';\n this.ppfx = this.config.pStylePrefix || '';\n this.sorter = o.sorter || null;\n this.propsConfig = o.propsConfig || {};\n this.customPreview = o.onPreview;\n this.listenTo(model, 'destroy remove', this.remove);\n this.listenTo(model, 'change:active', this.updateVisibility);\n this.listenTo(model.get('properties'), 'change', this.updatePreview);\n\n // For the sorter\n model.view = this;\n model.set({ droppable: 0, draggable: 1 });\n this.$el.data('model', model);\n },\n\n /**\n * Delegate sorting\n * @param {Event} e\n * */\n initSorter(e) {\n if (this.sorter) this.sorter.startSort(this.el);\n },\n\n remove(e) {\n if (e && e.stopPropagation) e.stopPropagation();\n\n const model = this.model;\n const collection = model.collection;\n const stackModel = this.stackModel;\n\n Backbone.View.prototype.remove.apply(this, arguments);\n\n if (collection.contains(model)) {\n collection.remove(model);\n }\n\n if (stackModel && stackModel.set) {\n stackModel.set({ stackIndex: null }, { silent: true });\n stackModel.trigger('updateValue');\n }\n },\n\n /**\n * Default method for changing preview box\n * @param {Collection} props\n * @param {Element} $el\n */\n onPreview(value) {\n const values = value.split(' ');\n const lim = 3;\n const result = [];\n this.model.get('properties').each((prop, index) => {\n var value = values[index] || '';\n\n if (value) {\n if (prop.get('type') == 'integer') {\n let valueInt = parseInt(value, 10);\n let unit = value.replace(valueInt, '');\n valueInt = !isNaN(valueInt) ? valueInt : 0;\n valueInt = valueInt > lim ? lim : valueInt;\n valueInt = valueInt < -lim ? -lim : valueInt;\n value = valueInt + unit;\n }\n }\n\n result.push(value);\n });\n\n return result.join(' ');\n },\n\n updatePreview() {\n const stackModel = this.stackModel;\n const customPreview = this.customPreview;\n const previewEl = this.getPreviewEl();\n const value = this.model.getFullValue();\n const preview = customPreview\n ? customPreview(value)\n : this.onPreview(value);\n\n if (preview && stackModel && previewEl) {\n previewEl.style[stackModel.get('property')] = preview;\n }\n },\n\n getPropertiesWrapper() {\n if (!this.propsWrapEl) {\n this.propsWrapEl = this.el.querySelector('[data-properties]');\n }\n return this.propsWrapEl;\n },\n\n getPreviewEl() {\n if (!this.previewEl) {\n this.previewEl = this.el.querySelector('[data-preview]');\n }\n return this.previewEl;\n },\n\n active() {\n const model = this.model;\n const collection = model.collection;\n collection.active(collection.indexOf(model));\n },\n\n updateVisibility() {\n const pfx = this.pfx;\n const wrapEl = this.getPropertiesWrapper();\n const active = this.model.get('active');\n wrapEl.style.display = active ? '' : 'none';\n this.$el[active ? 'addClass' : 'removeClass'](`${pfx}active`);\n },\n\n render() {\n const propsConfig = this.propsConfig;\n const { model, el, pfx } = this;\n const preview = model.get('preview');\n const properties = new PropertiesView({\n collection: model.get('properties'),\n config: this.config,\n target: propsConfig.target,\n customValue: propsConfig.customValue,\n propTarget: propsConfig.propTarget,\n onChange: propsConfig.onChange\n }).render().el;\n\n el.innerHTML = this.template(model);\n el.className = `${pfx}layer${!preview ? ` ${pfx}no-preview` : ''}`;\n this.getPropertiesWrapper().appendChild(properties);\n this.updateVisibility();\n this.updatePreview();\n return this;\n }\n});\n","import Backbone from 'backbone';\nimport LayerView from './LayerView';\n\nexport default Backbone.View.extend({\n initialize(o) {\n this.config = o.config || {};\n this.stackModel = o.stackModel;\n this.preview = o.preview;\n this.pfx = this.config.stylePrefix || '';\n this.ppfx = this.config.pStylePrefix || '';\n this.propsConfig = o.propsConfig;\n let pfx = this.pfx;\n let ppfx = this.ppfx;\n let collection = this.collection;\n this.className = `${pfx}layers ${ppfx}field`;\n this.listenTo(collection, 'add', this.addTo);\n this.listenTo(collection, 'deselectAll', this.deselectAll);\n this.listenTo(collection, 'reset', this.render);\n\n var em = this.config.em || '';\n var utils = em ? em.get('Utils') : '';\n\n this.sorter = utils\n ? new utils.Sorter({\n container: this.el,\n ignoreViewChildren: 1,\n containerSel: `.${pfx}layers`,\n itemSel: `.${pfx}layer`,\n pfx: this.config.pStylePrefix\n })\n : '';\n\n // For the Sorter\n collection.view = this;\n this.$el.data('model', collection);\n this.$el.data('collection', collection);\n },\n\n /**\n * Add to collection\n * @param Object Model\n *\n * @return Object\n * */\n addTo(model) {\n var i = this.collection.indexOf(model);\n this.addToCollection(model, null, i);\n },\n\n /**\n * Add new object to collection\n * @param Object Model\n * @param Object Fragment collection\n * @param {number} index Index of append\n *\n * @return Object Object created\n * */\n addToCollection(model, fragmentEl, index) {\n var fragment = fragmentEl || null;\n const stackModel = this.stackModel;\n const config = this.config;\n const sorter = this.sorter;\n const propsConfig = this.propsConfig;\n\n if (typeof this.preview !== 'undefined') {\n model.set('preview', this.preview);\n }\n\n var view = new LayerView({\n model,\n config,\n sorter,\n stackModel,\n propsConfig\n });\n var rendered = view.render().el;\n\n if (fragment) {\n fragment.appendChild(rendered);\n } else {\n if (typeof index != 'undefined') {\n var method = 'before';\n // If the added model is the last of collection\n // need to change the logic of append\n if (this.$el.children().length == index) {\n index--;\n method = 'after';\n }\n // In case the added is new in the collection index will be -1\n if (index < 0) {\n this.$el.append(rendered);\n } else\n this.$el\n .children()\n .eq(index)\n [method](rendered);\n } else this.$el.append(rendered);\n }\n\n return rendered;\n },\n\n /**\n * Deselect all\n *\n * @return void\n * */\n deselectAll() {\n this.$el.find('.' + this.pfx + 'layer').removeClass(this.pfx + 'active');\n },\n\n render() {\n var fragment = document.createDocumentFragment();\n this.$el.empty();\n\n this.collection.each(function(model) {\n this.addToCollection(model, fragment);\n }, this);\n\n this.$el.append(fragment);\n this.$el.attr('class', this.className);\n\n if (this.sorter) this.sorter.plh = null;\n\n return this;\n }\n});\n","import PropertyCompositeView from './PropertyCompositeView';\nimport LayersView from './LayersView';\n\nexport default PropertyCompositeView.extend({\n templateInput() {\n const pfx = this.pfx;\n const ppfx = this.ppfx;\n return `\n
\n \n
\n
\n `;\n },\n\n init() {\n const model = this.model;\n const pfx = this.pfx;\n model.set('stackIndex', null);\n this.events[`click [data-add-layer]`] = 'addLayer';\n this.listenTo(model, 'change:stackIndex', this.indexChanged);\n this.listenTo(model, 'updateValue', this.inputValueChanged);\n this.delegateEvents();\n },\n\n clear(e) {\n e && e.stopPropagation();\n this.model.get('layers').reset();\n this.model.clearValue();\n this.targetUpdated();\n },\n\n /**\n * Fired when the target is updated.\n * With detached mode the component will be always empty as its value\n * so we gonna check all props and find if it has any difference\n * */\n targetUpdated(...args) {\n if (!this.model.get('detached')) {\n PropertyCompositeView.prototype.targetUpdated.apply(this, args);\n } else {\n this.checkVisibility();\n }\n\n this.refreshLayers();\n },\n\n /**\n * Returns the collection of layers\n * @return {Collection}\n */\n getLayers() {\n return this.model.get('layers');\n },\n\n /**\n * Triggered when another layer has been selected.\n * This allow to move all rendered properties to a new\n * selected layer\n * @param {Event}\n *\n * @return {Object}\n * */\n indexChanged(e) {\n const model = this.model;\n this.getLayers().active(model.get('stackIndex'));\n },\n\n addLayer() {\n const model = this.model;\n const layers = this.getLayers();\n const properties = model.get('properties').deepClone();\n properties.each(property => property.set('value', ''));\n const layer = layers.add({ properties });\n\n // In detached mode inputValueChanged will add new 'layer value'\n // to all subprops\n this.inputValueChanged();\n\n // This will set subprops with a new default values\n model.set('stackIndex', layers.indexOf(layer));\n },\n\n inputValueChanged() {\n const model = this.model;\n this.elementUpdated();\n\n // If not detached I'll just put all the values from layers to property\n // eg. background: layer1Value, layer2Value, layer3Value, ...\n if (!model.get('detached')) {\n model.set('value', this.getLayerValues());\n } else {\n model.get('properties').each(prop => prop.trigger('change:value'));\n }\n },\n\n /**\n * There is no need to handle input update by the property itself,\n * this will be done by layers\n * @private\n */\n setValue() {},\n\n /**\n * Create value by layers\n * @return string\n * */\n getLayerValues() {\n return this.getLayers().getFullValue();\n },\n\n /**\n * Refresh layers\n * */\n refreshLayers() {\n let layersObj = [];\n const model = this.model;\n const layers = this.getLayers();\n const detached = model.get('detached');\n const target = this.getTarget();\n\n // With detached layers values will be assigned to their properties\n if (detached) {\n const style = target ? target.getStyle() : {};\n layersObj = layers.getLayersFromStyle(style);\n } else {\n let value = this.getTargetValue();\n value = value == model.getDefaultValue() ? '' : value;\n layersObj = layers.getLayersFromValue(value);\n }\n\n const toAdd = model.getLayersFromTarget(target) || layersObj;\n layers.reset();\n layers.add(toAdd);\n model.set({ stackIndex: null }, { silent: true });\n },\n\n onRender() {\n const self = this;\n const model = this.model;\n const fieldEl = this.el.querySelector('[data-layers-wrapper]');\n const PropertiesView = require('./PropertiesView').default;\n const propsConfig = {\n target: this.target,\n propTarget: this.propTarget,\n\n // Things to do when a single sub-property is changed\n onChange(el, view, opt) {\n const subModel = view.model;\n\n if (model.get('detached')) {\n const subProp = subModel.get('property');\n const values = self.getLayers().getPropertyValues(subProp);\n view.updateTargetStyle(values, null, opt);\n } else {\n model.set('value', model.getFullValue(), opt);\n }\n }\n };\n const layers = new LayersView({\n collection: this.getLayers(),\n stackModel: model,\n preview: model.get('preview'),\n config: this.config,\n propsConfig\n }).render().el;\n\n // Will use it to propogate changes\n new PropertiesView({\n target: this.target,\n collection: this.model.get('properties'),\n stackModel: model,\n config: this.config,\n onChange: propsConfig.onChange,\n propTarget: propsConfig.propTarget,\n customValue: propsConfig.customValue\n }).render();\n\n //model.get('properties')\n fieldEl.appendChild(layers);\n }\n});\n","import { isString } from 'underscore';\nimport Backbone from 'backbone';\nimport PropertyView from './PropertyView';\n\nconst $ = Backbone.$;\n\nexport default PropertyView.extend({\n templateInput() {\n const pfx = this.pfx;\n const ppfx = this.ppfx;\n const assetsLabel = this.config.assetsLabel || 'Images';\n return `\n
\n
\n
\n \n
\n
\n
\n
\n
\n
\n
\n
\n `;\n },\n\n init() {\n const em = this.em;\n this.modal = em.get('Modal');\n this.am = em.get('AssetManager');\n this.events['click #' + this.pfx + 'close'] = 'removeFile';\n this.events['click #' + this.pfx + 'images'] = 'openAssetManager';\n this.delegateEvents();\n },\n\n onRender() {\n if (!this.$input) {\n const plh = this.model.getDefaultValue();\n this.$input = $(``);\n }\n\n if (!this.$preview) {\n this.$preview = this.$el.find('#' + this.pfx + 'preview-file');\n }\n\n if (!this.$previewBox) {\n this.$previewBox = this.$el.find('#' + this.pfx + 'preview-box');\n }\n\n this.setValue(this.componentValue, 0);\n },\n\n clearCached() {\n PropertyView.prototype.clearCached.apply(this, arguments);\n this.$preview = null;\n this.$previewBox = null;\n },\n\n setValue(value, f) {\n PropertyView.prototype.setValue.apply(this, arguments);\n this.setPreviewView(value && value != this.model.getDefaultValue());\n this.setPreview(value);\n },\n\n /**\n * Change visibility of the preview box\n * @param bool Visibility\n *\n * @return void\n * */\n setPreviewView(v) {\n const pv = this.$previewBox;\n pv && pv[v ? 'addClass' : 'removeClass'](`${this.pfx}show`);\n },\n\n /**\n * Spread url\n * @param string Url\n *\n * @return void\n * */\n spreadUrl(url) {\n this.model.set('value', url);\n this.setPreviewView(1);\n },\n\n /**\n * Shows file preview\n * @param string Value\n * */\n setPreview(value) {\n const preview = this.$preview;\n value = value && value.indexOf('url(') < 0 ? `url(${value})` : value;\n preview && preview.css('background-image', value);\n },\n\n /** @inheritdoc */\n cleanValue() {\n this.setPreviewView(0);\n this.model.set({ value: '' }, { silent: true });\n },\n\n /**\n * Remove file from input\n *\n * @return void\n * */\n removeFile(...args) {\n this.model.set('value', this.model.getDefaultValue());\n PropertyView.prototype.cleanValue.apply(this, args);\n this.setPreviewView(0);\n },\n\n /**\n * Open dialog for image selecting\n * @param {Object} e Event\n *\n * @return void\n * */\n openAssetManager(e) {\n const { em, modal } = this;\n const editor = em ? em.get('Editor') : '';\n\n if (editor) {\n editor.runCommand('open-assets', {\n types: ['image'],\n accept: 'image/*',\n target: this.getTargetModel(),\n onClick() {},\n onDblClick() {},\n onSelect: asset => {\n modal.close();\n const url = isString(asset) ? asset : asset.get('src');\n this.spreadUrl(url);\n }\n });\n }\n }\n});\n","import Backbone from 'backbone';\nimport PropertyView from './PropertyView';\n\nconst $ = Backbone.$;\n\nexport default PropertyView.extend({\n templateInput() {\n return '';\n },\n\n init() {\n const model = this.model;\n this.listenTo(model, 'change:unit', this.modelValueChanged);\n this.listenTo(model, 'el:change', this.elementUpdated);\n this.listenTo(model, 'change:units', this.render);\n },\n\n setValue(value) {\n const parsed = this.model.parseValue(value);\n value = `${parsed.value}${parsed.unit}`;\n this.inputInst.setValue(value, { silent: 1 });\n },\n\n onRender() {\n const ppfx = this.ppfx;\n\n if (!this.input) {\n const input = this.model.input;\n input.ppfx = ppfx;\n input.render();\n const fields = this.el.querySelector(`.${ppfx}fields`);\n fields.appendChild(input.el);\n this.$input = input.inputEl;\n this.unit = input.unitEl;\n this.$unit = $(this.unit);\n this.input = this.$input.get(0);\n this.inputInst = input;\n }\n },\n\n clearCached() {\n PropertyView.prototype.clearCached.apply(this, arguments);\n this.unit = null;\n this.$unit = null;\n }\n});\n","import PropertyIntegerView from './PropertyIntegerView';\nimport InputColor from 'domain_abstract/ui/InputColor';\n\nexport default PropertyIntegerView.extend({\n setValue(value, opts = {}) {\n opts = { ...opts, silent: 1 };\n this.inputInst.setValue(value, opts);\n },\n\n onRender() {\n if (!this.input) {\n const ppfx = this.ppfx;\n const inputColor = new InputColor({\n target: this.target,\n model: this.model,\n ppfx\n });\n const input = inputColor.render();\n this.el.querySelector(`.${ppfx}fields`).appendChild(input.el);\n this.$input = input.inputEl;\n this.$color = input.colorEl;\n this.input = this.$input.get(0);\n this.inputInst = input;\n }\n }\n});\n","import Property from './Property';\n\nexport default Property.extend({\n defaults: () => ({\n ...Property.prototype.defaults,\n // Array of options, eg. [{name: 'Label ', value: '100'}]\n options: [],\n full: 1\n }),\n\n initialize(...args) {\n Property.prototype.initialize.apply(this, args);\n this.listenTo(this, 'change:options', this.onOptionChange);\n },\n\n onOptionChange() {\n this.set('list', this.get('options'));\n },\n\n getOptions() {\n const { options, list } = this.attributes;\n return options && options.length ? options : list;\n },\n\n setOptions(opts = []) {\n this.set('options', opts);\n return this;\n },\n\n addOption(opt) {\n if (opt) {\n const opts = this.getOptions();\n this.setOptions([...opts, opt]);\n }\n return this;\n }\n});\n","import Property from './PropertyRadio';\n\nexport default Property.extend({\n defaults: () => ({\n ...Property.prototype.defaults,\n full: 0\n })\n});\n","import Backbone from 'backbone';\nimport PropertyView from './PropertyView';\n\nconst $ = Backbone.$;\n\nexport default PropertyView.extend({\n templateInput() {\n const pfx = this.pfx;\n const ppfx = this.ppfx;\n return `\n
\n \n
\n
\n
\n
\n `;\n },\n\n initialize(...args) {\n PropertyView.prototype.initialize.apply(this, args);\n this.listenTo(this.model, 'change:options', this.updateOptions);\n },\n\n updateOptions() {\n this.input = null;\n this.onRender();\n },\n\n onRender() {\n var pfx = this.pfx;\n const options = this.model.getOptions();\n\n if (!this.input) {\n let optionsStr = '';\n\n options.forEach(option => {\n let name = option.name || option.value;\n let style = option.style ? option.style.replace(/\"/g, '"') : '';\n let styleAttr = style ? `style=\"${style}\"` : '';\n let value = option.value.replace(/\"/g, '"');\n optionsStr += ``;\n });\n\n const inputH = this.el.querySelector(`#${pfx}input-holder`);\n inputH.innerHTML = ``;\n this.input = inputH.firstChild;\n }\n }\n});\n","import PropertyView from './PropertyView';\n\nexport default PropertyView.extend({\n templateInput() {\n const pfx = this.pfx;\n const ppfx = this.ppfx;\n return `\n
\n
\n `;\n },\n\n onRender() {\n const pfx = this.pfx;\n const ppfx = this.ppfx;\n const itemCls = `${ppfx}radio-item-label`;\n const model = this.model;\n const prop = model.get('property');\n const options = model.get('list') || model.get('options') || [];\n\n if (!this.input) {\n if (options && options.length) {\n let inputStr = '';\n\n options.forEach(el => {\n let cl = el.className ? `${el.className} ${pfx}icon ${itemCls}` : '';\n let id = `${prop}-${el.value}`;\n let labelTxt = el.name || el.value;\n let titleAttr = el.title ? `title=\"${el.title}\"` : '';\n inputStr += `\n
\n \n \n
\n `;\n });\n\n const inputHld = this.el.querySelector(`.${ppfx}field`);\n inputHld.innerHTML = `
${inputStr}
`;\n this.input = inputHld.firstChild;\n }\n }\n },\n\n getInputValue() {\n const inputChk = this.getCheckedEl();\n return inputChk ? inputChk.value : '';\n },\n\n getCheckedEl() {\n const input = this.getInputEl();\n return input ? input.querySelector('input:checked') : '';\n },\n\n setValue(value) {\n const model = this.model;\n let val = value || model.get('value') || model.getDefaultValue();\n const input = this.getInputEl();\n const inputIn = input ? input.querySelector(`[value=\"${val}\"]`) : '';\n\n if (inputIn) {\n inputIn.checked = true;\n } else {\n const inputChk = this.getCheckedEl();\n inputChk && (inputChk.checked = false);\n }\n }\n});\n","import { isUndefined } from 'underscore';\nimport Property from './Property';\nimport InputNumber from 'domain_abstract/ui/InputNumber';\n\nexport default Property.extend({\n defaults: {\n ...Property.prototype.defaults,\n // Array of units, eg. ['px', '%']\n units: [],\n\n // Selected unit, eg. 'px'\n unit: '',\n\n // Integer value steps\n step: 1,\n\n // Minimum value\n min: '',\n\n // Maximum value\n max: ''\n },\n\n init() {\n const unit = this.get('unit');\n const units = this.get('units');\n this.input = new InputNumber({ model: this });\n\n if (units.length && !unit) {\n this.set('unit', units[0]);\n }\n },\n\n clearValue(opts = {}) {\n this.set({ value: undefined, unit: undefined }, opts);\n return this;\n },\n\n parseValue(val) {\n const parsed = Property.prototype.parseValue.apply(this, arguments);\n const { value, unit } = this.input.validateInputValue(parsed.value, {\n deepCheck: 1\n });\n parsed.value = value;\n parsed.unit = unit;\n return parsed;\n },\n\n getFullValue() {\n let value = this.get('value');\n let unit = this.get('unit');\n value = !isUndefined(value) ? value : '';\n unit = !isUndefined(unit) && value ? unit : '';\n value = `${value}${unit}`;\n return Property.prototype.getFullValue.apply(this, [value]);\n }\n});\n","import Property from './PropertyInteger';\n\nexport default Property.extend({\n defaults: {\n ...Property.prototype.defaults,\n showInput: 1\n }\n});\n","import Property from './PropertyIntegerView';\n\nexport default Property.extend({\n events() {\n return {\n ...Property.prototype.events,\n 'change [type=range]': 'inputValueChanged',\n 'input [type=range]': 'inputValueChangedSoft',\n change: ''\n };\n },\n\n templateInput(model) {\n const ppfx = this.ppfx;\n return `\n
\n \n
\n `;\n },\n\n getSliderEl() {\n if (!this.slider) {\n this.slider = this.el.querySelector('input[type=range]');\n }\n\n return this.slider;\n },\n\n inputValueChanged() {\n const model = this.model;\n const step = model.get('step');\n this.getInputEl().value = this.getSliderEl().value;\n const value = this.getInputValue() - step;\n model.set('value', value, { avoidStore: 1 }).set('value', value + step);\n this.elementUpdated();\n },\n\n inputValueChangedSoft() {\n this.getInputEl().value = this.getSliderEl().value;\n this.model.set('value', this.getInputValue(), { avoidStore: 1 });\n this.elementUpdated();\n },\n\n setValue(value) {\n const parsed = this.model.parseValue(value);\n this.getSliderEl().value = parseFloat(parsed.value);\n Property.prototype.setValue.apply(this, arguments);\n },\n\n onRender() {\n Property.prototype.onRender.apply(this, arguments);\n\n if (!this.model.get('showInput')) {\n this.inputInst.el.style.display = 'none';\n }\n },\n\n clearCached() {\n Property.prototype.clearCached.apply(this, arguments);\n this.slider = null;\n }\n});\n","import Backbone from 'backbone';\nimport TypeableCollection from 'domain_abstract/model/TypeableCollection';\nimport Property from './Property';\nimport PropertyStack from './PropertyStack';\nimport PropertyStackView from './../view/PropertyStackView';\nimport PropertyComposite from './PropertyComposite';\nimport PropertyCompositeView from './../view/PropertyCompositeView';\nimport PropertyFileView from './../view/PropertyFileView';\nimport PropertyColorView from './../view/PropertyColorView';\nimport PropertySelect from './PropertySelect';\nimport PropertySelectView from './../view/PropertySelectView';\nimport PropertyRadio from './PropertyRadio';\nimport PropertyRadioView from './../view/PropertyRadioView';\nimport PropertySlider from './PropertySlider';\nimport PropertySliderView from './../view/PropertySliderView';\nimport PropertyInteger from './PropertyInteger';\nimport PropertyIntegerView from './../view/PropertyIntegerView';\nimport PropertyView from './../view/PropertyView';\n\nexport default Backbone.Collection.extend(TypeableCollection).extend({\n types: [\n {\n id: 'stack',\n model: PropertyStack,\n view: PropertyStackView,\n isType(value) {\n if (value && value.type == 'stack') {\n return value;\n }\n }\n },\n {\n id: 'composite',\n model: PropertyComposite,\n view: PropertyCompositeView,\n isType(value) {\n if (value && value.type == 'composite') {\n return value;\n }\n }\n },\n {\n id: 'file',\n model: Property,\n view: PropertyFileView,\n isType(value) {\n if (value && value.type == 'file') {\n return value;\n }\n }\n },\n {\n id: 'color',\n model: Property,\n view: PropertyColorView,\n isType(value) {\n if (value && value.type == 'color') {\n return value;\n }\n }\n },\n {\n id: 'select',\n model: PropertySelect,\n view: PropertySelectView,\n isType(value) {\n if (value && value.type == 'select') {\n return value;\n }\n }\n },\n {\n id: 'radio',\n model: PropertyRadio,\n view: PropertyRadioView,\n isType(value) {\n if (value && value.type == 'radio') {\n return value;\n }\n }\n },\n {\n id: 'slider',\n model: PropertySlider,\n view: PropertySliderView,\n isType(value) {\n if (value && value.type == 'slider') {\n return value;\n }\n }\n },\n {\n id: 'integer',\n model: PropertyInteger,\n view: PropertyIntegerView,\n isType(value) {\n if (value && value.type == 'integer') {\n return value;\n }\n }\n },\n {\n id: 'base',\n model: Property,\n view: PropertyView,\n isType(value) {\n value.type = 'base';\n return value;\n }\n }\n ],\n\n deepClone() {\n const collection = this.clone();\n collection.reset(\n collection.map(model => {\n const cloned = model.clone();\n cloned.typeView = model.typeView;\n return cloned;\n })\n );\n return collection;\n },\n\n /**\n * Parse a value and return an array splitted by properties\n * @param {string} value\n * @return {Array}\n * @return\n */\n parseValue(value) {\n const properties = [];\n const values = value.split(' ');\n values.forEach((value, i) => {\n const property = this.at(i);\n if (!property) return;\n properties.push({ ...property.attributes, ...{ value } });\n });\n return properties;\n },\n\n getFullValue() {\n let result = '';\n this.each(model => (result += `${model.getFullValue()} `));\n return result.trim();\n }\n});\n","var g;\n\n// This works in non-strict mode\ng = (function() {\n\treturn this;\n})();\n\ntry {\n\t// This works if eval is allowed (see CSP)\n\tg = g || new Function(\"return this\")();\n} catch (e) {\n\t// This works if the window reference is available\n\tif (typeof window === \"object\") g = window;\n}\n\n// g can still be undefined, but nothing to do about it...\n// We return undefined, instead of nothing here, so it's\n// easier to handle this case. if(!global) { ...}\n\nmodule.exports = g;\n","import Backbone from 'backbone';\nconst $ = Backbone.$;\n\nexport default {\n /**\n * Start select position event\n * @param {HTMLElement} trg\n * @private\n * */\n startSelectPosition(trg, doc) {\n this.isPointed = false;\n var utils = this.editorModel.get('Utils');\n if (utils && !this.sorter)\n this.sorter = new utils.Sorter({\n container: this.getCanvasBody(),\n placer: this.canvas.getPlacerEl(),\n containerSel: '*',\n itemSel: '*',\n pfx: this.ppfx,\n direction: 'a',\n document: doc,\n wmargin: 1,\n nested: 1,\n em: this.editorModel,\n canvasRelative: 1,\n scale: () => this.em.getZoomDecimal()\n });\n trg && this.sorter.startSort(trg);\n },\n\n /**\n * Get frame position\n * @return {Object}\n * @private\n */\n getOffsetDim() {\n var frameOff = this.offset(this.canvas.getFrameEl());\n var canvasOff = this.offset(this.canvas.getElement());\n var top = frameOff.top - canvasOff.top;\n var left = frameOff.left - canvasOff.left;\n return { top, left };\n },\n\n /**\n * Stop select position event\n * @private\n * */\n stopSelectPosition() {\n this.posTargetCollection = null;\n this.posIndex =\n this.posMethod == 'after' && this.cDim.length !== 0\n ? this.posIndex + 1\n : this.posIndex; //Normalize\n if (this.sorter) {\n this.sorter.moved = 0;\n this.sorter.endMove();\n }\n if (this.cDim) {\n this.posIsLastEl =\n this.cDim.length !== 0 &&\n this.posMethod == 'after' &&\n this.posIndex == this.cDim.length;\n this.posTargetEl =\n this.cDim.length === 0\n ? $(this.outsideElem)\n : !this.posIsLastEl && this.cDim[this.posIndex]\n ? $(this.cDim[this.posIndex][5]).parent()\n : $(this.outsideElem);\n this.posTargetModel = this.posTargetEl.data('model');\n this.posTargetCollection = this.posTargetEl.data('model-comp');\n }\n },\n\n /**\n * Enabel select position\n * @private\n */\n enable() {\n this.startSelectPosition();\n },\n\n /**\n * Check if the pointer is near to the float component\n * @param {number} index\n * @param {string} method\n * @param {Array} dims\n * @return {Boolean}\n * @private\n * */\n nearFloat(index, method, dims) {\n var i = index || 0;\n var m = method || 'before';\n var len = dims.length;\n var isLast = len !== 0 && m == 'after' && i == len;\n if (\n len !== 0 &&\n ((!isLast && !dims[i][4]) ||\n (dims[i - 1] && !dims[i - 1][4]) ||\n (isLast && !dims[i - 1][4]))\n )\n return 1;\n return 0;\n },\n\n run() {\n this.enable();\n },\n\n stop() {\n this.stopSelectPosition();\n this.$wrapper.css('cursor', '');\n this.$wrapper.unbind();\n }\n};\n","import Promise from 'promise-polyfill';\n\nwindow.Promise = window.Promise || Promise;\n\nexport default (typeof fetch == 'function'\n ? fetch.bind()\n : (url, options) => {\n return new Promise((res, rej) => {\n const req = new XMLHttpRequest();\n req.open(options.method || 'get', url);\n req.withCredentials = options.credentials == 'include';\n\n for (let k in options.headers || {}) {\n req.setRequestHeader(k, options.headers[k]);\n }\n\n req.onload = e =>\n res({\n status: req.status,\n statusText: req.statusText,\n text: () => Promise.resolve(req.responseText)\n });\n req.onerror = rej;\n\n // Actually, fetch doesn't support onProgress feature\n if (req.upload && options.onProgress) {\n req.upload.onprogress = options.onProgress;\n }\n\n // Include body only if present\n options.body ? req.send(options.body) : req.send();\n });\n });\n","import { each, isString } from 'underscore';\n\nexport default config => {\n var TEXT_NODE = 'span';\n var c = config;\n var modelAttrStart = 'data-gjs-';\n\n return {\n compTypes: '',\n\n modelAttrStart,\n\n /**\n * Extract component props from an attribute object\n * @param {Object} attr\n * @returns {Object} An object containing props and attributes without them\n */\n splitPropsFromAttr(attr = {}) {\n const props = {};\n const attrs = {};\n\n each(attr, (value, key) => {\n if (key.indexOf(this.modelAttrStart) === 0) {\n const modelAttr = key.replace(modelAttrStart, '');\n const valueLen = value.length;\n const valStr = value && isString(value);\n const firstChar = valStr && value.substr(0, 1);\n const lastChar = valStr && value.substr(valueLen - 1);\n value = value === 'true' ? true : value;\n value = value === 'false' ? false : value;\n\n // Try to parse JSON where it's possible\n // I can get false positive here (eg. a selector '[data-attr]')\n // so put it under try/catch and let fail silently\n try {\n value =\n (firstChar == '{' && lastChar == '}') ||\n (firstChar == '[' && lastChar == ']')\n ? JSON.parse(value)\n : value;\n } catch (e) {}\n\n props[modelAttr] = value;\n } else {\n attrs[key] = value;\n }\n });\n\n return {\n props,\n attrs\n };\n },\n\n /**\n * Parse style string to object\n * @param {string} str\n * @return {Object}\n * @example\n * var stl = ParserHtml.parseStyle('color:black; width:100px; test:value;');\n * console.log(stl);\n * // {color: 'black', width: '100px', test: 'value'}\n */\n parseStyle(str) {\n var result = {};\n var decls = str.split(';');\n for (var i = 0, len = decls.length; i < len; i++) {\n var decl = decls[i].trim();\n if (!decl) continue;\n var prop = decl.split(':');\n result[prop[0].trim()] = prop\n .slice(1)\n .join(':')\n .trim();\n }\n return result;\n },\n\n /**\n * Parse class string to array\n * @param {string} str\n * @return {Array}\n * @example\n * var res = ParserHtml.parseClass('test1 test2 test3');\n * console.log(res);\n * // ['test1', 'test2', 'test3']\n */\n parseClass(str) {\n const result = [];\n const cls = str.split(' ');\n for (let i = 0, len = cls.length; i < len; i++) {\n const cl = cls[i].trim();\n if (!cl) continue;\n result.push(cl);\n }\n return result;\n },\n\n /**\n * Get data from the node element\n * @param {HTMLElement} el DOM element to traverse\n * @return {Array}\n */\n parseNode(el) {\n const result = [];\n const nodes = el.childNodes;\n\n for (var i = 0, len = nodes.length; i < len; i++) {\n const node = nodes[i];\n const attrs = node.attributes || [];\n const attrsLen = attrs.length;\n const nodePrev = result[result.length - 1];\n const nodeChild = node.childNodes.length;\n const ct = this.compTypes;\n let model = {};\n\n // Start with understanding what kind of component it is\n if (ct) {\n let obj = '';\n let type =\n node.getAttribute && node.getAttribute(`${modelAttrStart}type`);\n\n // If the type is already defined, use it\n if (type) {\n model = { type };\n } else {\n // Iterate over all available Component Types and\n // the first with a valid result will be that component\n for (let it = 0; it < ct.length; it++) {\n const compType = ct[it];\n obj = compType.model.isComponent(node);\n\n if (obj) {\n if (typeof obj !== 'object') {\n obj = { type: compType.id };\n }\n break;\n }\n }\n\n model = obj;\n }\n }\n\n // Set tag name if not yet done\n if (!model.tagName) {\n model.tagName = node.tagName ? node.tagName.toLowerCase() : '';\n }\n\n if (attrsLen) {\n model.attributes = {};\n }\n\n // Parse attributes\n for (let j = 0; j < attrsLen; j++) {\n const nodeName = attrs[j].nodeName;\n let nodeValue = attrs[j].nodeValue;\n\n // Isolate attributes\n if (nodeName == 'style') {\n model.style = this.parseStyle(nodeValue);\n } else if (nodeName == 'class') {\n model.classes = this.parseClass(nodeValue);\n } else if (nodeName == 'contenteditable') {\n continue;\n } else if (nodeName.indexOf(modelAttrStart) === 0) {\n const modelAttr = nodeName.replace(modelAttrStart, '');\n const valueLen = nodeValue.length;\n const firstChar = nodeValue && nodeValue.substr(0, 1);\n const lastChar = nodeValue && nodeValue.substr(valueLen - 1);\n nodeValue = nodeValue === 'true' ? true : nodeValue;\n nodeValue = nodeValue === 'false' ? false : nodeValue;\n\n // Try to parse JSON where it's possible\n // I can get false positive here (eg. a selector '[data-attr]')\n // so put it under try/catch and let fail silently\n try {\n nodeValue =\n (firstChar == '{' && lastChar == '}') ||\n (firstChar == '[' && lastChar == ']')\n ? JSON.parse(nodeValue)\n : nodeValue;\n } catch (e) {}\n\n model[modelAttr] = nodeValue;\n } else {\n model.attributes[nodeName] = nodeValue;\n }\n }\n\n // Check for nested elements but avoid it if already provided\n if (nodeChild && !model.components) {\n // Avoid infinite nested text nodes\n const firstChild = node.childNodes[0];\n\n // If there is only one child and it's a TEXTNODE\n // just make it content of the current node\n if (nodeChild === 1 && firstChild.nodeType === 3) {\n !model.type && (model.type = 'text');\n model.content = firstChild.nodeValue;\n } else {\n model.components = this.parseNode(node);\n }\n }\n\n // Check if it's a text node and if could be moved to the prevous model\n if (model.type == 'textnode') {\n if (nodePrev && nodePrev.type == 'textnode') {\n nodePrev.content += model.content;\n continue;\n }\n\n // Throw away empty nodes (keep spaces)\n if (!config.keepEmptyTextNodes) {\n const content = node.nodeValue;\n if (content != ' ' && !content.trim()) {\n continue;\n }\n }\n }\n\n // If all children are texts and there is some textnode the parent should\n // be text too otherwise I'm unable to edit texnodes\n const comps = model.components;\n if (!model.type && comps) {\n let allTxt = 1;\n let foundTextNode = 0;\n\n for (let ci = 0; ci < comps.length; ci++) {\n const comp = comps[ci];\n const cType = comp.type;\n\n if (\n ['text', 'textnode'].indexOf(cType) < 0 &&\n c.textTags.indexOf(comp.tagName) < 0\n ) {\n allTxt = 0;\n break;\n }\n\n if (cType == 'textnode') {\n foundTextNode = 1;\n }\n }\n\n if (allTxt && foundTextNode) {\n model.type = 'text';\n }\n }\n\n // If tagName is still empty and is not a textnode, do not push it\n if (!model.tagName && model.type != 'textnode') {\n continue;\n }\n\n result.push(model);\n }\n\n return result;\n },\n\n /**\n * Parse HTML string to a desired model object\n * @param {string} str HTML string\n * @param {ParserCss} parserCss In case there is style tags inside HTML\n * @return {Object}\n */\n parse(str, parserCss) {\n var config = (c.em && c.em.get('Config')) || {};\n var res = { html: '', css: '' };\n var el = document.createElement('div');\n el.innerHTML = str;\n var scripts = el.querySelectorAll('script');\n var i = scripts.length;\n\n // Remove all scripts\n if (!config.allowScripts) {\n while (i--) scripts[i].parentNode.removeChild(scripts[i]);\n }\n\n // Detach style tags and parse them\n if (parserCss) {\n var styleStr = '';\n var styles = el.querySelectorAll('style');\n var j = styles.length;\n\n while (j--) {\n styleStr = styles[j].innerHTML + styleStr;\n styles[j].parentNode.removeChild(styles[j]);\n }\n\n if (styleStr) res.css = parserCss.parse(styleStr);\n }\n\n var result = this.parseNode(el);\n\n if (result.length == 1) result = result[0];\n\n res.html = result;\n\n return res;\n }\n };\n};\n","import { isFunction } from 'underscore';\nimport Backbone from 'backbone';\n\nconst Model = Backbone.Model;\nconst View = Backbone.View;\n\nexport default {\n types: [],\n\n initialize(models, opts) {\n this.model = (attrs = {}, options = {}) => {\n let Model, View, type;\n\n if (attrs && attrs.type) {\n const baseType = this.getBaseType();\n type = this.getType(attrs.type);\n Model = type ? type.model : baseType.model;\n View = type ? type.view : baseType.view;\n } else {\n const typeFound = this.recognizeType(attrs);\n type = typeFound.type;\n Model = type.model;\n View = type.view;\n attrs = typeFound.attributes;\n }\n\n const model = new Model(attrs, options);\n model.typeView = View;\n return model;\n };\n const init = this.init && this.init.bind(this);\n init && init();\n },\n\n /**\n * Recognize type by any value\n * @param {mixed} value\n * @return {Object} Found type\n */\n recognizeType(value) {\n const types = this.getTypes();\n\n for (let i = 0; i < types.length; i++) {\n const type = types[i];\n let typeFound = type.isType(value);\n typeFound =\n typeof typeFound == 'boolean' && typeFound\n ? { type: type.id }\n : typeFound;\n\n if (typeFound) {\n return {\n type,\n attributes: typeFound\n };\n }\n }\n\n // If, for any reason, the type is not found it'll return the base one\n return {\n type: this.getBaseType(),\n attributes: value\n };\n },\n\n /**\n * Returns the base type (last object in the stack)\n * @return {Object}\n */\n getBaseType() {\n const types = this.getTypes();\n return types[types.length - 1];\n },\n\n /**\n * Get types\n * @return {Array}\n */\n getTypes() {\n return this.types;\n },\n\n /**\n * Get type\n * @param {string} id Type ID\n * @return {Object} Type definition\n */\n getType(id) {\n const types = this.getTypes();\n\n for (let i = 0; i < types.length; i++) {\n const type = types[i];\n if (type.id === id) {\n return type;\n }\n }\n },\n\n /**\n * Add new type\n * @param {string} id Type ID\n * @param {Object} definition Definition of the type. Each definition contains\n * `model` (business logic), `view` (presentation logic)\n * and `isType` function which recognize the type of the\n * passed entity\n * addType('my-type', {\n * model: {},\n * view: {},\n * isType: (value) => {},\n * })\n */\n addType(id, definition) {\n const type = this.getType(id);\n const baseType = this.getBaseType();\n const ModelInst = type ? type.model : baseType.model;\n const ViewInst = type ? type.view : baseType.view;\n let { model, view, isType } = definition;\n model =\n model instanceof Model || isFunction(model)\n ? model\n : ModelInst.extend(model || {});\n view =\n view instanceof View || isFunction(view)\n ? view\n : ViewInst.extend(view || {});\n\n if (type) {\n type.model = model;\n type.view = view;\n type.isType = isType || type.isType;\n } else {\n definition.id = id;\n definition.model = model;\n definition.view = view;\n definition.isType =\n isType ||\n function(value) {\n if (value && value.type == id) {\n return true;\n }\n };\n this.getTypes().unshift(definition);\n }\n }\n};\n","import Backbone from 'backbone';\nimport { bindAll, isUndefined, indexOf } from 'underscore';\nimport { on, off } from 'utils/mixins';\nimport Input from './Input';\n\nconst $ = Backbone.$;\n\nexport default Input.extend({\n events: {\n 'change input': 'handleChange',\n 'change select': 'handleUnitChange',\n 'click [data-arrow-up]': 'upArrowClick',\n 'click [data-arrow-down]': 'downArrowClick',\n 'mousedown [data-arrows]': 'downIncrement'\n },\n\n template() {\n const ppfx = this.ppfx;\n return `\n \n \n
\n
\n
\n
\n `;\n },\n\n inputClass() {\n const ppfx = this.ppfx;\n return this.opts.contClass || `${ppfx}field ${ppfx}field-integer`;\n },\n\n initialize(opts = {}) {\n Input.prototype.initialize.apply(this, arguments);\n bindAll(this, 'moveIncrement', 'upIncrement');\n this.doc = document;\n this.listenTo(this.model, 'change:unit', this.handleModelChange);\n },\n\n /**\n * Set value to the model\n * @param {string} value\n * @param {Object} opts\n */\n setValue(value, opts) {\n var opt = opts || {};\n var valid = this.validateInputValue(value, { deepCheck: 1 });\n var validObj = { value: valid.value };\n\n // If found some unit value\n if (valid.unit || valid.force) {\n validObj.unit = valid.unit;\n }\n\n this.model.set(validObj, opt);\n\n // Generally I get silent when I need to reflect data to view without\n // reupdating the target\n if (opt.silent) {\n this.handleModelChange();\n }\n },\n\n /**\n * Handled when the view is changed\n */\n handleChange(e) {\n e.stopPropagation();\n this.setValue(this.getInputEl().value);\n this.elementUpdated();\n },\n\n /**\n * Handled when the view is changed\n */\n handleUnitChange(e) {\n e.stopPropagation();\n var value = this.getUnitEl().value;\n this.model.set('unit', value);\n this.elementUpdated();\n },\n\n /**\n * Fired when the element of the property is updated\n */\n elementUpdated() {\n this.model.trigger('el:change');\n },\n\n /**\n * Updates the view when the model is changed\n * */\n handleModelChange() {\n const model = this.model;\n this.getInputEl().value = model.get('value');\n const unitEl = this.getUnitEl();\n unitEl && (unitEl.value = model.get('unit') || '');\n },\n\n /**\n * Get the unit element\n * @return {HTMLElement}\n */\n getUnitEl() {\n if (!this.unitEl) {\n const model = this.model;\n const units = model.get('units') || [];\n\n if (units.length) {\n const options = [];\n\n units.forEach(unit => {\n const selected = unit == model.get('unit') ? 'selected' : '';\n options.push(``);\n });\n\n const temp = document.createElement('div');\n temp.innerHTML = ``;\n this.unitEl = temp.firstChild;\n }\n }\n\n return this.unitEl;\n },\n\n /**\n * Invoked when the up arrow is clicked\n * */\n upArrowClick() {\n const model = this.model;\n const step = model.get('step');\n let value = parseInt(model.get('value'), 10);\n value = this.normalizeValue(value + step);\n var valid = this.validateInputValue(value);\n model.set('value', valid.value);\n this.elementUpdated();\n },\n\n /**\n * Invoked when the down arrow is clicked\n * */\n downArrowClick() {\n const model = this.model;\n const step = model.get('step');\n const value = parseInt(model.get('value'), 10);\n const val = this.normalizeValue(value - step);\n var valid = this.validateInputValue(val);\n model.set('value', valid.value);\n this.elementUpdated();\n },\n\n /**\n * Change easily integer input value with click&drag method\n * @param Event\n *\n * @return void\n * */\n downIncrement(e) {\n e.preventDefault();\n this.moved = 0;\n var value = this.model.get('value');\n value = this.normalizeValue(value);\n this.current = { y: e.pageY, val: value };\n on(this.doc, 'mousemove', this.moveIncrement);\n on(this.doc, 'mouseup', this.upIncrement);\n },\n\n /** While the increment is clicked, moving the mouse will update input value\n * @param Object\n *\n * @return bool\n * */\n moveIncrement(ev) {\n this.moved = 1;\n const model = this.model;\n const step = model.get('step');\n const data = this.current;\n var pos = this.normalizeValue(data.val + (data.y - ev.pageY) * step);\n this.prValue = this.validateInputValue(pos).value;\n model.set('value', this.prValue, { avoidStore: 1 });\n return false;\n },\n\n /**\n * Stop moveIncrement method\n * */\n upIncrement() {\n const model = this.model;\n const step = model.get('step');\n off(this.doc, 'mouseup', this.upIncrement);\n off(this.doc, 'mousemove', this.moveIncrement);\n\n if (this.prValue && this.moved) {\n var value = this.prValue - step;\n model.set('value', value, { avoidStore: 1 }).set('value', value + step);\n this.elementUpdated();\n }\n },\n\n normalizeValue(value, defValue = 0) {\n const model = this.model;\n const step = model.get('step');\n let stepDecimals = 0;\n\n if (isNaN(value)) {\n return defValue;\n }\n\n value = parseFloat(value);\n\n if (Math.floor(value) !== value) {\n const side = step.toString().split('.')[1];\n stepDecimals = side ? side.length : 0;\n }\n\n return stepDecimals ? parseFloat(value.toFixed(stepDecimals)) : value;\n },\n\n /**\n * Validate input value\n * @param {String} value Raw value\n * @param {Object} opts Options\n * @return {Object} Validated string\n */\n validateInputValue(value, opts) {\n var force = 0;\n var opt = opts || {};\n var model = this.model;\n const defValue = ''; //model.get('defaults');\n var val = !isUndefined(value) ? value : defValue;\n var units = model.get('units') || [];\n var unit = model.get('unit') || (units.length && units[0]) || '';\n var max = model.get('max');\n var min = model.get('min');\n\n if (opt.deepCheck) {\n var fixed = model.get('fixedValues') || [];\n\n if (val) {\n // If the value is one of the fixed values I leave it as it is\n var regFixed = new RegExp('^' + fixed.join('|'), 'g');\n if (fixed.length && regFixed.test(val)) {\n val = val.match(regFixed)[0];\n unit = '';\n force = 1;\n } else {\n var valCopy = val + '';\n val += ''; // Make it suitable for replace\n val = parseFloat(val.replace(',', '.'));\n val = !isNaN(val) ? val : defValue;\n var uN = valCopy.replace(val, '');\n // Check if exists as unit\n if (indexOf(units, uN) >= 0) unit = uN;\n }\n }\n }\n\n if (!isUndefined(max) && max !== '') val = val > max ? max : val;\n if (!isUndefined(min) && min !== '') val = val < min ? min : val;\n\n return {\n force,\n value: val,\n unit\n };\n },\n\n render() {\n Input.prototype.render.call(this);\n this.unitEl = null;\n const unit = this.getUnitEl();\n unit &&\n this.$el\n .find(`.${this.ppfx}field-units`)\n .get(0)\n .appendChild(unit);\n return this;\n }\n});\n","import Backbone from 'backbone';\n\nexport default Backbone.View.extend({\n // Default view\n itemView: '',\n\n // Defines the View per type\n itemsView: '',\n\n itemType: 'type',\n\n initialize(opts, config) {\n this.config = config || {};\n },\n\n /**\n * Add new model to the collection\n * @param {Model} model\n * @private\n * */\n addTo(model) {\n this.add(model);\n },\n\n itemViewNotFound(type) {\n const { config, ns } = this;\n const { em } = config;\n const warn = `${ns ? `[${ns}]: ` : ''}'${type}' type not found`;\n em && em.logWarning(warn);\n },\n\n /**\n * Render new model inside the view\n * @param {Model} model\n * @param {Object} fragment Fragment collection\n * @private\n * */\n add(model, fragment) {\n const { config, reuseView, itemsView = {} } = this;\n var frag = fragment || null;\n var itemView = this.itemView;\n var typeField = model.get(this.itemType);\n let view;\n\n if (itemsView[typeField]) {\n itemView = itemsView[typeField];\n } else if (typeField && !itemsView[typeField]) {\n this.itemViewNotFound(typeField);\n }\n\n if (model.view && reuseView) {\n view = model.view;\n } else {\n view = new itemView({ model, config }, config);\n }\n\n var rendered = view.render().el;\n\n if (frag) frag.appendChild(rendered);\n else this.$el.append(rendered);\n },\n\n render() {\n var frag = document.createDocumentFragment();\n this.$el.empty();\n\n if (this.collection.length)\n this.collection.each(function(model) {\n this.add(model, frag);\n }, this);\n\n this.$el.append(frag);\n return this;\n }\n});\n","import Backbone from 'backbone';\nimport { isUndefined } from 'underscore';\n\nexport default Backbone.View.extend({\n initialize(o) {\n this.opts = o || {};\n this.config = o.config || {};\n const coll = this.collection;\n this.listenTo(coll, 'add', this.addTo);\n this.listenTo(coll, 'reset', this.resetChildren);\n this.listenTo(coll, 'remove', this.removeChildren);\n },\n\n removeChildren(removed, coll, opts = {}) {\n const em = this.config.em;\n const view = removed.view;\n const tempComp = removed.opt.temporary;\n const tempRemove = opts.temporary;\n if (!view) return;\n view.remove.apply(view);\n const { childrenView, scriptContainer } = view;\n childrenView && childrenView.stopListening();\n scriptContainer && scriptContainer.remove();\n removed.components().forEach(it => this.removeChildren(it, coll, opts));\n\n if (em && !tempRemove) {\n // Remove the component from the global list\n const id = removed.getId();\n const domc = em.get('DomComponents');\n delete domc.componentsById[id];\n\n // Remove all related CSS rules\n const allRules = em.get('CssComposer').getAll();\n allRules.remove(\n allRules.filter(\n rule => rule.getSelectors().getFullString() === `#${id}`\n )\n );\n\n if (!tempComp) {\n const cm = em.get('Commands');\n const hasSign = removed.get('style-signature');\n const optStyle = { target: removed };\n hasSign && cm.run('core:component-style-clear', optStyle);\n removed.removed();\n em.trigger('component:remove', removed);\n }\n }\n },\n\n /**\n * Add to collection\n * @param {Model} model\n * @param {Collection} coll\n * @param {Object} opts\n * @private\n * */\n addTo(model, coll = {}, opts = {}) {\n const em = this.config.em;\n const i = this.collection.indexOf(model);\n this.addToCollection(model, null, i);\n\n if (em && !opts.temporary) {\n const triggerAdd = model => {\n em.trigger('component:add', model);\n model.components().forEach(comp => triggerAdd(comp));\n };\n triggerAdd(model);\n }\n },\n\n /**\n * Add new object to collection\n * @param {Object} Model\n * @param {Object} Fragment collection\n * @param {Integer} Index of append\n *\n * @return {Object} Object rendered\n * @private\n * */\n addToCollection(model, fragmentEl, index) {\n if (!this.compView) this.compView = require('./ComponentView').default;\n const { config, opts } = this;\n const fragment = fragmentEl || null;\n const dt = opts.componentTypes;\n const type = model.get('type');\n let viewObject = this.compView;\n\n for (let it = 0; it < dt.length; it++) {\n if (dt[it].id == type) {\n viewObject = dt[it].view;\n break;\n }\n }\n\n const view = new viewObject({\n model,\n config,\n componentTypes: dt\n });\n let rendered = view.render().el;\n\n if (fragment) {\n fragment.appendChild(rendered);\n } else {\n const parent = this.parentEl;\n const children = parent.childNodes;\n\n if (!isUndefined(index)) {\n const lastIndex = children.length == index;\n\n // If the added model is the last of collection\n // need to change the logic of append\n if (lastIndex) {\n index--;\n }\n\n // In case the added is new in the collection index will be -1\n if (lastIndex || !children.length) {\n parent.appendChild(rendered);\n } else {\n parent.insertBefore(rendered, children[index]);\n }\n } else {\n parent.appendChild(rendered);\n }\n }\n\n return rendered;\n },\n\n resetChildren() {\n this.parentEl.innerHTML = '';\n this.collection.each(model => this.addToCollection(model));\n },\n\n render(parent) {\n const el = this.el;\n const frag = document.createDocumentFragment();\n this.parentEl = parent || this.el;\n this.collection.each(model => this.addToCollection(model, frag));\n el.innerHTML = '';\n el.appendChild(frag);\n return this;\n }\n});\n","import { isUndefined, isString } from 'underscore';\nimport { getModel } from 'utils/mixins';\nimport Backbone from 'backbone';\nimport ComponentView from 'dom_components/view/ComponentView';\n\nconst inputProp = 'contentEditable';\nconst $ = Backbone.$;\nlet ItemsView;\n\nexport default Backbone.View.extend({\n events: {\n 'mousedown [data-toggle-move]': 'startSort',\n 'touchstart [data-toggle-move]': 'startSort',\n 'click [data-toggle-visible]': 'toggleVisibility',\n 'click [data-toggle-select]': 'handleSelect',\n 'mouseover [data-toggle-select]': 'handleHover',\n 'click [data-toggle-open]': 'toggleOpening',\n 'dblclick [data-name]': 'handleEdit',\n 'focusout [data-name]': 'handleEditEnd'\n },\n\n template(model) {\n const { pfx, ppfx, config, clsNoEdit } = this;\n const { hidable } = config;\n const count = this.countChildren(model);\n const addClass = !count ? this.clsNoChild : '';\n const clsTitle = `${this.clsTitle} ${addClass}`;\n const clsTitleC = `${this.clsTitleC} ${ppfx}one-bg`;\n const clsCaret = `${this.clsCaret} fa fa-chevron-right`;\n const clsInput = `${this.inputNameCls} ${clsNoEdit} ${ppfx}no-app`;\n const level = this.level + 1;\n const gut = `${30 + level * 10}px`;\n const name = model.getName();\n const icon = model.getIcon();\n const clsBase = `${pfx}layer`;\n\n return `\n ${\n hidable\n ? ``\n : ''\n }\n
\n
\n
\n \n ${icon ? `${icon}` : ''}\n ${name}\n
\n
\n
\n
${count || ''}
\n
\n \n
\n
`;\n },\n\n initialize(o = {}) {\n this.opt = o;\n this.level = o.level;\n this.config = o.config;\n this.em = o.config.em;\n this.ppfx = this.em.get('Config').stylePrefix;\n this.sorter = o.sorter || '';\n this.pfx = this.config.stylePrefix;\n const pfx = this.pfx;\n const ppfx = this.ppfx;\n const model = this.model;\n const components = model.get('components');\n const type = model.get('type') || 'default';\n model.set('open', false);\n this.listenTo(components, 'remove add reset', this.checkChildren);\n this.listenTo(model, 'change:status', this.updateStatus);\n this.listenTo(model, 'change:open', this.updateOpening);\n this.listenTo(model, 'change:style:display', this.updateVisibility);\n this.className = `${pfx}layer ${pfx}layer__t-${type} no-select ${ppfx}two-color`;\n this.inputNameCls = `${ppfx}layer-name`;\n this.clsTitleC = `${pfx}layer-title-c`;\n this.clsTitle = `${pfx}layer-title`;\n this.clsCaret = `${pfx}layer-caret`;\n this.clsCount = `${pfx}layer-count`;\n this.clsMove = `${pfx}layer-move`;\n this.clsChildren = `${pfx}layer-children`;\n this.clsNoChild = `${pfx}layer-no-chld`;\n this.clsEdit = `${this.inputNameCls}--edit`;\n this.clsNoEdit = `${this.inputNameCls}--no-edit`;\n this.$el.data('model', model);\n this.$el.data('collection', components);\n model.viewLayer = this;\n },\n\n getVisibilityEl() {\n if (!this.eyeEl) {\n this.eyeEl = this.$el.children(`.${this.pfx}layer-vis`);\n }\n\n return this.eyeEl;\n },\n\n updateVisibility() {\n const pfx = this.pfx;\n const model = this.model;\n const hClass = `${pfx}layer-hidden`;\n const hideIcon = 'fa-eye-slash';\n const hidden = model.getStyle().display == 'none';\n const method = hidden ? 'addClass' : 'removeClass';\n this.$el[method](hClass);\n this.getVisibilityEl()[method](hideIcon);\n },\n\n /**\n * Toggle visibility\n * @param\tEvent\n *\n * @return \tvoid\n * */\n toggleVisibility(e) {\n e && e.stopPropagation();\n const model = this.model;\n const style = model.getStyle();\n const hidden = style.display == 'none';\n\n if (hidden) {\n delete style.display;\n } else {\n style.display = 'none';\n }\n\n model.setStyle(style);\n },\n\n /**\n * Handle the edit of the component name\n */\n handleEdit(e) {\n e && e.stopPropagation();\n const { em, $el, clsNoEdit, clsEdit } = this;\n const inputEl = this.getInputName();\n inputEl[inputProp] = true;\n inputEl.focus();\n em && em.setEditing(1);\n $el\n .find(`.${this.inputNameCls}`)\n .removeClass(clsNoEdit)\n .addClass(clsEdit);\n },\n\n /**\n * Handle with the end of editing of the component name\n */\n handleEditEnd(e) {\n e && e.stopPropagation();\n const { em, $el, clsNoEdit, clsEdit } = this;\n const inputEl = this.getInputName();\n const name = inputEl.textContent;\n inputEl.scrollLeft = 0;\n inputEl[inputProp] = false;\n this.model.set({ name });\n em && em.setEditing(0);\n $el\n .find(`.${this.inputNameCls}`)\n .addClass(clsNoEdit)\n .removeClass(clsEdit);\n },\n\n /**\n * Get the input containing the name of the component\n * @return {HTMLElement}\n */\n getInputName() {\n if (!this.inputName) {\n this.inputName = this.el.querySelector(`.${this.inputNameCls}`);\n }\n return this.inputName;\n },\n\n /**\n * Update item opening\n *\n * @return void\n * */\n updateOpening() {\n var opened = this.opt.opened || {};\n var model = this.model;\n const chvDown = 'fa-chevron-down';\n\n if (model.get('open')) {\n this.$el.addClass('open');\n this.getCaret().addClass(chvDown);\n opened[model.cid] = model;\n } else {\n this.$el.removeClass('open');\n this.getCaret().removeClass(chvDown);\n delete opened[model.cid];\n }\n },\n\n /**\n * Toggle item opening\n * @param {Object}\te\n *\n * @return void\n * */\n toggleOpening(e) {\n e.stopPropagation();\n\n if (!this.model.get('components').length) return;\n\n this.model.set('open', !this.model.get('open'));\n },\n\n /**\n * Handle component selection\n */\n handleSelect(e) {\n e.stopPropagation();\n const { em, config } = this;\n\n if (em) {\n const model = this.model;\n em.setSelected(model, { fromLayers: 1 });\n const scroll = config.scrollCanvas;\n scroll && em.get('Canvas').scrollTo(model, scroll);\n }\n },\n\n /**\n * Handle component selection\n */\n handleHover(e) {\n e.stopPropagation();\n const { em, config, model } = this;\n em && config.showHover && em.setHovered(model, { fromLayers: 1 });\n },\n\n /**\n * Delegate to sorter\n * @param\tEvent\n * */\n startSort(e) {\n e.stopPropagation();\n const sorter = this.sorter;\n // Right or middel click\n if (e.button && e.button !== 0) return;\n sorter && sorter.startSort(e.target);\n },\n\n /**\n * Freeze item\n * @return\tvoid\n * */\n freeze() {\n this.$el.addClass(this.pfx + 'opac50');\n this.model.set('open', 0);\n },\n\n /**\n * Unfreeze item\n * @return\tvoid\n * */\n unfreeze() {\n this.$el.removeClass(this.pfx + 'opac50');\n },\n\n /**\n * Update item on status change\n * @param\tEvent\n * */\n updateStatus(e) {\n ComponentView.prototype.updateStatus.apply(this, [\n {\n avoidHover: !this.config.highlightHover\n }\n ]);\n },\n\n /**\n * Check if component is visible\n *\n * @return bool\n * */\n isVisible() {\n var css = this.model.get('style'),\n pr = css.display;\n if (pr && pr == 'none') return;\n return 1;\n },\n\n /**\n * Update item aspect after children changes\n *\n * @return void\n * */\n checkChildren() {\n const model = this.model;\n const count = this.countChildren(model);\n const pfx = this.pfx;\n const noChildCls = this.clsNoChild;\n const title = this.$el\n .children(`.${this.clsTitleC}`)\n .children(`.${this.clsTitle}`);\n\n if (!this.cnt) {\n this.cnt = this.$el.children(`.${this.clsCount}`);\n }\n\n if (count) {\n title.removeClass(noChildCls);\n this.cnt.html(count);\n } else {\n title.addClass(noChildCls);\n this.cnt.empty();\n model.set('open', 0);\n }\n },\n\n /**\n * Count children inside model\n * @param {Object} model\n * @return {number}\n * @private\n */\n countChildren(model) {\n var count = 0;\n model.get('components').each(function(m) {\n var isCountable = this.opt.isCountable;\n var hide = this.config.hideTextnode;\n if (isCountable && !isCountable(m, hide)) return;\n count++;\n }, this);\n return count;\n },\n\n getCaret() {\n if (!this.caret || !this.caret.length) {\n const pfx = this.pfx;\n this.caret = this.$el\n .children(`.${this.clsTitleC}`)\n .find(`.${this.clsCaret}`);\n }\n\n return this.caret;\n },\n\n setRoot(el) {\n el = isString(el) ? this.em.getWrapper().find(el)[0] : el;\n const model = getModel(el, $);\n if (!model) return;\n this.stopListening();\n this.model = model;\n this.initialize(this.opt);\n this.render();\n },\n\n render() {\n const { model, config, pfx, ppfx, opt } = this;\n const { isCountable } = opt;\n const hidden = isCountable && !isCountable(model, config.hideTextnode);\n const vis = this.isVisible();\n const el = this.$el.empty();\n const level = this.level + 1;\n\n if (isUndefined(ItemsView)) {\n ItemsView = require('./ItemsView').default;\n }\n\n const children = new ItemsView({\n collection: model.get('components'),\n config: this.config,\n sorter: this.sorter,\n opened: this.opt.opened,\n parent: model,\n level\n }).render().$el;\n\n if (!this.config.showWrapper && level === 1) {\n el.append(children);\n } else {\n el.html(this.template(model));\n el.find(`.${this.clsChildren}`).append(children);\n }\n\n if (!model.get('draggable') || !this.config.sortable) {\n el.children(`.${this.clsMove}`).remove();\n }\n\n !vis && (this.className += ` ${pfx}hide`);\n hidden && (this.className += ` ${ppfx}hidden`);\n el.attr('class', this.className);\n this.updateOpening();\n this.updateStatus();\n this.updateVisibility();\n return this;\n }\n});\n","import Backbone from 'backbone';\nimport { isUndefined } from 'underscore';\nimport ColorPicker from 'utils/ColorPicker';\nimport Input from './Input';\n\nconst $ = Backbone.$;\nColorPicker($);\n\nexport default Input.extend({\n template() {\n const ppfx = this.ppfx;\n return `\n
\n
\n
\n
\n
\n
\n `;\n },\n\n inputClass() {\n const ppfx = this.ppfx;\n return `${ppfx}field ${ppfx}field-color`;\n },\n\n holderClass() {\n return `${this.ppfx}input-holder`;\n },\n\n /**\n * Set value to the model\n * @param {string} val\n * @param {Object} opts\n */\n setValue(val, opts = {}) {\n const model = this.model;\n const def = model.get('defaults');\n const value = !isUndefined(val) ? val : !isUndefined(def) ? def : '';\n const inputEl = this.getInputEl();\n const colorEl = this.getColorEl();\n const valueClr = value != 'none' ? value : '';\n inputEl.value = value;\n colorEl.get(0).style.backgroundColor = valueClr;\n\n // This prevents from adding multiple thumbs in spectrum\n if (opts.fromTarget) {\n colorEl.spectrum('set', valueClr);\n this.noneColor = value == 'none';\n }\n },\n\n /**\n * Get the color input element\n * @return {HTMLElement}\n */\n getColorEl() {\n if (!this.colorEl) {\n const self = this;\n const ppfx = this.ppfx;\n var model = this.model;\n\n var colorEl = $(`
`);\n var cpStyle = colorEl.get(0).style;\n var elToAppend = this.em && this.em.config ? this.em.config.el : '';\n var colorPickerConfig =\n (this.em && this.em.getConfig && this.em.getConfig('colorPicker')) ||\n {};\n const getColor = color => {\n let cl =\n color.getAlpha() == 1 ? color.toHexString() : color.toRgbString();\n return cl.replace(/ /g, '');\n };\n\n let changed = 0;\n let previousColor;\n this.$el.find(`[data-colorp-c]`).append(colorEl);\n colorEl.spectrum({\n containerClassName: `${ppfx}one-bg ${ppfx}two-color`,\n appendTo: elToAppend || 'body',\n maxSelectionSize: 8,\n showPalette: true,\n showAlpha: true,\n chooseText: 'Ok',\n cancelText: '⨯',\n palette: [],\n\n // config expanded here so that the functions below are not overridden\n ...colorPickerConfig,\n\n move(color) {\n const cl = getColor(color);\n cpStyle.backgroundColor = cl;\n model.setValueFromInput(cl, 0);\n },\n change(color) {\n changed = 1;\n const cl = getColor(color);\n cpStyle.backgroundColor = cl;\n model.setValueFromInput(cl);\n self.noneColor = 0;\n },\n show(color) {\n changed = 0;\n previousColor = getColor(color);\n },\n hide(color) {\n if (!changed && previousColor) {\n if (self.noneColor) {\n previousColor = '';\n }\n cpStyle.backgroundColor = previousColor;\n colorEl.spectrum('set', previousColor);\n model.setValueFromInput(previousColor, 0);\n }\n }\n });\n\n this.colorEl = colorEl;\n }\n return this.colorEl;\n },\n\n render() {\n Input.prototype.render.call(this);\n // This will make the color input available on render\n this.getColorEl();\n return this;\n }\n});\n","// Without jquery I have to update few stuff\n//\n// Spectrum Colorpicker v1.8.0\n// https://github.com/bgrins/spectrum\n// Author: Brian Grinstead\n// License: MIT\n\nexport default function($, undefined) {\n 'use strict';\n\n var defaultOpts = {\n // Callbacks\n beforeShow: noop,\n move: noop,\n change: noop,\n show: noop,\n hide: noop,\n\n // Options\n color: false,\n flat: false,\n showInput: false,\n allowEmpty: false,\n showButtons: true,\n clickoutFiresChange: true,\n showInitial: false,\n showPalette: false,\n showPaletteOnly: false,\n hideAfterPaletteSelect: false,\n togglePaletteOnly: false,\n showSelectionPalette: true,\n localStorageKey: false,\n appendTo: 'body',\n maxSelectionSize: 7,\n cancelText: 'cancel',\n chooseText: 'choose',\n togglePaletteMoreText: 'more',\n togglePaletteLessText: 'less',\n clearText: 'Clear Color Selection',\n noColorSelectedText: 'No Color Selected',\n preferredFormat: false,\n className: '', // Deprecated - use containerClassName and replacerClassName instead.\n containerClassName: '',\n replacerClassName: '',\n showAlpha: false,\n theme: 'sp-light',\n palette: [\n [\n '#ffffff',\n '#000000',\n '#ff0000',\n '#ff8000',\n '#ffff00',\n '#008000',\n '#0000ff',\n '#4b0082',\n '#9400d3'\n ]\n ],\n selectionPalette: [],\n disabled: false,\n offset: null\n },\n spectrums = [],\n IE = !!/msie/i.exec(window.navigator.userAgent),\n rgbaSupport = (function() {\n function contains(str, substr) {\n return !!~('' + str).indexOf(substr);\n }\n\n var elem = document.createElement('div');\n var style = elem.style;\n style.cssText = 'background-color:rgba(0,0,0,.5)';\n return (\n contains(style.backgroundColor, 'rgba') ||\n contains(style.backgroundColor, 'hsla')\n );\n })(),\n replaceInput = [\n \"
\",\n \"
\",\n \"
\",\n '
'\n ].join(''),\n markup = (function() {\n // IE does not support gradients with multiple stops, so we need to simulate\n // that for the rainbow slider with 8 divs that each have a single gradient\n var gradientFix = '';\n if (IE) {\n for (var i = 1; i <= 6; i++) {\n gradientFix += \"
\";\n }\n }\n\n return [\n \"
\",\n \"
\",\n \"
\",\n \"
\",\n \"\",\n '
',\n '
',\n \"
\",\n \"
\",\n \"
\",\n \"
\",\n \"
\",\n \"
\",\n \"
\",\n \"
\",\n '
',\n '
',\n '
',\n \"
\",\n '
',\n \"
\",\n \"
\",\n gradientFix,\n '
',\n '
',\n \"
\",\n '
',\n \"
\",\n \"\",\n '
',\n \"
\",\n \"
\",\n \"\",\n \"\",\n '
',\n '
',\n '
'\n ].join('');\n })();\n\n function paletteTemplate(p, color, className, opts) {\n var html = [];\n for (var i = 0; i < p.length; i++) {\n var current = p[i];\n if (current) {\n var tiny = tinycolor(current);\n var c =\n tiny.toHsl().l < 0.5\n ? 'sp-thumb-el sp-thumb-dark'\n : 'sp-thumb-el sp-thumb-light';\n c += tinycolor.equals(color, current) ? ' sp-thumb-active' : '';\n var formattedString = tiny.toString(opts.preferredFormat || 'rgb');\n var swatchStyle = rgbaSupport\n ? 'background-color:' + tiny.toRgbString()\n : 'filter:' + tiny.toFilter();\n html.push(\n ''\n );\n } else {\n var cls = 'sp-clear-display';\n html.push(\n $('
')\n .append(\n $(\n ''\n ).attr('title', opts.noColorSelectedText)\n )\n .html()\n );\n }\n }\n return \"
\" + html.join('') + '
';\n }\n\n function hideAll() {\n for (var i = 0; i < spectrums.length; i++) {\n if (spectrums[i]) {\n spectrums[i].hide();\n }\n }\n }\n\n function instanceOptions(o, callbackContext) {\n var opts = $.extend({}, defaultOpts, o);\n opts.callbacks = {\n move: bind(opts.move, callbackContext),\n change: bind(opts.change, callbackContext),\n show: bind(opts.show, callbackContext),\n hide: bind(opts.hide, callbackContext),\n beforeShow: bind(opts.beforeShow, callbackContext)\n };\n return opts;\n }\n\n function spectrum(element, o) {\n var opts = instanceOptions(o, element),\n flat = opts.flat,\n showSelectionPalette = opts.showSelectionPalette,\n localStorageKey = opts.localStorageKey,\n theme = opts.theme,\n callbacks = opts.callbacks,\n resize = throttle(reflow, 10),\n visible = false,\n isDragging = false,\n dragWidth = 0,\n dragHeight = 0,\n dragHelperHeight = 0,\n slideHeight = 0,\n slideWidth = 0,\n alphaWidth = 0,\n alphaSlideHelperWidth = 0,\n slideHelperHeight = 0,\n currentHue = 0,\n currentSaturation = 0,\n currentValue = 0,\n currentAlpha = 1,\n palette = [],\n paletteArray = [],\n paletteLookup = {},\n selectionPalette = opts.selectionPalette.slice(0),\n maxSelectionSize = opts.maxSelectionSize,\n draggingClass = 'sp-dragging',\n shiftMovementDirection = null;\n\n var doc = element.ownerDocument,\n body = doc.body,\n boundElement = $(element),\n disabled = false,\n container = $(markup, doc).addClass(theme),\n pickerContainer = container.find('.sp-picker-container'),\n dragger = container.find('.sp-color'),\n dragHelper = container.find('.sp-dragger'),\n slider = container.find('.sp-hue'),\n slideHelper = container.find('.sp-slider'),\n alphaSliderInner = container.find('.sp-alpha-inner'),\n alphaSlider = container.find('.sp-alpha'),\n alphaSlideHelper = container.find('.sp-alpha-handle'),\n textInput = container.find('.sp-input'),\n paletteContainer = container.find('.sp-palette'),\n initialColorContainer = container.find('.sp-initial'),\n cancelButton = container.find('.sp-cancel'),\n clearButton = container.find('.sp-clear'),\n chooseButton = container.find('.sp-choose'),\n toggleButton = container.find('.sp-palette-toggle'),\n isInput = boundElement.is('input'),\n isInputTypeColor =\n isInput &&\n boundElement.attr('type') === 'color' &&\n inputTypeColorSupport(),\n shouldReplace = isInput && !flat,\n replacer = shouldReplace\n ? $(replaceInput)\n .addClass(theme)\n .addClass(opts.className)\n .addClass(opts.replacerClassName)\n : $([]),\n offsetElement = shouldReplace ? replacer : boundElement,\n previewElement = replacer.find('.sp-preview-inner'),\n initialColor = opts.color || (isInput && boundElement.val()),\n colorOnShow = false,\n currentPreferredFormat = opts.preferredFormat,\n clickoutFiresChange = !opts.showButtons || opts.clickoutFiresChange,\n isEmpty = !initialColor,\n allowEmpty = opts.allowEmpty && !isInputTypeColor;\n\n function applyOptions() {\n if (opts.showPaletteOnly) {\n opts.showPalette = true;\n }\n\n toggleButton.text(\n opts.showPaletteOnly\n ? opts.togglePaletteMoreText\n : opts.togglePaletteLessText\n );\n\n if (opts.palette) {\n palette = opts.palette.slice(0);\n paletteArray = $.isArray(palette[0]) ? palette : [palette];\n paletteLookup = {};\n for (var i = 0; i < paletteArray.length; i++) {\n for (var j = 0; j < paletteArray[i].length; j++) {\n var rgb = tinycolor(paletteArray[i][j]).toRgbString();\n paletteLookup[rgb] = true;\n }\n }\n }\n\n container.toggleClass('sp-flat', flat);\n container.toggleClass('sp-input-disabled', !opts.showInput);\n container.toggleClass('sp-alpha-enabled', opts.showAlpha);\n container.toggleClass('sp-clear-enabled', allowEmpty);\n container.toggleClass('sp-buttons-disabled', !opts.showButtons);\n container.toggleClass(\n 'sp-palette-buttons-disabled',\n !opts.togglePaletteOnly\n );\n container.toggleClass('sp-palette-disabled', !opts.showPalette);\n container.toggleClass('sp-palette-only', opts.showPaletteOnly);\n container.toggleClass('sp-initial-disabled', !opts.showInitial);\n container.addClass(opts.className).addClass(opts.containerClassName);\n\n reflow();\n }\n\n function initialize() {\n if (IE) {\n container.find('*:not(input)').attr('unselectable', 'on');\n }\n\n applyOptions();\n\n if (shouldReplace) {\n boundElement.after(replacer).hide();\n }\n\n if (!allowEmpty) {\n clearButton.hide();\n }\n\n if (flat) {\n boundElement.after(container).hide();\n } else {\n var appendTo =\n opts.appendTo === 'parent' ? boundElement.parent() : $(opts.appendTo);\n if (appendTo.length !== 1) {\n appendTo = $('body');\n }\n\n appendTo.append(container);\n }\n\n updateSelectionPaletteFromStorage();\n\n offsetElement.bind('click.spectrum touchstart.spectrum', function(e) {\n if (!disabled) {\n toggle();\n }\n\n e.stopPropagation();\n\n if (!$(e.target).is('input')) {\n e.preventDefault();\n }\n });\n\n if (boundElement.is(':disabled') || opts.disabled === true) {\n disable();\n }\n\n // Prevent clicks from bubbling up to document. This would cause it to be hidden.\n container.click(stopPropagation);\n\n // Handle user typed input\n textInput.change(setFromTextInput);\n textInput.bind('paste', function() {\n setTimeout(setFromTextInput, 1);\n });\n textInput.keydown(function(e) {\n if (e.keyCode == 13) {\n setFromTextInput();\n }\n });\n\n cancelButton.text(opts.cancelText);\n cancelButton.bind('click.spectrum', function(e) {\n e.stopPropagation();\n e.preventDefault();\n revert();\n hide();\n });\n\n clearButton.attr('title', opts.clearText);\n clearButton.bind('click.spectrum', function(e) {\n e.stopPropagation();\n e.preventDefault();\n isEmpty = true;\n move();\n\n if (flat) {\n //for the flat style, this is a change event\n updateOriginalInput(true);\n }\n });\n\n chooseButton.text(opts.chooseText);\n chooseButton.bind('click.spectrum', function(e) {\n e.stopPropagation();\n e.preventDefault();\n\n if (IE && textInput.is(':focus')) {\n textInput.trigger('change');\n }\n\n if (isValid()) {\n updateOriginalInput(true);\n hide();\n }\n });\n\n toggleButton.text(\n opts.showPaletteOnly\n ? opts.togglePaletteMoreText\n : opts.togglePaletteLessText\n );\n toggleButton.bind('click.spectrum', function(e) {\n e.stopPropagation();\n e.preventDefault();\n\n opts.showPaletteOnly = !opts.showPaletteOnly;\n\n // To make sure the Picker area is drawn on the right, next to the\n // Palette area (and not below the palette), first move the Palette\n // to the left to make space for the picker, plus 5px extra.\n // The 'applyOptions' function puts the whole container back into place\n // and takes care of the button-text and the sp-palette-only CSS class.\n if (!opts.showPaletteOnly && !flat) {\n container.css('left', '-=' + (pickerContainer.outerWidth(true) + 5));\n }\n applyOptions();\n });\n\n draggable(\n alphaSlider,\n function(dragX, dragY, e) {\n currentAlpha = dragX / alphaWidth;\n isEmpty = false;\n if (e.shiftKey) {\n currentAlpha = Math.round(currentAlpha * 10) / 10;\n }\n\n move();\n },\n dragStart,\n dragStop\n );\n\n draggable(\n slider,\n function(dragX, dragY) {\n currentHue = parseFloat(dragY / slideHeight);\n isEmpty = false;\n if (!opts.showAlpha) {\n currentAlpha = 1;\n }\n move();\n },\n dragStart,\n dragStop\n );\n\n draggable(\n dragger,\n function(dragX, dragY, e) {\n // shift+drag should snap the movement to either the x or y axis.\n if (!e.shiftKey) {\n shiftMovementDirection = null;\n } else if (!shiftMovementDirection) {\n var oldDragX = currentSaturation * dragWidth;\n var oldDragY = dragHeight - currentValue * dragHeight;\n var furtherFromX =\n Math.abs(dragX - oldDragX) > Math.abs(dragY - oldDragY);\n\n shiftMovementDirection = furtherFromX ? 'x' : 'y';\n }\n\n var setSaturation =\n !shiftMovementDirection || shiftMovementDirection === 'x';\n var setValue =\n !shiftMovementDirection || shiftMovementDirection === 'y';\n\n if (setSaturation) {\n currentSaturation = parseFloat(dragX / dragWidth);\n }\n if (setValue) {\n currentValue = parseFloat((dragHeight - dragY) / dragHeight);\n }\n\n isEmpty = false;\n if (!opts.showAlpha) {\n currentAlpha = 1;\n }\n\n move();\n },\n dragStart,\n dragStop\n );\n\n if (!!initialColor) {\n set(initialColor);\n\n // In case color was black - update the preview UI and set the format\n // since the set function will not run (default color is black).\n updateUI();\n currentPreferredFormat =\n opts.preferredFormat || tinycolor(initialColor).format;\n\n addColorToSelectionPalette(initialColor);\n } else {\n updateUI();\n }\n\n if (flat) {\n show();\n }\n\n function paletteElementClick(e) {\n if (e.data && e.data.ignore) {\n set(\n $(e.target)\n .closest('.sp-thumb-el')\n .data('color')\n );\n move();\n } else {\n set(\n $(e.target)\n .closest('.sp-thumb-el')\n .data('color')\n );\n move();\n updateOriginalInput(true);\n if (opts.hideAfterPaletteSelect) {\n hide();\n }\n }\n\n return false;\n }\n\n var paletteEvent = IE\n ? 'mousedown.spectrum'\n : 'click.spectrum touchstart.spectrum';\n paletteContainer.delegate(\n '.sp-thumb-el',\n paletteEvent,\n paletteElementClick\n );\n initialColorContainer.delegate(\n '.sp-thumb-el:nth-child(1)',\n paletteEvent,\n { ignore: true },\n paletteElementClick\n );\n }\n\n function updateSelectionPaletteFromStorage() {\n if (localStorageKey && window.localStorage) {\n // Migrate old palettes over to new format. May want to remove this eventually.\n try {\n var oldPalette = window.localStorage[localStorageKey].split(',#');\n if (oldPalette.length > 1) {\n delete window.localStorage[localStorageKey];\n $.each(oldPalette, function(i, c) {\n addColorToSelectionPalette(c);\n });\n }\n } catch (e) {}\n\n try {\n selectionPalette = window.localStorage[localStorageKey].split(';');\n } catch (e) {}\n }\n }\n\n function addColorToSelectionPalette(color) {\n if (showSelectionPalette) {\n var rgb = tinycolor(color).toRgbString();\n if (!paletteLookup[rgb] && $.inArray(rgb, selectionPalette) === -1) {\n selectionPalette.push(rgb);\n while (selectionPalette.length > maxSelectionSize) {\n selectionPalette.shift();\n }\n }\n\n if (localStorageKey && window.localStorage) {\n try {\n window.localStorage[localStorageKey] = selectionPalette.join(';');\n } catch (e) {}\n }\n }\n }\n\n function getUniqueSelectionPalette() {\n var unique = [];\n if (opts.showPalette) {\n for (var i = 0; i < selectionPalette.length; i++) {\n var rgb = tinycolor(selectionPalette[i]).toRgbString();\n\n if (!paletteLookup[rgb]) {\n unique.push(selectionPalette[i]);\n }\n }\n }\n\n return unique.reverse().slice(0, opts.maxSelectionSize);\n }\n\n function drawPalette() {\n var currentColor = get();\n\n var html = $.map(paletteArray, function(palette, i) {\n return paletteTemplate(\n palette,\n currentColor,\n 'sp-palette-row sp-palette-row-' + i,\n opts\n );\n });\n\n updateSelectionPaletteFromStorage();\n\n if (selectionPalette) {\n html.push(\n paletteTemplate(\n getUniqueSelectionPalette(),\n currentColor,\n 'sp-palette-row sp-palette-row-selection',\n opts\n )\n );\n }\n\n paletteContainer.html(html.join(''));\n }\n\n function drawInitial() {\n if (opts.showInitial) {\n var initial = colorOnShow;\n var current = get();\n initialColorContainer.html(\n paletteTemplate(\n [initial, current],\n current,\n 'sp-palette-row-initial',\n opts\n )\n );\n }\n }\n\n function dragStart() {\n if (dragHeight <= 0 || dragWidth <= 0 || slideHeight <= 0) {\n reflow();\n }\n isDragging = true;\n container.addClass(draggingClass);\n shiftMovementDirection = null;\n boundElement.trigger('dragstart.spectrum', [get()]);\n }\n\n function dragStop() {\n isDragging = false;\n container.removeClass(draggingClass);\n boundElement.trigger('dragstop.spectrum', [get()]);\n }\n\n function setFromTextInput() {\n var value = textInput.val();\n\n if ((value === null || value === '') && allowEmpty) {\n set(null);\n updateOriginalInput(true);\n } else {\n var tiny = tinycolor(value);\n if (tiny.isValid()) {\n set(tiny);\n updateOriginalInput(true);\n } else {\n textInput.addClass('sp-validation-error');\n }\n }\n }\n\n function toggle() {\n if (visible) {\n hide();\n } else {\n show();\n }\n }\n\n function show() {\n var event = $.Event('beforeShow.spectrum');\n\n if (visible) {\n reflow();\n return;\n }\n\n boundElement.trigger(event, [get()]);\n\n if (callbacks.beforeShow(get()) === false || event.isDefaultPrevented()) {\n return;\n }\n\n hideAll();\n visible = true;\n\n var $doc = $(doc);\n $doc.bind('keydown.spectrum', onkeydown);\n $doc.bind('click.spectrum', clickout);\n $(window).bind('resize.spectrum', resize);\n replacer.addClass('sp-active');\n container.removeClass('sp-hidden');\n\n reflow();\n updateUI();\n\n colorOnShow = get();\n\n drawInitial();\n callbacks.show(colorOnShow);\n boundElement.trigger('show.spectrum', [colorOnShow]);\n }\n\n function onkeydown(e) {\n // Close on ESC\n if (e.keyCode === 27) {\n hide();\n }\n }\n\n function clickout(e) {\n // Return on right click.\n if (e.button == 2) {\n return;\n }\n\n // If a drag event was happening during the mouseup, don't hide\n // on click.\n if (isDragging) {\n return;\n }\n\n if (clickoutFiresChange) {\n updateOriginalInput(true);\n } else {\n revert();\n }\n hide();\n }\n\n function hide() {\n // Return if hiding is unnecessary\n if (!visible || flat) {\n return;\n }\n visible = false;\n\n $(doc).unbind('keydown.spectrum', onkeydown);\n $(doc).unbind('click.spectrum', clickout);\n $(window).unbind('resize.spectrum', resize);\n\n replacer.removeClass('sp-active');\n container.addClass('sp-hidden');\n\n callbacks.hide(get());\n boundElement.trigger('hide.spectrum', [get()]);\n }\n\n function revert() {\n set(colorOnShow, true);\n }\n\n function set(color, ignoreFormatChange) {\n if (tinycolor.equals(color, get())) {\n // Update UI just in case a validation error needs\n // to be cleared.\n updateUI();\n return;\n }\n\n var newColor, newHsv;\n if (!color && allowEmpty) {\n isEmpty = true;\n } else {\n isEmpty = false;\n newColor = tinycolor(color);\n newHsv = newColor.toHsv();\n\n currentHue = (newHsv.h % 360) / 360;\n currentSaturation = newHsv.s;\n currentValue = newHsv.v;\n currentAlpha = newHsv.a;\n }\n updateUI();\n\n if (newColor && newColor.isValid() && !ignoreFormatChange) {\n currentPreferredFormat = opts.preferredFormat || newColor.getFormat();\n }\n }\n\n function get(opts) {\n opts = opts || {};\n\n if (allowEmpty && isEmpty) {\n return null;\n }\n\n return tinycolor.fromRatio(\n {\n h: currentHue,\n s: currentSaturation,\n v: currentValue,\n a: Math.round(currentAlpha * 100) / 100\n },\n { format: opts.format || currentPreferredFormat }\n );\n }\n\n function isValid() {\n return !textInput.hasClass('sp-validation-error');\n }\n\n function move() {\n updateUI();\n\n callbacks.move(get());\n boundElement.trigger('move.spectrum', [get()]);\n }\n\n function updateUI() {\n textInput.removeClass('sp-validation-error');\n\n updateHelperLocations();\n\n // Update dragger background color (gradients take care of saturation and value).\n var flatColor = tinycolor.fromRatio({ h: currentHue, s: 1, v: 1 });\n dragger.css('background-color', flatColor.toHexString());\n\n // Get a format that alpha will be included in (hex and names ignore alpha)\n var format = currentPreferredFormat;\n if (currentAlpha < 1 && !(currentAlpha === 0 && format === 'name')) {\n if (\n format === 'hex' ||\n format === 'hex3' ||\n format === 'hex6' ||\n format === 'name'\n ) {\n format = 'rgb';\n }\n }\n\n var realColor = get({ format: format }),\n displayColor = '';\n\n //reset background info for preview element\n previewElement.removeClass('sp-clear-display');\n previewElement.css('background-color', 'transparent');\n\n if (!realColor && allowEmpty) {\n // Update the replaced elements background with icon indicating no color selection\n previewElement.addClass('sp-clear-display');\n } else {\n var realHex = realColor.toHexString(),\n realRgb = realColor.toRgbString();\n\n // Update the replaced elements background color (with actual selected color)\n if (rgbaSupport || realColor.alpha === 1) {\n previewElement.css('background-color', realRgb);\n } else {\n previewElement.css('background-color', 'transparent');\n previewElement.css('filter', realColor.toFilter());\n }\n\n if (opts.showAlpha) {\n var rgb = realColor.toRgb();\n rgb.a = 0;\n var realAlpha = tinycolor(rgb).toRgbString();\n var gradient =\n 'linear-gradient(left, ' + realAlpha + ', ' + realHex + ')';\n\n if (IE) {\n alphaSliderInner.css(\n 'filter',\n tinycolor(realAlpha).toFilter({ gradientType: 1 }, realHex)\n );\n } else {\n alphaSliderInner.css('background', '-webkit-' + gradient);\n alphaSliderInner.css('background', '-moz-' + gradient);\n alphaSliderInner.css('background', '-ms-' + gradient);\n // Use current syntax gradient on unprefixed property.\n alphaSliderInner.css(\n 'background',\n 'linear-gradient(to right, ' + realAlpha + ', ' + realHex + ')'\n );\n }\n }\n\n displayColor = realColor.toString(format);\n }\n\n // Update the text entry input as it changes happen\n if (opts.showInput) {\n textInput.val(displayColor);\n }\n\n if (opts.showPalette) {\n drawPalette();\n }\n\n drawInitial();\n }\n\n function updateHelperLocations() {\n var s = currentSaturation;\n var v = currentValue;\n\n if (allowEmpty && isEmpty) {\n //if selected color is empty, hide the helpers\n alphaSlideHelper.hide();\n slideHelper.hide();\n dragHelper.hide();\n } else {\n //make sure helpers are visible\n alphaSlideHelper.show();\n slideHelper.show();\n dragHelper.show();\n\n // Where to show the little circle in that displays your current selected color\n var dragX = s * dragWidth;\n var dragY = dragHeight - v * dragHeight;\n dragX = Math.max(\n -dragHelperHeight,\n Math.min(dragWidth - dragHelperHeight, dragX - dragHelperHeight)\n );\n dragY = Math.max(\n -dragHelperHeight,\n Math.min(dragHeight - dragHelperHeight, dragY - dragHelperHeight)\n );\n dragHelper.css({\n top: dragY + 'px',\n left: dragX + 'px'\n });\n\n var alphaX = currentAlpha * alphaWidth;\n alphaSlideHelper.css({\n left: alphaX - alphaSlideHelperWidth / 2 + 'px'\n });\n\n // Where to show the bar that displays your current selected hue\n var slideY = currentHue * slideHeight;\n slideHelper.css({\n top: slideY - slideHelperHeight + 'px'\n });\n }\n }\n\n function updateOriginalInput(fireCallback) {\n var color = get(),\n displayColor = '',\n hasChanged = !tinycolor.equals(color, colorOnShow);\n\n if (color) {\n displayColor = color.toString(currentPreferredFormat);\n // Update the selection palette with the current color\n addColorToSelectionPalette(color);\n }\n\n if (isInput) {\n boundElement.val(displayColor);\n }\n\n if (fireCallback && hasChanged) {\n callbacks.change(color);\n boundElement.trigger('change', [color]);\n }\n }\n\n function reflow() {\n if (!visible) {\n return; // Calculations would be useless and wouldn't be reliable anyways\n }\n dragWidth = dragger.width();\n dragHeight = dragger.height();\n dragHelperHeight = dragHelper.height();\n slideWidth = slider.width();\n slideHeight = slider.height();\n slideHelperHeight = slideHelper.height();\n alphaWidth = alphaSlider.width();\n alphaSlideHelperWidth = alphaSlideHelper.width();\n\n if (!flat) {\n container.css('position', 'absolute');\n if (opts.offset) {\n container.offset(opts.offset);\n } else {\n container.offset(getOffset(container, offsetElement));\n }\n }\n\n updateHelperLocations();\n\n if (opts.showPalette) {\n drawPalette();\n }\n\n boundElement.trigger('reflow.spectrum');\n }\n\n function destroy() {\n boundElement.show();\n offsetElement.unbind('click.spectrum touchstart.spectrum');\n container.remove();\n replacer.remove();\n spectrums[spect.id] = null;\n }\n\n function option(optionName, optionValue) {\n if (optionName === undefined) {\n return $.extend({}, opts);\n }\n if (optionValue === undefined) {\n return opts[optionName];\n }\n\n opts[optionName] = optionValue;\n\n if (optionName === 'preferredFormat') {\n currentPreferredFormat = opts.preferredFormat;\n }\n applyOptions();\n }\n\n function enable() {\n disabled = false;\n boundElement.attr('disabled', false);\n offsetElement.removeClass('sp-disabled');\n }\n\n function disable() {\n hide();\n disabled = true;\n boundElement.attr('disabled', true);\n offsetElement.addClass('sp-disabled');\n }\n\n function setOffset(coord) {\n opts.offset = coord;\n reflow();\n }\n\n initialize();\n\n var spect = {\n show: show,\n hide: hide,\n toggle: toggle,\n reflow: reflow,\n option: option,\n enable: enable,\n disable: disable,\n offset: setOffset,\n set: function(c) {\n set(c);\n updateOriginalInput();\n },\n get: get,\n destroy: destroy,\n container: container\n };\n\n spect.id = spectrums.push(spect) - 1;\n\n return spect;\n }\n\n /**\n * checkOffset - get the offset below/above and left/right element depending on screen position\n * Thanks https://github.com/jquery/jquery-ui/blob/master/ui/jquery.ui.datepicker.js\n */\n function getOffset(picker, input) {\n var extraY = 0;\n var dpWidth = picker.outerWidth();\n var dpHeight = picker.outerHeight();\n var inputHeight = input.outerHeight();\n var doc = picker[0].ownerDocument;\n var docElem = doc.documentElement;\n var cW = docElem.clientWidth;\n var cH = docElem.clientHeight;\n var scL = $(doc).scrollLeft();\n var scT = $(doc).scrollTop();\n var viewWidth = cW + scL;\n var viewHeight = cH + scT;\n var offset = input.offset();\n\n offset.top += inputHeight;\n\n offset.left -= Math.min(\n offset.left,\n offset.left + dpWidth > viewWidth && viewWidth > dpWidth\n ? Math.abs(offset.left + dpWidth - viewWidth)\n : 0\n );\n\n offset.top -= Math.min(\n offset.top,\n offset.top + dpHeight > viewHeight && viewHeight > dpHeight\n ? Math.abs(dpHeight + inputHeight - extraY)\n : extraY\n );\n\n return offset;\n }\n\n /**\n * noop - do nothing\n */\n function noop() {}\n\n /**\n * stopPropagation - makes the code only doing this a little easier to read in line\n */\n function stopPropagation(e) {\n e.stopPropagation();\n }\n\n /**\n * Create a function bound to a given object\n * Thanks to underscore.js\n */\n function bind(func, obj) {\n var slice = Array.prototype.slice;\n var args = slice.call(arguments, 2);\n return function() {\n return func.apply(obj, args.concat(slice.call(arguments)));\n };\n }\n\n /**\n * Lightweight drag helper. Handles containment within the element, so that\n * when dragging, the x is within [0,element.width] and y is within [0,element.height]\n */\n function draggable(element, onmove, onstart, onstop) {\n onmove = onmove || function() {};\n onstart = onstart || function() {};\n onstop = onstop || function() {};\n var doc = document;\n var dragging = false;\n var offset = {};\n var maxHeight = 0;\n var maxWidth = 0;\n var hasTouch = 'ontouchstart' in window;\n\n var duringDragEvents = {};\n duringDragEvents['selectstart'] = prevent;\n duringDragEvents['dragstart'] = prevent;\n duringDragEvents['touchmove mousemove'] = move;\n duringDragEvents['touchend mouseup'] = stop;\n\n function prevent(e) {\n if (e.stopPropagation) {\n e.stopPropagation();\n }\n if (e.preventDefault) {\n e.preventDefault();\n }\n e.returnValue = false;\n }\n\n function move(e) {\n if (dragging) {\n // Mouseup happened outside of window\n if (IE && doc.documentMode < 9 && !e.button) {\n return stop();\n }\n\n var t0 = e && e.touches && e.touches[0];\n var pageX = (t0 && t0.pageX) || e.pageX;\n var pageY = (t0 && t0.pageY) || e.pageY;\n\n var dragX = Math.max(0, Math.min(pageX - offset.left, maxWidth));\n var dragY = Math.max(0, Math.min(pageY - offset.top, maxHeight));\n\n if (hasTouch) {\n // Stop scrolling in iOS\n prevent(e);\n }\n\n onmove.apply(element, [dragX, dragY, e]);\n }\n }\n\n function start(e) {\n var rightclick = e.which ? e.which == 3 : e.button == 2;\n\n if (!rightclick && !dragging) {\n if (onstart.apply(element, arguments) !== false) {\n dragging = true;\n maxHeight = $(element).height();\n maxWidth = $(element).width();\n offset = $(element).offset();\n\n $(doc).bind(duringDragEvents);\n $(doc.body).addClass('sp-dragging');\n\n move(e);\n\n prevent(e);\n }\n }\n }\n\n function stop() {\n if (dragging) {\n $(doc).unbind(duringDragEvents);\n $(doc.body).removeClass('sp-dragging');\n\n // Wait a tick before notifying observers to allow the click event\n // to fire in Chrome.\n setTimeout(function() {\n onstop.apply(element, arguments);\n }, 0);\n }\n dragging = false;\n }\n\n $(element).bind('touchstart mousedown', start);\n }\n\n function throttle(func, wait, debounce) {\n var timeout;\n return function() {\n var context = this,\n args = arguments;\n var throttler = function() {\n timeout = null;\n func.apply(context, args);\n };\n if (debounce) clearTimeout(timeout);\n if (debounce || !timeout) timeout = setTimeout(throttler, wait);\n };\n }\n\n function inputTypeColorSupport() {\n return $.fn.spectrum.inputTypeColorSupport();\n }\n\n /**\n * Define a jQuery plugin\n */\n var dataID = 'spectrum.id';\n $.fn.spectrum = function(opts, extra) {\n if (typeof opts == 'string') {\n var returnValue = this;\n var args = Array.prototype.slice.call(arguments, 1);\n\n this.each(function() {\n var spect = spectrums[$(this).data(dataID)];\n if (spect) {\n var method = spect[opts];\n if (!method) {\n throw new Error(\"Spectrum: no such method: '\" + opts + \"'\");\n }\n\n if (opts == 'get') {\n returnValue = spect.get();\n } else if (opts == 'container') {\n returnValue = spect.container;\n } else if (opts == 'option') {\n returnValue = spect.option.apply(spect, args);\n } else if (opts == 'destroy') {\n spect.destroy();\n $(this).removeData(dataID);\n } else {\n method.apply(spect, args);\n }\n }\n });\n\n return returnValue;\n }\n\n // Initializing a new instance of spectrum\n return this.spectrum('destroy').each(function() {\n var options = $.extend({}, opts, $(this).data());\n var spect = spectrum(this, options);\n $(this).data(dataID, spect.id);\n });\n };\n\n $.fn.spectrum.load = true;\n $.fn.spectrum.loadOpts = {};\n $.fn.spectrum.draggable = draggable;\n $.fn.spectrum.defaults = defaultOpts;\n $.fn.spectrum.inputTypeColorSupport = function inputTypeColorSupport() {\n if (typeof inputTypeColorSupport._cachedResult === 'undefined') {\n var colorInput = $(\"\")[0]; // if color element is supported, value will default to not null\n inputTypeColorSupport._cachedResult =\n colorInput.type === 'color' && colorInput.value !== '';\n }\n return inputTypeColorSupport._cachedResult;\n };\n\n $.spectrum = {};\n $.spectrum.localization = {};\n $.spectrum.palettes = {};\n\n $.fn.spectrum.processNativeColorInputs = function() {\n var colorInputs = $('input[type=color]');\n if (colorInputs.length && !inputTypeColorSupport()) {\n colorInputs.spectrum({\n preferredFormat: 'hex6'\n });\n }\n };\n\n // TinyColor v1.1.2\n // https://github.com/bgrins/TinyColor\n // Brian Grinstead, MIT License\n\n //(function() {\n\n var trimLeft = /^[\\s,#]+/,\n trimRight = /\\s+$/,\n tinyCounter = 0,\n math = Math,\n mathRound = math.round,\n mathMin = math.min,\n mathMax = math.max,\n mathRandom = math.random;\n\n var tinycolor = function(color, opts) {\n color = color ? color : '';\n opts = opts || {};\n\n // If input is already a tinycolor, return itself\n if (color instanceof tinycolor) {\n return color;\n }\n // If we are called as a function, call using new instead\n if (!(this instanceof tinycolor)) {\n return new tinycolor(color, opts);\n }\n\n var rgb = inputToRGB(color);\n (this._originalInput = color),\n (this._r = rgb.r),\n (this._g = rgb.g),\n (this._b = rgb.b),\n (this._a = rgb.a),\n (this._roundA = mathRound(100 * this._a) / 100),\n (this._format = opts.format || rgb.format);\n this._gradientType = opts.gradientType;\n\n // Don't let the range of [0,255] come back in [0,1].\n // Potentially lose a little bit of precision here, but will fix issues where\n // .5 gets interpreted as half of the total, instead of half of 1\n // If it was supposed to be 128, this was already taken care of by `inputToRgb`\n if (this._r < 1) {\n this._r = mathRound(this._r);\n }\n if (this._g < 1) {\n this._g = mathRound(this._g);\n }\n if (this._b < 1) {\n this._b = mathRound(this._b);\n }\n\n this._ok = rgb.ok;\n this._tc_id = tinyCounter++;\n };\n\n tinycolor.prototype = {\n isDark: function() {\n return this.getBrightness() < 128;\n },\n isLight: function() {\n return !this.isDark();\n },\n isValid: function() {\n return this._ok;\n },\n getOriginalInput: function() {\n return this._originalInput;\n },\n getFormat: function() {\n return this._format;\n },\n getAlpha: function() {\n return this._a;\n },\n getBrightness: function() {\n var rgb = this.toRgb();\n return (rgb.r * 299 + rgb.g * 587 + rgb.b * 114) / 1000;\n },\n setAlpha: function(value) {\n this._a = boundAlpha(value);\n this._roundA = mathRound(100 * this._a) / 100;\n return this;\n },\n toHsv: function() {\n var hsv = rgbToHsv(this._r, this._g, this._b);\n return { h: hsv.h * 360, s: hsv.s, v: hsv.v, a: this._a };\n },\n toHsvString: function() {\n var hsv = rgbToHsv(this._r, this._g, this._b);\n var h = mathRound(hsv.h * 360),\n s = mathRound(hsv.s * 100),\n v = mathRound(hsv.v * 100);\n return this._a == 1\n ? 'hsv(' + h + ', ' + s + '%, ' + v + '%)'\n : 'hsva(' + h + ', ' + s + '%, ' + v + '%, ' + this._roundA + ')';\n },\n toHsl: function() {\n var hsl = rgbToHsl(this._r, this._g, this._b);\n return { h: hsl.h * 360, s: hsl.s, l: hsl.l, a: this._a };\n },\n toHslString: function() {\n var hsl = rgbToHsl(this._r, this._g, this._b);\n var h = mathRound(hsl.h * 360),\n s = mathRound(hsl.s * 100),\n l = mathRound(hsl.l * 100);\n return this._a == 1\n ? 'hsl(' + h + ', ' + s + '%, ' + l + '%)'\n : 'hsla(' + h + ', ' + s + '%, ' + l + '%, ' + this._roundA + ')';\n },\n toHex: function(allow3Char) {\n return rgbToHex(this._r, this._g, this._b, allow3Char);\n },\n toHexString: function(allow3Char) {\n return '#' + this.toHex(allow3Char);\n },\n toHex8: function() {\n return rgbaToHex(this._r, this._g, this._b, this._a);\n },\n toHex8String: function() {\n return '#' + this.toHex8();\n },\n toRgb: function() {\n return {\n r: mathRound(this._r),\n g: mathRound(this._g),\n b: mathRound(this._b),\n a: this._a\n };\n },\n toRgbString: function() {\n return this._a == 1\n ? 'rgb(' +\n mathRound(this._r) +\n ', ' +\n mathRound(this._g) +\n ', ' +\n mathRound(this._b) +\n ')'\n : 'rgba(' +\n mathRound(this._r) +\n ', ' +\n mathRound(this._g) +\n ', ' +\n mathRound(this._b) +\n ', ' +\n this._roundA +\n ')';\n },\n toPercentageRgb: function() {\n return {\n r: mathRound(bound01(this._r, 255) * 100) + '%',\n g: mathRound(bound01(this._g, 255) * 100) + '%',\n b: mathRound(bound01(this._b, 255) * 100) + '%',\n a: this._a\n };\n },\n toPercentageRgbString: function() {\n return this._a == 1\n ? 'rgb(' +\n mathRound(bound01(this._r, 255) * 100) +\n '%, ' +\n mathRound(bound01(this._g, 255) * 100) +\n '%, ' +\n mathRound(bound01(this._b, 255) * 100) +\n '%)'\n : 'rgba(' +\n mathRound(bound01(this._r, 255) * 100) +\n '%, ' +\n mathRound(bound01(this._g, 255) * 100) +\n '%, ' +\n mathRound(bound01(this._b, 255) * 100) +\n '%, ' +\n this._roundA +\n ')';\n },\n toName: function() {\n if (this._a === 0) {\n return 'transparent';\n }\n\n if (this._a < 1) {\n return false;\n }\n\n return hexNames[rgbToHex(this._r, this._g, this._b, true)] || false;\n },\n toFilter: function(secondColor) {\n var hex8String = '#' + rgbaToHex(this._r, this._g, this._b, this._a);\n var secondHex8String = hex8String;\n var gradientType = this._gradientType ? 'GradientType = 1, ' : '';\n\n if (secondColor) {\n var s = tinycolor(secondColor);\n secondHex8String = s.toHex8String();\n }\n\n return (\n 'progid:DXImageTransform.Microsoft.gradient(' +\n gradientType +\n 'startColorstr=' +\n hex8String +\n ',endColorstr=' +\n secondHex8String +\n ')'\n );\n },\n toString: function(format) {\n var formatSet = !!format;\n format = format || this._format;\n\n var formattedString = false;\n var hasAlpha = this._a < 1 && this._a >= 0;\n var needsAlphaFormat =\n !formatSet &&\n hasAlpha &&\n (format === 'hex' ||\n format === 'hex6' ||\n format === 'hex3' ||\n format === 'name');\n\n if (needsAlphaFormat) {\n // Special case for \"transparent\", all other non-alpha formats\n // will return rgba when there is transparency.\n if (format === 'name' && this._a === 0) {\n return this.toName();\n }\n return this.toRgbString();\n }\n if (format === 'rgb') {\n formattedString = this.toRgbString();\n }\n if (format === 'prgb') {\n formattedString = this.toPercentageRgbString();\n }\n if (format === 'hex' || format === 'hex6') {\n formattedString = this.toHexString();\n }\n if (format === 'hex3') {\n formattedString = this.toHexString(true);\n }\n if (format === 'hex8') {\n formattedString = this.toHex8String();\n }\n if (format === 'name') {\n formattedString = this.toName();\n }\n if (format === 'hsl') {\n formattedString = this.toHslString();\n }\n if (format === 'hsv') {\n formattedString = this.toHsvString();\n }\n\n return formattedString || this.toHexString();\n },\n\n _applyModification: function(fn, args) {\n var color = fn.apply(null, [this].concat([].slice.call(args)));\n this._r = color._r;\n this._g = color._g;\n this._b = color._b;\n this.setAlpha(color._a);\n return this;\n },\n lighten: function() {\n return this._applyModification(lighten, arguments);\n },\n brighten: function() {\n return this._applyModification(brighten, arguments);\n },\n darken: function() {\n return this._applyModification(darken, arguments);\n },\n desaturate: function() {\n return this._applyModification(desaturate, arguments);\n },\n saturate: function() {\n return this._applyModification(saturate, arguments);\n },\n greyscale: function() {\n return this._applyModification(greyscale, arguments);\n },\n spin: function() {\n return this._applyModification(spin, arguments);\n },\n\n _applyCombination: function(fn, args) {\n return fn.apply(null, [this].concat([].slice.call(args)));\n },\n analogous: function() {\n return this._applyCombination(analogous, arguments);\n },\n complement: function() {\n return this._applyCombination(complement, arguments);\n },\n monochromatic: function() {\n return this._applyCombination(monochromatic, arguments);\n },\n splitcomplement: function() {\n return this._applyCombination(splitcomplement, arguments);\n },\n triad: function() {\n return this._applyCombination(triad, arguments);\n },\n tetrad: function() {\n return this._applyCombination(tetrad, arguments);\n }\n };\n\n // If input is an object, force 1 into \"1.0\" to handle ratios properly\n // String input requires \"1.0\" as input, so 1 will be treated as 1\n tinycolor.fromRatio = function(color, opts) {\n if (typeof color == 'object') {\n var newColor = {};\n for (var i in color) {\n if (color.hasOwnProperty(i)) {\n if (i === 'a') {\n newColor[i] = color[i];\n } else {\n newColor[i] = convertToPercentage(color[i]);\n }\n }\n }\n color = newColor;\n }\n\n return tinycolor(color, opts);\n };\n\n // Given a string or object, convert that input to RGB\n // Possible string inputs:\n //\n // \"red\"\n // \"#f00\" or \"f00\"\n // \"#ff0000\" or \"ff0000\"\n // \"#ff000000\" or \"ff000000\"\n // \"rgb 255 0 0\" or \"rgb (255, 0, 0)\"\n // \"rgb 1.0 0 0\" or \"rgb (1, 0, 0)\"\n // \"rgba (255, 0, 0, 1)\" or \"rgba 255, 0, 0, 1\"\n // \"rgba (1.0, 0, 0, 1)\" or \"rgba 1.0, 0, 0, 1\"\n // \"hsl(0, 100%, 50%)\" or \"hsl 0 100% 50%\"\n // \"hsla(0, 100%, 50%, 1)\" or \"hsla 0 100% 50%, 1\"\n // \"hsv(0, 100%, 100%)\" or \"hsv 0 100% 100%\"\n //\n function inputToRGB(color) {\n var rgb = { r: 0, g: 0, b: 0 };\n var a = 1;\n var ok = false;\n var format = false;\n\n if (typeof color == 'string') {\n color = stringInputToObject(color);\n }\n\n if (typeof color == 'object') {\n if (\n color.hasOwnProperty('r') &&\n color.hasOwnProperty('g') &&\n color.hasOwnProperty('b')\n ) {\n rgb = rgbToRgb(color.r, color.g, color.b);\n ok = true;\n format = String(color.r).substr(-1) === '%' ? 'prgb' : 'rgb';\n } else if (\n color.hasOwnProperty('h') &&\n color.hasOwnProperty('s') &&\n color.hasOwnProperty('v')\n ) {\n color.s = convertToPercentage(color.s);\n color.v = convertToPercentage(color.v);\n rgb = hsvToRgb(color.h, color.s, color.v);\n ok = true;\n format = 'hsv';\n } else if (\n color.hasOwnProperty('h') &&\n color.hasOwnProperty('s') &&\n color.hasOwnProperty('l')\n ) {\n color.s = convertToPercentage(color.s);\n color.l = convertToPercentage(color.l);\n rgb = hslToRgb(color.h, color.s, color.l);\n ok = true;\n format = 'hsl';\n }\n\n if (color.hasOwnProperty('a')) {\n a = color.a;\n }\n }\n\n a = boundAlpha(a);\n\n return {\n ok: ok,\n format: color.format || format,\n r: mathMin(255, mathMax(rgb.r, 0)),\n g: mathMin(255, mathMax(rgb.g, 0)),\n b: mathMin(255, mathMax(rgb.b, 0)),\n a: a\n };\n }\n\n // Conversion Functions\n // --------------------\n\n // `rgbToHsl`, `rgbToHsv`, `hslToRgb`, `hsvToRgb` modified from:\n // \n\n // `rgbToRgb`\n // Handle bounds / percentage checking to conform to CSS color spec\n // \n // *Assumes:* r, g, b in [0, 255] or [0, 1]\n // *Returns:* { r, g, b } in [0, 255]\n function rgbToRgb(r, g, b) {\n return {\n r: bound01(r, 255) * 255,\n g: bound01(g, 255) * 255,\n b: bound01(b, 255) * 255\n };\n }\n\n // `rgbToHsl`\n // Converts an RGB color value to HSL.\n // *Assumes:* r, g, and b are contained in [0, 255] or [0, 1]\n // *Returns:* { h, s, l } in [0,1]\n function rgbToHsl(r, g, b) {\n r = bound01(r, 255);\n g = bound01(g, 255);\n b = bound01(b, 255);\n\n var max = mathMax(r, g, b),\n min = mathMin(r, g, b);\n var h,\n s,\n l = (max + min) / 2;\n\n if (max == min) {\n h = s = 0; // achromatic\n } else {\n var d = max - min;\n s = l > 0.5 ? d / (2 - max - min) : d / (max + min);\n switch (max) {\n case r:\n h = (g - b) / d + (g < b ? 6 : 0);\n break;\n case g:\n h = (b - r) / d + 2;\n break;\n case b:\n h = (r - g) / d + 4;\n break;\n }\n\n h /= 6;\n }\n\n return { h: h, s: s, l: l };\n }\n\n // `hslToRgb`\n // Converts an HSL color value to RGB.\n // *Assumes:* h is contained in [0, 1] or [0, 360] and s and l are contained [0, 1] or [0, 100]\n // *Returns:* { r, g, b } in the set [0, 255]\n function hslToRgb(h, s, l) {\n var r, g, b;\n\n h = bound01(h, 360);\n s = bound01(s, 100);\n l = bound01(l, 100);\n\n function hue2rgb(p, q, t) {\n if (t < 0) t += 1;\n if (t > 1) t -= 1;\n if (t < 1 / 6) return p + (q - p) * 6 * t;\n if (t < 1 / 2) return q;\n if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6;\n return p;\n }\n\n if (s === 0) {\n r = g = b = l; // achromatic\n } else {\n var q = l < 0.5 ? l * (1 + s) : l + s - l * s;\n var p = 2 * l - q;\n r = hue2rgb(p, q, h + 1 / 3);\n g = hue2rgb(p, q, h);\n b = hue2rgb(p, q, h - 1 / 3);\n }\n\n return { r: r * 255, g: g * 255, b: b * 255 };\n }\n\n // `rgbToHsv`\n // Converts an RGB color value to HSV\n // *Assumes:* r, g, and b are contained in the set [0, 255] or [0, 1]\n // *Returns:* { h, s, v } in [0,1]\n function rgbToHsv(r, g, b) {\n r = bound01(r, 255);\n g = bound01(g, 255);\n b = bound01(b, 255);\n\n var max = mathMax(r, g, b),\n min = mathMin(r, g, b);\n var h,\n s,\n v = max;\n\n var d = max - min;\n s = max === 0 ? 0 : d / max;\n\n if (max == min) {\n h = 0; // achromatic\n } else {\n switch (max) {\n case r:\n h = (g - b) / d + (g < b ? 6 : 0);\n break;\n case g:\n h = (b - r) / d + 2;\n break;\n case b:\n h = (r - g) / d + 4;\n break;\n }\n h /= 6;\n }\n return { h: h, s: s, v: v };\n }\n\n // `hsvToRgb`\n // Converts an HSV color value to RGB.\n // *Assumes:* h is contained in [0, 1] or [0, 360] and s and v are contained in [0, 1] or [0, 100]\n // *Returns:* { r, g, b } in the set [0, 255]\n function hsvToRgb(h, s, v) {\n h = bound01(h, 360) * 6;\n s = bound01(s, 100);\n v = bound01(v, 100);\n\n var i = math.floor(h),\n f = h - i,\n p = v * (1 - s),\n q = v * (1 - f * s),\n t = v * (1 - (1 - f) * s),\n mod = i % 6,\n r = [v, q, p, p, t, v][mod],\n g = [t, v, v, q, p, p][mod],\n b = [p, p, t, v, v, q][mod];\n\n return { r: r * 255, g: g * 255, b: b * 255 };\n }\n\n // `rgbToHex`\n // Converts an RGB color to hex\n // Assumes r, g, and b are contained in the set [0, 255]\n // Returns a 3 or 6 character hex\n function rgbToHex(r, g, b, allow3Char) {\n var hex = [\n pad2(mathRound(r).toString(16)),\n pad2(mathRound(g).toString(16)),\n pad2(mathRound(b).toString(16))\n ];\n\n // Return a 3 character hex if possible\n if (\n allow3Char &&\n hex[0].charAt(0) == hex[0].charAt(1) &&\n hex[1].charAt(0) == hex[1].charAt(1) &&\n hex[2].charAt(0) == hex[2].charAt(1)\n ) {\n return hex[0].charAt(0) + hex[1].charAt(0) + hex[2].charAt(0);\n }\n\n return hex.join('');\n }\n // `rgbaToHex`\n // Converts an RGBA color plus alpha transparency to hex\n // Assumes r, g, b and a are contained in the set [0, 255]\n // Returns an 8 character hex\n function rgbaToHex(r, g, b, a) {\n var hex = [\n pad2(convertDecimalToHex(a)),\n pad2(mathRound(r).toString(16)),\n pad2(mathRound(g).toString(16)),\n pad2(mathRound(b).toString(16))\n ];\n\n return hex.join('');\n }\n\n // `equals`\n // Can be called with any tinycolor input\n tinycolor.equals = function(color1, color2) {\n if (!color1 || !color2) {\n return false;\n }\n return tinycolor(color1).toRgbString() == tinycolor(color2).toRgbString();\n };\n tinycolor.random = function() {\n return tinycolor.fromRatio({\n r: mathRandom(),\n g: mathRandom(),\n b: mathRandom()\n });\n };\n\n // Modification Functions\n // ----------------------\n // Thanks to less.js for some of the basics here\n // \n\n function desaturate(color, amount) {\n amount = amount === 0 ? 0 : amount || 10;\n var hsl = tinycolor(color).toHsl();\n hsl.s -= amount / 100;\n hsl.s = clamp01(hsl.s);\n return tinycolor(hsl);\n }\n\n function saturate(color, amount) {\n amount = amount === 0 ? 0 : amount || 10;\n var hsl = tinycolor(color).toHsl();\n hsl.s += amount / 100;\n hsl.s = clamp01(hsl.s);\n return tinycolor(hsl);\n }\n\n function greyscale(color) {\n return tinycolor(color).desaturate(100);\n }\n\n function lighten(color, amount) {\n amount = amount === 0 ? 0 : amount || 10;\n var hsl = tinycolor(color).toHsl();\n hsl.l += amount / 100;\n hsl.l = clamp01(hsl.l);\n return tinycolor(hsl);\n }\n\n function brighten(color, amount) {\n amount = amount === 0 ? 0 : amount || 10;\n var rgb = tinycolor(color).toRgb();\n rgb.r = mathMax(0, mathMin(255, rgb.r - mathRound(255 * -(amount / 100))));\n rgb.g = mathMax(0, mathMin(255, rgb.g - mathRound(255 * -(amount / 100))));\n rgb.b = mathMax(0, mathMin(255, rgb.b - mathRound(255 * -(amount / 100))));\n return tinycolor(rgb);\n }\n\n function darken(color, amount) {\n amount = amount === 0 ? 0 : amount || 10;\n var hsl = tinycolor(color).toHsl();\n hsl.l -= amount / 100;\n hsl.l = clamp01(hsl.l);\n return tinycolor(hsl);\n }\n\n // Spin takes a positive or negative amount within [-360, 360] indicating the change of hue.\n // Values outside of this range will be wrapped into this range.\n function spin(color, amount) {\n var hsl = tinycolor(color).toHsl();\n var hue = (mathRound(hsl.h) + amount) % 360;\n hsl.h = hue < 0 ? 360 + hue : hue;\n return tinycolor(hsl);\n }\n\n // Combination Functions\n // ---------------------\n // Thanks to jQuery xColor for some of the ideas behind these\n // \n\n function complement(color) {\n var hsl = tinycolor(color).toHsl();\n hsl.h = (hsl.h + 180) % 360;\n return tinycolor(hsl);\n }\n\n function triad(color) {\n var hsl = tinycolor(color).toHsl();\n var h = hsl.h;\n return [\n tinycolor(color),\n tinycolor({ h: (h + 120) % 360, s: hsl.s, l: hsl.l }),\n tinycolor({ h: (h + 240) % 360, s: hsl.s, l: hsl.l })\n ];\n }\n\n function tetrad(color) {\n var hsl = tinycolor(color).toHsl();\n var h = hsl.h;\n return [\n tinycolor(color),\n tinycolor({ h: (h + 90) % 360, s: hsl.s, l: hsl.l }),\n tinycolor({ h: (h + 180) % 360, s: hsl.s, l: hsl.l }),\n tinycolor({ h: (h + 270) % 360, s: hsl.s, l: hsl.l })\n ];\n }\n\n function splitcomplement(color) {\n var hsl = tinycolor(color).toHsl();\n var h = hsl.h;\n return [\n tinycolor(color),\n tinycolor({ h: (h + 72) % 360, s: hsl.s, l: hsl.l }),\n tinycolor({ h: (h + 216) % 360, s: hsl.s, l: hsl.l })\n ];\n }\n\n function analogous(color, results, slices) {\n results = results || 6;\n slices = slices || 30;\n\n var hsl = tinycolor(color).toHsl();\n var part = 360 / slices;\n var ret = [tinycolor(color)];\n\n for (hsl.h = (hsl.h - ((part * results) >> 1) + 720) % 360; --results; ) {\n hsl.h = (hsl.h + part) % 360;\n ret.push(tinycolor(hsl));\n }\n return ret;\n }\n\n function monochromatic(color, results) {\n results = results || 6;\n var hsv = tinycolor(color).toHsv();\n var h = hsv.h,\n s = hsv.s,\n v = hsv.v;\n var ret = [];\n var modification = 1 / results;\n\n while (results--) {\n ret.push(tinycolor({ h: h, s: s, v: v }));\n v = (v + modification) % 1;\n }\n\n return ret;\n }\n\n // Utility Functions\n // ---------------------\n\n tinycolor.mix = function(color1, color2, amount) {\n amount = amount === 0 ? 0 : amount || 50;\n\n var rgb1 = tinycolor(color1).toRgb();\n var rgb2 = tinycolor(color2).toRgb();\n\n var p = amount / 100;\n var w = p * 2 - 1;\n var a = rgb2.a - rgb1.a;\n\n var w1;\n\n if (w * a == -1) {\n w1 = w;\n } else {\n w1 = (w + a) / (1 + w * a);\n }\n\n w1 = (w1 + 1) / 2;\n\n var w2 = 1 - w1;\n\n var rgba = {\n r: rgb2.r * w1 + rgb1.r * w2,\n g: rgb2.g * w1 + rgb1.g * w2,\n b: rgb2.b * w1 + rgb1.b * w2,\n a: rgb2.a * p + rgb1.a * (1 - p)\n };\n\n return tinycolor(rgba);\n };\n\n // Readability Functions\n // ---------------------\n // \n\n // `readability`\n // Analyze the 2 colors and returns an object with the following properties:\n // `brightness`: difference in brightness between the two colors\n // `color`: difference in color/hue between the two colors\n tinycolor.readability = function(color1, color2) {\n var c1 = tinycolor(color1);\n var c2 = tinycolor(color2);\n var rgb1 = c1.toRgb();\n var rgb2 = c2.toRgb();\n var brightnessA = c1.getBrightness();\n var brightnessB = c2.getBrightness();\n var colorDiff =\n Math.max(rgb1.r, rgb2.r) -\n Math.min(rgb1.r, rgb2.r) +\n Math.max(rgb1.g, rgb2.g) -\n Math.min(rgb1.g, rgb2.g) +\n Math.max(rgb1.b, rgb2.b) -\n Math.min(rgb1.b, rgb2.b);\n\n return {\n brightness: Math.abs(brightnessA - brightnessB),\n color: colorDiff\n };\n };\n\n // `readable`\n // http://www.w3.org/TR/AERT#color-contrast\n // Ensure that foreground and background color combinations provide sufficient contrast.\n // *Example*\n // tinycolor.isReadable(\"#000\", \"#111\") => false\n tinycolor.isReadable = function(color1, color2) {\n var readability = tinycolor.readability(color1, color2);\n return readability.brightness > 125 && readability.color > 500;\n };\n\n // `mostReadable`\n // Given a base color and a list of possible foreground or background\n // colors for that base, returns the most readable color.\n // *Example*\n // tinycolor.mostReadable(\"#123\", [\"#fff\", \"#000\"]) => \"#000\"\n tinycolor.mostReadable = function(baseColor, colorList) {\n var bestColor = null;\n var bestScore = 0;\n var bestIsReadable = false;\n for (var i = 0; i < colorList.length; i++) {\n // We normalize both around the \"acceptable\" breaking point,\n // but rank brightness constrast higher than hue.\n\n var readability = tinycolor.readability(baseColor, colorList[i]);\n var readable = readability.brightness > 125 && readability.color > 500;\n var score = 3 * (readability.brightness / 125) + readability.color / 500;\n\n if (\n (readable && !bestIsReadable) ||\n (readable && bestIsReadable && score > bestScore) ||\n (!readable && !bestIsReadable && score > bestScore)\n ) {\n bestIsReadable = readable;\n bestScore = score;\n bestColor = tinycolor(colorList[i]);\n }\n }\n return bestColor;\n };\n\n // Big List of Colors\n // ------------------\n // \n var names = (tinycolor.names = {\n aliceblue: 'f0f8ff',\n antiquewhite: 'faebd7',\n aqua: '0ff',\n aquamarine: '7fffd4',\n azure: 'f0ffff',\n beige: 'f5f5dc',\n bisque: 'ffe4c4',\n black: '000',\n blanchedalmond: 'ffebcd',\n blue: '00f',\n blueviolet: '8a2be2',\n brown: 'a52a2a',\n burlywood: 'deb887',\n burntsienna: 'ea7e5d',\n cadetblue: '5f9ea0',\n chartreuse: '7fff00',\n chocolate: 'd2691e',\n coral: 'ff7f50',\n cornflowerblue: '6495ed',\n cornsilk: 'fff8dc',\n crimson: 'dc143c',\n cyan: '0ff',\n darkblue: '00008b',\n darkcyan: '008b8b',\n darkgoldenrod: 'b8860b',\n darkgray: 'a9a9a9',\n darkgreen: '006400',\n darkgrey: 'a9a9a9',\n darkkhaki: 'bdb76b',\n darkmagenta: '8b008b',\n darkolivegreen: '556b2f',\n darkorange: 'ff8c00',\n darkorchid: '9932cc',\n darkred: '8b0000',\n darksalmon: 'e9967a',\n darkseagreen: '8fbc8f',\n darkslateblue: '483d8b',\n darkslategray: '2f4f4f',\n darkslategrey: '2f4f4f',\n darkturquoise: '00ced1',\n darkviolet: '9400d3',\n deeppink: 'ff1493',\n deepskyblue: '00bfff',\n dimgray: '696969',\n dimgrey: '696969',\n dodgerblue: '1e90ff',\n firebrick: 'b22222',\n floralwhite: 'fffaf0',\n forestgreen: '228b22',\n fuchsia: 'f0f',\n gainsboro: 'dcdcdc',\n ghostwhite: 'f8f8ff',\n gold: 'ffd700',\n goldenrod: 'daa520',\n gray: '808080',\n green: '008000',\n greenyellow: 'adff2f',\n grey: '808080',\n honeydew: 'f0fff0',\n hotpink: 'ff69b4',\n indianred: 'cd5c5c',\n indigo: '4b0082',\n ivory: 'fffff0',\n khaki: 'f0e68c',\n lavender: 'e6e6fa',\n lavenderblush: 'fff0f5',\n lawngreen: '7cfc00',\n lemonchiffon: 'fffacd',\n lightblue: 'add8e6',\n lightcoral: 'f08080',\n lightcyan: 'e0ffff',\n lightgoldenrodyellow: 'fafad2',\n lightgray: 'd3d3d3',\n lightgreen: '90ee90',\n lightgrey: 'd3d3d3',\n lightpink: 'ffb6c1',\n lightsalmon: 'ffa07a',\n lightseagreen: '20b2aa',\n lightskyblue: '87cefa',\n lightslategray: '789',\n lightslategrey: '789',\n lightsteelblue: 'b0c4de',\n lightyellow: 'ffffe0',\n lime: '0f0',\n limegreen: '32cd32',\n linen: 'faf0e6',\n magenta: 'f0f',\n maroon: '800000',\n mediumaquamarine: '66cdaa',\n mediumblue: '0000cd',\n mediumorchid: 'ba55d3',\n mediumpurple: '9370db',\n mediumseagreen: '3cb371',\n mediumslateblue: '7b68ee',\n mediumspringgreen: '00fa9a',\n mediumturquoise: '48d1cc',\n mediumvioletred: 'c71585',\n midnightblue: '191970',\n mintcream: 'f5fffa',\n mistyrose: 'ffe4e1',\n moccasin: 'ffe4b5',\n navajowhite: 'ffdead',\n navy: '000080',\n oldlace: 'fdf5e6',\n olive: '808000',\n olivedrab: '6b8e23',\n orange: 'ffa500',\n orangered: 'ff4500',\n orchid: 'da70d6',\n palegoldenrod: 'eee8aa',\n palegreen: '98fb98',\n paleturquoise: 'afeeee',\n palevioletred: 'db7093',\n papayawhip: 'ffefd5',\n peachpuff: 'ffdab9',\n peru: 'cd853f',\n pink: 'ffc0cb',\n plum: 'dda0dd',\n powderblue: 'b0e0e6',\n purple: '800080',\n rebeccapurple: '663399',\n red: 'f00',\n rosybrown: 'bc8f8f',\n royalblue: '4169e1',\n saddlebrown: '8b4513',\n salmon: 'fa8072',\n sandybrown: 'f4a460',\n seagreen: '2e8b57',\n seashell: 'fff5ee',\n sienna: 'a0522d',\n silver: 'c0c0c0',\n skyblue: '87ceeb',\n slateblue: '6a5acd',\n slategray: '708090',\n slategrey: '708090',\n snow: 'fffafa',\n springgreen: '00ff7f',\n steelblue: '4682b4',\n tan: 'd2b48c',\n teal: '008080',\n thistle: 'd8bfd8',\n tomato: 'ff6347',\n turquoise: '40e0d0',\n violet: 'ee82ee',\n wheat: 'f5deb3',\n white: 'fff',\n whitesmoke: 'f5f5f5',\n yellow: 'ff0',\n yellowgreen: '9acd32'\n });\n\n // Make it easy to access colors via `hexNames[hex]`\n var hexNames = (tinycolor.hexNames = flip(names));\n\n // Utilities\n // ---------\n\n // `{ 'name1': 'val1' }` becomes `{ 'val1': 'name1' }`\n function flip(o) {\n var flipped = {};\n for (var i in o) {\n if (o.hasOwnProperty(i)) {\n flipped[o[i]] = i;\n }\n }\n return flipped;\n }\n\n // Return a valid alpha value [0,1] with all invalid values being set to 1\n function boundAlpha(a) {\n a = parseFloat(a);\n\n if (isNaN(a) || a < 0 || a > 1) {\n a = 1;\n }\n\n return a;\n }\n\n // Take input from [0, n] and return it as [0, 1]\n function bound01(n, max) {\n if (isOnePointZero(n)) {\n n = '100%';\n }\n\n var processPercent = isPercentage(n);\n n = mathMin(max, mathMax(0, parseFloat(n)));\n\n // Automatically convert percentage into number\n if (processPercent) {\n n = parseInt(n * max, 10) / 100;\n }\n\n // Handle floating point rounding errors\n if (math.abs(n - max) < 0.000001) {\n return 1;\n }\n\n // Convert into [0, 1] range if it isn't already\n return (n % max) / parseFloat(max);\n }\n\n // Force a number between 0 and 1\n function clamp01(val) {\n return mathMin(1, mathMax(0, val));\n }\n\n // Parse a base-16 hex value into a base-10 integer\n function parseIntFromHex(val) {\n return parseInt(val, 16);\n }\n\n // Need to handle 1.0 as 100%, since once it is a number, there is no difference between it and 1\n // \n function isOnePointZero(n) {\n return typeof n == 'string' && n.indexOf('.') != -1 && parseFloat(n) === 1;\n }\n\n // Check to see if string passed in is a percentage\n function isPercentage(n) {\n return typeof n === 'string' && n.indexOf('%') != -1;\n }\n\n // Force a hex value to have 2 characters\n function pad2(c) {\n return c.length == 1 ? '0' + c : '' + c;\n }\n\n // Replace a decimal with it's percentage value\n function convertToPercentage(n) {\n if (n <= 1) {\n n = n * 100 + '%';\n }\n\n return n;\n }\n\n // Converts a decimal to a hex value\n function convertDecimalToHex(d) {\n return Math.round(parseFloat(d) * 255).toString(16);\n }\n // Converts a hex value to a decimal\n function convertHexToDecimal(h) {\n return parseIntFromHex(h) / 255;\n }\n\n var matchers = (function() {\n // \n var CSS_INTEGER = '[-\\\\+]?\\\\d+%?';\n\n // \n var CSS_NUMBER = '[-\\\\+]?\\\\d*\\\\.\\\\d+%?';\n\n // Allow positive/negative integer/number. Don't capture the either/or, just the entire outcome.\n var CSS_UNIT = '(?:' + CSS_NUMBER + ')|(?:' + CSS_INTEGER + ')';\n\n // Actual matching.\n // Parentheses and commas are optional, but not required.\n // Whitespace can take the place of commas or opening paren\n var PERMISSIVE_MATCH3 =\n '[\\\\s|\\\\(]+(' +\n CSS_UNIT +\n ')[,|\\\\s]+(' +\n CSS_UNIT +\n ')[,|\\\\s]+(' +\n CSS_UNIT +\n ')\\\\s*\\\\)?';\n var PERMISSIVE_MATCH4 =\n '[\\\\s|\\\\(]+(' +\n CSS_UNIT +\n ')[,|\\\\s]+(' +\n CSS_UNIT +\n ')[,|\\\\s]+(' +\n CSS_UNIT +\n ')[,|\\\\s]+(' +\n CSS_UNIT +\n ')\\\\s*\\\\)?';\n\n return {\n rgb: new RegExp('rgb' + PERMISSIVE_MATCH3),\n rgba: new RegExp('rgba' + PERMISSIVE_MATCH4),\n hsl: new RegExp('hsl' + PERMISSIVE_MATCH3),\n hsla: new RegExp('hsla' + PERMISSIVE_MATCH4),\n hsv: new RegExp('hsv' + PERMISSIVE_MATCH3),\n hsva: new RegExp('hsva' + PERMISSIVE_MATCH4),\n hex3: /^([0-9a-fA-F]{1})([0-9a-fA-F]{1})([0-9a-fA-F]{1})$/,\n hex6: /^([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/,\n hex8: /^([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})([0-9a-fA-F]{2})$/\n };\n })();\n\n // `stringInputToObject`\n // Permissive string parsing. Take in a number of formats, and output an object\n // based on detected format. Returns `{ r, g, b }` or `{ h, s, l }` or `{ h, s, v}`\n function stringInputToObject(color) {\n color = color\n .replace(trimLeft, '')\n .replace(trimRight, '')\n .toLowerCase();\n var named = false;\n if (names[color]) {\n color = names[color];\n named = true;\n } else if (color == 'transparent') {\n return { r: 0, g: 0, b: 0, a: 0, format: 'name' };\n }\n\n // Try to match string input using regular expressions.\n // Keep most of the number bounding out of this function - don't worry about [0,1] or [0,100] or [0,360]\n // Just return an object and let the conversion functions handle that.\n // This way the result will be the same whether the tinycolor is initialized with string or object.\n var match;\n if ((match = matchers.rgb.exec(color))) {\n return { r: match[1], g: match[2], b: match[3] };\n }\n if ((match = matchers.rgba.exec(color))) {\n return { r: match[1], g: match[2], b: match[3], a: match[4] };\n }\n if ((match = matchers.hsl.exec(color))) {\n return { h: match[1], s: match[2], l: match[3] };\n }\n if ((match = matchers.hsla.exec(color))) {\n return { h: match[1], s: match[2], l: match[3], a: match[4] };\n }\n if ((match = matchers.hsv.exec(color))) {\n return { h: match[1], s: match[2], v: match[3] };\n }\n if ((match = matchers.hsva.exec(color))) {\n return { h: match[1], s: match[2], v: match[3], a: match[4] };\n }\n if ((match = matchers.hex8.exec(color))) {\n return {\n a: convertHexToDecimal(match[1]),\n r: parseIntFromHex(match[2]),\n g: parseIntFromHex(match[3]),\n b: parseIntFromHex(match[4]),\n format: named ? 'name' : 'hex8'\n };\n }\n if ((match = matchers.hex6.exec(color))) {\n return {\n r: parseIntFromHex(match[1]),\n g: parseIntFromHex(match[2]),\n b: parseIntFromHex(match[3]),\n format: named ? 'name' : 'hex'\n };\n }\n if ((match = matchers.hex3.exec(color))) {\n return {\n r: parseIntFromHex(match[1] + '' + match[1]),\n g: parseIntFromHex(match[2] + '' + match[2]),\n b: parseIntFromHex(match[3] + '' + match[3]),\n format: named ? 'name' : 'hex'\n };\n }\n\n return false;\n }\n\n window.tinycolor = tinycolor;\n //})();\n\n $(function() {\n if ($.fn.spectrum.load) {\n $.fn.spectrum.processNativeColorInputs();\n }\n });\n}\n","// keymaster.js\n// (c) 2011-2013 Thomas Fuchs\n// keymaster.js may be freely distributed under the MIT license.\n\n;(function(global){\n var k,\n _handlers = {},\n _mods = { 16: false, 18: false, 17: false, 91: false },\n _scope = 'all',\n // modifier keys\n _MODIFIERS = {\n '⇧': 16, shift: 16,\n '⌥': 18, alt: 18, option: 18,\n '⌃': 17, ctrl: 17, control: 17,\n '⌘': 91, command: 91\n },\n // special keys\n _MAP = {\n backspace: 8, tab: 9, clear: 12,\n enter: 13, 'return': 13,\n esc: 27, escape: 27, space: 32,\n left: 37, up: 38,\n right: 39, down: 40,\n del: 46, 'delete': 46,\n home: 36, end: 35,\n pageup: 33, pagedown: 34,\n ',': 188, '.': 190, '/': 191,\n '`': 192, '-': 189, '=': 187,\n ';': 186, '\\'': 222,\n '[': 219, ']': 221, '\\\\': 220\n },\n code = function(x){\n return _MAP[x] || x.toUpperCase().charCodeAt(0);\n },\n _downKeys = [];\n\n for(k=1;k<20;k++) _MAP['f'+k] = 111+k;\n\n // IE doesn't support Array#indexOf, so have a simple replacement\n function index(array, item){\n var i = array.length;\n while(i--) if(array[i]===item) return i;\n return -1;\n }\n\n // for comparing mods before unassignment\n function compareArray(a1, a2) {\n if (a1.length != a2.length) return false;\n for (var i = 0; i < a1.length; i++) {\n if (a1[i] !== a2[i]) return false;\n }\n return true;\n }\n\n var modifierMap = {\n 16:'shiftKey',\n 18:'altKey',\n 17:'ctrlKey',\n 91:'metaKey'\n };\n function updateModifierKey(event) {\n for(k in _mods) _mods[k] = event[modifierMap[k]];\n };\n\n // handle keydown event\n function dispatch(event) {\n var key, handler, k, i, modifiersMatch, scope;\n key = event.keyCode;\n\n if (index(_downKeys, key) == -1) {\n _downKeys.push(key);\n }\n\n // if a modifier key, set the key. property to true and return\n if(key == 93 || key == 224) key = 91; // right command on webkit, command on Gecko\n if(key in _mods) {\n _mods[key] = true;\n // 'assignKey' from inside this closure is exported to window.key\n for(k in _MODIFIERS) if(_MODIFIERS[k] == key) assignKey[k] = true;\n return;\n }\n updateModifierKey(event);\n\n // see if we need to ignore the keypress (filter() can can be overridden)\n // by default ignore key presses if a select, textarea, or input is focused\n if(!assignKey.filter.call(this, event)) return;\n\n // abort if no potentially matching shortcuts found\n if (!(key in _handlers)) return;\n\n scope = getScope();\n\n // for each potential shortcut\n for (i = 0; i < _handlers[key].length; i++) {\n handler = _handlers[key][i];\n\n // see if it's in the current scope\n if(handler.scope == scope || handler.scope == 'all'){\n // check if modifiers match if any\n modifiersMatch = handler.mods.length > 0;\n for(k in _mods)\n if((!_mods[k] && index(handler.mods, +k) > -1) ||\n (_mods[k] && index(handler.mods, +k) == -1)) modifiersMatch = false;\n // call the handler and stop the event if neccessary\n if((handler.mods.length == 0 && !_mods[16] && !_mods[18] && !_mods[17] && !_mods[91]) || modifiersMatch){\n if(handler.method(event, handler)===false){\n if(event.preventDefault) event.preventDefault();\n else event.returnValue = false;\n if(event.stopPropagation) event.stopPropagation();\n if(event.cancelBubble) event.cancelBubble = true;\n }\n }\n }\n }\n };\n\n // unset modifier keys on keyup\n function clearModifier(event){\n var key = event.keyCode, k,\n i = index(_downKeys, key);\n\n // remove key from _downKeys\n if (i >= 0) {\n _downKeys.splice(i, 1);\n }\n\n if(key == 93 || key == 224) key = 91;\n if(key in _mods) {\n _mods[key] = false;\n for(k in _MODIFIERS) if(_MODIFIERS[k] == key) assignKey[k] = false;\n }\n };\n\n function resetModifiers() {\n for(k in _mods) _mods[k] = false;\n for(k in _MODIFIERS) assignKey[k] = false;\n };\n\n // parse and assign shortcut\n function assignKey(key, scope, method){\n var keys, mods;\n keys = getKeys(key);\n if (method === undefined) {\n method = scope;\n scope = 'all';\n }\n\n // for each shortcut\n for (var i = 0; i < keys.length; i++) {\n // set modifier keys if any\n mods = [];\n key = keys[i].split('+');\n if (key.length > 1){\n mods = getMods(key);\n key = [key[key.length-1]];\n }\n // convert to keycode and...\n key = key[0]\n key = code(key);\n // ...store handler\n if (!(key in _handlers)) _handlers[key] = [];\n _handlers[key].push({ shortcut: keys[i], scope: scope, method: method, key: keys[i], mods: mods });\n }\n };\n\n // unbind all handlers for given key in current scope\n function unbindKey(key, scope) {\n var multipleKeys, keys,\n mods = [],\n i, j, obj;\n\n multipleKeys = getKeys(key);\n\n for (j = 0; j < multipleKeys.length; j++) {\n keys = multipleKeys[j].split('+');\n\n if (keys.length > 1) {\n mods = getMods(keys);\n key = keys[keys.length - 1];\n }\n\n key = code(key);\n\n if (scope === undefined) {\n scope = getScope();\n }\n if (!_handlers[key]) {\n return;\n }\n for (i = 0; i < _handlers[key].length; i++) {\n obj = _handlers[key][i];\n // only clear handlers if correct scope and mods match\n if (obj.scope === scope && compareArray(obj.mods, mods)) {\n _handlers[key][i] = {};\n }\n }\n }\n };\n\n // Returns true if the key with code 'keyCode' is currently down\n // Converts strings into key codes.\n function isPressed(keyCode) {\n if (typeof(keyCode)=='string') {\n keyCode = code(keyCode);\n }\n return index(_downKeys, keyCode) != -1;\n }\n\n function getPressedKeyCodes() {\n return _downKeys.slice(0);\n }\n\n function filter(event){\n var tagName = (event.target || event.srcElement).tagName;\n // ignore keypressed in any elements that support keyboard data input\n return !(tagName == 'INPUT' || tagName == 'SELECT' || tagName == 'TEXTAREA');\n }\n\n // initialize key. to false\n for(k in _MODIFIERS) assignKey[k] = false;\n\n // set current scope (default 'all')\n function setScope(scope){ _scope = scope || 'all' };\n function getScope(){ return _scope || 'all' };\n\n // delete all handlers for a given scope\n function deleteScope(scope){\n var key, handlers, i;\n\n for (key in _handlers) {\n handlers = _handlers[key];\n for (i = 0; i < handlers.length; ) {\n if (handlers[i].scope === scope) handlers.splice(i, 1);\n else i++;\n }\n }\n };\n\n // abstract key logic for assign and unassign\n function getKeys(key) {\n var keys;\n key = key.replace(/\\s/g, '');\n keys = key.split(',');\n if ((keys[keys.length - 1]) == '') {\n keys[keys.length - 2] += ',';\n }\n return keys;\n }\n\n // abstract mods logic for assign and unassign\n function getMods(key) {\n var mods = key.slice(0, key.length - 1);\n for (var mi = 0; mi < mods.length; mi++)\n mods[mi] = _MODIFIERS[mods[mi]];\n return mods;\n }\n\n // cross-browser events\n function addEvent(object, event, method) {\n if (object.addEventListener)\n object.addEventListener(event, method, false);\n else if(object.attachEvent)\n object.attachEvent('on'+event, function(){ method(window.event) });\n };\n\n // set the handlers globally on document\n addEvent(document, 'keydown', function(event) { dispatch(event) }); // Passing _scope to a callback to ensure it remains the same by execution. Fixes #48\n addEvent(document, 'keyup', clearModifier);\n\n // reset modifiers to false whenever the window is (re)focused.\n addEvent(window, 'focus', resetModifiers);\n\n // store previously defined key\n var previousKey = global.key;\n\n // restore previously defined key and return reference to our key object\n function noConflict() {\n var k = global.key;\n global.key = previousKey;\n return k;\n }\n\n // set window.key and window.key.set/get/deleteScope, and the default filter\n global.key = assignKey;\n global.key.setScope = setScope;\n global.key.getScope = getScope;\n global.key.deleteScope = deleteScope;\n global.key.filter = filter;\n global.key.isPressed = isPressed;\n global.key.getPressedKeyCodes = getPressedKeyCodes;\n global.key.noConflict = noConflict;\n global.key.unbind = unbindKey;\n\n if(typeof module !== 'undefined') module.exports = assignKey;\n\n})(this);\n","import promiseFinally from './finally';\n\n// Store setTimeout reference so promise-polyfill will be unaffected by\n// other code modifying setTimeout (like sinon.useFakeTimers())\nvar setTimeoutFunc = setTimeout;\n\nfunction isArray(x) {\n return Boolean(x && typeof x.length !== 'undefined');\n}\n\nfunction noop() {}\n\n// Polyfill for Function.prototype.bind\nfunction bind(fn, thisArg) {\n return function() {\n fn.apply(thisArg, arguments);\n };\n}\n\n/**\n * @constructor\n * @param {Function} fn\n */\nfunction Promise(fn) {\n if (!(this instanceof Promise))\n throw new TypeError('Promises must be constructed via new');\n if (typeof fn !== 'function') throw new TypeError('not a function');\n /** @type {!number} */\n this._state = 0;\n /** @type {!boolean} */\n this._handled = false;\n /** @type {Promise|undefined} */\n this._value = undefined;\n /** @type {!Array} */\n this._deferreds = [];\n\n doResolve(fn, this);\n}\n\nfunction handle(self, deferred) {\n while (self._state === 3) {\n self = self._value;\n }\n if (self._state === 0) {\n self._deferreds.push(deferred);\n return;\n }\n self._handled = true;\n Promise._immediateFn(function() {\n var cb = self._state === 1 ? deferred.onFulfilled : deferred.onRejected;\n if (cb === null) {\n (self._state === 1 ? resolve : reject)(deferred.promise, self._value);\n return;\n }\n var ret;\n try {\n ret = cb(self._value);\n } catch (e) {\n reject(deferred.promise, e);\n return;\n }\n resolve(deferred.promise, ret);\n });\n}\n\nfunction resolve(self, newValue) {\n try {\n // Promise Resolution Procedure: https://github.com/promises-aplus/promises-spec#the-promise-resolution-procedure\n if (newValue === self)\n throw new TypeError('A promise cannot be resolved with itself.');\n if (\n newValue &&\n (typeof newValue === 'object' || typeof newValue === 'function')\n ) {\n var then = newValue.then;\n if (newValue instanceof Promise) {\n self._state = 3;\n self._value = newValue;\n finale(self);\n return;\n } else if (typeof then === 'function') {\n doResolve(bind(then, newValue), self);\n return;\n }\n }\n self._state = 1;\n self._value = newValue;\n finale(self);\n } catch (e) {\n reject(self, e);\n }\n}\n\nfunction reject(self, newValue) {\n self._state = 2;\n self._value = newValue;\n finale(self);\n}\n\nfunction finale(self) {\n if (self._state === 2 && self._deferreds.length === 0) {\n Promise._immediateFn(function() {\n if (!self._handled) {\n Promise._unhandledRejectionFn(self._value);\n }\n });\n }\n\n for (var i = 0, len = self._deferreds.length; i < len; i++) {\n handle(self, self._deferreds[i]);\n }\n self._deferreds = null;\n}\n\n/**\n * @constructor\n */\nfunction Handler(onFulfilled, onRejected, promise) {\n this.onFulfilled = typeof onFulfilled === 'function' ? onFulfilled : null;\n this.onRejected = typeof onRejected === 'function' ? onRejected : null;\n this.promise = promise;\n}\n\n/**\n * Take a potentially misbehaving resolver function and make sure\n * onFulfilled and onRejected are only called once.\n *\n * Makes no guarantees about asynchrony.\n */\nfunction doResolve(fn, self) {\n var done = false;\n try {\n fn(\n function(value) {\n if (done) return;\n done = true;\n resolve(self, value);\n },\n function(reason) {\n if (done) return;\n done = true;\n reject(self, reason);\n }\n );\n } catch (ex) {\n if (done) return;\n done = true;\n reject(self, ex);\n }\n}\n\nPromise.prototype['catch'] = function(onRejected) {\n return this.then(null, onRejected);\n};\n\nPromise.prototype.then = function(onFulfilled, onRejected) {\n // @ts-ignore\n var prom = new this.constructor(noop);\n\n handle(this, new Handler(onFulfilled, onRejected, prom));\n return prom;\n};\n\nPromise.prototype['finally'] = promiseFinally;\n\nPromise.all = function(arr) {\n return new Promise(function(resolve, reject) {\n if (!isArray(arr)) {\n return reject(new TypeError('Promise.all accepts an array'));\n }\n\n var args = Array.prototype.slice.call(arr);\n if (args.length === 0) return resolve([]);\n var remaining = args.length;\n\n function res(i, val) {\n try {\n if (val && (typeof val === 'object' || typeof val === 'function')) {\n var then = val.then;\n if (typeof then === 'function') {\n then.call(\n val,\n function(val) {\n res(i, val);\n },\n reject\n );\n return;\n }\n }\n args[i] = val;\n if (--remaining === 0) {\n resolve(args);\n }\n } catch (ex) {\n reject(ex);\n }\n }\n\n for (var i = 0; i < args.length; i++) {\n res(i, args[i]);\n }\n });\n};\n\nPromise.resolve = function(value) {\n if (value && typeof value === 'object' && value.constructor === Promise) {\n return value;\n }\n\n return new Promise(function(resolve) {\n resolve(value);\n });\n};\n\nPromise.reject = function(value) {\n return new Promise(function(resolve, reject) {\n reject(value);\n });\n};\n\nPromise.race = function(arr) {\n return new Promise(function(resolve, reject) {\n if (!isArray(arr)) {\n return reject(new TypeError('Promise.race accepts an array'));\n }\n\n for (var i = 0, len = arr.length; i < len; i++) {\n Promise.resolve(arr[i]).then(resolve, reject);\n }\n });\n};\n\n// Use polyfill for setImmediate for performance gains\nPromise._immediateFn =\n // @ts-ignore\n (typeof setImmediate === 'function' &&\n function(fn) {\n // @ts-ignore\n setImmediate(fn);\n }) ||\n function(fn) {\n setTimeoutFunc(fn, 0);\n };\n\nPromise._unhandledRejectionFn = function _unhandledRejectionFn(err) {\n if (typeof console !== 'undefined' && console) {\n console.warn('Possible Unhandled Promise Rejection:', err); // eslint-disable-line no-console\n }\n};\n\nexport default Promise;\n","import Backbone from 'backbone';\n\nexport default Backbone.Model.extend({\n defaults: {\n id: '',\n label: '',\n tagName: 'span',\n className: '',\n command: '',\n context: '',\n buttons: [],\n attributes: {},\n options: {},\n active: false,\n dragDrop: false,\n togglable: true,\n runDefaultCommand: true,\n stopDefaultCommand: false,\n disable: false\n },\n\n initialize(options) {\n if (this.get('buttons').length) {\n var Buttons = require('./Buttons').default;\n this.set('buttons', new Buttons(this.get('buttons')));\n }\n }\n});\n","import Backbone from 'backbone';\nimport Button from './Button';\n\nexport default Backbone.Collection.extend({\n model: Button,\n\n /**\n * Deactivate all buttons, except one passed\n * @param {Object} except Model to ignore\n * @param {Boolean} r Recursive flag\n *\n * @return void\n * */\n deactivateAllExceptOne(except, r) {\n this.forEach((model, index) => {\n if (model !== except) {\n model.set('active', false);\n if (r && model.get('buttons').length)\n model.get('buttons').deactivateAllExceptOne(except, r);\n }\n });\n },\n\n /**\n * Deactivate all buttons\n * @param {String} ctx Context string\n *\n * @return void\n * */\n deactivateAll(ctx, sender) {\n const context = ctx || '';\n this.forEach(model => {\n if (model.get('context') == context && model !== sender) {\n model.set('active', false, { silent: 1 });\n model.trigger('updateActive', { fromCollection: 1 });\n }\n });\n },\n\n /**\n * Disables all buttons\n * @param {String} ctx Context string\n *\n * @return void\n * */\n disableAllButtons(ctx) {\n var context = ctx || '';\n this.forEach((model, index) => {\n if (model.get('context') == context) {\n model.set('disable', true);\n }\n });\n },\n\n /**\n * Disables all buttons, except one passed\n * @param {Object} except Model to ignore\n * @param {Boolean} r Recursive flag\n *\n * @return void\n * */\n disableAllButtonsExceptOne(except, r) {\n this.forEach((model, index) => {\n if (model !== except) {\n model.set('disable', true);\n if (r && model.get('buttons').length)\n model.get('buttons').disableAllButtonsExceptOne(except, r);\n }\n });\n }\n});\n","// CodeMirror, copyright (c) by Marijn Haverbeke and others\n// Distributed under an MIT license: https://codemirror.net/LICENSE\n\n(function(mod) {\n if (typeof exports == \"object\" && typeof module == \"object\") // CommonJS\n mod(require(\"../../lib/codemirror\"));\n else if (typeof define == \"function\" && define.amd) // AMD\n define([\"../../lib/codemirror\"], mod);\n else // Plain browser env\n mod(CodeMirror);\n})(function(CodeMirror) {\n\"use strict\";\n\nCodeMirror.defineMode(\"css\", function(config, parserConfig) {\n var inline = parserConfig.inline\n if (!parserConfig.propertyKeywords) parserConfig = CodeMirror.resolveMode(\"text/css\");\n\n var indentUnit = config.indentUnit,\n tokenHooks = parserConfig.tokenHooks,\n documentTypes = parserConfig.documentTypes || {},\n mediaTypes = parserConfig.mediaTypes || {},\n mediaFeatures = parserConfig.mediaFeatures || {},\n mediaValueKeywords = parserConfig.mediaValueKeywords || {},\n propertyKeywords = parserConfig.propertyKeywords || {},\n nonStandardPropertyKeywords = parserConfig.nonStandardPropertyKeywords || {},\n fontProperties = parserConfig.fontProperties || {},\n counterDescriptors = parserConfig.counterDescriptors || {},\n colorKeywords = parserConfig.colorKeywords || {},\n valueKeywords = parserConfig.valueKeywords || {},\n allowNested = parserConfig.allowNested,\n lineComment = parserConfig.lineComment,\n supportsAtComponent = parserConfig.supportsAtComponent === true;\n\n var type, override;\n function ret(style, tp) { type = tp; return style; }\n\n // Tokenizers\n\n function tokenBase(stream, state) {\n var ch = stream.next();\n if (tokenHooks[ch]) {\n var result = tokenHooks[ch](stream, state);\n if (result !== false) return result;\n }\n if (ch == \"@\") {\n stream.eatWhile(/[\\w\\\\\\-]/);\n return ret(\"def\", stream.current());\n } else if (ch == \"=\" || (ch == \"~\" || ch == \"|\") && stream.eat(\"=\")) {\n return ret(null, \"compare\");\n } else if (ch == \"\\\"\" || ch == \"'\") {\n state.tokenize = tokenString(ch);\n return state.tokenize(stream, state);\n } else if (ch == \"#\") {\n stream.eatWhile(/[\\w\\\\\\-]/);\n return ret(\"atom\", \"hash\");\n } else if (ch == \"!\") {\n stream.match(/^\\s*\\w*/);\n return ret(\"keyword\", \"important\");\n } else if (/\\d/.test(ch) || ch == \".\" && stream.eat(/\\d/)) {\n stream.eatWhile(/[\\w.%]/);\n return ret(\"number\", \"unit\");\n } else if (ch === \"-\") {\n if (/[\\d.]/.test(stream.peek())) {\n stream.eatWhile(/[\\w.%]/);\n return ret(\"number\", \"unit\");\n } else if (stream.match(/^-[\\w\\\\\\-]*/)) {\n stream.eatWhile(/[\\w\\\\\\-]/);\n if (stream.match(/^\\s*:/, false))\n return ret(\"variable-2\", \"variable-definition\");\n return ret(\"variable-2\", \"variable\");\n } else if (stream.match(/^\\w+-/)) {\n return ret(\"meta\", \"meta\");\n }\n } else if (/[,+>*\\/]/.test(ch)) {\n return ret(null, \"select-op\");\n } else if (ch == \".\" && stream.match(/^-?[_a-z][_a-z0-9-]*/i)) {\n return ret(\"qualifier\", \"qualifier\");\n } else if (/[:;{}\\[\\]\\(\\)]/.test(ch)) {\n return ret(null, ch);\n } else if (stream.match(/[\\w-.]+(?=\\()/)) {\n if (/^(url(-prefix)?|domain|regexp)$/.test(stream.current().toLowerCase())) {\n state.tokenize = tokenParenthesized;\n }\n return ret(\"variable callee\", \"variable\");\n } else if (/[\\w\\\\\\-]/.test(ch)) {\n stream.eatWhile(/[\\w\\\\\\-]/);\n return ret(\"property\", \"word\");\n } else {\n return ret(null, null);\n }\n }\n\n function tokenString(quote) {\n return function(stream, state) {\n var escaped = false, ch;\n while ((ch = stream.next()) != null) {\n if (ch == quote && !escaped) {\n if (quote == \")\") stream.backUp(1);\n break;\n }\n escaped = !escaped && ch == \"\\\\\";\n }\n if (ch == quote || !escaped && quote != \")\") state.tokenize = null;\n return ret(\"string\", \"string\");\n };\n }\n\n function tokenParenthesized(stream, state) {\n stream.next(); // Must be '('\n if (!stream.match(/\\s*[\\\"\\')]/, false))\n state.tokenize = tokenString(\")\");\n else\n state.tokenize = null;\n return ret(null, \"(\");\n }\n\n // Context management\n\n function Context(type, indent, prev) {\n this.type = type;\n this.indent = indent;\n this.prev = prev;\n }\n\n function pushContext(state, stream, type, indent) {\n state.context = new Context(type, stream.indentation() + (indent === false ? 0 : indentUnit), state.context);\n return type;\n }\n\n function popContext(state) {\n if (state.context.prev)\n state.context = state.context.prev;\n return state.context.type;\n }\n\n function pass(type, stream, state) {\n return states[state.context.type](type, stream, state);\n }\n function popAndPass(type, stream, state, n) {\n for (var i = n || 1; i > 0; i--)\n state.context = state.context.prev;\n return pass(type, stream, state);\n }\n\n // Parser\n\n function wordAsValue(stream) {\n var word = stream.current().toLowerCase();\n if (valueKeywords.hasOwnProperty(word))\n override = \"atom\";\n else if (colorKeywords.hasOwnProperty(word))\n override = \"keyword\";\n else\n override = \"variable\";\n }\n\n var states = {};\n\n states.top = function(type, stream, state) {\n if (type == \"{\") {\n return pushContext(state, stream, \"block\");\n } else if (type == \"}\" && state.context.prev) {\n return popContext(state);\n } else if (supportsAtComponent && /@component/i.test(type)) {\n return pushContext(state, stream, \"atComponentBlock\");\n } else if (/^@(-moz-)?document$/i.test(type)) {\n return pushContext(state, stream, \"documentTypes\");\n } else if (/^@(media|supports|(-moz-)?document|import)$/i.test(type)) {\n return pushContext(state, stream, \"atBlock\");\n } else if (/^@(font-face|counter-style)/i.test(type)) {\n state.stateArg = type;\n return \"restricted_atBlock_before\";\n } else if (/^@(-(moz|ms|o|webkit)-)?keyframes$/i.test(type)) {\n return \"keyframes\";\n } else if (type && type.charAt(0) == \"@\") {\n return pushContext(state, stream, \"at\");\n } else if (type == \"hash\") {\n override = \"builtin\";\n } else if (type == \"word\") {\n override = \"tag\";\n } else if (type == \"variable-definition\") {\n return \"maybeprop\";\n } else if (type == \"interpolation\") {\n return pushContext(state, stream, \"interpolation\");\n } else if (type == \":\") {\n return \"pseudo\";\n } else if (allowNested && type == \"(\") {\n return pushContext(state, stream, \"parens\");\n }\n return state.context.type;\n };\n\n states.block = function(type, stream, state) {\n if (type == \"word\") {\n var word = stream.current().toLowerCase();\n if (propertyKeywords.hasOwnProperty(word)) {\n override = \"property\";\n return \"maybeprop\";\n } else if (nonStandardPropertyKeywords.hasOwnProperty(word)) {\n override = \"string-2\";\n return \"maybeprop\";\n } else if (allowNested) {\n override = stream.match(/^\\s*:(?:\\s|$)/, false) ? \"property\" : \"tag\";\n return \"block\";\n } else {\n override += \" error\";\n return \"maybeprop\";\n }\n } else if (type == \"meta\") {\n return \"block\";\n } else if (!allowNested && (type == \"hash\" || type == \"qualifier\")) {\n override = \"error\";\n return \"block\";\n } else {\n return states.top(type, stream, state);\n }\n };\n\n states.maybeprop = function(type, stream, state) {\n if (type == \":\") return pushContext(state, stream, \"prop\");\n return pass(type, stream, state);\n };\n\n states.prop = function(type, stream, state) {\n if (type == \";\") return popContext(state);\n if (type == \"{\" && allowNested) return pushContext(state, stream, \"propBlock\");\n if (type == \"}\" || type == \"{\") return popAndPass(type, stream, state);\n if (type == \"(\") return pushContext(state, stream, \"parens\");\n\n if (type == \"hash\" && !/^#([0-9a-fA-f]{3,4}|[0-9a-fA-f]{6}|[0-9a-fA-f]{8})$/.test(stream.current())) {\n override += \" error\";\n } else if (type == \"word\") {\n wordAsValue(stream);\n } else if (type == \"interpolation\") {\n return pushContext(state, stream, \"interpolation\");\n }\n return \"prop\";\n };\n\n states.propBlock = function(type, _stream, state) {\n if (type == \"}\") return popContext(state);\n if (type == \"word\") { override = \"property\"; return \"maybeprop\"; }\n return state.context.type;\n };\n\n states.parens = function(type, stream, state) {\n if (type == \"{\" || type == \"}\") return popAndPass(type, stream, state);\n if (type == \")\") return popContext(state);\n if (type == \"(\") return pushContext(state, stream, \"parens\");\n if (type == \"interpolation\") return pushContext(state, stream, \"interpolation\");\n if (type == \"word\") wordAsValue(stream);\n return \"parens\";\n };\n\n states.pseudo = function(type, stream, state) {\n if (type == \"meta\") return \"pseudo\";\n\n if (type == \"word\") {\n override = \"variable-3\";\n return state.context.type;\n }\n return pass(type, stream, state);\n };\n\n states.documentTypes = function(type, stream, state) {\n if (type == \"word\" && documentTypes.hasOwnProperty(stream.current())) {\n override = \"tag\";\n return state.context.type;\n } else {\n return states.atBlock(type, stream, state);\n }\n };\n\n states.atBlock = function(type, stream, state) {\n if (type == \"(\") return pushContext(state, stream, \"atBlock_parens\");\n if (type == \"}\" || type == \";\") return popAndPass(type, stream, state);\n if (type == \"{\") return popContext(state) && pushContext(state, stream, allowNested ? \"block\" : \"top\");\n\n if (type == \"interpolation\") return pushContext(state, stream, \"interpolation\");\n\n if (type == \"word\") {\n var word = stream.current().toLowerCase();\n if (word == \"only\" || word == \"not\" || word == \"and\" || word == \"or\")\n override = \"keyword\";\n else if (mediaTypes.hasOwnProperty(word))\n override = \"attribute\";\n else if (mediaFeatures.hasOwnProperty(word))\n override = \"property\";\n else if (mediaValueKeywords.hasOwnProperty(word))\n override = \"keyword\";\n else if (propertyKeywords.hasOwnProperty(word))\n override = \"property\";\n else if (nonStandardPropertyKeywords.hasOwnProperty(word))\n override = \"string-2\";\n else if (valueKeywords.hasOwnProperty(word))\n override = \"atom\";\n else if (colorKeywords.hasOwnProperty(word))\n override = \"keyword\";\n else\n override = \"error\";\n }\n return state.context.type;\n };\n\n states.atComponentBlock = function(type, stream, state) {\n if (type == \"}\")\n return popAndPass(type, stream, state);\n if (type == \"{\")\n return popContext(state) && pushContext(state, stream, allowNested ? \"block\" : \"top\", false);\n if (type == \"word\")\n override = \"error\";\n return state.context.type;\n };\n\n states.atBlock_parens = function(type, stream, state) {\n if (type == \")\") return popContext(state);\n if (type == \"{\" || type == \"}\") return popAndPass(type, stream, state, 2);\n return states.atBlock(type, stream, state);\n };\n\n states.restricted_atBlock_before = function(type, stream, state) {\n if (type == \"{\")\n return pushContext(state, stream, \"restricted_atBlock\");\n if (type == \"word\" && state.stateArg == \"@counter-style\") {\n override = \"variable\";\n return \"restricted_atBlock_before\";\n }\n return pass(type, stream, state);\n };\n\n states.restricted_atBlock = function(type, stream, state) {\n if (type == \"}\") {\n state.stateArg = null;\n return popContext(state);\n }\n if (type == \"word\") {\n if ((state.stateArg == \"@font-face\" && !fontProperties.hasOwnProperty(stream.current().toLowerCase())) ||\n (state.stateArg == \"@counter-style\" && !counterDescriptors.hasOwnProperty(stream.current().toLowerCase())))\n override = \"error\";\n else\n override = \"property\";\n return \"maybeprop\";\n }\n return \"restricted_atBlock\";\n };\n\n states.keyframes = function(type, stream, state) {\n if (type == \"word\") { override = \"variable\"; return \"keyframes\"; }\n if (type == \"{\") return pushContext(state, stream, \"top\");\n return pass(type, stream, state);\n };\n\n states.at = function(type, stream, state) {\n if (type == \";\") return popContext(state);\n if (type == \"{\" || type == \"}\") return popAndPass(type, stream, state);\n if (type == \"word\") override = \"tag\";\n else if (type == \"hash\") override = \"builtin\";\n return \"at\";\n };\n\n states.interpolation = function(type, stream, state) {\n if (type == \"}\") return popContext(state);\n if (type == \"{\" || type == \";\") return popAndPass(type, stream, state);\n if (type == \"word\") override = \"variable\";\n else if (type != \"variable\" && type != \"(\" && type != \")\") override = \"error\";\n return \"interpolation\";\n };\n\n return {\n startState: function(base) {\n return {tokenize: null,\n state: inline ? \"block\" : \"top\",\n stateArg: null,\n context: new Context(inline ? \"block\" : \"top\", base || 0, null)};\n },\n\n token: function(stream, state) {\n if (!state.tokenize && stream.eatSpace()) return null;\n var style = (state.tokenize || tokenBase)(stream, state);\n if (style && typeof style == \"object\") {\n type = style[1];\n style = style[0];\n }\n override = style;\n if (type != \"comment\")\n state.state = states[state.state](type, stream, state);\n return override;\n },\n\n indent: function(state, textAfter) {\n var cx = state.context, ch = textAfter && textAfter.charAt(0);\n var indent = cx.indent;\n if (cx.type == \"prop\" && (ch == \"}\" || ch == \")\")) cx = cx.prev;\n if (cx.prev) {\n if (ch == \"}\" && (cx.type == \"block\" || cx.type == \"top\" ||\n cx.type == \"interpolation\" || cx.type == \"restricted_atBlock\")) {\n // Resume indentation from parent context.\n cx = cx.prev;\n indent = cx.indent;\n } else if (ch == \")\" && (cx.type == \"parens\" || cx.type == \"atBlock_parens\") ||\n ch == \"{\" && (cx.type == \"at\" || cx.type == \"atBlock\")) {\n // Dedent relative to current context.\n indent = Math.max(0, cx.indent - indentUnit);\n }\n }\n return indent;\n },\n\n electricChars: \"}\",\n blockCommentStart: \"/*\",\n blockCommentEnd: \"*/\",\n blockCommentContinue: \" * \",\n lineComment: lineComment,\n fold: \"brace\"\n };\n});\n\n function keySet(array) {\n var keys = {};\n for (var i = 0; i < array.length; ++i) {\n keys[array[i].toLowerCase()] = true;\n }\n return keys;\n }\n\n var documentTypes_ = [\n \"domain\", \"regexp\", \"url\", \"url-prefix\"\n ], documentTypes = keySet(documentTypes_);\n\n var mediaTypes_ = [\n \"all\", \"aural\", \"braille\", \"handheld\", \"print\", \"projection\", \"screen\",\n \"tty\", \"tv\", \"embossed\"\n ], mediaTypes = keySet(mediaTypes_);\n\n var mediaFeatures_ = [\n \"width\", \"min-width\", \"max-width\", \"height\", \"min-height\", \"max-height\",\n \"device-width\", \"min-device-width\", \"max-device-width\", \"device-height\",\n \"min-device-height\", \"max-device-height\", \"aspect-ratio\",\n \"min-aspect-ratio\", \"max-aspect-ratio\", \"device-aspect-ratio\",\n \"min-device-aspect-ratio\", \"max-device-aspect-ratio\", \"color\", \"min-color\",\n \"max-color\", \"color-index\", \"min-color-index\", \"max-color-index\",\n \"monochrome\", \"min-monochrome\", \"max-monochrome\", \"resolution\",\n \"min-resolution\", \"max-resolution\", \"scan\", \"grid\", \"orientation\",\n \"device-pixel-ratio\", \"min-device-pixel-ratio\", \"max-device-pixel-ratio\",\n \"pointer\", \"any-pointer\", \"hover\", \"any-hover\"\n ], mediaFeatures = keySet(mediaFeatures_);\n\n var mediaValueKeywords_ = [\n \"landscape\", \"portrait\", \"none\", \"coarse\", \"fine\", \"on-demand\", \"hover\",\n \"interlace\", \"progressive\"\n ], mediaValueKeywords = keySet(mediaValueKeywords_);\n\n var propertyKeywords_ = [\n \"align-content\", \"align-items\", \"align-self\", \"alignment-adjust\",\n \"alignment-baseline\", \"anchor-point\", \"animation\", \"animation-delay\",\n \"animation-direction\", \"animation-duration\", \"animation-fill-mode\",\n \"animation-iteration-count\", \"animation-name\", \"animation-play-state\",\n \"animation-timing-function\", \"appearance\", \"azimuth\", \"backface-visibility\",\n \"background\", \"background-attachment\", \"background-blend-mode\", \"background-clip\",\n \"background-color\", \"background-image\", \"background-origin\", \"background-position\",\n \"background-repeat\", \"background-size\", \"baseline-shift\", \"binding\",\n \"bleed\", \"bookmark-label\", \"bookmark-level\", \"bookmark-state\",\n \"bookmark-target\", \"border\", \"border-bottom\", \"border-bottom-color\",\n \"border-bottom-left-radius\", \"border-bottom-right-radius\",\n \"border-bottom-style\", \"border-bottom-width\", \"border-collapse\",\n \"border-color\", \"border-image\", \"border-image-outset\",\n \"border-image-repeat\", \"border-image-slice\", \"border-image-source\",\n \"border-image-width\", \"border-left\", \"border-left-color\",\n \"border-left-style\", \"border-left-width\", \"border-radius\", \"border-right\",\n \"border-right-color\", \"border-right-style\", \"border-right-width\",\n \"border-spacing\", \"border-style\", \"border-top\", \"border-top-color\",\n \"border-top-left-radius\", \"border-top-right-radius\", \"border-top-style\",\n \"border-top-width\", \"border-width\", \"bottom\", \"box-decoration-break\",\n \"box-shadow\", \"box-sizing\", \"break-after\", \"break-before\", \"break-inside\",\n \"caption-side\", \"caret-color\", \"clear\", \"clip\", \"color\", \"color-profile\", \"column-count\",\n \"column-fill\", \"column-gap\", \"column-rule\", \"column-rule-color\",\n \"column-rule-style\", \"column-rule-width\", \"column-span\", \"column-width\",\n \"columns\", \"content\", \"counter-increment\", \"counter-reset\", \"crop\", \"cue\",\n \"cue-after\", \"cue-before\", \"cursor\", \"direction\", \"display\",\n \"dominant-baseline\", \"drop-initial-after-adjust\",\n \"drop-initial-after-align\", \"drop-initial-before-adjust\",\n \"drop-initial-before-align\", \"drop-initial-size\", \"drop-initial-value\",\n \"elevation\", \"empty-cells\", \"fit\", \"fit-position\", \"flex\", \"flex-basis\",\n \"flex-direction\", \"flex-flow\", \"flex-grow\", \"flex-shrink\", \"flex-wrap\",\n \"float\", \"float-offset\", \"flow-from\", \"flow-into\", \"font\", \"font-feature-settings\",\n \"font-family\", \"font-kerning\", \"font-language-override\", \"font-size\", \"font-size-adjust\",\n \"font-stretch\", \"font-style\", \"font-synthesis\", \"font-variant\",\n \"font-variant-alternates\", \"font-variant-caps\", \"font-variant-east-asian\",\n \"font-variant-ligatures\", \"font-variant-numeric\", \"font-variant-position\",\n \"font-weight\", \"grid\", \"grid-area\", \"grid-auto-columns\", \"grid-auto-flow\",\n \"grid-auto-rows\", \"grid-column\", \"grid-column-end\", \"grid-column-gap\",\n \"grid-column-start\", \"grid-gap\", \"grid-row\", \"grid-row-end\", \"grid-row-gap\",\n \"grid-row-start\", \"grid-template\", \"grid-template-areas\", \"grid-template-columns\",\n \"grid-template-rows\", \"hanging-punctuation\", \"height\", \"hyphens\",\n \"icon\", \"image-orientation\", \"image-rendering\", \"image-resolution\",\n \"inline-box-align\", \"justify-content\", \"justify-items\", \"justify-self\", \"left\", \"letter-spacing\",\n \"line-break\", \"line-height\", \"line-stacking\", \"line-stacking-ruby\",\n \"line-stacking-shift\", \"line-stacking-strategy\", \"list-style\",\n \"list-style-image\", \"list-style-position\", \"list-style-type\", \"margin\",\n \"margin-bottom\", \"margin-left\", \"margin-right\", \"margin-top\",\n \"marks\", \"marquee-direction\", \"marquee-loop\",\n \"marquee-play-count\", \"marquee-speed\", \"marquee-style\", \"max-height\",\n \"max-width\", \"min-height\", \"min-width\", \"mix-blend-mode\", \"move-to\", \"nav-down\", \"nav-index\",\n \"nav-left\", \"nav-right\", \"nav-up\", \"object-fit\", \"object-position\",\n \"opacity\", \"order\", \"orphans\", \"outline\",\n \"outline-color\", \"outline-offset\", \"outline-style\", \"outline-width\",\n \"overflow\", \"overflow-style\", \"overflow-wrap\", \"overflow-x\", \"overflow-y\",\n \"padding\", \"padding-bottom\", \"padding-left\", \"padding-right\", \"padding-top\",\n \"page\", \"page-break-after\", \"page-break-before\", \"page-break-inside\",\n \"page-policy\", \"pause\", \"pause-after\", \"pause-before\", \"perspective\",\n \"perspective-origin\", \"pitch\", \"pitch-range\", \"place-content\", \"place-items\", \"place-self\", \"play-during\", \"position\",\n \"presentation-level\", \"punctuation-trim\", \"quotes\", \"region-break-after\",\n \"region-break-before\", \"region-break-inside\", \"region-fragment\",\n \"rendering-intent\", \"resize\", \"rest\", \"rest-after\", \"rest-before\", \"richness\",\n \"right\", \"rotation\", \"rotation-point\", \"ruby-align\", \"ruby-overhang\",\n \"ruby-position\", \"ruby-span\", \"shape-image-threshold\", \"shape-inside\", \"shape-margin\",\n \"shape-outside\", \"size\", \"speak\", \"speak-as\", \"speak-header\",\n \"speak-numeral\", \"speak-punctuation\", \"speech-rate\", \"stress\", \"string-set\",\n \"tab-size\", \"table-layout\", \"target\", \"target-name\", \"target-new\",\n \"target-position\", \"text-align\", \"text-align-last\", \"text-decoration\",\n \"text-decoration-color\", \"text-decoration-line\", \"text-decoration-skip\",\n \"text-decoration-style\", \"text-emphasis\", \"text-emphasis-color\",\n \"text-emphasis-position\", \"text-emphasis-style\", \"text-height\",\n \"text-indent\", \"text-justify\", \"text-outline\", \"text-overflow\", \"text-shadow\",\n \"text-size-adjust\", \"text-space-collapse\", \"text-transform\", \"text-underline-position\",\n \"text-wrap\", \"top\", \"transform\", \"transform-origin\", \"transform-style\",\n \"transition\", \"transition-delay\", \"transition-duration\",\n \"transition-property\", \"transition-timing-function\", \"unicode-bidi\",\n \"user-select\", \"vertical-align\", \"visibility\", \"voice-balance\", \"voice-duration\",\n \"voice-family\", \"voice-pitch\", \"voice-range\", \"voice-rate\", \"voice-stress\",\n \"voice-volume\", \"volume\", \"white-space\", \"widows\", \"width\", \"will-change\", \"word-break\",\n \"word-spacing\", \"word-wrap\", \"z-index\",\n // SVG-specific\n \"clip-path\", \"clip-rule\", \"mask\", \"enable-background\", \"filter\", \"flood-color\",\n \"flood-opacity\", \"lighting-color\", \"stop-color\", \"stop-opacity\", \"pointer-events\",\n \"color-interpolation\", \"color-interpolation-filters\",\n \"color-rendering\", \"fill\", \"fill-opacity\", \"fill-rule\", \"image-rendering\",\n \"marker\", \"marker-end\", \"marker-mid\", \"marker-start\", \"shape-rendering\", \"stroke\",\n \"stroke-dasharray\", \"stroke-dashoffset\", \"stroke-linecap\", \"stroke-linejoin\",\n \"stroke-miterlimit\", \"stroke-opacity\", \"stroke-width\", \"text-rendering\",\n \"baseline-shift\", \"dominant-baseline\", \"glyph-orientation-horizontal\",\n \"glyph-orientation-vertical\", \"text-anchor\", \"writing-mode\"\n ], propertyKeywords = keySet(propertyKeywords_);\n\n var nonStandardPropertyKeywords_ = [\n \"scrollbar-arrow-color\", \"scrollbar-base-color\", \"scrollbar-dark-shadow-color\",\n \"scrollbar-face-color\", \"scrollbar-highlight-color\", \"scrollbar-shadow-color\",\n \"scrollbar-3d-light-color\", \"scrollbar-track-color\", \"shape-inside\",\n \"searchfield-cancel-button\", \"searchfield-decoration\", \"searchfield-results-button\",\n \"searchfield-results-decoration\", \"zoom\"\n ], nonStandardPropertyKeywords = keySet(nonStandardPropertyKeywords_);\n\n var fontProperties_ = [\n \"font-family\", \"src\", \"unicode-range\", \"font-variant\", \"font-feature-settings\",\n \"font-stretch\", \"font-weight\", \"font-style\"\n ], fontProperties = keySet(fontProperties_);\n\n var counterDescriptors_ = [\n \"additive-symbols\", \"fallback\", \"negative\", \"pad\", \"prefix\", \"range\",\n \"speak-as\", \"suffix\", \"symbols\", \"system\"\n ], counterDescriptors = keySet(counterDescriptors_);\n\n var colorKeywords_ = [\n \"aliceblue\", \"antiquewhite\", \"aqua\", \"aquamarine\", \"azure\", \"beige\",\n \"bisque\", \"black\", \"blanchedalmond\", \"blue\", \"blueviolet\", \"brown\",\n \"burlywood\", \"cadetblue\", \"chartreuse\", \"chocolate\", \"coral\", \"cornflowerblue\",\n \"cornsilk\", \"crimson\", \"cyan\", \"darkblue\", \"darkcyan\", \"darkgoldenrod\",\n \"darkgray\", \"darkgreen\", \"darkkhaki\", \"darkmagenta\", \"darkolivegreen\",\n \"darkorange\", \"darkorchid\", \"darkred\", \"darksalmon\", \"darkseagreen\",\n \"darkslateblue\", \"darkslategray\", \"darkturquoise\", \"darkviolet\",\n \"deeppink\", \"deepskyblue\", \"dimgray\", \"dodgerblue\", \"firebrick\",\n \"floralwhite\", \"forestgreen\", \"fuchsia\", \"gainsboro\", \"ghostwhite\",\n \"gold\", \"goldenrod\", \"gray\", \"grey\", \"green\", \"greenyellow\", \"honeydew\",\n \"hotpink\", \"indianred\", \"indigo\", \"ivory\", \"khaki\", \"lavender\",\n \"lavenderblush\", \"lawngreen\", \"lemonchiffon\", \"lightblue\", \"lightcoral\",\n \"lightcyan\", \"lightgoldenrodyellow\", \"lightgray\", \"lightgreen\", \"lightpink\",\n \"lightsalmon\", \"lightseagreen\", \"lightskyblue\", \"lightslategray\",\n \"lightsteelblue\", \"lightyellow\", \"lime\", \"limegreen\", \"linen\", \"magenta\",\n \"maroon\", \"mediumaquamarine\", \"mediumblue\", \"mediumorchid\", \"mediumpurple\",\n \"mediumseagreen\", \"mediumslateblue\", \"mediumspringgreen\", \"mediumturquoise\",\n \"mediumvioletred\", \"midnightblue\", \"mintcream\", \"mistyrose\", \"moccasin\",\n \"navajowhite\", \"navy\", \"oldlace\", \"olive\", \"olivedrab\", \"orange\", \"orangered\",\n \"orchid\", \"palegoldenrod\", \"palegreen\", \"paleturquoise\", \"palevioletred\",\n \"papayawhip\", \"peachpuff\", \"peru\", \"pink\", \"plum\", \"powderblue\",\n \"purple\", \"rebeccapurple\", \"red\", \"rosybrown\", \"royalblue\", \"saddlebrown\",\n \"salmon\", \"sandybrown\", \"seagreen\", \"seashell\", \"sienna\", \"silver\", \"skyblue\",\n \"slateblue\", \"slategray\", \"snow\", \"springgreen\", \"steelblue\", \"tan\",\n \"teal\", \"thistle\", \"tomato\", \"turquoise\", \"violet\", \"wheat\", \"white\",\n \"whitesmoke\", \"yellow\", \"yellowgreen\"\n ], colorKeywords = keySet(colorKeywords_);\n\n var valueKeywords_ = [\n \"above\", \"absolute\", \"activeborder\", \"additive\", \"activecaption\", \"afar\",\n \"after-white-space\", \"ahead\", \"alias\", \"all\", \"all-scroll\", \"alphabetic\", \"alternate\",\n \"always\", \"amharic\", \"amharic-abegede\", \"antialiased\", \"appworkspace\",\n \"arabic-indic\", \"armenian\", \"asterisks\", \"attr\", \"auto\", \"auto-flow\", \"avoid\", \"avoid-column\", \"avoid-page\",\n \"avoid-region\", \"background\", \"backwards\", \"baseline\", \"below\", \"bidi-override\", \"binary\",\n \"bengali\", \"blink\", \"block\", \"block-axis\", \"bold\", \"bolder\", \"border\", \"border-box\",\n \"both\", \"bottom\", \"break\", \"break-all\", \"break-word\", \"bullets\", \"button\", \"button-bevel\",\n \"buttonface\", \"buttonhighlight\", \"buttonshadow\", \"buttontext\", \"calc\", \"cambodian\",\n \"capitalize\", \"caps-lock-indicator\", \"caption\", \"captiontext\", \"caret\",\n \"cell\", \"center\", \"checkbox\", \"circle\", \"cjk-decimal\", \"cjk-earthly-branch\",\n \"cjk-heavenly-stem\", \"cjk-ideographic\", \"clear\", \"clip\", \"close-quote\",\n \"col-resize\", \"collapse\", \"color\", \"color-burn\", \"color-dodge\", \"column\", \"column-reverse\",\n \"compact\", \"condensed\", \"contain\", \"content\", \"contents\",\n \"content-box\", \"context-menu\", \"continuous\", \"copy\", \"counter\", \"counters\", \"cover\", \"crop\",\n \"cross\", \"crosshair\", \"currentcolor\", \"cursive\", \"cyclic\", \"darken\", \"dashed\", \"decimal\",\n \"decimal-leading-zero\", \"default\", \"default-button\", \"dense\", \"destination-atop\",\n \"destination-in\", \"destination-out\", \"destination-over\", \"devanagari\", \"difference\",\n \"disc\", \"discard\", \"disclosure-closed\", \"disclosure-open\", \"document\",\n \"dot-dash\", \"dot-dot-dash\",\n \"dotted\", \"double\", \"down\", \"e-resize\", \"ease\", \"ease-in\", \"ease-in-out\", \"ease-out\",\n \"element\", \"ellipse\", \"ellipsis\", \"embed\", \"end\", \"ethiopic\", \"ethiopic-abegede\",\n \"ethiopic-abegede-am-et\", \"ethiopic-abegede-gez\", \"ethiopic-abegede-ti-er\",\n \"ethiopic-abegede-ti-et\", \"ethiopic-halehame-aa-er\",\n \"ethiopic-halehame-aa-et\", \"ethiopic-halehame-am-et\",\n \"ethiopic-halehame-gez\", \"ethiopic-halehame-om-et\",\n \"ethiopic-halehame-sid-et\", \"ethiopic-halehame-so-et\",\n \"ethiopic-halehame-ti-er\", \"ethiopic-halehame-ti-et\", \"ethiopic-halehame-tig\",\n \"ethiopic-numeric\", \"ew-resize\", \"exclusion\", \"expanded\", \"extends\", \"extra-condensed\",\n \"extra-expanded\", \"fantasy\", \"fast\", \"fill\", \"fixed\", \"flat\", \"flex\", \"flex-end\", \"flex-start\", \"footnotes\",\n \"forwards\", \"from\", \"geometricPrecision\", \"georgian\", \"graytext\", \"grid\", \"groove\",\n \"gujarati\", \"gurmukhi\", \"hand\", \"hangul\", \"hangul-consonant\", \"hard-light\", \"hebrew\",\n \"help\", \"hidden\", \"hide\", \"higher\", \"highlight\", \"highlighttext\",\n \"hiragana\", \"hiragana-iroha\", \"horizontal\", \"hsl\", \"hsla\", \"hue\", \"icon\", \"ignore\",\n \"inactiveborder\", \"inactivecaption\", \"inactivecaptiontext\", \"infinite\",\n \"infobackground\", \"infotext\", \"inherit\", \"initial\", \"inline\", \"inline-axis\",\n \"inline-block\", \"inline-flex\", \"inline-grid\", \"inline-table\", \"inset\", \"inside\", \"intrinsic\", \"invert\",\n \"italic\", \"japanese-formal\", \"japanese-informal\", \"justify\", \"kannada\",\n \"katakana\", \"katakana-iroha\", \"keep-all\", \"khmer\",\n \"korean-hangul-formal\", \"korean-hanja-formal\", \"korean-hanja-informal\",\n \"landscape\", \"lao\", \"large\", \"larger\", \"left\", \"level\", \"lighter\", \"lighten\",\n \"line-through\", \"linear\", \"linear-gradient\", \"lines\", \"list-item\", \"listbox\", \"listitem\",\n \"local\", \"logical\", \"loud\", \"lower\", \"lower-alpha\", \"lower-armenian\",\n \"lower-greek\", \"lower-hexadecimal\", \"lower-latin\", \"lower-norwegian\",\n \"lower-roman\", \"lowercase\", \"ltr\", \"luminosity\", \"malayalam\", \"match\", \"matrix\", \"matrix3d\",\n \"media-controls-background\", \"media-current-time-display\",\n \"media-fullscreen-button\", \"media-mute-button\", \"media-play-button\",\n \"media-return-to-realtime-button\", \"media-rewind-button\",\n \"media-seek-back-button\", \"media-seek-forward-button\", \"media-slider\",\n \"media-sliderthumb\", \"media-time-remaining-display\", \"media-volume-slider\",\n \"media-volume-slider-container\", \"media-volume-sliderthumb\", \"medium\",\n \"menu\", \"menulist\", \"menulist-button\", \"menulist-text\",\n \"menulist-textfield\", \"menutext\", \"message-box\", \"middle\", \"min-intrinsic\",\n \"mix\", \"mongolian\", \"monospace\", \"move\", \"multiple\", \"multiply\", \"myanmar\", \"n-resize\",\n \"narrower\", \"ne-resize\", \"nesw-resize\", \"no-close-quote\", \"no-drop\",\n \"no-open-quote\", \"no-repeat\", \"none\", \"normal\", \"not-allowed\", \"nowrap\",\n \"ns-resize\", \"numbers\", \"numeric\", \"nw-resize\", \"nwse-resize\", \"oblique\", \"octal\", \"opacity\", \"open-quote\",\n \"optimizeLegibility\", \"optimizeSpeed\", \"oriya\", \"oromo\", \"outset\",\n \"outside\", \"outside-shape\", \"overlay\", \"overline\", \"padding\", \"padding-box\",\n \"painted\", \"page\", \"paused\", \"persian\", \"perspective\", \"plus-darker\", \"plus-lighter\",\n \"pointer\", \"polygon\", \"portrait\", \"pre\", \"pre-line\", \"pre-wrap\", \"preserve-3d\",\n \"progress\", \"push-button\", \"radial-gradient\", \"radio\", \"read-only\",\n \"read-write\", \"read-write-plaintext-only\", \"rectangle\", \"region\",\n \"relative\", \"repeat\", \"repeating-linear-gradient\",\n \"repeating-radial-gradient\", \"repeat-x\", \"repeat-y\", \"reset\", \"reverse\",\n \"rgb\", \"rgba\", \"ridge\", \"right\", \"rotate\", \"rotate3d\", \"rotateX\", \"rotateY\",\n \"rotateZ\", \"round\", \"row\", \"row-resize\", \"row-reverse\", \"rtl\", \"run-in\", \"running\",\n \"s-resize\", \"sans-serif\", \"saturation\", \"scale\", \"scale3d\", \"scaleX\", \"scaleY\", \"scaleZ\", \"screen\",\n \"scroll\", \"scrollbar\", \"scroll-position\", \"se-resize\", \"searchfield\",\n \"searchfield-cancel-button\", \"searchfield-decoration\",\n \"searchfield-results-button\", \"searchfield-results-decoration\", \"self-start\", \"self-end\",\n \"semi-condensed\", \"semi-expanded\", \"separate\", \"serif\", \"show\", \"sidama\",\n \"simp-chinese-formal\", \"simp-chinese-informal\", \"single\",\n \"skew\", \"skewX\", \"skewY\", \"skip-white-space\", \"slide\", \"slider-horizontal\",\n \"slider-vertical\", \"sliderthumb-horizontal\", \"sliderthumb-vertical\", \"slow\",\n \"small\", \"small-caps\", \"small-caption\", \"smaller\", \"soft-light\", \"solid\", \"somali\",\n \"source-atop\", \"source-in\", \"source-out\", \"source-over\", \"space\", \"space-around\", \"space-between\", \"space-evenly\", \"spell-out\", \"square\",\n \"square-button\", \"start\", \"static\", \"status-bar\", \"stretch\", \"stroke\", \"sub\",\n \"subpixel-antialiased\", \"super\", \"sw-resize\", \"symbolic\", \"symbols\", \"system-ui\", \"table\",\n \"table-caption\", \"table-cell\", \"table-column\", \"table-column-group\",\n \"table-footer-group\", \"table-header-group\", \"table-row\", \"table-row-group\",\n \"tamil\",\n \"telugu\", \"text\", \"text-bottom\", \"text-top\", \"textarea\", \"textfield\", \"thai\",\n \"thick\", \"thin\", \"threeddarkshadow\", \"threedface\", \"threedhighlight\",\n \"threedlightshadow\", \"threedshadow\", \"tibetan\", \"tigre\", \"tigrinya-er\",\n \"tigrinya-er-abegede\", \"tigrinya-et\", \"tigrinya-et-abegede\", \"to\", \"top\",\n \"trad-chinese-formal\", \"trad-chinese-informal\", \"transform\",\n \"translate\", \"translate3d\", \"translateX\", \"translateY\", \"translateZ\",\n \"transparent\", \"ultra-condensed\", \"ultra-expanded\", \"underline\", \"unset\", \"up\",\n \"upper-alpha\", \"upper-armenian\", \"upper-greek\", \"upper-hexadecimal\",\n \"upper-latin\", \"upper-norwegian\", \"upper-roman\", \"uppercase\", \"urdu\", \"url\",\n \"var\", \"vertical\", \"vertical-text\", \"visible\", \"visibleFill\", \"visiblePainted\",\n \"visibleStroke\", \"visual\", \"w-resize\", \"wait\", \"wave\", \"wider\",\n \"window\", \"windowframe\", \"windowtext\", \"words\", \"wrap\", \"wrap-reverse\", \"x-large\", \"x-small\", \"xor\",\n \"xx-large\", \"xx-small\"\n ], valueKeywords = keySet(valueKeywords_);\n\n var allWords = documentTypes_.concat(mediaTypes_).concat(mediaFeatures_).concat(mediaValueKeywords_)\n .concat(propertyKeywords_).concat(nonStandardPropertyKeywords_).concat(colorKeywords_)\n .concat(valueKeywords_);\n CodeMirror.registerHelper(\"hintWords\", \"css\", allWords);\n\n function tokenCComment(stream, state) {\n var maybeEnd = false, ch;\n while ((ch = stream.next()) != null) {\n if (maybeEnd && ch == \"/\") {\n state.tokenize = null;\n break;\n }\n maybeEnd = (ch == \"*\");\n }\n return [\"comment\", \"comment\"];\n }\n\n CodeMirror.defineMIME(\"text/css\", {\n documentTypes: documentTypes,\n mediaTypes: mediaTypes,\n mediaFeatures: mediaFeatures,\n mediaValueKeywords: mediaValueKeywords,\n propertyKeywords: propertyKeywords,\n nonStandardPropertyKeywords: nonStandardPropertyKeywords,\n fontProperties: fontProperties,\n counterDescriptors: counterDescriptors,\n colorKeywords: colorKeywords,\n valueKeywords: valueKeywords,\n tokenHooks: {\n \"/\": function(stream, state) {\n if (!stream.eat(\"*\")) return false;\n state.tokenize = tokenCComment;\n return tokenCComment(stream, state);\n }\n },\n name: \"css\"\n });\n\n CodeMirror.defineMIME(\"text/x-scss\", {\n mediaTypes: mediaTypes,\n mediaFeatures: mediaFeatures,\n mediaValueKeywords: mediaValueKeywords,\n propertyKeywords: propertyKeywords,\n nonStandardPropertyKeywords: nonStandardPropertyKeywords,\n colorKeywords: colorKeywords,\n valueKeywords: valueKeywords,\n fontProperties: fontProperties,\n allowNested: true,\n lineComment: \"//\",\n tokenHooks: {\n \"/\": function(stream, state) {\n if (stream.eat(\"/\")) {\n stream.skipToEnd();\n return [\"comment\", \"comment\"];\n } else if (stream.eat(\"*\")) {\n state.tokenize = tokenCComment;\n return tokenCComment(stream, state);\n } else {\n return [\"operator\", \"operator\"];\n }\n },\n \":\": function(stream) {\n if (stream.match(/\\s*\\{/, false))\n return [null, null]\n return false;\n },\n \"$\": function(stream) {\n stream.match(/^[\\w-]+/);\n if (stream.match(/^\\s*:/, false))\n return [\"variable-2\", \"variable-definition\"];\n return [\"variable-2\", \"variable\"];\n },\n \"#\": function(stream) {\n if (!stream.eat(\"{\")) return false;\n return [null, \"interpolation\"];\n }\n },\n name: \"css\",\n helperType: \"scss\"\n });\n\n CodeMirror.defineMIME(\"text/x-less\", {\n mediaTypes: mediaTypes,\n mediaFeatures: mediaFeatures,\n mediaValueKeywords: mediaValueKeywords,\n propertyKeywords: propertyKeywords,\n nonStandardPropertyKeywords: nonStandardPropertyKeywords,\n colorKeywords: colorKeywords,\n valueKeywords: valueKeywords,\n fontProperties: fontProperties,\n allowNested: true,\n lineComment: \"//\",\n tokenHooks: {\n \"/\": function(stream, state) {\n if (stream.eat(\"/\")) {\n stream.skipToEnd();\n return [\"comment\", \"comment\"];\n } else if (stream.eat(\"*\")) {\n state.tokenize = tokenCComment;\n return tokenCComment(stream, state);\n } else {\n return [\"operator\", \"operator\"];\n }\n },\n \"@\": function(stream) {\n if (stream.eat(\"{\")) return [null, \"interpolation\"];\n if (stream.match(/^(charset|document|font-face|import|(-(moz|ms|o|webkit)-)?keyframes|media|namespace|page|supports)\\b/i, false)) return false;\n stream.eatWhile(/[\\w\\\\\\-]/);\n if (stream.match(/^\\s*:/, false))\n return [\"variable-2\", \"variable-definition\"];\n return [\"variable-2\", \"variable\"];\n },\n \"&\": function() {\n return [\"atom\", \"atom\"];\n }\n },\n name: \"css\",\n helperType: \"less\"\n });\n\n CodeMirror.defineMIME(\"text/x-gss\", {\n documentTypes: documentTypes,\n mediaTypes: mediaTypes,\n mediaFeatures: mediaFeatures,\n propertyKeywords: propertyKeywords,\n nonStandardPropertyKeywords: nonStandardPropertyKeywords,\n fontProperties: fontProperties,\n counterDescriptors: counterDescriptors,\n colorKeywords: colorKeywords,\n valueKeywords: valueKeywords,\n supportsAtComponent: true,\n tokenHooks: {\n \"/\": function(stream, state) {\n if (!stream.eat(\"*\")) return false;\n state.tokenize = tokenCComment;\n return tokenCComment(stream, state);\n }\n },\n name: \"css\",\n helperType: \"gss\"\n });\n\n});\n","export default {\n run(ed) {\n ed.DomComponents.clear();\n ed.CssComposer.clear();\n }\n};\n","import { bindAll } from 'underscore';\nimport { on, off, getKeyChar } from 'utils/mixins';\nimport Dragger from 'utils/Dragger';\n\nexport default {\n run(ed) {\n bindAll(this, 'onKeyUp', 'enableDragger', 'disableDragger');\n this.editor = ed;\n this.canvasModel = this.canvas.getCanvasView().model;\n this.toggleMove(1);\n },\n stop(ed) {\n this.toggleMove();\n this.disableDragger();\n },\n\n onKeyUp(ev) {\n if (getKeyChar(ev) === ' ') {\n this.editor.stopCommand(this.id);\n }\n },\n\n enableDragger(ev) {\n this.toggleDragger(1, ev);\n },\n\n disableDragger(ev) {\n this.toggleDragger(0, ev);\n },\n\n toggleDragger(enable, ev) {\n const { canvasModel, em } = this;\n let { dragger } = this;\n const methodCls = enable ? 'add' : 'remove';\n this.getCanvas().classList[methodCls](`${this.ppfx}is__grabbing`);\n\n if (!dragger) {\n dragger = new Dragger({\n getPosition() {\n return {\n x: canvasModel.get('x'),\n y: canvasModel.get('y')\n };\n },\n setPosition({ x, y }) {\n canvasModel.set({ x, y });\n },\n onStart(ev, dragger) {\n em.trigger('canvas:move:start', dragger);\n },\n onDrag(ev, dragger) {\n em.trigger('canvas:move', dragger);\n },\n onEnd(ev, dragger) {\n em.trigger('canvas:move:end', dragger);\n }\n });\n this.dragger = dragger;\n }\n\n enable ? dragger.start(ev) : dragger.stop();\n },\n\n toggleMove(enable) {\n const { ppfx } = this;\n const methodCls = enable ? 'add' : 'remove';\n const methodEv = enable ? 'on' : 'off';\n const methodsEv = { on, off };\n const canvas = this.getCanvas();\n const classes = [`${ppfx}is__grab`];\n !enable && classes.push(`${ppfx}is__grabbing`);\n classes.forEach(cls => canvas.classList[methodCls](cls));\n methodsEv[methodEv](document, 'keyup', this.onKeyUp);\n methodsEv[methodEv](canvas, 'mousedown', this.enableDragger);\n methodsEv[methodEv](document, 'mouseup', this.disableDragger);\n }\n};\n","import { isArray } from 'underscore';\n\nexport default {\n run(ed, sender, opts = {}) {\n let components = opts.component || ed.getSelectedAll();\n components = isArray(components) ? [...components] : [components];\n\n // It's important to deselect components first otherwise,\n // with undo, the component will be set with the wrong `collection`\n ed.select(null);\n\n components.forEach(component => {\n if (!component || !component.get('removable')) {\n console.warn('The element is not removable', component);\n return;\n }\n if (component) {\n const coll = component.collection;\n component.trigger('component:destroy');\n coll && coll.remove(component);\n }\n });\n\n return components;\n }\n};\n","import { keys, bindAll, each, isUndefined } from 'underscore';\nimport Dragger from 'utils/Dragger';\n\nexport default {\n run(editor, sender, opts = {}) {\n bindAll(\n this,\n 'setPosition',\n 'onStart',\n 'onDrag',\n 'onEnd',\n 'getPosition',\n 'getGuidesStatic',\n 'renderGuide',\n 'getGuidesTarget'\n );\n const { target, event, mode, dragger = {} } = opts;\n const el = target.getEl();\n const config = {\n doc: el.ownerDocument,\n onStart: this.onStart,\n onEnd: this.onEnd,\n onDrag: this.onDrag,\n getPosition: this.getPosition,\n setPosition: this.setPosition,\n guidesStatic: () => this.guidesStatic,\n guidesTarget: () => this.guidesTarget,\n ...dragger\n };\n this.setupGuides();\n this.opts = opts;\n this.editor = editor;\n this.em = editor.getModel();\n this.target = target;\n this.isTran = mode == 'translate';\n this.guidesContainer = this.getGuidesContainer();\n this.guidesTarget = this.getGuidesTarget();\n this.guidesStatic = this.getGuidesStatic();\n window.guidesTarget = this.guidesTarget;\n let drg = this.dragger;\n\n if (!drg) {\n drg = new Dragger(config);\n this.dragger = drg;\n } else {\n drg.setOptions(config);\n }\n\n event && drg.start(event);\n this.toggleDrag(1);\n\n return drg;\n },\n\n stop() {\n this.toggleDrag();\n },\n\n setupGuides() {\n (this.guides || []).forEach(item => {\n const { guide } = item;\n guide && guide.parentNode.removeChild(guide);\n });\n this.guides = [];\n },\n\n getGuidesContainer() {\n let { guidesEl } = this;\n\n if (!guidesEl) {\n const { editor, em, opts } = this;\n const pfx = editor.getConfig('stylePrefix');\n const elInfoX = document.createElement('div');\n const elInfoY = document.createElement('div');\n const guideContent = `
\n
\n
`;\n guidesEl = document.createElement('div');\n guidesEl.className = `${pfx}guides`;\n elInfoX.className = `${pfx}guide-info ${pfx}guide-info__x`;\n elInfoY.className = `${pfx}guide-info ${pfx}guide-info__y`;\n elInfoX.innerHTML = guideContent;\n elInfoY.innerHTML = guideContent;\n guidesEl.appendChild(elInfoX);\n guidesEl.appendChild(elInfoY);\n editor.Canvas.getToolsEl().appendChild(guidesEl);\n this.guidesEl = guidesEl;\n this.elGuideInfoX = elInfoX;\n this.elGuideInfoY = elInfoY;\n this.elGuideInfoContentX = elInfoX.querySelector(\n `.${pfx}guide-info__content`\n );\n this.elGuideInfoContentY = elInfoY.querySelector(\n `.${pfx}guide-info__content`\n );\n em.on('canvas:update', () => {\n this.updateGuides();\n opts.debug && this.guides.forEach(item => this.renderGuide(item));\n });\n }\n\n return guidesEl;\n },\n\n getGuidesStatic() {\n let result = [];\n const el = this.target.getEl();\n const { parentNode = {} } = el;\n each(\n parentNode.children,\n item =>\n (result = result.concat(el !== item ? this.getElementGuides(item) : []))\n );\n\n return result.concat(this.getElementGuides(parentNode));\n },\n\n getGuidesTarget() {\n return this.getElementGuides(this.target.getEl());\n },\n\n updateGuides(guides) {\n (guides || this.guides).forEach(item => {\n const { origin } = item;\n const { top, height, left, width } = editor.Canvas.getElementPos(origin);\n\n switch (item.type) {\n case 't':\n return (item.y = top);\n case 'b':\n return (item.y = top + height);\n case 'l':\n return (item.x = left);\n case 'r':\n return (item.x = left + width);\n case 'x':\n return (item.x = left + width / 2);\n case 'y':\n return (item.y = top + height / 2);\n }\n });\n },\n\n getGuidePosUpdate(item, rect) {\n const result = {};\n const { top, height, left, width } = rect;\n\n switch (item.type) {\n case 't':\n result.y = top;\n break;\n case 'b':\n result.y = top + height;\n break;\n case 'l':\n result.x = left;\n break;\n case 'r':\n result.x = left + width;\n break;\n case 'x':\n result.x = left + width / 2;\n break;\n case 'y':\n result.y = top + height / 2;\n break;\n }\n\n return result;\n },\n\n renderGuide(item = {}) {\n const el = item.guide || document.createElement('div');\n const { Canvas } = this.editor;\n const { topScroll, top } = Canvas.getRect();\n const frameTop = Canvas.getCanvasView().getFrameOffset().top;\n const un = 'px';\n const guideSize = item.active ? 2 : 1;\n let numEl = el.children[0];\n el.style = `position: absolute; background-color: ${\n item.active ? 'green' : 'red'\n };`;\n\n if (!el.children.length) {\n numEl = document.createElement('div');\n numEl.style =\n 'position: absolute; color: red; padding: 5px; top: 0; left: 0;';\n el.appendChild(numEl);\n }\n\n if (item.y) {\n el.style.width = '100%';\n el.style.height = `${guideSize}${un}`;\n el.style.top = `${item.y}${un}`;\n el.style.left = 0;\n } else {\n el.style.width = `${guideSize}${un}`;\n el.style.height = '100%';\n el.style.left = `${item.x}${un}`;\n el.style.top = `${topScroll - frameTop + top}${un}`;\n }\n\n !item.guide && this.guidesContainer.appendChild(el);\n return el;\n },\n\n getElementGuides(el) {\n const { editor, opts } = this;\n const { top, height, left, width } = editor.Canvas.getElementPos(el);\n const guides = [\n { type: 't', y: top }, // Top\n { type: 'b', y: top + height }, // Bottom\n { type: 'l', x: left }, // Left\n { type: 'r', x: left + width }, // Right\n { type: 'x', x: left + width / 2 }, // Mid x\n { type: 'y', y: top + height / 2 } // Mid y\n ].map(item => ({\n ...item,\n origin: el,\n originRect: editor.Canvas.getElementPos(el),\n guide: opts.debug && this.renderGuide(item)\n }));\n guides.forEach(item => this.guides.push(item));\n\n return guides;\n },\n\n getTranslate(transform, axis = 'x') {\n let result = 0;\n (transform || '').split(' ').forEach(item => {\n const itemStr = item.trim();\n const fn = `translate${axis.toUpperCase()}(`;\n if (itemStr.indexOf(fn) === 0)\n result = parseFloat(itemStr.replace(fn, ''));\n });\n return result;\n },\n\n setTranslate(transform, axis, value) {\n const fn = `translate${axis.toUpperCase()}(`;\n const val = `${fn}${value})`;\n let result = (transform || '')\n .split(' ')\n .map(item => {\n const itemStr = item.trim();\n if (itemStr.indexOf(fn) === 0) item = val;\n return item;\n })\n .join(' ');\n if (result.indexOf(fn) < 0) result += ` ${val}`;\n\n return result;\n },\n\n getPosition() {\n const { target, isTran } = this;\n const { left, top, transform } = target.getStyle();\n let x = 0;\n let y = 0;\n\n if (isTran) {\n x = this.getTranslate(transform);\n y = this.getTranslate(transform, 'y');\n } else {\n x = parseFloat(left);\n y = parseFloat(top);\n }\n\n return { x, y };\n },\n\n setPosition({ x, y, end, position, width, height }) {\n const { target, isTran } = this;\n const unit = 'px';\n const en = !end ? 1 : ''; // this will trigger the final change\n const left = `${x}${unit}`;\n const top = `${y}${unit}`;\n\n if (isTran) {\n let transform = target.getStyle()['transform'] || '';\n transform = this.setTranslate(transform, 'x', left);\n transform = this.setTranslate(transform, 'y', top);\n return target.addStyle({ transform, en }, { avoidStore: !end });\n }\n\n const adds = { position, width, height };\n const style = { left, top, en };\n keys(adds).forEach(add => {\n const prop = adds[add];\n if (prop) style[add] = prop;\n });\n target.addStyle(style, { avoidStore: !end });\n },\n\n onStart() {\n const { target, editor, isTran, opts } = this;\n const { center } = opts;\n const { Canvas } = editor;\n const style = target.getStyle();\n const position = 'absolute';\n if (isTran) return;\n\n if (style.position !== position) {\n let { left, top, width, height } = Canvas.offset(target.getEl());\n\n // Check if to center the target to the pointer position\n if (center) {\n const { x, y } = Canvas.getMouseRelativeCanvas(event);\n left = x;\n top = y;\n }\n\n this.setPosition({\n x: left,\n y: top,\n width: `${width}px`,\n height: `${height}px`,\n position\n });\n }\n },\n\n onDrag(...args) {\n const { guidesTarget, opts } = this;\n const { onDrag } = opts;\n this.updateGuides(guidesTarget);\n opts.debug && guidesTarget.forEach(item => this.renderGuide(item));\n opts.guidesInfo &&\n this.renderGuideInfo(guidesTarget.filter(item => item.active));\n onDrag && onDrag(...args);\n },\n\n onEnd(...args) {\n const { editor, opts, id } = this;\n const { onEnd } = opts;\n onEnd && onEnd(...args);\n editor.stopCommand(id);\n this.hideGuidesInfo();\n },\n\n hideGuidesInfo() {\n ['X', 'Y'].forEach(item => {\n const guide = this[`elGuideInfo${item}`];\n if (guide) guide.style.display = 'none';\n });\n },\n\n /**\n * Render guides with spacing information\n */\n renderGuideInfo(guides = []) {\n const { guidesStatic, editor } = this;\n this.hideGuidesInfo();\n\n guides.forEach(item => {\n const { origin, x } = item;\n const rectOrigin = editor.Canvas.getElementPos(origin);\n const axis = isUndefined(x) ? 'y' : 'x';\n const isY = axis === 'y';\n const origEdge1 = rectOrigin[isY ? 'left' : 'top'];\n const origEdge1Raw = rectOrigin.rect[isY ? 'left' : 'top'];\n const origEdge2 = isY\n ? origEdge1 + rectOrigin.width\n : origEdge1 + rectOrigin.height;\n const origEdge2Raw = isY\n ? origEdge1Raw + rectOrigin.rect.width\n : origEdge1Raw + rectOrigin.rect.height;\n const elGuideInfo = this[`elGuideInfo${axis.toUpperCase()}`];\n const elGuideInfoCnt = this[`elGuideInfoContent${axis.toUpperCase()}`];\n const guideInfoStyle = elGuideInfo.style;\n\n // Find the nearest element\n const res = guidesStatic\n .filter(stat => stat[axis] === item[axis])\n .map(stat => {\n const { left, width, top, height } = stat.originRect;\n const statEdge1 = isY ? left : top;\n const statEdge2 = isY ? left + width : top + height;\n return {\n gap:\n statEdge2 < origEdge1\n ? origEdge1 - statEdge2\n : statEdge1 - origEdge2,\n guide: stat\n };\n })\n .filter(item => item.gap > 0)\n .sort((a, b) => a.gap - b.gap)\n .map(item => item.guide)[0];\n\n if (res) {\n const { left, width, top, height, rect } = res.originRect;\n const isEdge1 = isY ? left < rectOrigin.left : top < rectOrigin.top;\n const statEdge1 = isY ? left : top;\n const statEdge1Raw = isY ? rect.left : rect.top;\n const statEdge2 = isY ? left + width : top + height;\n const statEdge2Raw = isY\n ? rect.left + rect.width\n : rect.top + rect.height;\n const pos2 = `${isY ? item.y : item.x}px`;\n const size = isEdge1 ? origEdge1 - statEdge2 : statEdge1 - origEdge2;\n const sizeRaw = isEdge1\n ? origEdge1Raw - statEdge2Raw\n : statEdge1Raw - origEdge2Raw;\n guideInfoStyle.display = '';\n guideInfoStyle[isY ? 'top' : 'left'] = pos2;\n guideInfoStyle[isY ? 'left' : 'top'] = `${\n isEdge1 ? statEdge2 : origEdge2\n }px`;\n guideInfoStyle[isY ? 'width' : 'height'] = `${size}px`;\n elGuideInfoCnt.innerHTML = `${Math.round(sizeRaw)}px`;\n }\n });\n },\n\n toggleDrag(enable) {\n const { ppfx, editor } = this;\n const methodCls = enable ? 'add' : 'remove';\n const classes = [`${ppfx}is__grabbing`];\n const { Canvas } = editor;\n const body = Canvas.getBody();\n classes.forEach(cls => body.classList[methodCls](cls));\n Canvas[enable ? 'startAutoscroll' : 'stopAutoscroll']();\n }\n};\n","export default {\n run(ed) {\n if (!ed.Canvas.hasFocus()) return;\n const toSelect = [];\n\n ed.getSelectedAll().forEach(component => {\n const coll = component.components();\n const next = coll && coll.at(0);\n next && toSelect.push(next);\n });\n\n toSelect.length && ed.select(toSelect);\n }\n};\n","export default {\n run(ed, snd, opts = {}) {\n if (!ed.Canvas.hasFocus() && !opts.force) return;\n const toSelect = [];\n\n ed.getSelectedAll().forEach(component => {\n let next = component.parent();\n\n // Recurse through the parent() chain until a selectable parent is found\n while (next && !next.get('selectable')) {\n next = next.parent();\n }\n\n next && toSelect.push(next);\n });\n\n toSelect.length && ed.select(toSelect);\n }\n};\n","export default {\n run(ed) {\n if (!ed.Canvas.hasFocus()) return;\n const toSelect = [];\n\n ed.getSelectedAll().forEach(component => {\n const coll = component.collection;\n const at = coll.indexOf(component);\n const next = coll.at(at + 1);\n toSelect.push(next || component);\n });\n\n toSelect.length && ed.select(toSelect);\n }\n};\n","export default {\n run(ed) {\n if (!ed.Canvas.hasFocus()) return;\n const toSelect = [];\n\n ed.getSelectedAll().forEach(component => {\n const coll = component.collection;\n const at = coll.indexOf(component);\n const next = coll.at(at - 1);\n toSelect.push(next && at - 1 >= 0 ? next : component);\n });\n\n toSelect.length && ed.select(toSelect);\n }\n};\n","import { isArray } from 'underscore';\n\nexport default {\n run(ed, sender, opts = {}) {\n const { target } = opts;\n const dc = ed.DomComponents;\n const type = target.get('type');\n const len = dc.getWrapper().find(`[data-gjs-type=\"${type}\"]`).length;\n const toRemove = [];\n\n if (!len) {\n const rules = ed.CssComposer.getAll();\n let toClear = target.get('style-signature');\n toClear = isArray(toClear) ? toClear : [toClear];\n\n rules.forEach(rule => {\n const selector = rule.selectorsToString();\n toClear.forEach(part => {\n part && selector.indexOf(part) >= 0 && toRemove.push(rule);\n });\n });\n\n rules.remove(toRemove);\n }\n\n return toRemove;\n }\n};\n","export default {\n run(ed) {\n const em = ed.getModel();\n const models = [...ed.getSelectedAll()];\n\n if (models.length) {\n em.set('clipboard', models);\n }\n }\n};\n","import { extend, bindAll } from 'underscore';\nimport Backbone from 'backbone';\nimport SelectComponent from './SelectComponent';\n\nconst $ = Backbone.$;\n\nexport default extend({}, SelectComponent, {\n init(o) {\n bindAll(this, 'startDelete', 'stopDelete', 'onDelete');\n this.hoverClass = this.pfx + 'hover-delete';\n this.badgeClass = this.pfx + 'badge-red';\n },\n\n enable() {\n var that = this;\n this.$el\n .find('*')\n .mouseover(this.startDelete)\n .mouseout(this.stopDelete)\n .click(this.onDelete);\n },\n\n /**\n * Start command\n * @param {Object} e\n * @private\n */\n startDelete(e) {\n e.stopPropagation();\n var $this = $(e.target);\n\n // Show badge if possible\n if ($this.data('model').get('removable')) {\n $this.addClass(this.hoverClass);\n this.attachBadge($this.get(0));\n }\n },\n\n /**\n * Stop command\n * @param {Object} e\n * @private\n */\n stopDelete(e) {\n e.stopPropagation();\n var $this = $(e.target);\n $this.removeClass(this.hoverClass);\n\n // Hide badge if possible\n if (this.badge) this.badge.css({ left: -1000, top: -1000 });\n },\n\n /**\n * Delete command\n * @param {Object} e\n * @private\n */\n onDelete(e) {\n e.stopPropagation();\n var $this = $(e.target);\n\n // Do nothing in case can't remove\n if (!$this.data('model').get('removable')) return;\n\n $this.data('model').destroy();\n this.removeBadge();\n this.clean();\n },\n\n /**\n * Updates badge label\n * @param {Object} model\n * @private\n * */\n updateBadgeLabel(model) {\n this.badge.html('Remove ' + model.getName());\n }\n});\n","import Backbone from 'backbone';\nconst $ = Backbone.$;\n\nexport default {\n run(editor, sender, opts = {}) {\n sender && sender.set && sender.set('active', 0);\n const config = editor.getConfig();\n const modal = editor.Modal;\n const pfx = config.stylePrefix;\n this.cm = editor.CodeManager || null;\n\n if (!this.$editors) {\n const oHtmlEd = this.buildEditor('htmlmixed', 'hopscotch', 'HTML');\n const oCsslEd = this.buildEditor('css', 'hopscotch', 'CSS');\n this.htmlEditor = oHtmlEd.el;\n this.cssEditor = oCsslEd.el;\n const $editors = $(`
`);\n $editors.append(oHtmlEd.$el).append(oCsslEd.$el);\n this.$editors = $editors;\n }\n\n modal\n .open({\n title: config.textViewCode,\n content: this.$editors\n })\n .getModel()\n .once('change:open', () => editor.stopCommand(this.id));\n this.htmlEditor.setContent(editor.getHtml());\n this.cssEditor.setContent(editor.getCss());\n },\n\n stop(editor) {\n const modal = editor.Modal;\n modal && modal.close();\n },\n\n buildEditor(codeName, theme, label) {\n const input = document.createElement('textarea');\n !this.codeMirror && (this.codeMirror = this.cm.getViewer('CodeMirror'));\n\n const el = this.codeMirror.clone().set({\n label,\n codeName,\n theme,\n input\n });\n\n const $el = new this.cm.EditorView({\n model: el,\n config: this.cm.getConfig()\n }).render().$el;\n\n el.init(input);\n\n return { el, $el };\n }\n};\n","import { isElement } from 'underscore';\n\nexport default {\n /**\n * Check if fullscreen mode is enabled\n * @return {Boolean}\n */\n isEnabled() {\n var d = document;\n if (\n d.fullscreenElement ||\n d.webkitFullscreenElement ||\n d.mozFullScreenElement\n )\n return 1;\n else return 0;\n },\n\n /**\n * Enable fullscreen mode and return browser prefix\n * @param {HTMLElement} el\n * @return {string}\n */\n enable(el) {\n var pfx = '';\n if (el.requestFullscreen) el.requestFullscreen();\n else if (el.webkitRequestFullscreen) {\n pfx = 'webkit';\n el.webkitRequestFullscreen();\n } else if (el.mozRequestFullScreen) {\n pfx = 'moz';\n el.mozRequestFullScreen();\n } else if (el.msRequestFullscreen) el.msRequestFullscreen();\n else console.warn('Fullscreen not supported');\n return pfx;\n },\n\n /**\n * Disable fullscreen mode\n */\n disable() {\n const d = document;\n if (this.isEnabled()) {\n if (d.exitFullscreen) d.exitFullscreen();\n else if (d.webkitExitFullscreen) d.webkitExitFullscreen();\n else if (d.mozCancelFullScreen) d.mozCancelFullScreen();\n else if (d.msExitFullscreen) d.msExitFullscreen();\n }\n },\n\n /**\n * Triggered when the state of the fullscreen is changed. Inside detects if\n * it's enabled\n * @param {strinf} pfx Browser prefix\n * @param {Event} e\n */\n fsChanged(pfx, e) {\n var d = document;\n var ev = (pfx || '') + 'fullscreenchange';\n if (!this.isEnabled()) {\n this.stop(null, this.sender);\n document.removeEventListener(ev, this.fsChanged);\n }\n },\n\n run(editor, sender, opts = {}) {\n this.sender = sender;\n const { target } = opts;\n const targetEl = isElement(target)\n ? target\n : document.querySelector(target);\n const pfx = this.enable(targetEl || editor.getContainer());\n this.fsChanged = this.fsChanged.bind(this, pfx);\n document.addEventListener(pfx + 'fullscreenchange', this.fsChanged);\n editor.trigger('change:canvasOffset');\n },\n\n stop(editor, sender) {\n if (sender && sender.set) sender.set('active', false);\n this.disable();\n if (editor) editor.trigger('change:canvasOffset');\n }\n};\n","import { extend, bindAll } from 'underscore';\nimport Backbone from 'backbone';\nimport { on, off } from 'utils/mixins';\nimport SelectComponent from './SelectComponent';\nimport SelectPosition from './SelectPosition';\n\nconst $ = Backbone.$;\n\nexport default extend({}, SelectPosition, SelectComponent, {\n init(o) {\n SelectComponent.init.apply(this, arguments);\n bindAll(this, 'initSorter', 'rollback', 'onEndMove');\n this.opt = o;\n this.hoverClass = this.ppfx + 'highlighter-warning';\n this.badgeClass = this.ppfx + 'badge-warning';\n this.noSelClass = this.ppfx + 'no-select';\n },\n\n enable(...args) {\n SelectComponent.enable.apply(this, args);\n this.getBadgeEl().addClass(this.badgeClass);\n this.getHighlighterEl().addClass(this.hoverClass);\n var wp = this.$wrapper;\n wp.css('cursor', 'move');\n wp.on('mousedown', this.initSorter);\n\n // Avoid strange moving behavior\n wp.addClass(this.noSelClass);\n },\n\n /**\n * Overwrite for doing nothing\n * @private\n */\n toggleClipboard() {},\n\n /**\n * Delegate sorting\n * @param {Event} e\n * @private\n * */\n initSorter(e) {\n var el = $(e.target).data('model');\n var drag = el.get('draggable');\n if (!drag) return;\n\n // Avoid badge showing on move\n this.cacheEl = null;\n this.startSelectPosition(e.target, this.frameEl.contentDocument);\n this.sorter.draggable = drag;\n this.sorter.onEndMove = this.onEndMove.bind(this);\n this.stopSelectComponent();\n this.$wrapper.off('mousedown', this.initSorter);\n on(this.getContentWindow(), 'keydown', this.rollback);\n },\n\n /**\n * Init sorter from model\n * @param {Object} model\n * @private\n */\n initSorterFromModel(model) {\n var drag = model.get('draggable');\n if (!drag) return;\n // Avoid badge showing on move\n this.cacheEl = null;\n var el = model.view.el;\n this.startSelectPosition(el, this.frameEl.contentDocument);\n this.sorter.draggable = drag;\n this.sorter.onEndMove = this.onEndMoveFromModel.bind(this);\n\n /*\n this.sorter.setDragHelper(el);\n var dragHelper = this.sorter.dragHelper;\n dragHelper.className = this.ppfx + 'drag-helper';\n dragHelper.innerHTML = '';\n dragHelper.backgroundColor = 'white';\n */\n\n this.stopSelectComponent();\n on(this.getContentWindow(), 'keydown', this.rollback);\n },\n\n /**\n * Init sorter from models\n * @param {Object} model\n * @private\n */\n initSorterFromModels(models) {\n // TODO: if one only check for `draggable`\n // Avoid badge showing on move\n this.cacheEl = null;\n const lastModel = models[models.length - 1];\n const doc = this.frameEl.contentDocument;\n this.startSelectPosition(lastModel.view.el, doc);\n this.sorter.draggable = lastModel.get('draggable');\n this.sorter.toMove = models;\n this.sorter.onEndMove = this.onEndMoveFromModel.bind(this);\n this.stopSelectComponent();\n on(this.getContentWindow(), 'keydown', this.rollback);\n },\n\n onEndMoveFromModel() {\n off(this.getContentWindow(), 'keydown', this.rollback);\n },\n\n /**\n * Callback after sorting\n * @private\n */\n onEndMove() {\n this.enable();\n off(this.getContentWindow(), 'keydown', this.rollback);\n },\n\n /**\n * Say what to do after the component was selected (selectComponent)\n * @param {Event} e\n * @param {Object} Selected element\n * @private\n * */\n onSelect(e, el) {},\n\n /**\n * Used to bring the previous situation before start moving the component\n * @param {Event} e\n * @param {Boolean} Indicates if rollback in anycase\n * @private\n * */\n rollback(e, force) {\n var key = e.which || e.keyCode;\n if (key == 27 || force) {\n this.sorter.moved = false;\n this.sorter.endMove();\n }\n return;\n },\n\n /**\n * Returns badge element\n * @return {HTMLElement}\n * @private\n */\n getBadgeEl() {\n if (!this.$badge) this.$badge = $(this.getBadge());\n return this.$badge;\n },\n\n /**\n * Returns highlighter element\n * @return {HTMLElement}\n * @private\n */\n getHighlighterEl() {\n if (!this.$hl) this.$hl = $(this.canvas.getHighlighter());\n return this.$hl;\n },\n\n stop(...args) {\n SelectComponent.stop.apply(this, args);\n this.getBadgeEl().removeClass(this.badgeClass);\n this.getHighlighterEl().removeClass(this.hoverClass);\n var wp = this.$wrapper;\n wp.css('cursor', '')\n .unbind()\n .removeClass(this.noSelClass);\n }\n});\n","export default {\n run(editor, sender, opts = {}) {\n const modal = editor.Modal;\n const am = editor.AssetManager;\n const config = am.getConfig();\n const amContainer = am.getContainer();\n const title = opts.modalTitle || config.modalTitle || '';\n const types = opts.types;\n const accept = opts.accept;\n\n am.setTarget(opts.target);\n am.onClick(opts.onClick);\n am.onDblClick(opts.onDblClick);\n am.onSelect(opts.onSelect);\n\n if (!this.rendered || types) {\n let assets = am.getAll().filter(i => 1);\n\n if (types && types.length) {\n assets = assets.filter(a => types.indexOf(a.get('type')) !== -1);\n }\n\n am.render(assets);\n this.rendered = 1;\n }\n\n if (accept) {\n const uploadEl = amContainer.querySelector(\n `input#${config.stylePrefix}uploadFile`\n );\n uploadEl && uploadEl.setAttribute('accept', accept);\n }\n\n modal\n .open({\n title,\n content: amContainer\n })\n .getModel()\n .once('change:open', () => editor.stopCommand(this.id));\n return this;\n },\n\n stop(editor) {\n editor.Modal.close();\n return this;\n }\n};\n","export default {\n run(editor, sender) {\n const bm = editor.BlockManager;\n const pn = editor.Panels;\n\n if (!this.blocks) {\n bm.render();\n const id = 'views-container';\n const blocks = document.createElement('div');\n const panels = pn.getPanel(id) || pn.addPanel({ id });\n blocks.appendChild(bm.getContainer());\n panels.set('appendContent', blocks).trigger('change:appendContent');\n this.blocks = blocks;\n }\n\n this.blocks.style.display = 'block';\n },\n\n stop() {\n const blocks = this.blocks;\n blocks && (blocks.style.display = 'none');\n }\n};\n","import Backbone from 'backbone';\nimport Layers from 'navigator';\n\nconst $ = Backbone.$;\n\nexport default {\n run(editor) {\n const lm = editor.LayerManager;\n const pn = editor.Panels;\n\n if (!this.layers) {\n const id = 'views-container';\n const layers = document.createElement('div');\n const panels = pn.getPanel(id) || pn.addPanel({ id });\n layers.appendChild(lm.render());\n panels.set('appendContent', layers).trigger('change:appendContent');\n this.layers = layers;\n }\n\n this.layers.style.display = 'block';\n },\n\n stop() {\n const layers = this.layers;\n layers && (layers.style.display = 'none');\n }\n};\n","import Backbone from 'backbone';\nimport StyleManager from 'style_manager';\n\nconst $ = Backbone.$;\n\nexport default {\n run(em, sender) {\n this.sender = sender;\n if (!this.$cn) {\n var config = em.getConfig(),\n panels = em.Panels;\n // Main container\n this.$cn = $('
');\n // Secondary container\n this.$cn2 = $('
');\n this.$cn.append(this.$cn2);\n\n // Device Manager\n var dvm = em.DeviceManager;\n if (dvm && config.showDevices) {\n var devicePanel = panels.addPanel({ id: 'devices-c' });\n devicePanel\n .set('appendContent', dvm.render())\n .trigger('change:appendContent');\n }\n\n // Class Manager container\n var clm = em.SelectorManager;\n if (clm) this.$cn2.append(clm.render([]));\n\n this.$cn2.append(em.StyleManager.render());\n var smConfig = em.StyleManager.getConfig();\n const pfx = smConfig.stylePrefix;\n // Create header\n this.$header = $(\n `
${smConfig.textNoElement}
`\n );\n this.$cn.append(this.$header);\n\n // Create panel if not exists\n if (!panels.getPanel('views-container'))\n this.panel = panels.addPanel({ id: 'views-container' });\n else this.panel = panels.getPanel('views-container');\n\n // Add all containers to the panel\n this.panel.set('appendContent', this.$cn).trigger('change:appendContent');\n\n this.target = em.editor;\n this.listenTo(this.target, 'component:toggled', this.toggleSm);\n }\n this.toggleSm();\n },\n\n /**\n * Toggle Style Manager visibility\n * @private\n */\n toggleSm() {\n const { target, sender } = this;\n if (sender && sender.get && !sender.get('active')) return;\n\n if (target.getSelectedAll().length === 1) {\n this.$cn2.show();\n this.$header.hide();\n } else {\n this.$cn2.hide();\n this.$header.show();\n }\n },\n\n stop() {\n // Hide secondary container if exists\n if (this.$cn2) this.$cn2.hide();\n\n // Hide header container if exists\n if (this.$header) this.$header.hide();\n }\n};\n","import Backbone from 'backbone';\n\nconst $ = Backbone.$;\n\nexport default {\n run(editor, sender) {\n this.sender = sender;\n\n var config = editor.Config;\n var pfx = config.stylePrefix;\n var tm = editor.TraitManager;\n var panelC;\n\n if (!this.$cn) {\n var tmView = tm.getTraitsViewer();\n var confTm = tm.getConfig();\n this.$cn = $('
');\n this.$cn2 = $('
');\n this.$cn.append(this.$cn2);\n this.$header = $('
').append(\n `
${confTm.textNoElement}
`\n );\n this.$cn.append(this.$header);\n this.$cn2.append(\n `
${confTm.labelContainer}
`\n );\n this.$cn2.append(tmView.render().el);\n var panels = editor.Panels;\n\n if (!panels.getPanel('views-container'))\n panelC = panels.addPanel({ id: 'views-container' });\n else panelC = panels.getPanel('views-container');\n\n panelC\n .set('appendContent', this.$cn.get(0))\n .trigger('change:appendContent');\n\n this.target = editor.getModel();\n this.listenTo(this.target, 'component:toggled', this.toggleTm);\n }\n\n this.toggleTm();\n },\n\n /**\n * Toggle Trait Manager visibility\n * @private\n */\n toggleTm() {\n const sender = this.sender;\n if (sender && sender.get && !sender.get('active')) return;\n\n if (this.target.getSelectedAll().length === 1) {\n this.$cn2.show();\n this.$header.hide();\n } else {\n this.$cn2.hide();\n this.$header.show();\n }\n },\n\n stop() {\n this.$cn2 && this.$cn2.hide();\n this.$header && this.$header.hide();\n }\n};\n","import { isArray, contains } from 'underscore';\n\nexport default {\n run(ed) {\n const em = ed.getModel();\n const clp = em.get('clipboard');\n const selected = ed.getSelected();\n\n if (clp && selected) {\n ed.getSelectedAll().forEach(comp => {\n if (!comp) return;\n const coll = comp.collection;\n const at = coll.indexOf(comp) + 1;\n const copyable = clp.filter(cop => cop.get('copyable'));\n let added;\n\n if (contains(clp, comp) && comp.get('copyable')) {\n added = coll.add(comp.clone(), { at });\n } else {\n added = coll.add(copyable.map(cop => cop.clone()), { at });\n }\n\n added = isArray(added) ? added : [added];\n added.forEach(add => ed.trigger('component:paste', add));\n });\n\n selected.emitUpdate();\n }\n }\n};\n","import { each } from 'underscore';\n\nexport default {\n getPanels(editor) {\n if (!this.panels) {\n this.panels = editor.Panels.getPanelsEl();\n }\n\n return this.panels;\n },\n\n tglPointers(editor, val) {\n const body = editor.Canvas.getBody();\n const elP = body.querySelectorAll(`.${this.ppfx}no-pointer`);\n each(elP, item => (item.style.pointerEvents = val ? '' : 'all'));\n },\n\n run(editor, sender) {\n this.sender = sender;\n editor.stopCommand('sw-visibility');\n editor.getModel().stopDefault();\n const panels = this.getPanels(editor);\n const canvas = editor.Canvas.getElement();\n const editorEl = editor.getEl();\n const pfx = editor.Config.stylePrefix;\n\n if (!this.helper) {\n const helper = document.createElement('span');\n helper.className = `${pfx}off-prv fa fa-eye-slash`;\n editorEl.appendChild(helper);\n helper.onclick = () => this.stopCommand();\n this.helper = helper;\n }\n\n this.helper.style.display = 'inline-block';\n this.tglPointers(editor);\n panels.style.display = 'none';\n const canvasS = canvas.style;\n canvasS.width = '100%';\n canvasS.height = '100%';\n canvasS.top = '0';\n canvasS.left = '0';\n canvasS.padding = '0';\n canvasS.margin = '0';\n editor.refresh();\n },\n\n stop(editor) {\n const { sender = {} } = this;\n sender.set && sender.set('active', 0);\n const panels = this.getPanels(editor);\n editor.runCommand('sw-visibility');\n editor.getModel().runDefault();\n panels.style.display = '';\n const canvas = editor.Canvas.getElement();\n canvas.setAttribute('style', '');\n\n if (this.helper) {\n this.helper.style.display = 'none';\n }\n\n editor.refresh();\n this.tglPointers(editor, 1);\n }\n};\n","export default {\n run(editor, sender, opts) {\n var opt = opts || {};\n var el = opt.el || '';\n var canvas = editor.Canvas;\n var canvasResizer = this.canvasResizer;\n var options = opt.options || {};\n var canvasView = canvas.getCanvasView();\n options.appendTo = canvas.getResizerEl();\n options.prefix = editor.getConfig().stylePrefix;\n options.posFetcher = canvasView.getElementPos.bind(canvasView);\n options.mousePosFetcher = canvas.getMouseRelativePos;\n\n // Create the resizer for the canvas if not yet created\n if (!canvasResizer || opt.forceNew) {\n this.canvasResizer = editor.Utils.Resizer.init(options);\n canvasResizer = this.canvasResizer;\n }\n\n canvasResizer.setOptions(options);\n canvasResizer.blur();\n canvasResizer.focus(el);\n return canvasResizer;\n },\n\n stop() {\n const resizer = this.canvasResizer;\n resizer && resizer.blur();\n }\n};\n","import Backbone from 'backbone';\nimport { isTextNode } from 'utils/mixins';\nconst $ = Backbone.$;\n\nexport default {\n getOffsetMethod(state) {\n var method = state || '';\n return 'get' + method + 'OffsetViewerEl';\n },\n\n run(editor, sender, opts) {\n var opt = opts || {};\n var state = opt.state || '';\n var config = editor.getConfig();\n const zoom = this.em.getZoomDecimal();\n const el = opt.el || '';\n\n if (\n !config.showOffsets ||\n isTextNode(el) ||\n (!config.showOffsetsSelected && state == 'Fixed')\n ) {\n editor.stopCommand(this.id, opts);\n return;\n }\n\n var canvas = editor.Canvas;\n var pos = opt.elPos || canvas.getElementPos(el);\n var style = window.getComputedStyle(el);\n var ppfx = this.ppfx;\n var stateVar = state + 'State';\n var method = this.getOffsetMethod(state);\n var offsetViewer = canvas[method]();\n offsetViewer.style.display = 'block';\n\n var marginT = this['marginT' + state];\n var marginB = this['marginB' + state];\n var marginL = this['marginL' + state];\n var marginR = this['marginR' + state];\n var padT = this['padT' + state];\n var padB = this['padB' + state];\n var padL = this['padL' + state];\n var padR = this['padR' + state];\n\n if (!this[stateVar]) {\n var stateLow = state.toLowerCase();\n var marginName = stateLow + 'margin-v';\n var paddingName = stateLow + 'padding-v';\n var marginV = $(`
`).get(0);\n var paddingV = $(`
`).get(0);\n var marginEls = ppfx + marginName + '-el';\n var paddingEls = ppfx + paddingName + '-el';\n const fullMargName = `${marginEls} ${ppfx + marginName}`;\n const fullPadName = `${paddingEls} ${ppfx + paddingName}`;\n marginT = $(`
`).get(0);\n marginB = $(`
`).get(0);\n marginL = $(`
`).get(0);\n marginR = $(`
`).get(0);\n padT = $(`
`).get(0);\n padB = $(`
`).get(0);\n padL = $(`
`).get(0);\n padR = $(`
`).get(0);\n this['marginT' + state] = marginT;\n this['marginB' + state] = marginB;\n this['marginL' + state] = marginL;\n this['marginR' + state] = marginR;\n this['padT' + state] = padT;\n this['padB' + state] = padB;\n this['padL' + state] = padL;\n this['padR' + state] = padR;\n marginV.appendChild(marginT);\n marginV.appendChild(marginB);\n marginV.appendChild(marginL);\n marginV.appendChild(marginR);\n paddingV.appendChild(padT);\n paddingV.appendChild(padB);\n paddingV.appendChild(padL);\n paddingV.appendChild(padR);\n offsetViewer.appendChild(marginV);\n offsetViewer.appendChild(paddingV);\n this[stateVar] = '1';\n }\n\n var unit = 'px';\n var marginLeftSt = parseFloat(style.marginLeft.replace(unit, '')) * zoom;\n var marginRightSt = parseFloat(style.marginRight.replace(unit, '')) * zoom;\n var marginTopSt = parseFloat(style.marginTop.replace(unit, '')) * zoom;\n var marginBottomSt =\n parseFloat(style.marginBottom.replace(unit, '')) * zoom;\n var mtStyle = marginT.style;\n var mbStyle = marginB.style;\n var mlStyle = marginL.style;\n var mrStyle = marginR.style;\n var ptStyle = padT.style;\n var pbStyle = padB.style;\n var plStyle = padL.style;\n var prStyle = padR.style;\n var posLeft = parseFloat(pos.left);\n var widthEl = parseFloat(style.width) * zoom + unit;\n\n // Margin style\n mtStyle.height = marginTopSt + unit;\n mtStyle.width = widthEl;\n mtStyle.top = pos.top - marginTopSt + unit;\n mtStyle.left = posLeft + unit;\n\n mbStyle.height = marginBottomSt + unit;\n mbStyle.width = widthEl;\n mbStyle.top = pos.top + pos.height + unit;\n mbStyle.left = posLeft + unit;\n\n var marginSideH = pos.height + marginTopSt + marginBottomSt + unit;\n var marginSideT = pos.top - marginTopSt + unit;\n mlStyle.height = marginSideH;\n mlStyle.width = marginLeftSt + unit;\n mlStyle.top = marginSideT;\n mlStyle.left = posLeft - marginLeftSt + unit;\n\n mrStyle.height = marginSideH;\n mrStyle.width = marginRightSt + unit;\n mrStyle.top = marginSideT;\n mrStyle.left = posLeft + pos.width + unit;\n\n // Padding style\n var padTop = parseFloat(style.paddingTop) * zoom;\n ptStyle.height = padTop + unit;\n ptStyle.width = widthEl;\n ptStyle.top = pos.top + unit;\n ptStyle.left = posLeft + unit;\n\n var padBot = parseFloat(style.paddingBottom) * zoom;\n pbStyle.height = padBot + unit;\n pbStyle.width = widthEl;\n pbStyle.top = pos.top + pos.height - padBot + unit;\n pbStyle.left = posLeft + unit;\n\n var padSideH = pos.height - padBot - padTop + unit;\n var padSideT = pos.top + padTop + unit;\n plStyle.height = padSideH;\n plStyle.width = parseFloat(style.paddingLeft) * zoom + unit;\n plStyle.top = padSideT;\n plStyle.left = pos.left + unit;\n\n var padRight = parseFloat(style.paddingRight) * zoom;\n prStyle.height = padSideH;\n prStyle.width = padRight + unit;\n prStyle.top = padSideT;\n prStyle.left = pos.left + pos.width - padRight + unit;\n },\n\n stop(editor, sender, opts) {\n var opt = opts || {};\n var state = opt.state || '';\n var method = this.getOffsetMethod(state);\n var canvas = editor.Canvas;\n var offsetViewer = canvas[method]();\n offsetViewer.style.display = 'none';\n }\n};\n","export default {\n run(ed) {\n ed.Canvas.getBody().className = this.ppfx + 'dashed';\n },\n\n stop(ed) {\n ed.Canvas.getBody().className = '';\n }\n};\n","export default {\n stylePrefix: 'sm-',\n\n sectors: [],\n\n // Specify the element to use as a container, string (query) or HTMLElement\n // With the empty value, nothing will be rendered\n appendTo: '',\n\n // Text to show in case no element selected\n textNoElement: 'Select an element before using Style Manager',\n\n // Text for layers\n textLayer: 'Layer',\n\n // Hide the property in case it's not stylable for the\n // selected component (each component has 'stylable' property)\n hideNotStylable: true,\n\n // Highlight changed properties of the selected component\n highlightChanged: true,\n\n // Highlight computed properties of the selected component\n highlightComputed: true,\n\n // Show computed properties of the selected component, if this value\n // is set to false, highlightComputed will not take effect\n showComputed: true,\n\n // Adds the possibility to clear property value from the target style\n clearProperties: 0,\n\n // Properties not to take in account for computed styles\n avoidComputed: ['width', 'height']\n};\n","export default () => ({\n /**\n * Build props object by their name\n * @param {Array|string} props Array of properties name\n * @return {Array}\n */\n build(props) {\n var objs = [];\n var dftFixedValues = ['initial', 'inherit'];\n\n if (typeof props === 'string') props = [props];\n\n for (var i = 0, len = props.length; i < len; i++) {\n var obj = {};\n var prop = props[i];\n obj.property = prop;\n\n // Property\n switch (prop) {\n case 'border-radius-c':\n obj.property = 'border-radius';\n break;\n }\n\n // Fixed values\n switch (prop) {\n case 'top':\n case 'right':\n case 'bottom':\n case 'left':\n case 'margin-top':\n case 'margin-right':\n case 'margin-bottom':\n case 'margin-left':\n case 'padding-top':\n case 'padding-right':\n case 'padding-bottom':\n case 'padding-left':\n case 'width':\n case 'max-width':\n case 'min-width':\n case 'height':\n case 'max-height':\n case 'min-height':\n case 'flex-basis':\n obj.fixedValues = ['initial', 'inherit', 'auto'];\n break;\n case 'font-size':\n obj.fixedValues = [\n 'medium',\n 'xx-small',\n 'x-small',\n 'small',\n 'large',\n 'x-large',\n 'xx-large',\n 'smaller',\n 'larger',\n 'length',\n 'initial',\n 'inherit'\n ];\n break;\n case 'letter-spacing':\n case 'line-height':\n obj.fixedValues = ['normal', 'initial', 'inherit'];\n break;\n }\n\n // Type\n switch (prop) {\n case 'float':\n case 'position':\n case 'text-align':\n obj.type = 'radio';\n break;\n case 'display':\n case 'flex-direction':\n case 'flex-wrap':\n case 'justify-content':\n case 'align-items':\n case 'align-content':\n case 'align-self':\n case 'font-family':\n case 'font-weight':\n case 'border-style':\n case 'box-shadow-type':\n case 'background-repeat':\n case 'background-position':\n case 'background-attachment':\n case 'background-size':\n case 'transition-property':\n case 'transition-timing-function':\n case 'cursor':\n case 'overflow':\n case 'overflow-x':\n case 'overflow-y':\n obj.type = 'select';\n break;\n case 'top':\n case 'right':\n case 'bottom':\n case 'left':\n case 'margin-top':\n case 'margin-right':\n case 'margin-bottom':\n case 'margin-left':\n case 'padding-top':\n case 'padding-right':\n case 'padding-bottom':\n case 'padding-left':\n case 'min-height':\n case 'min-width':\n case 'max-height':\n case 'max-width':\n case 'width':\n case 'height':\n case 'font-size':\n case 'letter-spacing':\n case 'line-height':\n case 'text-shadow-h':\n case 'text-shadow-v':\n case 'text-shadow-blur':\n case 'border-radius-c':\n case 'border-top-left-radius':\n case 'border-top-right-radius':\n case 'border-bottom-left-radius':\n case 'border-bottom-right-radius':\n case 'border-width':\n case 'box-shadow-h':\n case 'box-shadow-v':\n case 'box-shadow-blur':\n case 'box-shadow-spread':\n case 'transition-duration':\n case 'perspective':\n case 'transform-rotate-x':\n case 'transform-rotate-y':\n case 'transform-rotate-z':\n case 'transform-scale-x':\n case 'transform-scale-y':\n case 'transform-scale-z':\n case 'order':\n case 'flex-grow':\n case 'flex-shrink':\n case 'flex-basis':\n obj.type = 'integer';\n break;\n case 'margin':\n case 'padding':\n case 'border-radius':\n case 'border':\n case 'transform':\n obj.type = 'composite';\n break;\n case 'color':\n case 'text-shadow-color':\n case 'background-color':\n case 'border-color':\n case 'box-shadow-color':\n obj.type = 'color';\n break;\n case 'text-shadow':\n case 'box-shadow':\n case 'background':\n case 'transition':\n obj.type = 'stack';\n break;\n case 'background-image':\n obj.type = 'file';\n break;\n }\n\n // Defaults\n switch (prop) {\n case 'float':\n case 'background-color':\n case 'background-image':\n case 'text-shadow':\n obj.defaults = 'none';\n break;\n case 'display':\n obj.defaults = 'block';\n break;\n case 'flex-direction':\n obj.defaults = 'row';\n break;\n case 'flex-wrap':\n obj.defaults = 'nowrap';\n break;\n case 'justify-content':\n obj.defaults = 'flex-start';\n break;\n case 'align-items':\n obj.defaults = 'stretch';\n break;\n case 'align-content':\n obj.defaults = 'stretch';\n break;\n case 'align-self':\n obj.defaults = 'auto';\n break;\n case 'position':\n obj.defaults = 'static';\n break;\n case 'margin-top':\n case 'margin-right':\n case 'margin-bottom':\n case 'margin-left':\n case 'padding-top':\n case 'padding-right':\n case 'padding-bottom':\n case 'padding-left':\n case 'text-shadow-h':\n case 'text-shadow-v':\n case 'text-shadow-blur':\n case 'border-radius-c':\n case 'box-shadow-h':\n case 'box-shadow-v':\n case 'box-shadow-spread':\n case 'perspective':\n case 'transform-rotate-x':\n case 'transform-rotate-y':\n case 'transform-rotate-z':\n case 'order':\n case 'flex-grow':\n obj.defaults = 0;\n break;\n case 'border-top-left-radius':\n case 'border-top-right-radius':\n case 'border-bottom-left-radius':\n case 'border-bottom-right-radius':\n obj.defaults = '0px';\n break;\n case 'transform-scale-x':\n case 'transform-scale-y':\n case 'transform-scale-z':\n case 'flex-shrink':\n obj.defaults = 1;\n break;\n case 'box-shadow-blur':\n obj.defaults = '5px';\n break;\n case 'top':\n case 'right':\n case 'bottom':\n case 'left':\n case 'min-height':\n case 'min-width':\n case 'max-height':\n case 'max-width':\n case 'width':\n case 'height':\n case 'background-size':\n case 'cursor':\n case 'flex-basis':\n obj.defaults = 'auto';\n break;\n case 'font-family':\n obj.defaults = 'Arial, Helvetica, sans-serif';\n break;\n case 'font-size':\n case 'border-width':\n obj.defaults = 'medium';\n break;\n case 'font-weight':\n obj.defaults = '400';\n break;\n case 'letter-spacing':\n case 'line-height':\n obj.defaults = 'normal';\n break;\n case 'color':\n case 'text-shadow-color':\n case 'border-color':\n case 'box-shadow-color':\n obj.defaults = 'black';\n break;\n case 'text-align':\n obj.defaults = 'left';\n break;\n case 'border-style':\n obj.defaults = 'solid';\n break;\n case 'box-shadow-type':\n obj.defaults = '';\n break;\n case 'background-repeat':\n obj.defaults = 'repeat';\n break;\n case 'background-position':\n obj.defaults = 'left top';\n break;\n case 'background-attachment':\n obj.defaults = 'scroll';\n break;\n case 'transition-property':\n obj.defaults = 'width';\n break;\n case 'transition-duration':\n obj.defaults = '2';\n break;\n case 'transition-timing-function':\n obj.defaults = 'ease';\n break;\n case 'overflow':\n case 'overflow-x':\n case 'overflow-y':\n obj.defaults = 'visible';\n break;\n }\n\n /*\n * Add styleable dependency on other properties. Allows properties to be\n * dynamically hidden or shown based on values of other properties.\n *\n * Property will be styleable if all of the properties (keys) in the\n * requires object have any of the values specified in the array.\n */\n switch (prop) {\n case 'flex-direction':\n case 'flex-wrap':\n case 'justify-content':\n case 'align-items':\n case 'align-content':\n obj.requires = { display: ['flex'] };\n break;\n case 'order':\n case 'flex-basis':\n case 'flex-grow':\n case 'flex-shrink':\n case 'align-self':\n obj.requiresParent = { display: ['flex'] };\n break;\n }\n\n // Units\n switch (prop) {\n case 'top':\n case 'bottom':\n case 'margin-top':\n case 'margin-bottom':\n case 'padding-top':\n case 'padding-bottom':\n case 'min-height':\n case 'max-height':\n case 'height':\n obj.units = ['px', '%', 'vh'];\n break;\n case 'right':\n case 'left':\n case 'margin-right':\n case 'margin-left':\n case 'padding-right':\n case 'padding-left':\n case 'min-width':\n case 'max-width':\n case 'width':\n obj.units = ['px', '%', 'vw'];\n break;\n case 'flex-basis':\n obj.units = ['px', '%', 'vw', 'vh'];\n break;\n case 'text-shadow-v':\n case 'text-shadow-h':\n case 'text-shadow-blur':\n case 'border-radius-c':\n case 'border-top-left-radius':\n case 'border-top-right-radius':\n case 'border-bottom-left-radius':\n case 'border-bottom-right-radius':\n case 'box-shadow-h':\n case 'box-shadow-v':\n obj.units = ['px', '%'];\n break;\n case 'font-size':\n case 'letter-spacing':\n case 'line-height':\n obj.units = ['px', 'em', 'rem', '%'];\n break;\n case 'border-width':\n obj.units = ['px', 'em'];\n break;\n case 'box-shadow-blur':\n case 'box-shadow-spread':\n case 'perspective':\n obj.units = ['px'];\n break;\n case 'transition-duration':\n obj.units = ['s'];\n break;\n case 'transform-rotate-x':\n case 'transform-rotate-y':\n case 'transform-rotate-z':\n obj.units = ['deg'];\n break;\n }\n\n // Min/Max\n switch (prop) {\n case 'padding-top':\n case 'padding-right':\n case 'padding-bottom':\n case 'padding-left':\n case 'min-height':\n case 'min-width':\n case 'max-height':\n case 'max-width':\n case 'width':\n case 'height':\n case 'font-size':\n case 'text-shadow-blur':\n case 'border-radius-c':\n case 'border-top-left-radius':\n case 'border-top-right-radius':\n case 'border-bottom-left-radius':\n case 'border-bottom-right-radius':\n case 'border-width':\n case 'box-shadow-blur':\n case 'transition-duration':\n case 'perspective':\n case 'flex-basis':\n obj.min = 0;\n break;\n }\n\n // Preview\n switch (prop) {\n case 'text-shadow':\n case 'box-shadow':\n case 'background':\n obj.preview = true;\n break;\n }\n\n // Detached\n switch (prop) {\n case 'background':\n obj.detached = true;\n break;\n }\n\n // Functions\n switch (prop) {\n case 'transform-rotate-x':\n obj.functionName = 'rotateX';\n break;\n case 'transform-rotate-y':\n obj.functionName = 'rotateY';\n break;\n case 'transform-rotate-z':\n obj.functionName = 'rotateZ';\n break;\n case 'transform-scale-x':\n obj.functionName = 'scaleX';\n break;\n case 'transform-scale-y':\n obj.functionName = 'scaleY';\n break;\n case 'transform-scale-z':\n obj.functionName = 'scaleZ';\n break;\n case 'background-image':\n obj.functionName = 'url';\n break;\n }\n\n // Options\n switch (prop) {\n case 'float':\n obj.list = [{ value: 'none' }, { value: 'left' }, { value: 'right' }];\n break;\n case 'display':\n obj.list = [\n { value: 'block' },\n { value: 'inline' },\n { value: 'inline-block' },\n { value: 'flex' },\n { value: 'none' }\n ];\n break;\n case 'flex-direction':\n obj.list = [\n { value: 'row' },\n { value: 'row-reverse' },\n { value: 'column' },\n { value: 'column-reverse' }\n ];\n break;\n case 'flex-wrap':\n obj.list = [\n { value: 'nowrap' },\n { value: 'wrap' },\n { value: 'wrap-reverse' }\n ];\n break;\n case 'justify-content':\n obj.list = [\n { value: 'flex-start' },\n { value: 'flex-end' },\n { value: 'center' },\n { value: 'space-between' },\n { value: 'space-around' },\n { value: 'space-evenly' }\n ];\n break;\n case 'align-items':\n obj.list = [\n { value: 'flex-start' },\n { value: 'flex-end' },\n { value: 'center' },\n { value: 'baseline' },\n { value: 'stretch' }\n ];\n break;\n case 'align-content':\n obj.list = [\n { value: 'flex-start' },\n { value: 'flex-end' },\n { value: 'center' },\n { value: 'space-between' },\n { value: 'space-around' },\n { value: 'stretch' }\n ];\n break;\n case 'align-self':\n obj.list = [\n { value: 'auto' },\n { value: 'flex-start' },\n { value: 'flex-end' },\n { value: 'center' },\n { value: 'baseline' },\n { value: 'stretch' }\n ];\n break;\n case 'position':\n obj.list = [\n { value: 'static' },\n { value: 'relative' },\n { value: 'absolute' },\n { value: 'fixed' }\n ];\n break;\n case 'font-family':\n var ss = ', sans-serif';\n var fonts = [\n 'Arial, Helvetica' + ss,\n 'Arial Black, Gadget' + ss,\n 'Brush Script MT' + ss,\n 'Comic Sans MS, cursive' + ss,\n 'Courier New, Courier, monospace',\n 'Georgia, serif',\n 'Helvetica, serif',\n 'Impact, Charcoal' + ss,\n 'Lucida Sans Unicode, Lucida Grande' + ss,\n 'Tahoma, Geneva' + ss,\n 'Times New Roman, Times, serif',\n 'Trebuchet MS, Helvetica' + ss,\n 'Verdana, Geneva' + ss\n ];\n obj.list = [];\n for (var j = 0, l = fonts.length; j < l; j++) {\n var font = {};\n font.value = fonts[j];\n font.name = fonts[j].split(',')[0];\n obj.list.push(font);\n }\n break;\n case 'font-weight':\n obj.list = [\n { value: '100', name: 'Thin' },\n { value: '200', name: 'Extra-Light' },\n { value: '300', name: 'Light' },\n { value: '400', name: 'Normal' },\n { value: '500', name: 'Medium' },\n { value: '600', name: 'Semi-Bold' },\n { value: '700', name: 'Bold' },\n { value: '800', name: 'Extra-Bold' },\n { value: '900', name: 'Ultra-Bold' }\n ];\n break;\n case 'text-align':\n obj.list = [\n { value: 'left' },\n { value: 'center' },\n { value: 'right' },\n { value: 'justify' }\n ];\n break;\n case 'border-style':\n obj.list = [\n { value: 'none' },\n { value: 'solid' },\n { value: 'dotted' },\n { value: 'dashed' },\n { value: 'double' },\n { value: 'groove' },\n { value: 'ridge' },\n { value: 'inset' },\n { value: 'outset' }\n ];\n break;\n case 'box-shadow-type':\n obj.list = [\n { value: '', name: 'Outside' },\n { value: 'inset', name: 'Inside' }\n ];\n break;\n case 'background-repeat':\n obj.list = [\n { value: 'repeat' },\n { value: 'repeat-x' },\n { value: 'repeat-y' },\n { value: 'no-repeat' }\n ];\n break;\n case 'background-position':\n obj.list = [\n { value: 'left top' },\n { value: 'left center' },\n { value: 'left bottom' },\n { value: 'right top' },\n { value: 'right center' },\n { value: 'right bottom' },\n { value: 'center top' },\n { value: 'center center' },\n { value: 'center bottom' }\n ];\n break;\n case 'background-attachment':\n obj.list = [\n { value: 'scroll' },\n { value: 'fixed' },\n { value: 'local' }\n ];\n break;\n case 'background-size':\n obj.list = [\n { value: 'auto' },\n { value: 'cover' },\n { value: 'contain' }\n ];\n break;\n case 'transition-property':\n obj.list = [\n { value: 'all' },\n { value: 'width' },\n { value: 'height' },\n { value: 'background-color' },\n { value: 'transform' },\n { value: 'box-shadow' },\n { value: 'opacity' }\n ];\n break;\n case 'transition-timing-function':\n obj.list = [\n { value: 'linear' },\n { value: 'ease' },\n { value: 'ease-in' },\n { value: 'ease-out' },\n { value: 'ease-in-out' }\n ];\n break;\n case 'cursor':\n obj.list = [\n { value: 'auto' },\n { value: 'pointer' },\n { value: 'copy' },\n { value: 'crosshair' },\n { value: 'grab' },\n { value: 'grabbing' },\n { value: 'help' },\n { value: 'move' },\n { value: 'text' }\n ];\n break;\n case 'overflow':\n case 'overflow-x':\n case 'overflow-y':\n obj.list = [\n { value: 'visible' },\n { value: 'hidden' },\n { value: 'scroll' },\n { value: 'auto' }\n ];\n break;\n }\n\n // Properties\n switch (prop) {\n case 'margin':\n obj.properties = this.build([\n 'margin-top',\n 'margin-right',\n 'margin-bottom',\n 'margin-left'\n ]);\n break;\n case 'padding':\n obj.properties = this.build([\n 'padding-top',\n 'padding-right',\n 'padding-bottom',\n 'padding-left'\n ]);\n break;\n case 'text-shadow':\n obj.properties = this.build([\n 'text-shadow-h',\n 'text-shadow-v',\n 'text-shadow-blur',\n 'text-shadow-color'\n ]);\n break;\n case 'border':\n obj.properties = this.build([\n 'border-width',\n 'border-style',\n 'border-color'\n ]);\n break;\n case 'border-radius':\n obj.properties = this.build([\n 'border-top-left-radius',\n 'border-top-right-radius',\n 'border-bottom-right-radius',\n 'border-bottom-left-radius'\n ]);\n break;\n case 'box-shadow':\n obj.properties = this.build([\n 'box-shadow-h',\n 'box-shadow-v',\n 'box-shadow-blur',\n 'box-shadow-spread',\n 'box-shadow-color',\n 'box-shadow-type'\n ]);\n break;\n case 'background':\n obj.properties = this.build([\n 'background-image',\n 'background-repeat',\n 'background-position',\n 'background-attachment',\n 'background-size'\n ]);\n break;\n case 'transition':\n obj.properties = this.build([\n 'transition-property',\n 'transition-duration',\n 'transition-timing-function'\n ]);\n break;\n case 'transform':\n obj.properties = this.build([\n 'transform-rotate-x',\n 'transform-rotate-y',\n 'transform-rotate-z',\n 'transform-scale-x',\n 'transform-scale-y',\n 'transform-scale-z'\n ]);\n break;\n }\n\n objs.push(obj);\n }\n\n return objs;\n }\n});\n","import Backbone from 'backbone';\nimport { extend } from 'underscore';\nimport Properties from './Properties';\nimport PropertyFactory from './PropertyFactory';\n\nexport default Backbone.Model.extend({\n defaults: {\n id: '',\n name: '',\n open: true,\n buildProps: '',\n extendBuilded: 1,\n properties: []\n },\n\n initialize(opts) {\n const o = opts || {};\n const builded = this.buildProperties(o.buildProps);\n const name = this.get('name') || '';\n let props = [];\n !this.get('id') && this.set('id', name.replace(/ /g, '_').toLowerCase());\n\n if (!builded) props = this.get('properties');\n else props = this.extendProperties(builded);\n\n const propsModel = new Properties(props);\n propsModel.sector = this;\n this.set('properties', propsModel);\n },\n\n /**\n * Extend properties\n * @param {Array} props Start properties\n * @param {Array} moProps Model props\n * @param {Boolean} ex Returns the same amount of passed model props\n * @return {Array} Final props\n * @private\n */\n extendProperties(props, moProps, ex) {\n var pLen = props.length;\n var mProps = moProps || this.get('properties');\n var ext = this.get('extendBuilded');\n var isolated = [];\n\n for (var i = 0, len = mProps.length; i < len; i++) {\n var mProp = mProps[i];\n var found = 0;\n\n for (var j = 0; j < pLen; j++) {\n var prop = props[j];\n if (mProp.property == prop.property || mProp.id == prop.property) {\n // Check for nested properties\n var mPProps = mProp.properties;\n if (mPProps && mPProps.length) {\n mProp.properties = this.extendProperties(\n prop.properties || [],\n mPProps,\n 1\n );\n }\n props[j] = ext ? extend(prop, mProp) : mProp;\n isolated[j] = props[j];\n found = 1;\n continue;\n }\n }\n\n if (!found) {\n props.push(mProp);\n isolated.push(mProp);\n }\n }\n\n return ex ? isolated.filter(i => i) : props;\n },\n\n /**\n * Build properties\n * @param {Array} propr Array of props as sting\n * @return {Array}\n * @private\n */\n buildProperties(props) {\n var r;\n var buildP = props || [];\n\n if (!buildP.length) return;\n\n if (!this.propFactory) this.propFactory = new PropertyFactory();\n\n r = this.propFactory.build(buildP);\n\n return r;\n }\n});\n","import Backbone from 'backbone';\nimport Sector from './Sector';\n\nexport default Backbone.Collection.extend({\n model: Sector\n});\n","import Backbone from 'backbone';\nimport { template } from 'underscore';\nimport PropertiesView from './PropertiesView';\n\nexport default Backbone.View.extend({\n template: template(`\n
title\" data-sector-title>\n caret\" class=\"fa\">\n <%= label %>\n
`),\n\n events: {\n 'click [data-sector-title]': 'toggle'\n },\n\n initialize(o) {\n this.config = o.config || {};\n this.pfx = this.config.stylePrefix || '';\n this.target = o.target || {};\n this.propTarget = o.propTarget || {};\n this.caretR = 'fa-caret-right';\n this.caretD = 'fa-caret-down';\n const model = this.model;\n this.listenTo(model, 'change:open', this.updateOpen);\n this.listenTo(model, 'updateVisibility', this.updateVisibility);\n this.listenTo(model, 'destroy remove', this.remove);\n },\n\n /**\n * If all properties are hidden this will hide the sector\n */\n updateVisibility() {\n var show;\n this.model.get('properties').each(prop => {\n if (prop.get('visible')) {\n show = 1;\n }\n });\n this.el.style.display = show ? 'block' : 'none';\n },\n\n /**\n * Update visibility\n */\n updateOpen() {\n if (this.model.get('open')) this.show();\n else this.hide();\n },\n\n /**\n * Show the content of the sector\n * */\n show() {\n this.$el.addClass(this.pfx + 'open');\n this.getPropertiesEl().style.display = '';\n this.$caret.removeClass(this.caretR).addClass(this.caretD);\n },\n\n /**\n * Hide the content of the sector\n * */\n hide() {\n this.$el.removeClass(this.pfx + 'open');\n this.getPropertiesEl().style.display = 'none';\n this.$caret.removeClass(this.caretD).addClass(this.caretR);\n },\n\n getPropertiesEl() {\n return this.$el.find(`.${this.pfx}properties`).get(0);\n },\n\n /**\n * Toggle visibility\n * */\n toggle(e) {\n var v = this.model.get('open') ? 0 : 1;\n this.model.set('open', v);\n },\n\n render() {\n const { pfx, model } = this;\n const { id } = model.attributes;\n this.$el.html(\n this.template({\n pfx,\n label: model.get('name')\n })\n );\n this.$caret = this.$el.find(`#${pfx}caret`);\n this.renderProperties();\n this.$el.attr('class', `${pfx}sector ${pfx}sector__${id} no-select`);\n this.updateOpen();\n return this;\n },\n\n renderProperties() {\n var objs = this.model.get('properties');\n\n if (objs) {\n var view = new PropertiesView({\n collection: objs,\n target: this.target,\n propTarget: this.propTarget,\n config: this.config\n });\n this.$el.append(view.render().el);\n }\n }\n});\n","import Backbone from 'backbone';\nimport { extend, isString } from 'underscore';\nimport { isTaggableNode } from 'utils/mixins';\nimport { appendAtIndex } from 'utils/dom';\nimport SectorView from './SectorView';\n\nexport default Backbone.View.extend({\n initialize(o = {}) {\n const config = o.config || {};\n this.pfx = config.stylePrefix || '';\n this.ppfx = config.pStylePrefix || '';\n this.target = o.target || {};\n this.config = config;\n\n // The target that will emit events for properties\n const target = {};\n extend(target, Backbone.Events);\n const body = document.body;\n const dummy = document.createElement(`el-${new Date().getTime()}`);\n body.appendChild(dummy);\n target.computedDefault = { ...window.getComputedStyle(dummy) };\n body.removeChild(dummy);\n this.propTarget = target;\n const coll = this.collection;\n const events =\n 'component:toggled component:update:classes component:update:state change:device';\n this.listenTo(coll, 'add', this.addTo);\n this.listenTo(coll, 'reset', this.render);\n this.listenTo(this.target, events, this.targetUpdated);\n },\n\n /**\n * Add to collection\n * @param {Object} model Model\n * @return {Object}\n * @private\n * */\n addTo(model, coll, opts = {}) {\n this.addToCollection(model, null, opts);\n },\n\n /**\n * Fired when target is updated\n * @private\n */\n targetUpdated() {\n const em = this.target;\n const pt = this.propTarget;\n let model = em.getSelected();\n if (!model) return;\n\n const config = em.get('Config');\n const state = !config.devicePreviewMode ? model.get('state') : '';\n const el = model.getEl();\n pt.helper = null;\n\n // Create computed style container\n if (el && isTaggableNode(el)) {\n const stateStr = state ? `:${state}` : null;\n pt.computed = window.getComputedStyle(el, stateStr);\n }\n\n // Create a new rule for the state as a helper\n const appendStateRule = (style = {}) => {\n const cc = em.get('CssComposer');\n const helperCls = 'hc-state';\n const rules = cc.getAll();\n let helperRule = cc.getClassRule(helperCls);\n\n if (!helperRule) {\n helperRule = cc.setClassRule(helperCls);\n } else {\n // I will make it last again, otherwise it could be overridden\n rules.remove(helperRule);\n rules.add(helperRule);\n }\n\n helperRule.set('important', 1);\n helperRule.setStyle(style);\n pt.helper = helperRule;\n };\n\n model = em.get('StyleManager').getModelToStyle(model);\n state && appendStateRule(model.getStyle());\n pt.model = model;\n pt.trigger('update');\n },\n\n /**\n * Select different target for the Style Manager.\n * It could be a Component, CSSRule, or a string of any CSS selector\n * @param {Component|CSSRule|String} target\n * @return {Styleable} A Component or CSSRule\n */\n setTarget(target, opts = {}) {\n const em = this.target;\n const config = em.get('Config');\n const { targetIsClass, stylable } = opts;\n let model = target;\n\n if (isString(target)) {\n let rule;\n const rules = em.get('CssComposer').getAll();\n\n if (targetIsClass) {\n rule = rules.filter(\n rule => rule.get('selectors').getFullString() === target\n )[0];\n }\n\n if (!rule) {\n rule = rules.filter(rule => rule.get('selectorsAdd') === target)[0];\n }\n\n if (!rule) {\n rule = rules.add({ selectors: [], selectorsAdd: target });\n }\n\n stylable && rule.set({ stylable });\n model = rule;\n }\n\n const state = !config.devicePreviewMode ? model.get('state') : '';\n const pt = this.propTarget;\n pt.model = model;\n pt.trigger('styleManager:update', model);\n return model;\n },\n\n /**\n * Add new object to collection\n * @param {Object} model Model\n * @param {Object} fragmentEl collection\n * @return {Object} Object created\n * @private\n * */\n addToCollection(model, fragmentEl, opts = {}) {\n const { pfx, target, propTarget, config, el } = this;\n const appendTo = fragmentEl || el;\n const rendered = new SectorView({\n model,\n id: `${pfx}${model.get('id')}`,\n name: model.get('name'),\n properties: model.get('properties'),\n target,\n propTarget,\n config\n }).render().el;\n appendAtIndex(appendTo, rendered, opts.at);\n\n return rendered;\n },\n\n render() {\n const frag = document.createDocumentFragment();\n const $el = this.$el;\n const pfx = this.pfx;\n const ppfx = this.ppfx;\n $el.empty();\n this.collection.each(model => this.addToCollection(model, frag));\n $el.append(frag);\n $el.addClass(`${pfx}sectors ${ppfx}one-bg ${ppfx}two-color`);\n return this;\n }\n});\n","/**\n * With Style Manager you build categories (called sectors) of CSS properties which could be used to customize the style of components.\n * You can customize the initial state of the module from the editor initialization, by passing the following [Configuration Object](https://github.com/artf/grapesjs/blob/master/src/style_manager/config/config.js)\n * ```js\n * const editor = grapesjs.init({\n * styleManager: {\n * // options\n * }\n * })\n * ```\n *\n * Once the editor is instantiated you can use its API. Before using these methods you should get the module from the instance\n *\n * ```js\n * const styleManager = editor.StyleManager;\n * ```\n *\n * * [getConfig](#getconfig)\n * * [addSector](#addsector)\n * * [getSector](#getsector)\n * * [removeSector](#removesector)\n * * [getSectors](#getsectors)\n * * [addProperty](#addproperty)\n * * [getProperty](#getproperty)\n * * [removeProperty](#removeproperty)\n * * [getProperties](#getproperties)\n * * [getModelToStyle](#getmodeltostyle)\n * * [addType](#addtype)\n * * [getType](#gettype)\n * * [getTypes](#gettypes)\n * * [createType](#createtype)\n *\n * @module StyleManager\n */\n\nimport { isElement } from 'underscore';\nimport defaults from './config/config';\nimport Sectors from './model/Sectors';\nimport Properties from './model/Properties';\nimport SectorsView from './view/SectorsView';\n\nexport default () => {\n var c = {};\n let properties;\n var sectors, SectView;\n\n return {\n /**\n * Name of the module\n * @type {String}\n * @private\n */\n name: 'StyleManager',\n\n /**\n * Get configuration object\n * @return {Object}\n */\n getConfig() {\n return c;\n },\n\n /**\n * Initialize module. Automatically called with a new instance of the editor\n * @param {Object} config Configurations\n * @private\n */\n init(config) {\n c = { ...defaults, ...config };\n const ppfx = c.pStylePrefix;\n this.em = c.em;\n if (ppfx) c.stylePrefix = ppfx + c.stylePrefix;\n properties = new Properties();\n sectors = new Sectors([], c);\n SectView = new SectorsView({\n collection: sectors,\n target: c.em,\n config: c\n });\n\n return this;\n },\n\n onLoad() {\n sectors.add(c.sectors);\n },\n\n postRender() {\n const elTo = this.getConfig().appendTo;\n\n if (elTo) {\n const el = isElement(elTo) ? elTo : document.querySelector(elTo);\n el.appendChild(this.render());\n }\n },\n\n /**\n * Add new sector to the collection. If the sector with the same id already exists,\n * that one will be returned\n * @param {string} id Sector id\n * @param {Object} sector Object representing sector\n * @param {string} [sector.name=''] Sector's label\n * @param {Boolean} [sector.open=true] Indicates if the sector should be opened\n * @param {Array} [sector.properties=[]] Array of properties\n * @param {Object} [options={}] Options\n * @return {Sector} Added Sector\n * @example\n * var sector = styleManager.addSector('mySector',{\n * name: 'My sector',\n * open: true,\n * properties: [{ name: 'My property'}]\n * }, { at: 0 });\n * // With `at: 0` we place the new sector at the beginning of the collection\n * */\n addSector(id, sector, opts = {}) {\n let result = this.getSector(id);\n\n if (!result) {\n sector.id = id;\n result = sectors.add(sector, opts);\n }\n\n return result;\n },\n\n /**\n * Get sector by id\n * @param {string} id Sector id\n * @return {Sector|null}\n * @example\n * var sector = styleManager.getSector('mySector');\n * */\n getSector(id, opts = {}) {\n const res = sectors.where({ id })[0];\n !res && opts.warn && this._logNoSector(id);\n return res;\n },\n\n /**\n * Remove a sector by id\n * @param {string} id Sector id\n * @return {Sector} Removed sector\n * @example\n * const removed = styleManager.removeSector('mySector');\n */\n removeSector(id) {\n return this.getSectors().remove(this.getSector(id, { warn: 1 }));\n },\n\n /**\n * Get all sectors\n * @return {Sectors} Collection of sectors\n * */\n getSectors() {\n return sectors;\n },\n\n /**\n * Add property to the sector identified by id\n * @param {string} sectorId Sector id\n * @param {Object} property Property object\n * @param {string} [property.name=''] Name of the property\n * @param {string} [property.property=''] CSS property, eg. `min-height`\n * @param {string} [property.type=''] Type of the property: integer | radio | select | color | file | composite | stack\n * @param {Array} [property.units=[]] Unit of measure available, eg. ['px','%','em']. Only for integer type\n * @param {string} [property.unit=''] Default selected unit from `units`. Only for integer type\n * @param {number} [property.min=null] Min possible value. Only for integer type\n * @param {number} [property.max=null] Max possible value. Only for integer type\n * @param {string} [property.defaults=''] Default value\n * @param {string} [property.info=''] Some description\n * @param {string} [property.icon=''] Class name. If exists no text will be displayed\n * @param {Boolean} [property.preview=false] Show layers preview. Only for stack type\n * @param {string} [property.functionName=''] Indicates if value need to be wrapped in some function, for istance `transform: rotate(90deg)`\n * @param {Array} [property.properties=[]] Nested properties for composite and stack type\n * @param {Array} [property.layers=[]] Layers for stack properties\n * @param {Array} [property.list=[]] List of possible options for radio and select types\n * @param {Object} [options={}] Options\n * @return {Property|null} Added Property or `null` in case sector doesn't exist\n * @example\n * var property = styleManager.addProperty('mySector',{\n * name: 'Minimum height',\n * property: 'min-height',\n * type: 'select',\n * defaults: '100px',\n * list: [{\n * value: '100px',\n * name: '100',\n * },{\n * value: '200px',\n * name: '200',\n * }],\n * }, { at: 0 });\n * // With `at: 0` we place the new property at the beginning of the collection\n */\n addProperty(sectorId, property, opts = {}) {\n const sector = this.getSector(sectorId, { warn: 1 });\n let prop = null;\n if (sector) prop = sector.get('properties').add(property, opts);\n\n return prop;\n },\n\n /**\n * Get property by its CSS name and sector id\n * @param {string} sectorId Sector id\n * @param {string} name CSS property name, eg. 'min-height'\n * @return {Property|null}\n * @example\n * var property = styleManager.getProperty('mySector','min-height');\n */\n getProperty(sectorId, name) {\n const sector = this.getSector(sectorId, { warn: 1 });\n let prop = null;\n\n if (sector) {\n prop = sector.get('properties').where({ property: name });\n prop = prop.length == 1 ? prop[0] : prop;\n }\n\n return prop;\n },\n\n /**\n * Remove a property from the sector\n * @param {string} sectorId Sector id\n * @param {string} name CSS property name, eg. 'min-height'\n * @return {Property} Removed property\n * @example\n * const property = styleManager.removeProperty('mySector', 'min-height');\n */\n removeProperty(sectorId, name) {\n const props = this.getProperties(sectorId);\n return props && props.remove(this.getProperty(sectorId, name));\n },\n\n /**\n * Get properties of the sector\n * @param {string} sectorId Sector id\n * @return {Properties} Collection of properties\n * @example\n * var properties = styleManager.getProperties('mySector');\n */\n getProperties(sectorId) {\n let props = null;\n const sector = this.getSector(sectorId, { warn: 1 });\n if (sector) props = sector.get('properties');\n\n return props;\n },\n\n /**\n * Get what to style inside Style Manager. If you select the component\n * without classes the entity is the Component itself and all changes will\n * go inside its 'style' property. Otherwise, if the selected component has\n * one or more classes, the function will return the corresponding CSS Rule\n * @param {Model} model\n * @return {Model}\n */\n getModelToStyle(model) {\n const em = c.em;\n const classes = model.get('classes');\n const id = model.getId();\n\n if (em) {\n const config = em.getConfig();\n const um = em.get('UndoManager');\n const cssC = em.get('CssComposer');\n const state = !config.devicePreviewMode ? model.get('state') : '';\n const valid = classes.getStyleable();\n const hasClasses = valid.length;\n const opts = { state };\n let rule;\n\n // I stop undo manager here as after adding the CSSRule (generally after\n // selecting the component) and calling undo() it will remove the rule from\n // the collection, therefore updating it in style manager will not affect it\n // #268\n um.stop();\n\n if (hasClasses) {\n const deviceW = em.getCurrentMedia();\n rule = cssC.get(valid, state, deviceW);\n\n if (!rule) {\n rule = cssC.add(valid, state, deviceW);\n }\n } else if (config.avoidInlineStyle) {\n rule = cssC.getIdRule(id, opts);\n !rule && (rule = cssC.setIdRule(id, {}, opts));\n if (model.is('wrapper')) rule.set('wrapper', 1);\n }\n\n rule && (model = rule);\n um.start();\n }\n\n return model;\n },\n\n /**\n * Add new property type\n * @param {string} id Type ID\n * @param {Object} definition Definition of the type. Each definition contains\n * `model` (business logic), `view` (presentation logic)\n * and `isType` function which recognize the type of the\n * passed entity\n *@example\n * styleManager.addType('my-type', {\n * model: {},\n * view: {},\n * isType: (value) => {\n * if (value && value.type == 'my-type') {\n * return value;\n * }\n * },\n * })\n */\n addType(id, definition) {\n properties.addType(id, definition);\n },\n\n /**\n * Get type\n * @param {string} id Type ID\n * @return {Object} Type definition\n */\n getType(id) {\n return properties.getType(id);\n },\n\n /**\n * Get all types\n * @return {Array}\n */\n getTypes() {\n return properties.getTypes();\n },\n\n /**\n * Create new property from type\n * @param {string} id Type ID\n * @param {Object} [options={}] Options\n * @param {Object} [options.model={}] Custom model object\n * @param {Object} [options.view={}] Custom view object\n * @return {PropertyView}\n * @example\n * const propView = styleManager.createType('integer', {\n * model: {units: ['px', 'rem']}\n * });\n * propView.render();\n * propView.model.on('change:value', ...);\n * someContainer.appendChild(propView.el);\n */\n createType(id, { model = {}, view = {} } = {}) {\n const type = this.getType(id);\n\n if (type) {\n return new type.view({\n model: new type.model(model),\n config: c,\n ...view\n });\n }\n },\n\n /**\n * Select different target for the Style Manager.\n * It could be a Component, CSSRule, or a string of any CSS selector\n * @param {Component|CSSRule|String} target\n * @return {Styleable} A Component or CSSRule\n */\n setTarget(target, opts) {\n return SectView.setTarget(target, opts);\n },\n\n getEmitter() {\n return SectView.propTarget;\n },\n\n /**\n * Render sectors and properties\n * @return {HTMLElement}\n * @private\n * */\n render() {\n return SectView.render().el;\n },\n\n _logNoSector(sectorId) {\n const { em } = this;\n em && em.logWarning(`'${sectorId}' sector not found`);\n }\n };\n};\n","export default {\n stylePrefix: '',\n\n // Specify the element to use as a container, string (query) or HTMLElement\n // With the empty value, nothing will be rendered\n appendTo: '',\n\n // Enable/Disable globally the possibility to sort layers\n sortable: 1,\n\n // Enable/Disable globally the possibility to hide layers\n hidable: 1,\n\n // Hide textnodes\n hideTextnode: 1,\n\n // Indicate a query string of the element to be selected as the root of layers.\n // By default the root is the wrapper\n root: '',\n\n // Indicates if the wrapper is visible in layers\n showWrapper: 1,\n\n // Show hovered components in canvas\n showHover: 1,\n\n // Scroll to selected component in Canvas when it's selected in Layers\n // true, false or `scrollIntoView`-like options,\n // `block: 'nearest'` avoids the issue of window scolling\n scrollCanvas: { behavior: 'smooth', block: 'nearest' },\n\n // Scroll to selected component in Layers when it's selected in Canvas\n // true, false or `scrollIntoView`-like options\n scrollLayers: { behavior: 'auto', block: 'nearest' },\n\n // Highlight when a layer component is hovered\n highlightHover: 1\n};\n","import defaults from './config/config';\nimport ItemView from './view/ItemView';\nimport { isElement } from 'underscore';\n\nexport default () => {\n let em;\n let layers;\n let config = {};\n\n return {\n name: 'LayerManager',\n\n init(opts = {}) {\n config = { ...defaults, ...opts };\n config.stylePrefix = opts.pStylePrefix;\n em = config.em;\n\n return this;\n },\n\n getConfig() {\n return config;\n },\n\n onLoad() {\n layers = new ItemView({\n level: 0,\n config,\n opened: config.opened || {},\n model: em.get('DomComponents').getWrapper()\n });\n em && em.on('component:selected', this.componentChanged);\n this.componentChanged();\n },\n\n postRender() {\n const elTo = config.appendTo;\n const root = config.root;\n root && this.setRoot(root);\n\n if (elTo) {\n const el = isElement(elTo) ? elTo : document.querySelector(elTo);\n el.appendChild(this.render());\n }\n },\n\n /**\n * Set new root for layers\n * @param {HTMLElement|Component|String} el Component to be set as the root\n * @return {self}\n */\n setRoot(el) {\n layers.setRoot(el);\n return this;\n },\n\n /**\n * Get the root of layers\n * @return {Component}\n */\n getRoot() {\n return layers.model;\n },\n\n /**\n * Return the view of layers\n * @return {View}\n */\n getAll() {\n return layers;\n },\n\n /**\n * Triggered when the selected component is changed\n * @private\n */\n componentChanged(selected, opts = {}) {\n if (opts.fromLayers) return;\n const opened = em.get('opened');\n const model = em.getSelected();\n const scroll = config.scrollLayers;\n let parent = model && model.collection ? model.collection.parent : null;\n for (let cid in opened) opened[cid].set('open', 0);\n\n while (parent) {\n parent.set('open', 1);\n opened[parent.cid] = parent;\n parent = parent.collection ? parent.collection.parent : null;\n }\n\n if (model && scroll) {\n const el = model.viewLayer && model.viewLayer.el;\n el && el.scrollIntoView(scroll);\n }\n },\n\n render() {\n return layers.render().el;\n }\n };\n};\n","/*!\n * Backbone.Undo.js v0.2\n * \n * Copyright (c)2013 Oliver Sartun\n * Released under the MIT License\n *\n * Documentation and full license available at\n * https://github.com/osartun/Backbone.Undo.js\n */\n\n\n(function (factory) {\n\tif (typeof define === \"function\" && define.amd) {\n\t\t// AMD support\n\t\tdefine([\"underscore\", \"backbone\"], factory);\n\t} else if (typeof exports !== 'undefined') {\n\t\t// CommonJS support\n\t\tmodule.exports = factory(\n\t\t\trequire(\"underscore\"),\n\t\t\trequire(\"backbone\")\n\t\t);\n\t} else {\n\t\t// Non-modular execution\n\t\tfactory(_, Backbone);\n }\n})(function (_, Backbone) {\n\n\tvar core_slice = Array.prototype.slice;\n\n\t/**\n\t * As call is faster than apply, this is a faster version of apply as it uses call.\n\t * \n\t * @param {Function} fn \tThe function to execute \n\t * @param {Object} ctx \tThe context the function should be called in\n\t * @param {Array} args \tThe array of arguments that should be applied to the function\n\t * @return Forwards whatever the called function returns\n\t */\n\tfunction apply (fn, ctx, args) {\n\t\treturn args.length <= 4 ?\n\t\t\tfn.call(ctx, args[0], args[1], args[2], args[3]) :\n\t\t\tfn.apply(ctx, args);\n\t}\n\n\t/**\n\t * Uses slice on an array or an array-like object.\n\t * \n\t * @param {Array|Object} \tarr \tThe array or array-like object.\n\t * @param {Number} \t\t[index]\tThe index from where the array should be sliced. Default is 0.\n\t * @return {Array} The sliced array\n\t */\n\tfunction slice (arr, index) {\n\t\treturn core_slice.call(arr, index);\n\t}\n\n\t/**\n\t * Checks if an object has one or more specific keys. The keys \n\t * don't have to be an owned property.\n\t * You can call this function either this way:\n\t * hasKeys(obj, [\"a\", \"b\", \"c\"])\n\t * or this way:\n\t * hasKeys(obj, \"a\", \"b\", \"c\")\n\t * \n\t * @param {Object} \tobj \tThe object to check on\n\t * @param {Array} \tkeys \tThe keys to check for\n\t * @return {Boolean} True, if the object has all those keys\n\t */\n\tfunction hasKeys (obj, keys) {\n\t\tif (obj == null) return false;\n\t\tif (!_.isArray(keys)) {\n\t\t\tkeys = slice(arguments, 1);\n\t\t}\n\t\treturn _.all(keys, function (key) {\n\t\t\treturn key in obj;\n\t\t});\n\t}\n\n\t/**\n\t * Returns a number that is unique per call stack. The number gets \n\t * changed after the call stack has been completely processed.\n\t * \n\t * @return {number} MagicFusionIndex\n\t */\n\tvar getMagicFusionIndex = (function () {\n\t\t// If you add several models to a collection or set several\n\t\t// attributes on a model all in sequence and yet all for\n\t\t// example in one function, then several Undo-Actions are\n\t\t// generated.\n\t\t// If you want to undo your last action only the last model\n\t\t// would be removed from the collection or the last set\n\t\t// attribute would be changed back to its previous value.\n\t\t// To prevent that we have to figure out a way to combine\n\t\t// all those actions that happened \"at the same time\". \n\t\t// Timestamps aren't exact enough. A complex routine could \n\t\t// run several milliseconds and in that time produce a lot \n\t\t// of actions with different timestamps.\n\t\t// Instead we take advantage of the single-threadedness of\n\t\t// JavaScript:\n\n\t\tvar callstackWasIndexed = false, magicFusionIndex = -1;\n\t\tfunction indexCycle() {\n\t\t\tmagicFusionIndex++;\n\t\t\tcallstackWasIndexed = true;\n\t\t\t_.defer(function () {\n\t\t\t\t// Here comes the magic. With a Timeout of 0 \n\t\t\t\t// milliseconds this function gets called whenever\n\t\t\t\t// the current callstack is completed\n\t\t\t\tcallstackWasIndexed = false;\n\t\t\t})\n\t\t}\n\t\treturn function () {\n\t\t\tif (!callstackWasIndexed) {\n\t\t\t\tindexCycle();\n\t\t\t}\n\t\t\treturn magicFusionIndex;\n\t\t}\n\t})();\n\n\t/**\n\t * To prevent binding a listener several times to one \n\t * object, we register the objects in an ObjectRegistry\n\t *\n\t * @constructor\n\t */\n\tfunction ObjectRegistry () {\n\t\t// This uses two different ways of storing\n\t\t// objects: In case the object has a cid\n\t\t// (which Backbone objects typically have)\n\t\t// it uses this cid as an index. That way\n\t\t// the Array's length attribute doesn't \n\t\t// change and the object isn't an item \n\t\t// in the array, but an object-property.\n\t\t// Otherwise it's added to the Array as an\n\t\t// item.\n\t\t// That way we can use the fast property-\n\t\t// lookup and only have to fall back to \n\t\t// iterating over the array in case \n\t\t// non-Backbone-objects are registered.\n\t\tthis.registeredObjects = [];\n\t\t// To return a list of all registered \n\t\t// objects in the 'get' method we have to\n\t\t// store the objects that have a cid in\n\t\t// an additional array. \n\t\tthis.cidIndexes = [];\n\t}\n\tObjectRegistry.prototype = {\n\t\t/**\n\t\t * Returns whether the object is already registered in this ObjectRegistry or not.\n\t\t * \n\t\t * @this \t{ObjectRegistry}\n\t\t * @param \t{Object} \t\t obj \tThe object to check\n\t\t * @return \t{Boolean} True if the object is already registered\n\t\t */\n\t\tisRegistered: function (obj) {\n\t\t\t// This is where we get a performance boost \n\t\t\t// by using the two different ways of storing \n\t\t\t// objects.\n\t\t\treturn obj && obj.cid ? this.registeredObjects[obj.cid] : _.contains(this.registeredObjects, obj);\n\t\t},\n\t\t/**\n\t\t * Registers an object in this ObjectRegistry.\n\t\t * \n\t\t * @this \t{ObjectRegistry}\n\t\t * @param \t{Object} \t\t obj \tThe object to register\n\t\t * @return \t{undefined}\n\t\t */\n\t\tregister: function (obj) {\n\t\t\tif (!this.isRegistered(obj)) {\n\t\t\t\tif (obj && obj.cid) {\n\t\t\t\t\tthis.registeredObjects[obj.cid] = obj;\n\t\t\t\t\tthis.cidIndexes.push(obj.cid);\n\t\t\t\t} else {\n\t\t\t\t\tthis.registeredObjects.push(obj);\n\t\t\t\t}\n\t\t\t\treturn true;\n\t\t\t}\n\t\t\treturn false;\n\t\t},\n\t\t/**\n\t\t * Unregisters an object from this ObjectRegistry.\n\t\t * \n\t\t * @this {ObjectRegistry}\n\t\t * @param {Object} obj The object to unregister\n\t\t * @return {undefined}\n\t\t */\n\t\tunregister: function (obj) {\n\t\t\tif (this.isRegistered(obj)) {\n\t\t\t\tif (obj && obj.cid) {\n\t\t\t\t\tdelete this.registeredObjects[obj.cid];\n\t\t\t\t\tthis.cidIndexes.splice(_.indexOf(this.cidIndexes, obj.cid), 1);\n\t\t\t\t} else {\n\t\t\t\t\tvar i = _.indexOf(this.registeredObjects, obj);\n\t\t\t\t\tthis.registeredObjects.splice(i, 1);\n\t\t\t\t}\n\t\t\t\treturn true;\n\t\t\t}\n\t\t\treturn false;\n\t\t},\n\t\t/**\n\t\t * Returns an array of all objects that are currently in this ObjectRegistry.\n\t\t * \n\t\t * @return {Array} An array of all the objects which are currently in the ObjectRegistry\n\t\t */\n\t\tget: function () {\n\t\t\treturn (_.map(this.cidIndexes, function (cid) {return this.registeredObjects[cid];}, this)).concat(this.registeredObjects);\n\t\t}\n\t}\n\n\t/**\n\t * Binds or unbinds the \"all\"-listener for one or more objects.\n\t * \n\t * @param {String} which \tEither \"on\" or \"off\"\n\t * @param {Object[]} objects \tArray of the objects on which the \"all\"-listener should be bound / unbound to\n\t * @param {Function} [fn] \t\tThe function that should be bound / unbound. Optional in case of \"off\"\n\t * @param {Object} [ctx] \tThe context the function should be called in\n\t * @return {undefined}\n\t */\n\tfunction onoff(which, objects, fn, ctx) {\n\t\tfor (var i = 0, l = objects.length, obj; i < l; i++) {\n\t\t\tobj = objects[i];\n\t\t\tif (!obj) continue;\n\t\t\tif (which === \"on\") {\n\t\t\t\tif (!ctx.objectRegistry.register(obj)) {\n\t\t\t\t\t// register returned false, so obj was already registered\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\t\t\t} else {\n\t\t\t\tif (!ctx.objectRegistry.unregister(obj)) {\n\t\t\t\t\t// unregister returned false, so obj wasn't registered\n\t\t\t\t\tcontinue;\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (_.isFunction(obj[which])) {\n\t\t\t\tobj[which](\"all\", fn, ctx);\n\t\t\t}\n\t\t}\n\t}\n\n\t/**\n\t * Calls the undo/redo-function for a specific action.\n\t * \n\t * @param {String} which \tEither \"undo\" or \"redo\"\n\t * @param {Object} action \tThe Action's attributes\n\t * @return {undefined}\n\t */\n\tfunction actionUndoRedo (which, action) {\n\t\tvar type = action.type, undoTypes = action.undoTypes, fn = !undoTypes[type] || undoTypes[type][which];\n\t\tif (_.isFunction(fn)) {\n\t\t\tfn(action.object, action.before, action.after, action.options);\n\t\t}\n\t}\n\n\t/**\n\t * The main undo/redo function.\n\t *\n\t * @param {String} \t\twhich \t Either \"undo\" or \"redo\"\n\t * @param {UndoManager} \tmanager\t The UndoManager-instance on which an \"undo\"/\"redo\"-Event is triggered afterwards\n\t * @param {UndoStack} \t\tstack \t The UndoStack on which we perform\n\t * @param {Boolean} \t\tmagic \t If true, undoes / redoes all actions with the same magicFusionIndex\n\t * @param {Boolean} \t\teverything If true, undoes / redoes every action that had been tracked\n\t * @return {undefined}\n\t */\n\tfunction managerUndoRedo (which, manager, stack, magic, everything) {\n\t\tif (stack.isCurrentlyUndoRedoing || \n\t\t\t(which === \"undo\" && stack.pointer === -1) ||\n\t\t\t(which === \"redo\" && stack.pointer === stack.length - 1)) {\n\t\t\t// We're either currently in an undo- / redo-process or \n\t\t\t// we reached the end of the stack\n\t\t\treturn;\n\t\t}\n\t\tstack.isCurrentlyUndoRedoing = true;\n\t\tvar action, actions, isUndo = which === \"undo\";\n\t\tif (everything) {\n\t\t\t// Undo / Redo all steps until you reach the stack's beginning / end\n\t\t\tactions = isUndo && stack.pointer === stack.length - 1 || // If at the stack's end calling undo\n\t\t\t\t\t !isUndo && stack.pointer === -1 ? // or at the stack's beginning calling redo\n\t\t\t\t\t _.clone(stack.models) : // => Take all the models. Otherwise:\n\t\t\t\t\t core_slice.apply(stack.models, isUndo ? [0, stack.pointer] : [stack.pointer, stack.length - 1]);\n\t\t} else {\n\t\t\t// Undo / Redo only one step\n\t\t\taction = stack.at(isUndo ? stack.pointer : stack.pointer + 1);\n\t\t\tactions = magic ? stack.where({\"magicFusionIndex\": action.get(\"magicFusionIndex\")}) : [action];\n\t\t}\n\t\t\n\t\tstack.pointer += (isUndo ? -1 : 1) * actions.length;\n\t\twhile (action = isUndo ? actions.pop() : actions.shift()) {\n\t\t\t// Here we're calling the Action's undo / redo method\n\t\t\taction[which]();\n\t\t}\n\t\tstack.isCurrentlyUndoRedoing = false;\n\n\t\tmanager.trigger(which, manager);\n\t}\n\n\t/**\n\t * Checks whether an UndoAction should be created or not. Therefore it checks\n\t * whether a \"condition\" property is set in the undoTypes-object of the specific\n\t * event type. If not, it returns true. If it's set and a boolean, it returns it.\n\t * If it's a function, it returns its result, converting it into a boolean. \n\t * Otherwise it returns true.\n\t * \n\t * @param {Object} \tundoTypesType \tThe object within the UndoTypes that holds the function for this event type (i.e. \"change\")\n\t * @param {Arguments} \targs \t\tThe arguments the \"condition\" function is called with\n\t * @return {Boolean} \tTrue, if an UndoAction should be created\n\t */\n\tfunction validateUndoActionCreation (undoTypesType, args) {\n\t\tvar condition = undoTypesType.condition, type = typeof condition;\n\t\treturn type === \"function\" ? !!apply(condition, undoTypesType, args) :\n\t\t\ttype === \"boolean\" ? condition : true;\n\t}\n\n\t/**\n\t * Adds an Undo-Action to the stack.\n\t * \n\t * @param {UndoStack} \t\tstack \t\tThe undostack the action should be added to.\n\t * @param {String} \t\t\ttype \t\tThe event type (i.e. \"change\")\n\t * @param {Arguments} \t\targs \t\tThe arguments passed to the undoTypes' \"on\"-handler\n\t * @param {OwnedUndoTypes} \tundoTypes \tThe undoTypes-object which has the \"on\"-handler\n\t * @return {undefined}\n\t */\n\tfunction addToStack(stack, type, args, undoTypes) {\n\t\tif (stack.track && !stack.isCurrentlyUndoRedoing && type in undoTypes &&\n\t\t\tvalidateUndoActionCreation(undoTypes[type], args)) {\n\t\t\t// An UndoAction should be created\n\t\t\tvar res = apply(undoTypes[type][\"on\"], undoTypes[type], args), diff;\n\t\t\tif (hasKeys(res, \"object\", \"before\", \"after\")) {\n\t\t\t\tres.type = type;\n\t\t\t\tres.magicFusionIndex = getMagicFusionIndex();\n\t\t\t\tres.undoTypes = undoTypes;\n\t\t\t\tif (stack.pointer < stack.length - 1) {\n\t\t\t\t\t// New Actions must always be added to the end of the stack.\n\t\t\t\t\t// If the pointer is not pointed to the last action in the\n\t\t\t\t\t// stack, presumably because actions were undone before, then\n\t\t\t\t\t// all following actions must be discarded\n\t\t\t\t\tvar diff = stack.length - stack.pointer - 1;\n\t\t\t\t\twhile (diff--) {\n\t\t\t\t\t\tstack.pop();\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\tstack.pointer = stack.length;\n\t\t\t\tstack.add(res);\n\t\t\t\tif (stack.length > stack.maximumStackLength) {\n\t\t\t\t\tstack.shift();\n\t\t\t\t\tstack.pointer--;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\n\t/**\n\t * Predefined UndoTypes object with default handlers for the most common events.\n\t * @type {Object}\n\t */\n\tvar UndoTypes = {\n\t\t\"add\": {\n\t\t\t\"undo\": function (collection, ignore, model, options) {\n\t\t\t\t// Undo add = remove\n\t\t\t\tcollection.remove(model, options);\n\t\t\t},\n\t\t\t\"redo\": function (collection, ignore, model, options) {\n\t\t\t\t// Redo add = add\n\t\t\t\tif (options.index) {\n\t\t\t\t\toptions.at = options.index;\n\t\t\t\t}\n\t\t\t\tcollection.add(model, options);\n\t\t\t},\n\t\t\t\"on\": function (model, collection, options) {\n\t\t\t\treturn {\n\t\t\t\t\tobject: collection,\n\t\t\t\t\tbefore: undefined,\n\t\t\t\t\tafter: model,\n\t\t\t\t\toptions: _.clone(options)\n\t\t\t\t};\n\t\t\t}\n\t\t},\n\t\t\"remove\": {\n\t\t\t\"undo\": function (collection, model, ignore, options) {\n\t\t\t\tif (\"index\" in options) {\n\t\t\t\t\toptions.at = options.index;\n\t\t\t\t}\n\t\t\t\tcollection.add(model, options);\n\t\t\t},\n\t\t\t\"redo\": function (collection, model, ignore, options) {\n\t\t\t\tcollection.remove(model, options);\n\t\t\t},\n\t\t\t\"on\": function (model, collection, options) {\n\t\t\t\treturn {\n\t\t\t\t\tobject: collection,\n\t\t\t\t\tbefore: model,\n\t\t\t\t\tafter: undefined,\n\t\t\t\t\toptions: _.clone(options)\n\t\t\t\t};\n\t\t\t}\n\t\t},\n\t\t\"change\": {\n\t\t\t\"undo\": function (model, before, after, options) {\n\t\t\t\tif (_.isEmpty(before)) {\n\t\t\t\t\t_.each(_.keys(after), model.unset, model);\n\t\t\t\t} else {\n\t\t\t\t\tmodel.set(before);\n\t\t\t\t\tif (options && options.unsetData && options.unsetData.before && options.unsetData.before.length) {\n\t\t\t\t\t\t_.each(options.unsetData.before, model.unset, model);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t},\n\t\t\t\"redo\": function (model, before, after, options) {\n\t\t\t\tif (_.isEmpty(after)) {\n\t\t\t\t\t_.each(_.keys(before), model.unset, model);\n\t\t\t\t} else {\n\t\t\t\t\tmodel.set(after);\n\t\t\t\t\tif (options && options.unsetData && options.unsetData.after && options.unsetData.after.length) {\n\t\t\t\t\t\t_.each(options.unsetData.after, model.unset, model);\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t},\n\t\t\t\"on\": function (model, options) {\n\t\t\t\tvar\n\t\t\t\tafterAttributes = model.changedAttributes(),\n\t\t\t\tkeysAfter = _.keys(afterAttributes),\n\t\t\t\tpreviousAttributes = _.pick(model.previousAttributes(), keysAfter),\n\t\t\t\tkeysPrevious = _.keys(previousAttributes),\n\t\t\t\tunsetData = (options || (options = {})).unsetData = {\n\t\t\t\t\tafter: [],\n\t\t\t\t\tbefore: []\n\t\t\t\t};\n\n\t\t\t\tif (keysAfter.length != keysPrevious.length) {\n\t\t\t\t\t// There are new attributes or old attributes have been unset\n\t\t\t\t\tif (keysAfter.length > keysPrevious.length) {\n\t\t\t\t\t\t// New attributes have been added\n\t\t\t\t\t\t_.each(keysAfter, function (val) {\n\t\t\t\t\t\t\tif (!(val in previousAttributes)) {\n\t\t\t\t\t\t\t\tunsetData.before.push(val);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t}, this);\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// Old attributes have been unset\n\t\t\t\t\t\t_.each(keysPrevious, function (val) {\n\t\t\t\t\t\t\tif (!(val in afterAttributes)) {\n\t\t\t\t\t\t\t\tunsetData.after.push(val);\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t})\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t\treturn {\n\t\t\t\t\tobject: model,\n\t\t\t\t\tbefore: previousAttributes,\n\t\t\t\t\tafter: afterAttributes,\n\t\t\t\t\toptions: _.clone(options)\n\t\t\t\t};\n\t\t\t}\n\t\t},\n\t\t\"reset\": {\n\t\t\t\"undo\": function (collection, before, after) {\n\t\t\t\tcollection.reset(before);\n\t\t\t},\n\t\t\t\"redo\": function (collection, before, after) {\n\t\t\t\tcollection.reset(after);\n\t\t\t},\n\t\t\t\"on\": function (collection, options) {\n\t\t\t\treturn {\n\t\t\t\t\tobject: collection,\n\t\t\t\t\tbefore: options.previousModels,\n\t\t\t\t\tafter: _.clone(collection.models)\n\t\t\t\t};\n\t\t\t}\n\t\t}\n\t};\n\n\t/**\n\t * Every UndoManager instance has an own undoTypes object\n\t * which is an instance of OwnedUndoTypes. OwnedUndoTypes' \n\t * prototype is the global UndoTypes object. Changes to the \n\t * global UndoTypes object take effect on every instance of\n\t * UndoManager as the object is its prototype. And yet every \n\t * local UndoTypes object can be changed individually.\n\t *\n\t * @constructor\n\t */\n\tfunction OwnedUndoTypes () {}\n\tOwnedUndoTypes.prototype = UndoTypes;\n\n\t/**\n\t * Adds, changes or removes an undo-type from an UndoTypes-object.\n\t * You can call it this way:\n\t * manipulateUndoType (1, \"reset\", {\"on\": function () {}}, undoTypes)\n\t * or this way to perform bulk actions:\n\t * manipulateUndoType (1, {\"reset\": {\"on\": function () {}}}, undoTypes)\n\t * In case of removing undo-types you can pass an Array for performing\n\t * bulk actions:\n\t * manipulateUndoType(2, [\"reset\", \"change\"], undoTypes)\n\t * \n\t * @param {Number} \t\t\t\t manipType \t\tIndicates the kind of action to execute: 0 for add, 1 for change, 2 for remove\n\t * @param {String|Object|Array} \t undoType \t\t\tThe type of undoType that should be added/changed/removed. Can be an object / array to perform bulk actions\n\t * @param {Object} \t\t\t\t [fns] \t\t\tObject with the functions to add / change. Is optional in case you passed an object as undoType that contains these functions\n\t * @param {OwnedUndoTypes|UndoTypes} undoTypesInstance The undoTypes object to act on\n\t * @return {undefined}\n\t */\n\tfunction manipulateUndoType (manipType, undoType, fns, undoTypesInstance) {\n\t\t// manipType, passed by the calling function\n\t\t// 0: add\n\t\t// 1: change\n\t\t// 2: remove\n\t\tif (typeof undoType === \"object\") {\n\t\t\t// bulk action. Iterate over this data.\n\t\t\treturn _.each(undoType, function (val, key) {\n\t\t\t\t\tif (manipType === 2) { // remove\n\t\t\t\t\t\t// undoType is an array\n\t\t\t\t\t\tmanipulateUndoType (manipType, val, fns, undoTypesInstance);\n\t\t\t\t\t} else {\n\t\t\t\t\t\t// undoType is an object\n\t\t\t\t\t\tmanipulateUndoType (manipType, key, val, fns);\n\t\t\t\t\t}\n\t\t\t\t})\n\t\t}\n\n\t\tswitch (manipType) {\n\t\t\tcase 0: // add\n\t\t\t\tif (hasKeys(fns, \"undo\", \"redo\", \"on\") && _.all(_.pick(fns, \"undo\", \"redo\", \"on\"), _.isFunction)) {\n\t\t\t\t\tundoTypesInstance[undoType] = fns;\n\t\t\t\t} \n\t\t\tbreak;\n\t\t\tcase 1: // change\n\t\t\t\tif (undoTypesInstance[undoType] && _.isObject(fns)) {\n\t\t\t\t\t// undoTypeInstance[undoType] may be a prototype's property\n\t\t\t\t\t// So, if we did this _.extend(undoTypeInstance[undoType], fns)\n\t\t\t\t\t// we would extend the object on the prototype which means\n\t\t\t\t\t// that this change would have a global effect\n\t\t\t\t\t// Instead we just want to manipulate this instance. That's why\n\t\t\t\t\t// we're doing this:\n\t\t\t\t\tundoTypesInstance[undoType] = _.extend({}, undoTypesInstance[undoType], fns);\n\t\t\t\t} \n\t\t\tbreak;\n\t\t\tcase 2: // remove\n\t\t\t\tdelete undoTypesInstance[undoType]; \n\t\t\tbreak;\n\t\t}\n\t\treturn this;\n\t}\n\n\t/**\n\t * Instantiating \"Action\" creates the UndoActions that \n\t * are collected in an UndoStack. It holds all relevant \n\t * data to undo / redo an action and has an undo / redo \n\t * method.\n\t */\n\tvar Action = Backbone.Model.extend({\n\t\tdefaults: {\n\t\t\ttype: null, // \"add\", \"change\", \"reset\", etc.\n\t\t\tobject: null, // The object on which the action occurred\n\t\t\tbefore: null, // The previous values which were changed with this action\n\t\t\tafter: null, // The values after this action\n\t\t\tmagicFusionIndex: null // The magicFusionIndex helps to combine \n\t\t\t// all actions that occurred \"at the same time\" to undo/redo them altogether\n\t\t},\n\t\t/**\n\t\t * Undoes this action.\n\t\t * @param {OwnedUndoTypes|UndoTypes} undoTypes The undoTypes object which contains the \"undo\"-handler that should be used\n\t\t * @return {undefined}\n\t\t */\n\t\tundo: function (undoTypes) {\n\t\t\tactionUndoRedo(\"undo\", this.attributes);\n\t\t},\n\t\t/**\n\t\t * Redoes this action.\n\t\t * @param {OwnedUndoTypes|UndoTypes} undoTypes The undoTypes object which contains the \"redo\"-handler that should be used\n\t\t * @return {undefined}\n\t\t */\n\t\tredo: function (undoTypes) {\n\t\t\tactionUndoRedo(\"redo\", this.attributes);\n\t\t}\n\t}),\n\t/**\n\t * An UndoStack is a collection of UndoActions in \n\t * chronological order.\n\t */\n\tUndoStack = Backbone.Collection.extend({\n\t\tmodel: Action,\n\t\tpointer: -1, // The pointer indicates the index where we are located within the stack. We start at -1\n\t\ttrack: false,\n\t\tisCurrentlyUndoRedoing: false,\n\t\tmaximumStackLength: Infinity,\n\t\tsetMaxLength: function (val) {\n\t\t\tthis.maximumStackLength = val;\n\t\t}\n\t}),\n\t/**\n\t * An instance of UndoManager can keep track of \n\t * changes to objects and helps to undo them.\n\t */\n\tUndoManager = Backbone.Model.extend({\n\t\tdefaults: {\n\t\t\tmaximumStackLength: Infinity,\n\t\t\ttrack: false\n\t\t},\n\t\t/**\n\t\t * The constructor function.\n\t\t * @param {attr} \t\t[attr] Object with parameters. The available parameters are:\n\t\t * \t - maximumStackLength {number} \tSet the undo-stack's maximum size\n\t\t * - track \t\t\t\t{boolean}\tStart tracking changes right away\n\t\t * @return {undefined}\n\t\t */\n\t\tinitialize: function (attr) {\n\t\t\tthis.stack = new UndoStack;\n\t\t\tthis.objectRegistry = new ObjectRegistry();\n\t\t\tthis.undoTypes = new OwnedUndoTypes();\n\n\t\t\t// sync the maximumStackLength attribute with our stack\n\t\t\tthis.stack.setMaxLength(this.get(\"maximumStackLength\"));\n\t\t\tthis.on(\"change:maximumStackLength\", function (model, value) {\n\t\t\t\tthis.stack.setMaxLength(value);\n\t\t\t}, this);\n\n\t\t\t// Start tracking, if attr.track == true\n\t\t\tif (attr && attr.track) {\n\t\t\t\tthis.startTracking();\n\t\t\t}\n\n\t\t\t// Register objects passed in the \"register\" attribute\n\t\t\tif (attr && attr.register) {\n\t\t\t\tif (_.isArray(attr.register) || _.isArguments(attr.register)) {\n\t\t\t\t\tapply(this.register, this, attr.register);\n\t\t\t\t} else {\n\t\t\t\t\tthis.register(attr.register);\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\t\t/**\n\t\t * Starts tracking. Changes of registered objects won't be processed until you've called this function\n\t\t * @return {undefined}\n\t\t */\n\t\tstartTracking: function () {\n\t\t\tthis.set(\"track\", true);\n\t\t\tthis.stack.track = true;\n\t\t},\n\t\t/**\n\t\t * Stops tracking. Afterwards changes of registered objects won't be processed.\n\t\t * @return {undefined}\n\t\t */\n\t\tstopTracking: function () {\n\t\t\tthis.set(\"track\", false);\n\t\t\tthis.stack.track = false;\n\t\t},\n\t\t/**\n\t\t * Return the state of the tracking\n\t\t * @return {boolean}\n\t\t */\n\t\tisTracking: function () {\n\t\t\treturn this.get(\"track\");\n\t\t},\n\t\t/**\n\t\t * This is the \"all\"-handler which is bound to registered \n\t\t * objects. It creates an UndoAction from the event and adds \n\t\t * it to the stack.\n\t\t * \n\t\t * @param {String} \ttype \tThe event type\n\t\t * @return {undefined}\n\t\t */\n\t\t_addToStack: function (type) {\n\t\t\taddToStack(this.stack, type, slice(arguments, 1), this.undoTypes);\n\t\t},\n\t\t/**\n\t\t * Registers one or more objects to track their changes.\n\t\t * @param {...Object} \tobj \tThe object or objects of which changes should be tracked\n\t\t * @return {undefined}\n\t\t */\n\t\tregister: function () {\n\t\t\tonoff(\"on\", arguments, this._addToStack, this);\n\t\t},\n\t\t/**\n\t\t * Unregisters one or more objects.\n\t\t * @param {...Object} \tobj \tThe object or objects of which changes shouldn't be tracked any longer\n\t\t * @return {undefined}\n\t\t */\n\t\tunregister: function () {\n\t\t\tonoff(\"off\", arguments, this._addToStack, this);\n\t\t},\n\t\t/**\n\t\t * Unregisters all previously registered objects.\n\t\t * @return {undefined}\n\t\t */\n\t\tunregisterAll: function () {\n\t\t\tapply(this.unregister, this, this.objectRegistry.get());\n\t\t},\n\t\t/**\n\t\t * Undoes the last action or the last set of actions in case 'magic' is true.\n\t\t * @param {Boolean} \t[magic] \tIf true, all actions that happened basically at the same time are undone together\n\t\t * @return {undefined}\n\t\t */\n\t\tundo: function (magic) {\n\t\t\tmanagerUndoRedo(\"undo\", this, this.stack, magic);\n\t\t},\n\n\t\t/**\n\t\t * Undoes all actions ever tracked by the undo manager\n\t\t * @return {undefined}\n\t\t */\n\t\tundoAll: function () {\n\t\t\tmanagerUndoRedo(\"undo\", this, this.stack, false, true);\n\t\t},\n\n\t\t/**\n\t\t * Redoes a previously undone action or a set of actions.\n\t\t * @param {Boolean} \t[magic] \tIf true, all actions that happened basically at the same time are redone together\n\t\t * @return {undefined}\n\t\t */\n\t\tredo: function (magic) {\n\t\t\tmanagerUndoRedo(\"redo\", this, this.stack, magic);\n\t\t},\n\n\t\t/**\n\t\t * Redoes all actions ever tracked by the undo manager\n\t\t * @return {undefined}\n\t\t */\n\t\tredoAll: function () {\n\t\t\tmanagerUndoRedo(\"redo\", this, this.stack, false, true);\n\t\t},\n\t\t/**\n\t\t * Checks if there's an action in the stack that can be undone / redone\n\t\t * @param {String} \ttype \tEither \"undo\" or \"redo\"\n\t\t * @return {Boolean} True if there is a set of actions which can be undone / redone\n\t\t */\n\t\tisAvailable: function (type) {\n\t\t\tvar s = this.stack, l = s.length;\n\n\t\t\tswitch (type) {\n\t\t\t\tcase \"undo\": return l > 0 && s.pointer > -1;\n\t\t\t\tcase \"redo\": return l > 0 && s.pointer < l - 1;\n\t\t\t\tdefault: return false;\n\t\t\t}\n\t\t},\n\t\t/**\n\t\t * Sets the stack-reference to the stack of another undoManager.\n\t\t * @param {UndoManager} \tundoManager \tThe undoManager whose stack-reference is set to this stack\n\t\t * @return {undefined}\n\t\t */\n\t\tmerge: function (undoManager) {\n\t\t\t// This sets the stack-reference to the stack of another \n\t\t\t// undoManager so that the stack of this other undoManager \n\t\t\t// is used by two different managers.\n\t\t\t// This enables to set up a main-undoManager and besides it\n\t\t\t// several others for special, exceptional cases (by using\n\t\t\t// instance-based custom UndoTypes). Models / collections \n\t\t\t// which need this special treatment are only registered at \n\t\t\t// those special undoManagers. Those special ones are then \n\t\t\t// merged into the main-undoManager to write on its stack. \n\t\t\t// That way it's easier to manage exceptional cases.\n\t\t\tvar args = _.isArray(undoManager) ? undoManager : slice(arguments), manager;\n\t\t\twhile (manager = args.pop()) {\n\t\t\t\tif (manager instanceof UndoManager &&\n\t\t\t\t\tmanager.stack instanceof UndoStack) {\n\t\t\t\t\t// set the stack reference to our stack\n\t\t\t\t\tmanager.stack = this.stack;\n\t\t\t\t}\n\t\t\t}\n\t\t},\n\t\t/**\n\t\t * Add an UndoType to this specific UndoManager-instance.\n\t\t * @param {String} type The event this UndoType is made for\n\t\t * @param {Object} fns An object of functions that are called to generate the data for an UndoAction or to process it. Must have the properties \"undo\", \"redo\" and \"on\". Can have the property \"condition\".\n\t\t * @return {undefined}\n\t\t */\n\t\taddUndoType: function (type, fns) {\n\t\t\tmanipulateUndoType(0, type, fns, this.undoTypes);\n\t\t},\n\t\t/**\n\t\t * Overwrite properties of an existing UndoType for this specific UndoManager-instance.\n\t\t * @param {String} type The event the UndoType is made for\n\t\t * @param {Object} fns An object of functions that are called to generate the data for an UndoAction or to process it. It extends the existing object.\n\t\t * @return {undefined}\n\t\t */\n\t\tchangeUndoType: function (type, fns) {\n\t\t\tmanipulateUndoType(1, type, fns, this.undoTypes);\n\t\t},\n\t\t/**\n\t\t * Remove one or more UndoTypes of this specific UndoManager-instance to fall back to the global UndoTypes.\n\t\t * @param {String|Array} type The event the UndoType that should be removed is made for. You can also pass an array of events.\n\t\t * @return {undefined}\n\t\t */\n\t\tremoveUndoType: function (type) {\n\t\t\tmanipulateUndoType(2, type, undefined, this.undoTypes);\n\t\t},\n\n\t\t/**\n\t\t * Removes all actions from the stack.\n\t\t * @return {undefined}\n\t\t */\n\t\tclear: function() {\n\t\t\tthis.stack.reset();\n\t\t\tthis.stack.pointer = -1;\n\t\t}\n\t});\n\n\t_.extend(UndoManager, {\n\t\t/**\n\t\t * Change the UndoManager's default attributes\n\t\t * @param {Object} defaultAttributes An object with the new default values.\n\t\t * @return {undefined}\n\t\t */\n\t\tdefaults: function (defaultAttributes) {\n\t\t\t_.extend(UndoManager.prototype.defaults, defaultAttributes);\n\t\t},\n\t\t/**\n\t\t * Add an UndoType to the global UndoTypes-object.\n\t\t * @param {String} type The event this UndoType is made for\n\t\t * @param {Object} fns An object of functions that are called to generate the data for an UndoAction or to process it. Must have the properties \"undo\", \"redo\" and \"on\". Can have the property \"condition\".\n\t\t * @return {undefined}\n\t\t */\n\t\t\"addUndoType\": function (type, fns) {\n\t\t\tmanipulateUndoType(0, type, fns, UndoTypes);\n\t\t},\n\t\t/**\n\t\t * Overwrite properties of an existing UndoType in the global UndoTypes-object.\n\t\t * @param {String} type The event the UndoType is made for\n\t\t * @param {Object} fns An object of functions that are called to generate the data for an UndoAction or to process it. It extends the existing object.\n\t\t * @return {undefined}\n\t\t */\n\t\t\"changeUndoType\": function (type, fns) {\n\t\t\tmanipulateUndoType(1, type, fns, UndoTypes)\n\t\t},\n\t\t/**\n\t\t * Remove one or more UndoTypes of this specific UndoManager-instance to fall back to the global UndoTypes.\n\t\t * @param {String|Array} type The event the UndoType that should be removed is made for. You can also pass an array of events.\n\t\t * @return {undefined}\n\t\t */\n\t\t\"removeUndoType\": function (type) {\n\t\t\tmanipulateUndoType(2, type, undefined, UndoTypes);\n\t\t}\n\t})\n\n\treturn Backbone.UndoManager = UndoManager;\n\n});\n","/**\n * @this {Promise}\n */\nfunction finallyConstructor(callback) {\n var constructor = this.constructor;\n return this.then(\n function(value) {\n // @ts-ignore\n return constructor.resolve(callback()).then(function() {\n return value;\n });\n },\n function(reason) {\n // @ts-ignore\n return constructor.resolve(callback()).then(function() {\n // @ts-ignore\n return constructor.reject(reason);\n });\n }\n );\n}\n\nexport default finallyConstructor;\n","var arrayWithHoles = require(\"./arrayWithHoles\");\n\nvar iterableToArrayLimit = require(\"./iterableToArrayLimit\");\n\nvar nonIterableRest = require(\"./nonIterableRest\");\n\nfunction _slicedToArray(arr, i) {\n return arrayWithHoles(arr) || iterableToArrayLimit(arr, i) || nonIterableRest();\n}\n\nmodule.exports = _slicedToArray;","module.exports = function(module) {\n\tif (!module.webpackPolyfill) {\n\t\tmodule.deprecate = function() {};\n\t\tmodule.paths = [];\n\t\t// module.parent = undefined by default\n\t\tif (!module.children) module.children = [];\n\t\tObject.defineProperty(module, \"loaded\", {\n\t\t\tenumerable: true,\n\t\t\tget: function() {\n\t\t\t\treturn module.l;\n\t\t\t}\n\t\t});\n\t\tObject.defineProperty(module, \"id\", {\n\t\t\tenumerable: true,\n\t\t\tget: function() {\n\t\t\t\treturn module.i;\n\t\t\t}\n\t\t});\n\t\tmodule.webpackPolyfill = 1;\n\t}\n\treturn module;\n};\n","/**\n * You can customize the initial state of the module from the editor initialization\n * ```js\n * const editor = grapesjs.init({\n * keymaps: {\n * // Object of keymaps\n * defaults: {\n * 'your-namespace:keymap-name' {\n * keys: '⌘+z, ctrl+z',\n * handler: 'some-command-id'\n * },\n * ...\n * }\n * }\n * })\n * ```\n *\n * Once the editor is instantiated you can use its API. Before using these methods you should get the module from the instance\n *\n * ```js\n * const keymaps = editor.Keymaps;\n * ```\n *\n * * [getConfig](#getconfig)\n * * [add](#add)\n * * [get](#get)\n * * [getAll](#getAll)\n * * [remove](#remove)\n * * [removeAll](#removeall)\n *\n * @module Keymaps\n */\n\nimport { isString } from 'underscore';\nimport keymaster from 'keymaster';\n\nexport default () => {\n let em;\n let config;\n const keymaps = {};\n const configDef = {\n defaults: {\n 'core:undo': {\n keys: '⌘+z, ctrl+z',\n handler: 'core:undo'\n },\n 'core:redo': {\n keys: '⌘+shift+z, ctrl+shift+z',\n handler: 'core:redo'\n },\n 'core:copy': {\n keys: '⌘+c, ctrl+c',\n handler: 'core:copy'\n },\n 'core:paste': {\n keys: '⌘+v, ctrl+v',\n handler: 'core:paste'\n },\n 'core:component-next': {\n keys: 's',\n handler: 'core:component-next'\n },\n 'core:component-prev': {\n keys: 'w',\n handler: 'core:component-prev'\n },\n 'core:component-enter': {\n keys: 'd',\n handler: 'core:component-enter'\n },\n 'core:component-exit': {\n keys: 'a',\n handler: 'core:component-exit'\n },\n 'core:component-delete': {\n keys: 'backspace, delete',\n handler: 'core:component-delete'\n }\n }\n };\n\n return {\n keymaster,\n\n name: 'Keymaps',\n\n /**\n * Get module configurations\n * @return {Object} Configuration object\n */\n getConfig() {\n return config;\n },\n\n /**\n * Initialize module\n * @param {Object} config Configurations\n * @private\n */\n init(opts = {}) {\n config = { ...configDef, ...opts };\n em = config.em;\n this.em = em;\n return this;\n },\n\n onLoad() {\n const defKeys = config.defaults;\n\n for (let id in defKeys) {\n const value = defKeys[id];\n this.add(id, value.keys, value.handler);\n }\n },\n\n /**\n * Add new keymap\n * @param {string} id Keymap id\n * @param {string} keys Keymap keys, eg. `ctrl+a`, `⌘+z, ctrl+z`\n * @param {Function|string} handler Keymap handler, might be a function\n * @param {Object} [opts={}] Options\n * @return {Object} Added keymap\n * or just a command id as a string\n * @example\n * // 'ns' is just a custom namespace\n * keymaps.add('ns:my-keymap', '⌘+j, ⌘+u, ctrl+j, alt+u', editor => {\n * console.log('do stuff');\n * });\n * // or\n * keymaps.add('ns:my-keymap', '⌘+s, ctrl+s', 'some-gjs-command');\n *\n * // listen to events\n * editor.on('keymap:emit', (id, shortcut, e) => {\n * // ...\n * })\n */\n add(id, keys, handler, opts = {}) {\n const { em } = this;\n const cmd = em.get('Commands');\n const editor = em.getEditor();\n const canvas = em.get('Canvas');\n const keymap = { id, keys, handler };\n const pk = keymaps[id];\n pk && this.remove(id);\n keymaps[id] = keymap;\n keymaster(keys, (e, h) => {\n // It's safer putting handlers resolution inside the callback\n const opt = { event: e, h };\n handler = isString(handler) ? cmd.get(handler) : handler;\n opts.prevent && canvas.getCanvasView().preventDefault(e);\n const ableTorun = !em.isEditing() && !editor.Canvas.isInputFocused();\n if (ableTorun || opts.force) {\n typeof handler == 'object'\n ? handler.run(editor, 0, opt)\n : handler(editor, 0, opt);\n const args = [id, h.shortcut, e];\n em.trigger('keymap:emit', ...args);\n em.trigger(`keymap:emit:${id}`, ...args);\n }\n });\n em.trigger('keymap:add', keymap);\n return keymap;\n },\n\n /**\n * Get the keymap by id\n * @param {string} id Keymap id\n * @return {Object} Keymap object\n * @example\n * keymaps.get('ns:my-keymap');\n * // -> {keys, handler};\n */\n get(id) {\n return keymaps[id];\n },\n\n /**\n * Get all keymaps\n * @return {Object}\n * @example\n * keymaps.getAll();\n * // -> {id1: {}, id2: {}};\n */\n getAll() {\n return keymaps;\n },\n\n /**\n * Remove the keymap by id\n * @param {string} id Keymap id\n * @return {Object} Removed keymap\n * @example\n * keymaps.remove('ns:my-keymap');\n * // -> {keys, handler};\n */\n remove(id) {\n const em = this.em;\n const keymap = this.get(id);\n\n if (keymap) {\n delete keymaps[id];\n keymaster.unbind(keymap.keys);\n em && em.trigger('keymap:remove', keymap);\n return keymap;\n }\n },\n\n /**\n * Remove all binded keymaps\n * @return {this}\n */\n removeAll() {\n Object.keys(keymaps).forEach(keymap => this.remove(keymap));\n return this;\n }\n };\n};\n","/**\n * This module allows to manage the stack of changes applied in canvas.\n * Once the editor is instantiated you can use its API. Before using these methods you should get the module from the instance\n *\n * ```js\n * const um = editor.UndoManager;\n * ```\n *\n * * [getConfig](#getconfig)\n * * [add](#add)\n * * [remove](#remove)\n * * [removeAll](#removeall)\n * * [start](#start)\n * * [stop](#stop)\n * * [undo](#undo)\n * * [undoAll](#undoall)\n * * [redo](#redo)\n * * [redoAll](#redoall)\n * * [hasUndo](#hasundo)\n * * [hasRedo](#hasredo)\n * * [getStack](#getstack)\n * * [clear](#clear)\n *\n * @module UndoManager\n */\n\nimport UndoManager from 'backbone-undo';\n\nexport default () => {\n let em;\n let um;\n let config;\n let beforeCache;\n const configDef = {};\n\n return {\n name: 'UndoManager',\n\n /**\n * Initialize module\n * @param {Object} config Configurations\n * @private\n */\n init(opts = {}) {\n config = { ...opts, ...configDef };\n em = config.em;\n this.em = em;\n um = new UndoManager({ track: true, register: [] });\n um.changeUndoType('change', { condition: false });\n um.changeUndoType('add', {\n on(model, collection, options = {}) {\n if (options.avoidStore) return;\n return {\n object: collection,\n before: undefined,\n after: model,\n options: { ...options }\n };\n }\n });\n um.changeUndoType('remove', {\n on(model, collection, options = {}) {\n if (options.avoidStore) return;\n return {\n object: collection,\n before: model,\n after: undefined,\n options: { ...options }\n };\n }\n });\n const customUndoType = {\n on(object, value, opt = {}) {\n !beforeCache && (beforeCache = object.previousAttributes());\n\n if (opt.avoidStore) {\n return;\n } else {\n const result = {\n object,\n before: beforeCache,\n after: object.toJSON()\n };\n beforeCache = null;\n return result;\n }\n },\n\n undo(model, bf, af, opt) {\n model.set(bf);\n },\n\n redo(model, bf, af, opt) {\n model.set(af);\n }\n };\n\n const events = ['style', 'attributes', 'content', 'src'];\n events.forEach(ev => um.addUndoType(`change:${ev}`, customUndoType));\n um.on('undo redo', () =>\n em.trigger('component:toggled change:canvasOffset')\n );\n ['undo', 'redo'].forEach(ev => um.on(ev, () => em.trigger(ev)));\n\n return this;\n },\n\n /**\n * Get module configurations\n * @return {Object} Configuration object\n * @example\n * const config = um.getConfig();\n * // { ... }\n */\n getConfig() {\n return config;\n },\n\n /**\n * Add an entity (Model/Collection) to track\n * Note: New Components and CSSRules will be added automatically\n * @param {Model|Collection} entity Entity to track\n * @return {this}\n * @example\n * um.add(someModelOrCollection);\n */\n add(entity) {\n um.register(entity);\n return this;\n },\n\n /**\n * Remove and stop tracking the entity (Model/Collection)\n * @param {Model|Collection} entity Entity to remove\n * @return {this}\n * @example\n * um.remove(someModelOrCollection);\n */\n remove(entity) {\n um.unregister(entity);\n return this;\n },\n\n /**\n * Remove all entities\n * @return {this}\n * @example\n * um.removeAll();\n */\n removeAll() {\n um.unregisterAll();\n return this;\n },\n\n /**\n * Start/resume tracking changes\n * @return {this}\n * @example\n * um.start();\n */\n start() {\n um.startTracking();\n return this;\n },\n\n /**\n * Stop tracking changes\n * @return {this}\n * @example\n * um.stop();\n */\n stop() {\n um.stopTracking();\n return this;\n },\n\n /**\n * Undo last change\n * @return {this}\n * @example\n * um.undo();\n */\n undo() {\n !em.isEditing() && um.undo(1);\n return this;\n },\n\n /**\n * Undo all changes\n * @return {this}\n * @example\n * um.undoAll();\n */\n undoAll() {\n um.undoAll();\n return this;\n },\n\n /**\n * Redo last change\n * @return {this}\n * @example\n * um.redo();\n */\n redo() {\n !em.isEditing() && um.redo(1);\n return this;\n },\n\n /**\n * Redo all changes\n * @return {this}\n * @example\n * um.redoAll();\n */\n redoAll() {\n um.redoAll();\n return this;\n },\n\n /**\n * Checks if exists an available undo\n * @return {Boolean}\n * @example\n * um.hasUndo();\n */\n hasUndo() {\n return um.isAvailable('undo');\n },\n\n /**\n * Checks if exists an available redo\n * @return {Boolean}\n * @example\n * um.hasRedo();\n */\n hasRedo() {\n return um.isAvailable('redo');\n },\n\n /**\n * Get stack of changes\n * @return {Collection}\n * @example\n * const stack = um.getStack();\n * stack.each(item => ...);\n */\n getStack() {\n return um.stack;\n },\n\n /**\n * Clear the stack\n * @return {this}\n * @example\n * um.clear();\n */\n clear() {\n um.clear();\n return this;\n },\n\n getInstance() {\n return um;\n }\n };\n};\n","var scope = (typeof global !== \"undefined\" && global) ||\n (typeof self !== \"undefined\" && self) ||\n window;\nvar apply = Function.prototype.apply;\n\n// DOM APIs, for completeness\n\nexports.setTimeout = function() {\n return new Timeout(apply.call(setTimeout, scope, arguments), clearTimeout);\n};\nexports.setInterval = function() {\n return new Timeout(apply.call(setInterval, scope, arguments), clearInterval);\n};\nexports.clearTimeout =\nexports.clearInterval = function(timeout) {\n if (timeout) {\n timeout.close();\n }\n};\n\nfunction Timeout(id, clearFn) {\n this._id = id;\n this._clearFn = clearFn;\n}\nTimeout.prototype.unref = Timeout.prototype.ref = function() {};\nTimeout.prototype.close = function() {\n this._clearFn.call(scope, this._id);\n};\n\n// Does not start the time, just sets up the members needed.\nexports.enroll = function(item, msecs) {\n clearTimeout(item._idleTimeoutId);\n item._idleTimeout = msecs;\n};\n\nexports.unenroll = function(item) {\n clearTimeout(item._idleTimeoutId);\n item._idleTimeout = -1;\n};\n\nexports._unrefActive = exports.active = function(item) {\n clearTimeout(item._idleTimeoutId);\n\n var msecs = item._idleTimeout;\n if (msecs >= 0) {\n item._idleTimeoutId = setTimeout(function onTimeout() {\n if (item._onTimeout)\n item._onTimeout();\n }, msecs);\n }\n};\n\n// setimmediate attaches itself to the global object\nrequire(\"setimmediate\");\n// On some exotic environments, it's not clear which object `setimmediate` was\n// able to install onto. Search each possibility in the same order as the\n// `setimmediate` library.\nexports.setImmediate = (typeof self !== \"undefined\" && self.setImmediate) ||\n (typeof global !== \"undefined\" && global.setImmediate) ||\n (this && this.setImmediate);\nexports.clearImmediate = (typeof self !== \"undefined\" && self.clearImmediate) ||\n (typeof global !== \"undefined\" && global.clearImmediate) ||\n (this && this.clearImmediate);\n","(function (global, undefined) {\n \"use strict\";\n\n if (global.setImmediate) {\n return;\n }\n\n var nextHandle = 1; // Spec says greater than zero\n var tasksByHandle = {};\n var currentlyRunningATask = false;\n var doc = global.document;\n var registerImmediate;\n\n function setImmediate(callback) {\n // Callback can either be a function or a string\n if (typeof callback !== \"function\") {\n callback = new Function(\"\" + callback);\n }\n // Copy function arguments\n var args = new Array(arguments.length - 1);\n for (var i = 0; i < args.length; i++) {\n args[i] = arguments[i + 1];\n }\n // Store and register the task\n var task = { callback: callback, args: args };\n tasksByHandle[nextHandle] = task;\n registerImmediate(nextHandle);\n return nextHandle++;\n }\n\n function clearImmediate(handle) {\n delete tasksByHandle[handle];\n }\n\n function run(task) {\n var callback = task.callback;\n var args = task.args;\n switch (args.length) {\n case 0:\n callback();\n break;\n case 1:\n callback(args[0]);\n break;\n case 2:\n callback(args[0], args[1]);\n break;\n case 3:\n callback(args[0], args[1], args[2]);\n break;\n default:\n callback.apply(undefined, args);\n break;\n }\n }\n\n function runIfPresent(handle) {\n // From the spec: \"Wait until any invocations of this algorithm started before this one have completed.\"\n // So if we're currently running a task, we'll need to delay this invocation.\n if (currentlyRunningATask) {\n // Delay by doing a setTimeout. setImmediate was tried instead, but in Firefox 7 it generated a\n // \"too much recursion\" error.\n setTimeout(runIfPresent, 0, handle);\n } else {\n var task = tasksByHandle[handle];\n if (task) {\n currentlyRunningATask = true;\n try {\n run(task);\n } finally {\n clearImmediate(handle);\n currentlyRunningATask = false;\n }\n }\n }\n }\n\n function installNextTickImplementation() {\n registerImmediate = function(handle) {\n process.nextTick(function () { runIfPresent(handle); });\n };\n }\n\n function canUsePostMessage() {\n // The test against `importScripts` prevents this implementation from being installed inside a web worker,\n // where `global.postMessage` means something completely different and can't be used for this purpose.\n if (global.postMessage && !global.importScripts) {\n var postMessageIsAsynchronous = true;\n var oldOnMessage = global.onmessage;\n global.onmessage = function() {\n postMessageIsAsynchronous = false;\n };\n global.postMessage(\"\", \"*\");\n global.onmessage = oldOnMessage;\n return postMessageIsAsynchronous;\n }\n }\n\n function installPostMessageImplementation() {\n // Installs an event handler on `global` for the `message` event: see\n // * https://developer.mozilla.org/en/DOM/window.postMessage\n // * http://www.whatwg.org/specs/web-apps/current-work/multipage/comms.html#crossDocumentMessages\n\n var messagePrefix = \"setImmediate$\" + Math.random() + \"$\";\n var onGlobalMessage = function(event) {\n if (event.source === global &&\n typeof event.data === \"string\" &&\n event.data.indexOf(messagePrefix) === 0) {\n runIfPresent(+event.data.slice(messagePrefix.length));\n }\n };\n\n if (global.addEventListener) {\n global.addEventListener(\"message\", onGlobalMessage, false);\n } else {\n global.attachEvent(\"onmessage\", onGlobalMessage);\n }\n\n registerImmediate = function(handle) {\n global.postMessage(messagePrefix + handle, \"*\");\n };\n }\n\n function installMessageChannelImplementation() {\n var channel = new MessageChannel();\n channel.port1.onmessage = function(event) {\n var handle = event.data;\n runIfPresent(handle);\n };\n\n registerImmediate = function(handle) {\n channel.port2.postMessage(handle);\n };\n }\n\n function installReadyStateChangeImplementation() {\n var html = doc.documentElement;\n registerImmediate = function(handle) {\n // Create a ` : '';\n return html;\n },\n\n /**\n * Returns CSS built inside canvas\n * @param {Object} [opts={}] Options\n * @return {string} CSS string\n * @private\n */\n getCss(opts = {}) {\n const config = this.config;\n const wrapperIsBody = config.wrapperIsBody;\n const avoidProt = opts.avoidProtected;\n const keepUnusedStyles = !isUndefined(opts.keepUnusedStyles)\n ? opts.keepUnusedStyles\n : config.keepUnusedStyles;\n const cssc = this.get('CssComposer');\n const wrp = this.get('DomComponents').getComponent();\n const protCss = !avoidProt ? config.protectedCss : '';\n\n return (\n protCss +\n this.get('CodeManager').getCode(wrp, 'css', {\n cssc,\n wrapperIsBody,\n keepUnusedStyles\n })\n );\n },\n\n /**\n * Returns JS of all components\n * @return {string} JS string\n * @private\n */\n getJs() {\n var wrp = this.get('DomComponents').getWrapper();\n return this.get('CodeManager')\n .getCode(wrp, 'js')\n .trim();\n },\n\n /**\n * Store data to the current storage\n * @param {Function} clb Callback function\n * @return {Object} Stored data\n * @private\n */\n store(clb) {\n var sm = this.get('StorageManager');\n var store = {};\n if (!sm) return;\n\n // Fetch what to store\n this.get('storables').forEach(m => {\n var obj = m.store(1);\n for (var el in obj) store[el] = obj[el];\n });\n\n sm.store(store, res => {\n clb && clb(res);\n this.set('changesCount', 0);\n this.trigger('storage:store', store);\n });\n\n return store;\n },\n\n /**\n * Load data from the current storage\n * @param {Function} clb Callback function\n * @private\n */\n load(clb = null) {\n this.getCacheLoad(1, res => {\n this.get('storables').forEach(module => module.load(res));\n clb && clb(res);\n });\n },\n\n /**\n * Returns cached load\n * @param {Boolean} force Force to reload\n * @param {Function} clb Callback function\n * @return {Object}\n * @private\n */\n getCacheLoad(force, clb) {\n var f = force ? 1 : 0;\n if (this.cacheLoad && !f) return this.cacheLoad;\n var sm = this.get('StorageManager');\n var load = [];\n\n if (!sm) return {};\n\n this.get('storables').forEach(m => {\n var key = m.storageKey;\n key = typeof key === 'function' ? key() : key;\n var keys = key instanceof Array ? key : [key];\n keys.forEach(k => {\n load.push(k);\n });\n });\n\n sm.load(load, res => {\n this.cacheLoad = res;\n clb && clb(res);\n setTimeout(() => this.trigger('storage:load', res), 0);\n });\n },\n\n /**\n * Returns device model by name\n * @return {Device|null}\n * @private\n */\n getDeviceModel() {\n var name = this.get('device');\n return this.get('DeviceManager').get(name);\n },\n\n /**\n * Run default command if setted\n * @param {Object} [opts={}] Options\n * @private\n */\n runDefault(opts = {}) {\n var command = this.get('Commands').get(this.config.defaultCommand);\n if (!command || this.defaultRunning) return;\n command.stop(this, this, opts);\n command.run(this, this, opts);\n this.defaultRunning = 1;\n },\n\n /**\n * Stop default command\n * @param {Object} [opts={}] Options\n * @private\n */\n stopDefault(opts = {}) {\n var command = this.get('Commands').get(this.config.defaultCommand);\n if (!command) return;\n command.stop(this, this, opts);\n this.defaultRunning = 0;\n },\n\n /**\n * Update canvas dimensions and refresh data useful for tools positioning\n * @private\n */\n refreshCanvas() {\n this.set('canvasOffset', null);\n this.set('canvasOffset', this.get('Canvas').getOffset());\n },\n\n /**\n * Clear all selected stuf inside the window, sometimes is useful to call before\n * doing some dragging opearation\n * @param {Window} win If not passed the current one will be used\n * @private\n */\n clearSelection(win) {\n var w = win || window;\n w.getSelection().removeAllRanges();\n },\n\n /**\n * Get the current media text\n * @return {string}\n */\n getCurrentMedia() {\n const config = this.config;\n const device = this.getDeviceModel();\n const condition = config.mediaCondition;\n const preview = config.devicePreviewMode;\n const width = device && device.get('widthMedia');\n return device && width && !preview ? `(${condition}: ${width})` : '';\n },\n\n /**\n * Return the component wrapper\n * @return {Component}\n */\n getWrapper() {\n return this.get('DomComponents').getWrapper();\n },\n\n /**\n * Return the count of changes made to the content and not yet stored.\n * This count resets at any `store()`\n * @return {number}\n */\n getDirtyCount() {\n return this.get('changesCount');\n },\n\n getZoomDecimal() {\n return this.get('Canvas').getZoomDecimal();\n },\n\n setDragMode(value) {\n return this.set('dmode', value);\n },\n\n /**\n * Returns true if the editor is in absolute mode\n * @returns {Boolean}\n */\n inAbsoluteMode() {\n return this.get('dmode') === 'absolute';\n },\n\n /**\n * Destroy editor\n */\n destroyAll() {\n const {\n DomComponents,\n CssComposer,\n UndoManager,\n Panels,\n Canvas,\n Keymaps\n } = this.attributes;\n DomComponents.clear();\n CssComposer.clear();\n UndoManager.clear().removeAll();\n Panels.getPanels().reset();\n Canvas.getCanvasView().remove();\n Keymaps.removeAll();\n this.view.remove();\n this.stopListening();\n $(this.config.el)\n .empty()\n .attr(this.attrsOrig);\n },\n\n setEditing(value) {\n this.set('editing', value);\n return this;\n },\n\n isEditing() {\n return !!this.get('editing');\n },\n\n log(msg, opts = {}) {\n const { ns, level = 'debug' } = opts;\n this.trigger('log', msg, opts);\n level && this.trigger(`log:${level}`, msg, opts);\n\n if (ns) {\n const logNs = `log-${ns}`;\n this.trigger(logNs, msg, opts);\n level && this.trigger(`${logNs}:${level}`, msg, opts);\n }\n },\n\n logInfo(msg, opts) {\n this.log(msg, { ...opts, level: 'info' });\n },\n\n logWarning(msg, opts) {\n this.log(msg, { ...opts, level: 'warning' });\n },\n\n logError(msg, opts) {\n this.log(msg, { ...opts, level: 'error' });\n },\n\n /**\n * Set/get data from the HTMLElement\n * @param {HTMLElement} el\n * @param {string} name Data name\n * @param {any} value Date value\n * @return {any}\n * @private\n */\n data(el, name, value) {\n const varName = '_gjs-data';\n\n if (!el[varName]) {\n el[varName] = {};\n }\n\n if (isUndefined(value)) {\n return el[varName][name];\n } else {\n el[varName][name] = value;\n }\n }\n});\n","import { isObject, isString, each, isUndefined } from 'underscore';\n\nexport default ({ $, Backbone }) => {\n if (Backbone) {\n const ViewProt = Backbone.View.prototype;\n const eventNsMap = {};\n ViewProt.eventNsMap = eventNsMap;\n\n ViewProt.delegate = function(eventName, selector, listener) {\n const vid = '.delegateEvents' + this.cid;\n this.$el.on(eventName, selector, listener);\n //return this;\n let eventMap = eventNsMap[vid];\n\n if (!eventMap) {\n eventMap = [];\n eventNsMap[vid] = eventMap;\n }\n\n eventMap.push({ eventName, selector, listener });\n return this;\n };\n\n ViewProt.undelegateEvents = function() {\n const vid = '.delegateEvents' + this.cid;\n if (this.$el) {\n //this.$el.off(); return this;\n let eventMap = eventNsMap[vid];\n\n if (eventMap) {\n eventMap.forEach(({ eventName, selector, listener }) => {\n this.$el.off(eventName);\n });\n }\n }\n return this;\n };\n\n ViewProt.undelegate = function(ev, sel, list) {\n const vid = '.delegateEvents' + this.cid;\n //this.$el.off(ev, sel, list); return this;\n let eventMap = eventNsMap[vid];\n\n if (eventMap) {\n eventMap.forEach(({ eventName, selector, listener }) => {\n if (eventName == ev && selector == sel) {\n this.$el.off(eventName);\n }\n });\n }\n\n return this;\n };\n }\n\n if ($ && $.prototype.constructor.name !== 'jQuery') {\n const fn = $.fn;\n\n const splitNamespace = function(name) {\n const namespaceArray = name.split('.');\n return name.indexOf('.') !== 0\n ? [namespaceArray[0], namespaceArray.slice(1)]\n : [null, namespaceArray];\n };\n\n const on = $.prototype.on;\n const off = $.prototype.off;\n const trigger = $.prototype.trigger;\n const offset = $.prototype.offset;\n const getEvents = eventName => eventName.split(/[,\\s]+/g);\n const getNamespaces = eventName => eventName.split('.');\n\n fn.on = function(eventName, delegate, callback, runOnce) {\n if (typeof eventName == 'string') {\n const events = getEvents(eventName);\n\n if (events.length == 1) {\n eventName = events[0];\n let namespaces = getNamespaces(eventName);\n\n if (eventName.indexOf('.') !== 0) {\n eventName = namespaces[0];\n }\n\n namespaces = namespaces.slice(1);\n\n if (namespaces.length) {\n //console.log('Found event with namespaces', namespaces, eventName, delegate, this);\n const cashNs = this.data('_cashNs') || [];\n // cashNs[namespace]\n this.data('_cashNs', namespaces); // for each ns need to store '.store' => eventName, delegate, callback\n }\n\n return on.call(this, eventName, delegate, callback, runOnce);\n } else {\n events.forEach(eventName =>\n this.on(eventName, delegate, callback, runOnce)\n );\n return this;\n }\n } else {\n return on.call(this, eventName, delegate, callback, runOnce);\n }\n };\n\n fn.off = function(eventName, callback) {\n if (typeof eventName == 'string') {\n const events = getEvents(eventName);\n\n if (events.length == 1) {\n eventName = events[0];\n let namespaces = getNamespaces(eventName);\n\n if (eventName.indexOf('.') !== 0) {\n eventName = namespaces[0];\n }\n\n namespaces = namespaces.slice(1);\n\n if (namespaces.length) {\n // Have to off only with the same namespace\n }\n\n return off.call(this, eventName, callback);\n } else {\n events.forEach(eventName => this.off(eventName, callback));\n return this;\n }\n } else {\n return off.call(this, eventName, callback);\n }\n };\n\n fn.trigger = function(eventName, data) {\n if (eventName instanceof $.Event) {\n return this.trigger(eventName.type, data);\n }\n\n if (typeof eventName == 'string') {\n const events = getEvents(eventName);\n\n if (events.length == 1) {\n eventName = events[0];\n let namespaces = getNamespaces(eventName);\n\n if (eventName.indexOf('.') !== 0) {\n eventName = namespaces[0];\n }\n\n namespaces = namespaces.slice(1);\n\n if (namespaces.length) {\n // have to trigger with same namespaces and eventName\n }\n\n return trigger.call(this, eventName, data);\n } else {\n events.forEach(eventName => this.trigger(eventName, data));\n return this;\n }\n } else {\n return trigger.call(this, eventName, data);\n }\n };\n\n fn.hide = function() {\n return this.css('display', 'none');\n };\n\n fn.show = function() {\n return this.css('display', 'block');\n };\n\n fn.focus = function() {\n const el = this.get(0);\n el && el.focus();\n return this;\n };\n\n // For SVGs in IE\n (fn.removeClass = function(c) {\n if (!arguments.length) {\n return this.attr('class', '');\n }\n const classes = isString(c) && c.match(/\\S+/g);\n return classes\n ? this.each(function(el) {\n each(classes, function(c) {\n if (el.classList) {\n el.classList.remove(c);\n } else {\n const val = el.className;\n const bval = el.className.baseVal;\n\n if (!isUndefined(bval)) {\n val.baseVal = bval.replace(c, '');\n } else {\n el.className = val.replace(c, '');\n }\n }\n });\n })\n : this;\n }),\n (fn.remove = function() {\n return this.each(node => {\n return node.parentNode && node.parentNode.removeChild(node);\n });\n }),\n // For spectrum compatibility\n (fn.bind = function(ev, h) {\n return this.on(ev, h);\n });\n\n fn.unbind = function(ev, h) {\n if (isObject(ev)) {\n for (let name in ev) {\n ev.hasOwnProperty(name) && this.off(name, ev[name]);\n }\n\n return this;\n } else {\n return this.off(ev, h);\n }\n };\n\n fn.click = function(h) {\n return h ? this.on('click', h) : this.trigger('click');\n };\n\n fn.change = function(h) {\n return h ? this.on('change', h) : this.trigger('change');\n };\n\n fn.keydown = function(h) {\n return h ? this.on('keydown', h) : this.trigger('keydown');\n };\n\n fn.delegate = function(selector, events, data, handler) {\n if (!handler) {\n handler = data;\n }\n\n return this.on(events, selector, function(e) {\n e.data = data;\n handler(e);\n });\n };\n\n fn.scrollLeft = function() {\n let el = this.get(0);\n el = el.nodeType == 9 ? el.defaultView : el;\n let win = el instanceof Window ? el : null;\n return win ? win.pageXOffset : el.scrollLeft || 0;\n };\n\n fn.scrollTop = function() {\n let el = this.get(0);\n el = el.nodeType == 9 ? el.defaultView : el;\n let win = el instanceof Window ? el : null;\n return win ? win.pageYOffset : el.scrollTop || 0;\n };\n\n fn.offset = function(coords) {\n let top, left;\n\n if (coords) {\n top = coords.top;\n left = coords.left;\n }\n\n if (typeof top != 'undefined') {\n this.css('top', `${top}px`);\n }\n if (typeof left != 'undefined') {\n this.css('left', `${left}px`);\n }\n\n return offset.call(this);\n };\n\n $.map = function(items, clb) {\n const ar = [];\n\n for (var i = 0; i < items.length; i++) {\n ar.push(clb(items[i], i));\n }\n\n return ar;\n };\n\n const indexOf = Array.prototype.indexOf;\n\n $.inArray = function(val, arr, i) {\n return arr == null ? -1 : indexOf.call(arr, val, i);\n };\n\n $.Event = function(src, props) {\n if (!(this instanceof $.Event)) {\n return new $.Event(src, props);\n }\n\n this.type = src;\n this.isDefaultPrevented = () => false;\n };\n }\n};\n","import Backbone from 'backbone';\nconst $ = Backbone.$;\n\nexport default Backbone.View.extend({\n initialize() {\n const { model } = this;\n model.view = this;\n this.conf = model.config;\n this.pn = model.get('Panels');\n model.on('loaded', () => {\n this.pn.active();\n this.pn.disableButtons();\n model.runDefault();\n setTimeout(() => model.trigger('load', model.get('Editor')));\n });\n },\n\n render() {\n const model = this.model;\n const el = this.$el;\n const conf = this.conf;\n const contEl = $(conf.el || `body ${conf.container}`);\n const pfx = conf.stylePrefix;\n el.empty();\n\n if (conf.width) contEl.css('width', conf.width);\n\n if (conf.height) contEl.css('height', conf.height);\n\n el.append(model.get('Canvas').render());\n el.append(this.pn.render());\n el.attr('class', `${pfx}editor ${pfx}one-bg ${pfx}two-color`);\n contEl\n .addClass(`${pfx}editor-cont`)\n .empty()\n .append(el);\n\n return this;\n }\n});\n","/**\n * Editor contains the top level API which you'll probably use to customize the editor or extend it with plugins.\n * You get the Editor instance on init method and you can pass options via its [Configuration Object](https://github.com/artf/grapesjs/blob/master/src/editor/config/config.js)\n *\n * ```js\n * const editor = grapesjs.init({\n * // options\n * });\n * ```\n *\n * ## Available Events\n *\n * You can make use of available events in this way\n * ```js\n * editor.on('EVENT-NAME', (some, argument) => {\n * // do something\n * })\n * ```\n *\n * ### Components\n * * `component:create` - Component is created (only the model, is not yet mounted in the canvas), called after the init() method\n * * `component:mount` - Component is mounted to an element and rendered in canvas\n * * `component:add` - Triggered when a new component is added to the editor, the model is passed as an argument to the callback\n * * `component:remove` - Triggered when a component is removed, the model is passed as an argument to the callback\n * * `component:clone` - Triggered when a component is cloned, the new model is passed as an argument to the callback\n * * `component:update` - Triggered when a component is updated (moved, styled, etc.), the model is passed as an argument to the callback\n * * `component:update:{propertyName}` - Listen any property change, the model is passed as an argument to the callback\n * * `component:styleUpdate` - Triggered when the style of the component is updated, the model is passed as an argument to the callback\n * * `component:styleUpdate:{propertyName}` - Listen for a specific style property change, the model is passed as an argument to the callback\n * * `component:selected` - New component selected, the selected model is passed as an argument to the callback\n * * `component:deselected` - Component deselected, the deselected model is passed as an argument to the callback\n * * `component:toggled` - Component selection changed, toggled model is passed as an argument to the callback\n * * `component:type:add` - New component type added, the new type is passed as an argument to the callback\n * * `component:type:update` - Component type updated, the updated type is passed as an argument to the callback\n * ### Blocks\n * * `block:add` - New block added\n * * `block:remove` - Block removed\n * * `block:drag:start` - Started dragging block, model of the block is passed as an argument\n * * `block:drag` - Dragging block, the block's model and the drag event are passed as arguments\n * * `block:drag:stop` - Dragging of the block is stopped. As agruments for the callback you get, the dropped component model (if dropped successfully) and the model of the block\n * ### Assets\n * * `asset:add` - New asset added\n * * `asset:remove` - Asset removed\n * * `asset:upload:start` - Before the upload is started\n * * `asset:upload:end` - After the upload is ended\n * * `asset:upload:error` - On any error in upload, passes the error as an argument\n * * `asset:upload:response` - On upload response, passes the result as an argument\n * ### Keymaps\n * * `keymap:add` - New keymap added. The new keyamp object is passed as an argument\n * * `keymap:remove` - Keymap removed. The removed keyamp object is passed as an argument\n * * `keymap:emit` - Some keymap emitted, in arguments you get keymapId, shortcutUsed, Event\n * * `keymap:emit:{keymapId}` - `keymapId` emitted, in arguments you get keymapId, shortcutUsed, Event\n * ### Style Manager\n * * `styleManager:update:target` - The target (Component or CSSRule) is changed\n * * `styleManager:change` - Triggered on style property change from new selected component, the view of the property is passed as an argument to the callback\n * * `styleManager:change:{propertyName}` - As above but for a specific style property\n * ### Storages\n * * `storage:start` - Before the storage request is started\n * * `storage:start:store` - Before the store request. The object to store is passed as an argumnet (which you can edit)\n * * `storage:start:load` - Before the load request. Items to load are passed as an argumnet (which you can edit)\n * * `storage:load` - Triggered when something was loaded from the storage, loaded object passed as an argumnet\n * * `storage:store` - Triggered when something is stored to the storage, stored object passed as an argumnet\n * * `storage:end` - After the storage request is ended\n * * `storage:end:store` - After the store request\n * * `storage:end:load` - After the load request\n * * `storage:error` - On any error on storage request, passes the error as an argument\n * * `storage:error:store` - Error on store request, passes the error as an argument\n * * `storage:error:load` - Error on load request, passes the error as an argument\n * ### Canvas\n * * `canvas:dragenter` - When something is dragged inside the canvas, `DataTransfer` instance passed as an argument\n * * `canvas:dragover` - When something is dragging on canvas, `DataTransfer` instance passed as an argument\n * * `canvas:drop` - Something is dropped in canvas, `DataTransfer` instance and the dropped model are passed as arguments\n * * `canvas:dragend` - When a drag operation is ended, `DataTransfer` instance passed as an argument\n * * `canvas:dragdata` - On any dataTransfer parse, `DataTransfer` instance and the `result` are passed as arguments.\n * By changing `result.content` you're able to customize what is dropped\n * ### Selectors\n * * `selector:add` - Triggers when a new selector/class is created\n * ### RTE\n * * `rte:enable` - RTE enabled. The view, on which RTE is enabled, is passed as an argument\n * * `rte:disable` - RTE disabled. The view, on which RTE is disabled, is passed as an argument\n * ### Modal\n * * `modal:open` - Modal is opened\n * * `modal:close` - Modal is closed\n * ### Commands\n * * `run:{commandName}` - Triggered when some command is called to run (eg. editor.runCommand('preview'))\n * * `stop:{commandName}` - Triggered when some command is called to stop (eg. editor.stopCommand('preview'))\n * * `run:{commandName}:before` - Triggered before the command is called\n * * `stop:{commandName}:before` - Triggered before the command is called to stop\n * * `abort:{commandName}` - Triggered when the command execution is aborted (`editor.on(`run:preview:before`, opts => opts.abort = 1);`)\n * * `run` - Triggered on run of any command. The id and the result are passed as arguments to the callback\n * * `stop` - Triggered on stop of any command. The id and the result are passed as arguments to the callback\n * ### General\n * * `canvasScroll` - Canvas is scrolled\n * * `update` - The structure of the template is updated (its HTML/CSS)\n * * `undo` - Undo executed\n * * `redo` - Redo executed\n * * `load` - Editor is loaded\n *\n * @module Editor\n */\nimport $ from 'cash-dom';\nimport defaults from './config/config';\nimport EditorModel from './model/Editor';\nimport EditorView from './view/EditorView';\n\nexport default (config = {}) => {\n const c = {\n ...defaults,\n ...config\n };\n\n c.pStylePrefix = c.stylePrefix;\n var em = new EditorModel(c);\n var editorView = new EditorView({\n model: em,\n config: c\n });\n\n return {\n $,\n\n /**\n * @property {EditorModel}\n * @private\n */\n editor: em,\n\n /**\n * @property {DomComponents}\n * @private\n */\n DomComponents: em.get('DomComponents'),\n\n /**\n * @property {LayerManager}\n * @private\n */\n LayerManager: em.get('LayerManager'),\n\n /**\n * @property {CssComposer}\n * @private\n */\n CssComposer: em.get('CssComposer'),\n\n /**\n * @property {StorageManager}\n * @private\n */\n StorageManager: em.get('StorageManager'),\n\n /**\n * @property {AssetManager}\n * @private\n */\n AssetManager: em.get('AssetManager'),\n\n /**\n * @property {BlockManager}\n * @private\n */\n BlockManager: em.get('BlockManager'),\n\n /**\n * @property {TraitManager}\n * @private\n */\n TraitManager: em.get('TraitManager'),\n\n /**\n * @property {SelectorManager}\n * @private\n */\n SelectorManager: em.get('SelectorManager'),\n\n /**\n * @property {CodeManager}\n * @private\n */\n CodeManager: em.get('CodeManager'),\n\n /**\n * @property {Commands}\n * @private\n */\n Commands: em.get('Commands'),\n\n /**\n * @property {Keymaps}\n * @private\n */\n Keymaps: em.get('Keymaps'),\n\n /**\n * @property {Modal}\n * @private\n */\n Modal: em.get('Modal'),\n\n /**\n * @property {Panels}\n * @private\n */\n Panels: em.get('Panels'),\n\n /**\n * @property {StyleManager}\n * @private\n */\n StyleManager: em.get('StyleManager'),\n\n /**\n * @property {Canvas}\n * @private\n */\n Canvas: em.get('Canvas'),\n\n /**\n * @property {UndoManager}\n * @private\n */\n UndoManager: em.get('UndoManager'),\n\n /**\n * @property {DeviceManager}\n * @private\n */\n DeviceManager: em.get('DeviceManager'),\n\n /**\n * @property {RichTextEditor}\n * @private\n */\n RichTextEditor: em.get('RichTextEditor'),\n\n /**\n * @property {Parser}\n * @private\n */\n Parser: em.get('Parser'),\n\n /**\n * @property {Utils}\n * @private\n */\n Utils: em.get('Utils'),\n\n /**\n * @property {Utils}\n * @private\n */\n Config: em.get('Config'),\n\n /**\n * Initialize editor model\n * @return {this}\n * @private\n */\n init() {\n em.init(this);\n return this;\n },\n\n /**\n * Returns configuration object\n * @param {string} [prop] Property name\n * @return {any} Returns the configuration object or\n * the value of the specified property\n */\n getConfig(prop) {\n return em.getConfig(prop);\n },\n\n /**\n * Returns HTML built inside canvas\n * @return {string} HTML string\n */\n getHtml(opts) {\n return em.getHtml(opts);\n },\n\n /**\n * Returns CSS built inside canvas\n * @param {Object} [opts={}] Options\n * @param {Boolean} [opts.avoidProtected=false] Don't include protected CSS\n * @return {string} CSS string\n */\n getCss(opts) {\n return em.getCss(opts);\n },\n\n /**\n * Returns JS of all components\n * @return {string} JS string\n */\n getJs() {\n return em.getJs();\n },\n\n /**\n * Return the complete tree of components. Use `getWrapper` to include also the wrapper\n * @return {Components}\n */\n getComponents() {\n return em.get('DomComponents').getComponents();\n },\n\n /**\n * Return the wrapper and its all components\n * @return {Component}\n */\n getWrapper() {\n return em.get('DomComponents').getWrapper();\n },\n\n /**\n * Set components inside editor's canvas. This method overrides actual components\n * @param {Array|Object|string} components HTML string or components model\n * @return {this}\n * @example\n * editor.setComponents('
New component
');\n * // or\n * editor.setComponents({\n * type: 'text',\n * classes:['cls'],\n * content: 'New component'\n * });\n */\n setComponents(components) {\n em.setComponents(components);\n return this;\n },\n\n /**\n * Add components\n * @param {Array|Object|string} components HTML string or components model\n * @param {Object} opts Options\n * @param {Boolean} [opts.avoidUpdateStyle=false] If the HTML string contains styles,\n * by default, they will be created and, if already exist, updated. When this option\n * is true, styles already created will not be updated.\n * @return {Array}\n * @example\n * editor.addComponents('
New component
');\n * // or\n * editor.addComponents({\n * type: 'text',\n * classes:['cls'],\n * content: 'New component'\n * });\n */\n addComponents(components, opts) {\n return this.getWrapper().append(components, opts);\n },\n\n /**\n * Returns style in JSON format object\n * @return {Object}\n */\n getStyle() {\n return em.get('CssComposer').getAll();\n },\n\n /**\n * Set style inside editor's canvas. This method overrides actual style\n * @param {Array|Object|string} style CSS string or style model\n * @return {this}\n * @example\n * editor.setStyle('.cls{color: red}');\n * //or\n * editor.setStyle({\n * selectors: ['cls']\n * style: { color: 'red' }\n * });\n */\n setStyle(style) {\n em.setStyle(style);\n return this;\n },\n\n /**\n * Returns the last selected component, if there is one\n * @return {Model}\n */\n getSelected() {\n return em.getSelected();\n },\n\n /**\n * Returns an array of all selected components\n * @return {Array}\n */\n getSelectedAll() {\n return em.getSelectedAll();\n },\n\n /**\n * Get a stylable entity from the selected component.\n * If you select a component without classes the entity is the Component\n * itself and all changes will go inside its 'style' attribute. Otherwise,\n * if the selected component has one or more classes, the function will\n * return the corresponding CSS Rule\n * @return {Model}\n */\n getSelectedToStyle() {\n let selected = em.getSelected();\n\n if (selected) {\n return this.StyleManager.getModelToStyle(selected);\n }\n },\n\n /**\n * Select a component\n * @param {Component|HTMLElement} el Component to select\n * @param {Object} [opts] Options\n * @param {Boolean} [opts.scroll] Scroll canvas to the selected element\n * @return {this}\n * @example\n * // Select dropped block\n * editor.on('block:drag:stop', function(model) {\n * editor.select(model);\n * });\n */\n select(el, opts) {\n em.setSelected(el, opts);\n return this;\n },\n\n /**\n * Add component to selection\n * @param {Component|HTMLElement|Array} el Component to select\n * @return {this}\n * @example\n * editor.selectAdd(model);\n */\n selectAdd(el) {\n em.addSelected(el);\n return this;\n },\n\n /**\n * Remove component from selection\n * @param {Component|HTMLElement|Array} el Component to select\n * @return {this}\n * @example\n * editor.selectRemove(model);\n */\n selectRemove(el) {\n em.removeSelected(el);\n return this;\n },\n\n /**\n * Toggle component selection\n * @param {Component|HTMLElement|Array} el Component to select\n * @return {this}\n * @example\n * editor.selectToggle(model);\n */\n selectToggle(el) {\n em.toggleSelected(el);\n return this;\n },\n\n /**\n * Set device to the editor. If the device exists it will\n * change the canvas to the proper width\n * @param {string} name Name of the device\n * @return {this}\n * @example\n * editor.setDevice('Tablet');\n */\n setDevice(name) {\n em.set('device', name);\n return this;\n },\n\n /**\n * Return the actual active device\n * @return {string} Device name\n * @example\n * var device = editor.getDevice();\n * console.log(device);\n * // 'Tablet'\n */\n getDevice() {\n return em.get('device');\n },\n\n /**\n * Execute command\n * @param {string} id Command ID\n * @param {Object} options Custom options\n * @return {*} The return is defined by the command\n * @example\n * editor.runCommand('myCommand', {someValue: 1});\n */\n runCommand(id, options = {}) {\n return em.get('Commands').run(id, options);\n },\n\n /**\n * Stop the command if stop method was provided\n * @param {string} id Command ID\n * @param {Object} options Custom options\n * @return {*} The return is defined by the command\n * @example\n * editor.stopCommand('myCommand', {someValue: 1});\n */\n stopCommand(id, options = {}) {\n return em.get('Commands').stop(id, options);\n },\n\n /**\n * Store data to the current storage\n * @param {Function} clb Callback function\n * @return {Object} Stored data\n */\n store(clb) {\n return em.store(clb);\n },\n\n /**\n * Load data from the current storage\n * @param {Function} clb Callback function\n * @return {Object} Stored data\n */\n load(clb) {\n return em.load(clb);\n },\n\n /**\n * Returns container element. The one which was indicated as 'container'\n * on init method\n * @return {HTMLElement}\n */\n getContainer() {\n return c.el;\n },\n\n /**\n * Return the count of changes made to the content and not yet stored.\n * This count resets at any `store()`\n * @return {number}\n */\n getDirtyCount() {\n return em.getDirtyCount();\n },\n\n /**\n * Update editor dimensions and refresh data useful for positioning of tools\n *\n * This method could be useful when you update, for example, some position\n * of the editor element (eg. canvas, panels, etc.) with CSS, where without\n * refresh you'll get misleading position of tools (eg. rich text editor,\n * component highlighter, etc.)\n *\n * @private\n */\n refresh() {\n em.refreshCanvas();\n },\n\n /**\n * Replace the built-in Rich Text Editor with a custom one.\n * @param {Object} obj Custom RTE Interface\n * @example\n * editor.setCustomRte({\n * // Function for enabling custom RTE\n * // el is the HTMLElement of the double clicked Text Component\n * // rte is the same instance you have returned the first time you call\n * // enable(). This is useful if need to check if the RTE is already enabled so\n * // ion this case you'll need to return the RTE and the end of the function\n * enable: function(el, rte) {\n * rte = new MyCustomRte(el, {}); // this depends on the Custom RTE API\n * ...\n * return rte; // return the RTE instance\n * },\n *\n * // Disable the editor, called for example when you unfocus the Text Component\n * disable: function(el, rte) {\n * rte.blur(); // this depends on the Custom RTE API\n * }\n *\n * // Called when the Text Component is focused again. If you returned the RTE instance\n * // from the enable function, the enable won't be called again instead will call focus,\n * // in this case to avoid double binding of the editor\n * focus: function (el, rte) {\n * rte.focus(); // this depends on the Custom RTE API\n * }\n * });\n */\n setCustomRte(obj) {\n this.RichTextEditor.customRte = obj;\n },\n\n /**\n * Replace the default CSS parser with a custom one.\n * The parser function receives a CSS string as a parameter and expects\n * an array of CSSRule objects as a result. If you need to remove the\n * custom parser, pass `null` as the argument\n * @param {Function|null} parser Parser function\n * @return {this}\n * @example\n * editor.setCustomParserCss(css => {\n * const result = [];\n * // ... parse the CSS string\n * result.push({\n * selectors: '.someclass, div .otherclass',\n * style: { color: 'red' }\n * })\n * // ...\n * return result;\n * });\n */\n setCustomParserCss(parser) {\n this.Parser.getConfig().parserCss = parser;\n return this;\n },\n\n /**\n * Change the global drag mode of components.\n * To get more about this feature read: https://github.com/artf/grapesjs/issues/1936\n * @param {String} value Drag mode, options: 'absolute' | 'translate'\n * @returns {this}\n */\n setDragMode(value) {\n em.setDragMode(value);\n return this;\n },\n\n /**\n * Trigger event log message\n * @param {*} msg Message to log\n * @param {Object} [opts={}] Custom options\n * @param {String} [opts.ns=''] Namespace of the log (eg. to use in plugins)\n * @param {String} [opts.level='debug'] Level of the log, `debug`, `info`, `warning`, `error`\n * @return {this}\n * @example\n * editor.log('Something done!', { ns: 'from-plugin-x', level: 'info' });\n * // This will trigger following events\n * // `log`, `log:info`, `log-from-plugin-x`, `log-from-plugin-x:info`\n * // Callbacks of those events will always receive the message and\n * // options, as arguments, eg:\n * // editor.on('log:info', (msg, opts) => console.info(msg, opts))\n */\n log(msg, opts = {}) {\n em.log(msg, opts);\n return this;\n },\n\n /**\n * Attach event\n * @param {string} event Event name\n * @param {Function} callback Callback function\n * @return {this}\n */\n on(event, callback) {\n em.on(event, callback);\n return this;\n },\n\n /**\n * Attach event and detach it after the first run\n * @param {string} event Event name\n * @param {Function} callback Callback function\n * @return {this}\n */\n once(event, callback) {\n em.once(event, callback);\n return this;\n },\n\n /**\n * Detach event\n * @param {string} event Event name\n * @param {Function} callback Callback function\n * @return {this}\n */\n off(event, callback) {\n em.off(event, callback);\n return this;\n },\n\n /**\n * Trigger event\n * @param {string} event Event to trigger\n * @return {this}\n */\n trigger(event) {\n em.trigger.apply(em, arguments);\n return this;\n },\n\n /**\n * Destroy the editor\n */\n destroy() {\n return em.destroyAll();\n },\n\n /**\n * Returns editor element\n * @return {HTMLElement}\n * @private\n */\n getEl() {\n return editorView.el;\n },\n\n /**\n * Returns editor model\n * @return {Model}\n * @private\n */\n getModel() {\n return em;\n },\n\n /**\n * Render editor\n * @return {HTMLElement}\n */\n render() {\n // Do post render stuff after the iframe is loaded otherwise it'll\n // be empty during tests\n em.on('loaded', () => {\n this.UndoManager.clear();\n em.get('modules').forEach(module => {\n module.postRender && module.postRender(editorView);\n });\n });\n\n editorView.render();\n return editorView.el;\n }\n };\n};\n","export default {\n plugins: []\n};\n","/**\n * File made for IE/Edge support\n * https://github.com/artf/grapesjs/issues/214\n */\n\nexport default () => {\n /**\n * Check if IE/Edge\n * @return {Boolean}\n */\n const isIE = () => {\n let match;\n const agent = window.navigator.userAgent;\n const rules = [\n ['edge', /Edge\\/([0-9\\._]+)/],\n ['ie', /MSIE\\s(7\\.0)/],\n ['ie', /MSIE\\s([0-9\\.]+);.*Trident\\/[4-7].0/],\n ['ie', /Trident\\/7\\.0.*rv\\:([0-9\\.]+).*\\).*Gecko$/]\n ];\n\n for (let i = 0; i < rules.length; i++) {\n const rule = rules[i];\n match = rule[1].exec(agent);\n if (match) break;\n }\n\n return !!match;\n };\n\n if (isIE()) {\n const originalCreateHTMLDocument =\n DOMImplementation.prototype.createHTMLDocument;\n DOMImplementation.prototype.createHTMLDocument = title => {\n if (!title) title = '';\n return originalCreateHTMLDocument.apply(document.implementation, [title]);\n };\n }\n};\n","import $ from 'cash-dom';\nimport Editor from './editor';\nimport { isElement, isFunction } from 'underscore';\nimport polyfills from 'utils/polyfills';\nimport PluginManager from './plugin_manager';\n\npolyfills();\n\nconst plugins = new PluginManager();\nconst editors = [];\nconst defaultConfig = {\n // If true renders editor on init\n autorender: 1,\n\n // Array of plugins to init\n plugins: [],\n\n // Custom options for plugins\n pluginsOpts: {}\n};\n\nexport default {\n $,\n\n editors,\n\n plugins,\n\n // Will be replaced on build\n version: '<# VERSION #>',\n\n /**\n * Initialize the editor with passed options\n * @param {Object} config Configuration object\n * @param {string|HTMLElement} config.container Selector which indicates where render the editor\n * @param {Boolean} [config.autorender=true] If true, auto-render the content\n * @param {Array} [config.plugins=[]] Array of plugins to execute on start\n * @param {Object} [config.pluginsOpts={}] Custom options for plugins\n * @return {Editor} Editor instance\n * @example\n * var editor = grapesjs.init({\n * container: '#myeditor',\n * components: '
Hello world
',\n * style: '.hello{color: red}',\n * })\n */\n init(config = {}) {\n const els = config.container;\n if (!els) throw new Error(\"'container' is required\");\n config = { ...defaultConfig, ...config };\n config.el = isElement(els) ? els : document.querySelector(els);\n const editor = new Editor(config).init();\n\n // Load plugins\n config.plugins.forEach(pluginId => {\n let plugin = plugins.get(pluginId);\n const plgOptions = config.pluginsOpts[pluginId] || {};\n\n // Try to search in global context\n if (!plugin) {\n const wplg = window[pluginId];\n plugin = wplg && wplg.default ? wplg.default : wplg;\n }\n\n if (plugin) {\n plugin(editor, plgOptions);\n } else if (isFunction(pluginId)) {\n pluginId(editor, plgOptions);\n } else {\n console.warn(`Plugin ${pluginId} not found`);\n }\n });\n\n // Execute `onLoad` on modules once all plugins are initialized.\n // A plugin might have extended/added some custom type so this\n // is a good point to load stuff like components, css rules, etc.\n editor.getModel().loadOnStart();\n config.autorender && editor.render();\n editors.push(editor);\n\n return editor;\n }\n};\n","import defaults from './config/config';\n\nexport default config => {\n var c = config || {};\n\n // Set default options\n for (var name in defaults) {\n if (!(name in c)) c[name] = defaults[name];\n }\n\n var plugins = {};\n\n return {\n /**\n * Add new plugin. Plugins could not be overwritten\n * @param {string} id Plugin ID\n * @param {Function} plugin Function which contains all plugin logic\n * @return {Function} The plugin function\n * @example\n * PluginManager.add('some-plugin', function(editor){\n * editor.Commands.add('new-command', {\n * run: function(editor, senderBtn){\n * console.log('Executed new-command');\n * }\n * })\n * });\n */\n add(id, plugin) {\n if (plugins[id]) {\n return plugins[id];\n }\n\n plugins[id] = plugin;\n return plugin;\n },\n\n /**\n * Returns plugin by ID\n * @param {string} id Plugin ID\n * @return {Function|undefined} Plugin\n * @example\n * var plugin = PluginManager.get('some-plugin');\n * plugin(editor);\n */\n get(id) {\n return plugins[id];\n },\n\n /**\n * Returns object with all plugins\n * @return {Object}\n */\n getAll() {\n return plugins;\n }\n };\n};\n","export default {\n stylePrefix: 'trt-',\n\n // Specify the element to use as a container, string (query) or HTMLElement\n // With the empty value, nothing will be rendered\n appendTo: '',\n\n labelContainer: 'Component settings',\n\n // Placeholder label for text input types\n labelPlhText: 'eg. Text here',\n\n // Placeholder label for href input\n labelPlhHref: 'eg. https://google.com',\n\n // Default options for the target input\n optionsTarget: [\n { value: '', name: 'This window' },\n { value: '_blank', name: 'New window' }\n ],\n\n // Text to show in case no element selected\n textNoElement: 'Select an element before using Trait Manager'\n};\n","import Backbone from 'backbone';\nimport { isUndefined, isString, isFunction } from 'underscore';\nimport { capitalize } from 'utils/mixins';\n\nconst $ = Backbone.$;\n\nexport default Backbone.View.extend({\n events: {},\n eventCapture: ['change'],\n\n appendInput: 1,\n\n attributes() {\n return this.model.get('attributes');\n },\n\n templateLabel() {\n const { ppfx } = this;\n const label = this.getLabel();\n return `
${label}
`;\n },\n\n templateInput() {\n const { clsField } = this;\n return `
`;\n },\n\n initialize(o = {}) {\n const { config = {} } = o;\n const { model, eventCapture } = this;\n const { target } = model;\n const { type } = model.attributes;\n this.config = config;\n this.em = config.em;\n this.pfx = config.stylePrefix || '';\n this.ppfx = config.pStylePrefix || '';\n this.target = target;\n const { ppfx } = this;\n this.clsField = `${ppfx}field ${ppfx}field-${type}`;\n [['change:value', this.onValueChange], ['remove', this.removeView]].forEach(\n ([event, clb]) => {\n model.off(event, clb);\n this.listenTo(model, event, clb);\n }\n );\n model.view = this;\n this.listenTo(model, 'change:label', this.render);\n this.listenTo(model, 'change:placeholder', this.rerender);\n eventCapture.forEach(event => (this.events[event] = 'onChange'));\n this.delegateEvents();\n this.init();\n },\n\n getClbOpts() {\n return {\n component: this.target,\n trait: this.model,\n elInput: this.getInputElem()\n };\n },\n\n removeView() {\n this.remove();\n this.removed();\n },\n\n init() {},\n removed() {},\n onRender() {},\n onUpdate() {},\n onEvent() {},\n\n /**\n * Fires when the input is changed\n * @private\n */\n onChange(event) {\n const el = this.getInputElem();\n if (el && !isUndefined(el.value)) {\n this.model.set('value', el.value);\n }\n this.onEvent({\n ...this.getClbOpts(),\n event\n });\n },\n\n getValueForTarget() {\n return this.model.get('value');\n },\n\n setInputValue(value) {\n const el = this.getInputElem();\n el && (el.value = value);\n },\n\n /**\n * On change callback\n * @private\n */\n onValueChange(model, value, opts = {}) {\n if (opts.fromTarget) {\n this.setInputValue(model.get('value'));\n this.postUpdate();\n } else {\n const val = this.getValueForTarget();\n model.setTargetValue(val, opts);\n }\n },\n\n /**\n * Render label\n * @private\n */\n renderLabel() {\n const { $el, target } = this;\n const label = this.getLabel();\n let tpl = this.templateLabel(target);\n\n if (this.createLabel) {\n tpl =\n this.createLabel({\n label,\n component: target,\n trait: this\n }) || '';\n }\n\n $el.find('[data-label]').append(tpl);\n },\n\n /**\n * Returns label for the input\n * @return {string}\n * @private\n */\n getLabel() {\n const { label, name } = this.model.attributes;\n return capitalize(label || name).replace(/-/g, ' ');\n },\n\n /**\n * Returns current target component\n */\n getComponent() {\n return this.target;\n },\n\n /**\n * Returns input element\n * @return {HTMLElement}\n * @private\n */\n getInputEl() {\n if (!this.$input) {\n const md = this.model;\n const plh = md.get('placeholder') || md.get('default') || '';\n const type = md.get('type') || 'text';\n const min = md.get('min');\n const max = md.get('max');\n const value = this.getModelValue();\n const input = $(``);\n\n if (!isUndefined(value)) {\n md.set({ value }, { silent: true });\n input.prop('value', value);\n }\n\n if (min) {\n input.prop('min', min);\n }\n\n if (max) {\n input.prop('max', max);\n }\n\n this.$input = input;\n }\n return this.$input.get(0);\n },\n\n getInputElem() {\n const { input, $input } = this;\n return (\n input || ($input && $input.get && $input.get(0)) || this.getElInput()\n );\n },\n\n getModelValue() {\n let value;\n const model = this.model;\n const target = this.target;\n const name = model.get('name');\n\n if (model.get('changeProp')) {\n value = target.get(name);\n } else {\n const attrs = target.get('attributes');\n value = model.get('value') || attrs[name];\n }\n\n return !isUndefined(value) ? value : '';\n },\n\n getElInput() {\n return this.elInput;\n },\n\n /**\n * Renders input\n * @private\n * */\n renderField() {\n const { $el, appendInput, model } = this;\n const inputs = $el.find('[data-input]');\n const el = inputs[inputs.length - 1];\n let tpl = model.el;\n\n if (!tpl) {\n tpl = this.createInput\n ? this.createInput(this.getClbOpts())\n : this.getInputEl();\n }\n\n if (isString(tpl)) {\n el.innerHTML = tpl;\n this.elInput = el.firstChild;\n } else {\n appendInput ? el.appendChild(tpl) : el.insertBefore(tpl, el.firstChild);\n this.elInput = tpl;\n }\n\n model.el = this.elInput;\n },\n\n hasLabel() {\n const { label } = this.model.attributes;\n return !this.noLabel && label !== false;\n },\n\n rerender() {\n this.model.el = null;\n this.render();\n },\n\n postUpdate() {\n this.onUpdate(this.getClbOpts());\n },\n\n render() {\n const { $el, pfx, ppfx, model } = this;\n const { type } = model.attributes;\n const hasLabel = this.hasLabel && this.hasLabel();\n const cls = `${pfx}trait`;\n this.$input = null;\n let tmpl = `
\n ${hasLabel ? `
` : ''}\n
\n ${\n this.templateInput\n ? isFunction(this.templateInput)\n ? this.templateInput(this.getClbOpts())\n : this.templateInput\n : ''\n }\n
\n
`;\n $el.empty().append(tmpl);\n hasLabel && this.renderLabel();\n this.renderField();\n this.el.className = `${cls}__wrp`;\n this.postUpdate();\n this.onRender(this.getClbOpts());\n return this;\n }\n});\n","import Backbone from 'backbone';\nimport { isString, isUndefined } from 'underscore';\nimport TraitView from './TraitView';\n\nconst $ = Backbone.$;\n\nexport default TraitView.extend({\n init() {\n this.listenTo(this.model, 'change:options', this.rerender);\n },\n\n templateInput() {\n const { ppfx, clsField } = this;\n return `
\n
\n
\n
\n
\n
`;\n },\n\n /**\n * Returns input element\n * @return {HTMLElement}\n * @private\n */\n getInputEl() {\n if (!this.$input) {\n const { model } = this;\n const opts = model.get('options') || [];\n let input = '';\n this.$input = $(input);\n let val = model.getTargetValue() || model.get('value');\n !isUndefined(val) && this.$input.val(val);\n }\n\n return this.$input.get(0);\n }\n});\n","import { isUndefined } from 'underscore';\nimport TraitView from './TraitView';\n\nexport default TraitView.extend({\n appendInput: 0,\n\n templateInput() {\n const { ppfx, clsField } = this;\n return ``;\n },\n\n /**\n * Fires when the input is changed\n * @private\n */\n onChange() {\n const value = this.getInputElem().checked;\n this.model.set('value', this.getCheckedValue(value));\n },\n\n getCheckedValue(checked) {\n let result = checked;\n const { valueTrue, valueFalse } = this.model.attributes;\n\n if (result && !isUndefined(valueTrue)) {\n result = valueTrue;\n }\n\n if (!result && !isUndefined(valueFalse)) {\n result = valueFalse;\n }\n\n return result;\n },\n\n /**\n * Returns input element\n * @return {HTMLElement}\n * @private\n */\n getInputEl(...args) {\n const toInit = !this.$input;\n const el = TraitView.prototype.getInputEl.apply(this, args);\n\n if (toInit) {\n let checked, targetValue;\n const { model, target } = this;\n const { valueTrue, valueFalse } = model.attributes;\n const name = model.get('name');\n\n if (model.get('changeProp')) {\n checked = target.get(name);\n targetValue = checked;\n } else {\n targetValue = target.get('attributes')[name];\n checked = targetValue || targetValue === '' ? !0 : !1;\n }\n\n if (!isUndefined(valueFalse) && targetValue === valueFalse) {\n checked = !1;\n }\n\n el.checked = checked;\n }\n\n return el;\n }\n});\n","import TraitView from './TraitView';\nimport InputNumber from 'domain_abstract/ui/InputNumber';\n\nexport default TraitView.extend({\n getValueForTarget() {\n const { model } = this;\n const { value, unit } = model.attributes;\n return value ? value + unit : '';\n },\n\n /**\n * Returns input element\n * @return {HTMLElement}\n * @private\n */\n getInputEl() {\n if (!this.input) {\n var value = this.getModelValue();\n var inputNumber = new InputNumber({\n contClass: this.ppfx + 'field-int',\n model: this.model,\n ppfx: this.ppfx\n });\n this.input = inputNumber.render();\n this.$input = this.input.inputEl;\n this.$unit = this.input.unitEl;\n this.model.set('value', value);\n this.$input.val(value);\n this.input = inputNumber.el;\n }\n return this.input;\n }\n});\n","import TraitView from './TraitView';\nimport InputColor from 'domain_abstract/ui/InputColor';\n\nexport default TraitView.extend({\n templateInput: '',\n\n /**\n * Returns input element\n * @return {HTMLElement}\n * @private\n */\n getInputEl() {\n if (!this.input) {\n const model = this.model;\n const value = this.getModelValue();\n const inputColor = new InputColor({\n model,\n target: this.config.em,\n contClass: this.ppfx + 'field-color',\n ppfx: this.ppfx\n });\n const input = inputColor.render();\n input.setValue(value, { fromTarget: 1 });\n this.input = input.el;\n }\n\n return this.input;\n }\n});\n","import { isString } from 'underscore';\nimport TraitView from './TraitView';\n\nexport default TraitView.extend({\n events: {\n 'click button': 'handleClick'\n },\n\n templateInput: '',\n\n handleClick() {\n const { model, em } = this;\n const command = model.get('command');\n\n if (command) {\n if (isString(command)) {\n em.get('Commands').run(command);\n } else {\n command(em.get('Editor'), model);\n }\n }\n },\n\n renderLabel() {\n if (this.model.get('label')) {\n TraitView.prototype.renderLabel.apply(this, arguments);\n }\n },\n\n getInputEl() {\n const { model, ppfx } = this;\n const { labelButton, text, full } = model.props();\n const label = labelButton || text;\n const className = `${ppfx}btn`;\n const input = ``;\n return input;\n }\n});\n","import DomainViews from 'domain_abstract/view/DomainViews';\nimport TraitView from './TraitView';\nimport TraitSelectView from './TraitSelectView';\nimport TraitCheckboxView from './TraitCheckboxView';\nimport TraitNumberView from './TraitNumberView';\nimport TraitColorView from './TraitColorView';\nimport TraitButtonView from './TraitButtonView';\n\nexport default DomainViews.extend({\n ns: 'Traits',\n itemView: TraitView,\n reuseView: 1,\n\n itemsView: {\n text: TraitView,\n number: TraitNumberView,\n select: TraitSelectView,\n checkbox: TraitCheckboxView,\n color: TraitColorView,\n button: TraitButtonView\n },\n\n initialize(o = {}) {\n const config = o.config || {};\n this.config = config;\n this.em = o.editor;\n this.pfx = config.stylePrefix || '';\n this.ppfx = config.pStylePrefix || '';\n this.className = this.pfx + 'traits';\n const toListen = 'component:toggled';\n this.listenTo(this.em, toListen, this.updatedCollection);\n this.updatedCollection();\n },\n\n /**\n * Update view collection\n * @private\n */\n updatedCollection() {\n const ppfx = this.ppfx;\n const comp = this.em.getSelected();\n this.el.className = `${this.className} ${ppfx}one-bg ${ppfx}two-color`;\n this.collection = comp ? comp.get('traits') : [];\n this.render();\n }\n});\n","import { defaults, isElement } from 'underscore';\nimport defaultOpts from './config/config';\nimport TraitsView from './view/TraitsView';\n\nexport default () => {\n let c = {};\n let TraitsViewer;\n\n return {\n TraitsView,\n\n /**\n * Name of the module\n * @type {String}\n * @private\n */\n name: 'TraitManager',\n\n /**\n * Get configuration object\n * @return {Object}\n * @private\n */\n getConfig() {\n return c;\n },\n\n /**\n * Initialize module. Automatically called with a new instance of the editor\n * @param {Object} config Configurations\n */\n init(config = {}) {\n c = config;\n defaults(c, defaultOpts);\n const ppfx = c.pStylePrefix;\n ppfx && (c.stylePrefix = `${ppfx}${c.stylePrefix}`);\n TraitsViewer = new TraitsView({\n collection: [],\n editor: c.em,\n config: c\n });\n return this;\n },\n\n postRender() {\n const elTo = this.getConfig().appendTo;\n\n if (elTo) {\n const el = isElement(elTo) ? elTo : document.querySelector(elTo);\n el.appendChild(this.render());\n }\n },\n\n /**\n *\n * Get Traits viewer\n * @private\n */\n getTraitsViewer() {\n return TraitsViewer;\n },\n\n /**\n * Add new trait type\n * @param {string} name Type name\n * @param {Object} methods Object representing the trait\n */\n addType(name, trait) {\n var itemView = TraitsViewer.itemView;\n TraitsViewer.itemsView[name] = itemView.extend(trait);\n },\n\n /**\n * Get trait type\n * @param {string} name Type name\n * @return {Object}\n */\n getType(name) {\n return TraitsViewer.itemsView[name];\n },\n\n render() {\n return TraitsViewer.render().el;\n }\n };\n};\n","export default {\n // Default assets\n // eg. [\n // 'https://...image1.png',\n // 'https://...image2.png',\n // {type: 'image', src: 'https://...image3.png', someOtherCustomProp: 1},\n // ..\n // ]\n assets: [],\n\n // Content to add where there is no assets to show\n // eg. 'No assets here, drag to upload'\n noAssets: '',\n\n // Style prefix\n stylePrefix: 'am-',\n\n // Upload endpoint, set `false` to disable upload\n // upload: 'https://endpoint/upload/assets',\n // upload: false,\n upload: 0,\n\n // The name used in POST to pass uploaded files\n uploadName: 'files',\n\n // Custom headers to pass with the upload request\n headers: {},\n\n // Custom parameters to pass with the upload request, eg. csrf token\n params: {},\n\n // The credentials setting for the upload request, eg. 'include', 'omit'\n credentials: 'include',\n\n // Allow uploading multiple files per request.\n // If disabled filename will not have '[]' appended\n multiUpload: true,\n\n // If true, tries to add automatically uploaded assets.\n // To make it work the server should respond with a JSON containing assets\n // in a data key, eg:\n // {\n // data: [\n // 'https://.../image.png',\n // ...\n // {src: 'https://.../image2.png'},\n // ...\n // ]\n // }\n autoAdd: 1,\n\n // Text on upload input\n uploadText: 'Drop files here or click to upload',\n\n // Label for the add button\n addBtnText: 'Add image',\n\n // To upload your assets, the module uses Fetch API, with this option you\n // overwrite it with something else.\n // It should return a Promise\n // @example\n // customFetch: (url, options) => axios(url, { data: options.body }),\n customFetch: '',\n\n // Custom uploadFile function.\n // Differently from the `customFetch` option, this gives a total control\n // over the uploading process, but you also have to emit all `asset:upload:*` events\n // by yourself (if you need to use them somewhere)\n // @example\n // uploadFile: (e) => {\n // var files = e.dataTransfer ? e.dataTransfer.files : e.target.files;\n // // ...send somewhere\n // }\n uploadFile: '',\n\n // In the absence of 'uploadFile' or 'upload' assets will be embedded as Base64\n embedAsBase64: 1,\n\n // Handle the image url submit from the built-in 'Add image' form\n // @example\n // handleAdd: (textFromInput) => {\n // // some check...\n // editor.AssetManager.add(textFromInput);\n // }\n handleAdd: '',\n\n // Enable an upload dropzone on the entire editor (not document) when dragging\n // files over it\n // If active the dropzone disable/hide the upload dropzone in asset modal,\n // otherwise you will get double drops (#507)\n dropzone: 0,\n\n // Open the asset manager once files are been dropped via the dropzone\n openAssetsOnDrop: 1,\n\n // Any dropzone content to append inside dropzone element\n dropzoneContent: '',\n\n // Default title for the asset manager modal\n modalTitle: 'Select Image',\n\n //Default placeholder for input\n inputPlaceholder: 'http://path/to/the/image.jpg',\n\n //method called before upload, on return false upload is canceled.\n // @example\n // beforeUpload: (files) => {\n // // logic...\n // var stopUpload = true;\n // if(stopUpload) return false;\n // }\n beforeUpload: null\n};\n","import Backbone from 'backbone';\n\nexport default Backbone.Model.extend({\n idAttribute: 'src',\n\n defaults: {\n type: '',\n src: ''\n },\n\n /**\n * Get filename of the asset\n * @return {string}\n * @private\n * */\n getFilename() {\n return this.get('src')\n .split('/')\n .pop();\n },\n\n /**\n * Get extension of the asset\n * @return {string}\n * @private\n * */\n getExtension() {\n return this.getFilename()\n .split('.')\n .pop();\n }\n});\n","import Asset from './Asset';\n\nexport default Asset.extend({\n defaults: {\n ...Asset.prototype.defaults,\n type: 'image',\n unitDim: 'px',\n height: 0,\n width: 0\n }\n});\n","import { isFunction } from 'underscore';\nimport AssetView from './AssetView';\n\nexport default AssetView.extend({\n events: {\n 'click [data-toggle=asset-remove]': 'onRemove',\n click: 'onClick',\n dblclick: 'onDblClick'\n },\n\n getPreview() {\n const pfx = this.pfx;\n const src = this.model.get('src');\n return `\n
\n
\n `;\n },\n\n getInfo() {\n const pfx = this.pfx;\n const model = this.model;\n let name = model.get('name');\n let width = model.get('width');\n let height = model.get('height');\n let unit = model.get('unitDim');\n let dim = width && height ? `${width}x${height}${unit}` : '';\n name = name || model.getFilename();\n return `\n
${name}
\n
${dim}
\n `;\n },\n\n init(o) {\n const pfx = this.pfx;\n this.className += ` ${pfx}asset-image`;\n },\n\n /**\n * Triggered when the asset is clicked\n * @private\n * */\n onClick() {\n var onClick = this.config.onClick;\n var model = this.model;\n this.collection.trigger('deselectAll');\n this.$el.addClass(this.pfx + 'highlight');\n\n if (isFunction(onClick)) {\n onClick(model);\n } else {\n this.updateTarget(this.collection.target);\n }\n },\n\n /**\n * Triggered when the asset is double clicked\n * @private\n * */\n onDblClick() {\n const { em, model } = this;\n const onDblClick = this.config.onDblClick;\n\n if (isFunction(onDblClick)) {\n onDblClick(model);\n } else {\n this.updateTarget(this.collection.target);\n em && em.get('Modal').close();\n }\n\n var onSelect = this.collection.onSelect;\n isFunction(onSelect) && onSelect(model);\n },\n\n /**\n * Remove asset from collection\n * @private\n * */\n onRemove(e) {\n e.stopImmediatePropagation();\n this.model.collection.remove(this.model);\n }\n});\n","import Backbone from 'backbone';\nimport { clone } from 'underscore';\n\nexport default Backbone.View.extend({\n initialize(o = {}) {\n this.options = o;\n this.collection = o.collection;\n const config = o.config || {};\n this.config = config;\n this.pfx = config.stylePrefix || '';\n this.ppfx = config.pStylePrefix || '';\n this.em = config.em;\n this.className = this.pfx + 'asset';\n this.listenTo(this.model, 'destroy remove', this.remove);\n this.model.view = this;\n const init = this.init && this.init.bind(this);\n init && init(o);\n },\n\n template() {\n const pfx = this.pfx;\n return `\n
\n ${this.getPreview()}\n
\n
\n ${this.getInfo()}\n
\n
\n ⨯\n
\n `;\n },\n\n /**\n * Update target if exists\n * @param {Model} target\n * @private\n * */\n updateTarget(target) {\n if (target && target.set) {\n target.set('attributes', clone(target.get('attributes')));\n target.set('src', this.model.get('src'));\n }\n },\n\n getPreview() {\n return '';\n },\n\n getInfo() {\n return '';\n },\n\n render() {\n const el = this.el;\n el.innerHTML = this.template(this, this.model);\n el.className = this.className;\n return this;\n }\n});\n","import Backbone from 'backbone';\nimport AssetImage from './AssetImage';\nimport AssetImageView from './../view/AssetImageView';\nimport TypeableCollection from 'domain_abstract/model/TypeableCollection';\n\nexport default Backbone.Collection.extend(TypeableCollection).extend({\n types: [\n {\n id: 'image',\n model: AssetImage,\n view: AssetImageView,\n isType(value) {\n if (typeof value == 'string') {\n return {\n type: 'image',\n src: value\n };\n }\n return value;\n }\n }\n ]\n});\n","import Backbone from 'backbone';\n\nexport default Backbone.View.extend({\n events: {\n submit: 'handleSubmit'\n },\n\n template(view) {\n const pfx = view.pfx;\n const ppfx = view.ppfx;\n return `\n
\n
\n
\n
\n \n
\n \n
\n
\n
\n
\n
\n
\n `;\n },\n\n initialize(o) {\n this.options = o;\n this.config = o.config;\n this.pfx = this.config.stylePrefix || '';\n this.ppfx = this.config.pStylePrefix || '';\n const coll = this.collection;\n this.listenTo(coll, 'reset', this.renderAssets);\n this.listenTo(coll, 'add', this.addToAsset);\n this.listenTo(coll, 'remove', this.removedAsset);\n this.listenTo(coll, 'deselectAll', this.deselectAll);\n },\n\n /**\n * Add new asset to the collection via string\n * @param {Event} e Event object\n * @return {this}\n * @private\n */\n handleSubmit(e) {\n e.preventDefault();\n const input = this.getAddInput();\n const url = input.value.trim();\n const handleAdd = this.config.handleAdd;\n\n if (!url) {\n return;\n }\n\n input.value = '';\n this.getAssetsEl().scrollTop = 0;\n\n if (handleAdd) {\n handleAdd.bind(this)(url);\n } else {\n this.options.globalCollection.add(url, { at: 0 });\n }\n },\n\n /**\n * Returns assets element\n * @return {HTMLElement}\n * @private\n */\n getAssetsEl() {\n //if(!this.assets) // Not able to cache as after the rerender it losses the ref\n return this.el.querySelector(`.${this.pfx}assets`);\n },\n\n /**\n * Returns input url element\n * @return {HTMLElement}\n * @private\n */\n getAddInput() {\n if (!this.inputUrl || !this.inputUrl.value)\n this.inputUrl = this.el.querySelector(`.${this.pfx}add-asset input`);\n return this.inputUrl;\n },\n\n /**\n * Triggered when an asset is removed\n * @param {Asset} model Removed asset\n * @private\n */\n removedAsset(model) {\n if (!this.collection.length) {\n this.toggleNoAssets();\n }\n },\n\n /**\n * Add asset to collection\n * @private\n * */\n addToAsset(model) {\n if (this.collection.length == 1) {\n this.toggleNoAssets(1);\n }\n this.addAsset(model);\n },\n\n /**\n * Add new asset to collection\n * @param Object Model\n * @param Object Fragment collection\n * @return Object Object created\n * @private\n * */\n addAsset(model, fragmentEl = null) {\n const fragment = fragmentEl;\n const collection = this.collection;\n const config = this.config;\n const rendered = new model.typeView({\n model,\n collection,\n config\n }).render().el;\n\n if (fragment) {\n fragment.appendChild(rendered);\n } else {\n const assetsEl = this.getAssetsEl();\n if (assetsEl) {\n assetsEl.insertBefore(rendered, assetsEl.firstChild);\n }\n }\n\n return rendered;\n },\n\n /**\n * Checks if to show noAssets\n * @param {Boolean} hide\n * @private\n */\n toggleNoAssets(hide) {\n const assetsEl = this.$el.find(`.${this.pfx}assets`);\n\n if (hide) {\n assetsEl.empty();\n } else {\n const noAssets = this.config.noAssets;\n noAssets && assetsEl.append(noAssets);\n }\n },\n\n /**\n * Deselect all assets\n * @private\n * */\n deselectAll() {\n const pfx = this.pfx;\n this.$el.find(`.${pfx}highlight`).removeClass(`${pfx}highlight`);\n },\n\n renderAssets() {\n const fragment = document.createDocumentFragment();\n const assets = this.$el.find(`.${this.pfx}assets`);\n assets.empty();\n this.toggleNoAssets(this.collection.length);\n this.collection.each(model => this.addAsset(model, fragment));\n assets.append(fragment);\n },\n\n render() {\n const fuRendered = this.options.fu.render().el;\n this.$el.empty();\n this.$el.append(fuRendered).append(this.template(this));\n this.el.className = `${this.ppfx}asset-manager`;\n this.renderAssets();\n this.rendered = 1;\n return this;\n }\n});\n","import { template } from 'underscore';\nimport Backbone from 'backbone';\nimport fetch from 'utils/fetch';\n\nexport default Backbone.View.extend(\n {\n template: template(`\n
\n
title\"><%= title %>
\n \" name=\"file\" accept=\"*/*\" <%= disabled ? 'disabled' : '' %> <%= multiUpload ? 'multiple' : '' %>/>\n
\n
\n `),\n\n events: {},\n\n initialize(opts = {}) {\n this.options = opts;\n const c = opts.config || {};\n this.config = c;\n this.pfx = c.stylePrefix || '';\n this.ppfx = c.pStylePrefix || '';\n this.target = this.options.globalCollection || {};\n this.uploadId = this.pfx + 'uploadFile';\n this.disabled =\n c.disableUpload !== undefined\n ? c.disableUpload\n : !c.upload && !c.embedAsBase64;\n this.multiUpload = c.multiUpload !== undefined ? c.multiUpload : true;\n this.events['change #' + this.uploadId] = 'uploadFile';\n let uploadFile = c.uploadFile;\n\n if (uploadFile) {\n this.uploadFile = uploadFile.bind(this);\n } else if (!c.upload && c.embedAsBase64) {\n this.uploadFile = this.constructor.embedAsBase64;\n }\n\n this.delegateEvents();\n },\n\n /**\n * Triggered before the upload is started\n * @private\n */\n onUploadStart() {\n const em = this.config.em;\n em && em.trigger('asset:upload:start');\n },\n\n /**\n * Triggered after the upload is ended\n * @param {Object|string} res End result\n * @private\n */\n onUploadEnd(res) {\n const { $el, config } = this;\n const em = config.em;\n em && em.trigger('asset:upload:end', res);\n const input = $el.find('input');\n input && input.val('');\n },\n\n /**\n * Triggered on upload error\n * @param {Object} err Error\n * @private\n */\n onUploadError(err) {\n const em = this.config.em;\n console.error(err);\n this.onUploadEnd(err);\n em && em.trigger('asset:upload:error', err);\n },\n\n /**\n * Triggered on upload response\n * @param {string} text Response text\n * @private\n */\n onUploadResponse(text, clb) {\n const em = this.config.em;\n const config = this.config;\n const target = this.target;\n let json;\n try {\n json = typeof text === 'string' ? JSON.parse(text) : text;\n } catch (e) {\n json = text;\n }\n\n em && em.trigger('asset:upload:response', json);\n\n if (config.autoAdd && target) {\n target.add(json.data, { at: 0 });\n }\n\n this.onUploadEnd(text);\n clb && clb(json);\n },\n\n /**\n * Upload files\n * @param {Object} e Event\n * @return {Promise}\n * @private\n * */\n uploadFile(e, clb) {\n const files = e.dataTransfer ? e.dataTransfer.files : e.target.files;\n const { config } = this;\n const { beforeUpload } = config;\n\n const beforeUploadResponse = beforeUpload && beforeUpload(files);\n if (beforeUploadResponse === false) return;\n\n const body = new FormData();\n const { params, customFetch } = config;\n\n for (let param in params) {\n body.append(param, params[param]);\n }\n\n if (this.multiUpload) {\n for (let i = 0; i < files.length; i++) {\n body.append(`${config.uploadName}[]`, files[i]);\n }\n } else if (files.length) {\n body.append(config.uploadName, files[0]);\n }\n\n var target = this.target;\n const url = config.upload;\n const headers = config.headers;\n const reqHead = 'X-Requested-With';\n\n if (typeof headers[reqHead] == 'undefined') {\n headers[reqHead] = 'XMLHttpRequest';\n }\n\n if (url) {\n this.onUploadStart();\n const fetchOpts = {\n method: 'post',\n credentials: config.credentials || 'include',\n headers,\n body\n };\n const fetchResult = customFetch\n ? customFetch(url, fetchOpts)\n : fetch(url, fetchOpts).then(res =>\n ((res.status / 200) | 0) == 1\n ? res.text()\n : res.text().then(text => Promise.reject(text))\n );\n return fetchResult\n .then(text => this.onUploadResponse(text, clb))\n .catch(err => this.onUploadError(err));\n }\n },\n\n /**\n * Make input file droppable\n * @private\n * */\n initDrop() {\n var that = this;\n if (!this.uploadForm) {\n this.uploadForm = this.$el.find('form').get(0);\n if ('draggable' in this.uploadForm) {\n var uploadFile = this.uploadFile;\n this.uploadForm.ondragover = function() {\n this.className = that.pfx + 'hover';\n return false;\n };\n this.uploadForm.ondragleave = function() {\n this.className = '';\n return false;\n };\n this.uploadForm.ondrop = function(e) {\n this.className = '';\n e.preventDefault();\n that.uploadFile(e);\n return;\n };\n }\n }\n },\n\n initDropzone(ev) {\n let addedCls = 0;\n const c = this.config;\n const em = ev.model;\n const edEl = ev.el;\n const editor = em.get('Editor');\n const container = em.get('Config').el;\n const frameEl = em.get('Canvas').getBody();\n const ppfx = this.ppfx;\n const updatedCls = `${ppfx}dropzone-active`;\n const dropzoneCls = `${ppfx}dropzone`;\n const cleanEditorElCls = () => {\n edEl.className = edEl.className.replace(updatedCls, '').trim();\n addedCls = 0;\n };\n const onDragOver = () => {\n if (!addedCls) {\n edEl.className += ` ${updatedCls}`;\n addedCls = 1;\n }\n return false;\n };\n const onDragLeave = () => {\n cleanEditorElCls();\n return false;\n };\n const onDrop = e => {\n cleanEditorElCls();\n e.preventDefault();\n e.stopPropagation();\n this.uploadFile(e);\n\n if (c.openAssetsOnDrop && editor) {\n const target = editor.getSelected();\n editor.runCommand('open-assets', {\n target,\n onSelect() {\n editor.Modal.close();\n editor.AssetManager.setTarget(null);\n }\n });\n }\n\n return false;\n };\n\n ev.$el.append(`
${c.dropzoneContent}
`);\n cleanEditorElCls();\n\n if ('draggable' in edEl) {\n [edEl, frameEl].forEach(item => {\n item.ondragover = onDragOver;\n item.ondragleave = onDragLeave;\n item.ondrop = onDrop;\n });\n }\n },\n\n render() {\n this.$el.html(\n this.template({\n title: this.config.uploadText,\n uploadId: this.uploadId,\n disabled: this.disabled,\n multiUpload: this.multiUpload,\n pfx: this.pfx\n })\n );\n this.initDrop();\n this.$el.attr('class', this.pfx + 'file-uploader');\n return this;\n }\n },\n {\n embedAsBase64: function(e, clb) {\n // List files dropped\n const files = e.dataTransfer ? e.dataTransfer.files : e.target.files;\n const response = { data: [] };\n\n // Unlikely, widely supported now\n if (!FileReader) {\n this.onUploadError(\n new Error('Unsupported platform, FileReader is not defined')\n );\n return;\n }\n\n const promises = [];\n const mimeTypeMatcher = /^(.+)\\/(.+)$/;\n\n for (const file of files) {\n // For each file a reader (to read the base64 URL)\n // and a promise (to track and merge results and errors)\n const promise = new Promise((resolve, reject) => {\n const reader = new FileReader();\n reader.addEventListener('load', event => {\n let type;\n const name = file.name;\n\n // Try to find the MIME type of the file.\n const match = mimeTypeMatcher.exec(file.type);\n if (match) {\n type = match[1]; // The first part in the MIME, \"image\" in image/png\n } else {\n type = file.type;\n }\n\n /*\n // Show local video files, http://jsfiddle.net/dsbonev/cCCZ2/embedded/result,js,html,css/\n var URL = window.URL || window.webkitURL\n var file = this.files[0]\n var type = file.type\n var videoNode = document.createElement('video');\n var canPlay = videoNode.canPlayType(type) // can use also for 'audio' types\n if (canPlay === '') canPlay = 'no'\n var message = 'Can play type \"' + type + '\": ' + canPlay\n var isError = canPlay === 'no'\n displayMessage(message, isError)\n\n if (isError) {\n return\n }\n\n var fileURL = URL.createObjectURL(file)\n videoNode.src = fileURL\n */\n\n // If it's an image, try to find its size\n if (type === 'image') {\n const data = {\n src: reader.result,\n name,\n type,\n height: 0,\n width: 0\n };\n\n const image = new Image();\n image.addEventListener('error', error => {\n reject(error);\n });\n image.addEventListener('load', () => {\n data.height = image.height;\n data.width = image.width;\n resolve(data);\n });\n image.src = data.src;\n } else if (type) {\n // Not an image, but has a type\n resolve({\n src: reader.result,\n name,\n type\n });\n } else {\n // No type found, resolve with the URL only\n resolve(reader.result);\n }\n });\n reader.addEventListener('error', error => {\n reject(error);\n });\n reader.addEventListener('abort', error => {\n reject('Aborted');\n });\n\n reader.readAsDataURL(file);\n });\n\n promises.push(promise);\n }\n\n Promise.all(promises).then(\n data => {\n response.data = data;\n this.onUploadResponse(response, clb);\n },\n error => {\n this.onUploadError(error);\n }\n );\n }\n }\n);\n","/**\n * You can customize the initial state of the module from the editor initialization, by passing the following [Configuration Object](https://github.com/artf/grapesjs/blob/master/src/asset_manager/config/config.js)\n * ```js\n * const editor = grapesjs.init({\n * assetManager: {\n * // options\n * }\n * })\n * ```\n *\n * Once the editor is instantiated you can use its API. Before using these methods you should get the module from the instance\n *\n * ```js\n * const assetManager = editor.AssetManager;\n * ```\n *\n * * [add](#add)\n * * [get](#get)\n * * [getAll](#getall)\n * * [getAllVisible](#getallvisible)\n * * [remove](#remove)\n * * [store](#store)\n * * [load](#load)\n * * [getContainer](#getcontainer)\n * * [getAssetsEl](#getassetsel)\n * * [addType](#addtype)\n * * [getType](#gettype)\n * * [getTypes](#gettypes)\n *\n * @module AssetManager\n */\n\nimport defaults from './config/config';\nimport Assets from './model/Assets';\nimport AssetsView from './view/AssetsView';\nimport FileUpload from './view/FileUploader';\n\nexport default () => {\n let c = {};\n let assets, am, fu;\n\n return {\n /**\n * Name of the module\n * @type {String}\n * @private\n */\n name: 'AssetManager',\n\n /**\n * Mandatory for the storage manager\n * @type {String}\n * @private\n */\n storageKey: 'assets',\n\n getConfig() {\n return c;\n },\n\n /**\n * Initialize module\n * @param {Object} config Configurations\n * @private\n */\n init(config) {\n c = config || {};\n\n for (let name in defaults) {\n if (!(name in c)) c[name] = defaults[name];\n }\n\n const ppfx = c.pStylePrefix;\n const em = c.em;\n\n if (ppfx) {\n c.stylePrefix = ppfx + c.stylePrefix;\n }\n\n // Global assets collection\n assets = new Assets([]);\n const obj = {\n // Collection visible in asset manager\n collection: new Assets([]),\n globalCollection: assets,\n config: c\n };\n fu = new FileUpload(obj);\n obj.fu = fu;\n am = new AssetsView(obj);\n\n // Setup the sync between the global and public collections\n assets.listenTo(assets, 'add', model => {\n this.getAllVisible().add(model);\n em && em.trigger('asset:add', model);\n });\n\n assets.listenTo(assets, 'remove', model => {\n this.getAllVisible().remove(model);\n em && em.trigger('asset:remove', model);\n });\n\n return this;\n },\n\n /**\n * Add new asset/s to the collection. URLs are supposed to be unique\n * @param {string|Object|Array|Array} asset URL strings or an objects representing the resource.\n * @param {Object} [opts] Options\n * @return {Model}\n * @example\n * // In case of strings, would be interpreted as images\n * assetManager.add('http://img.jpg');\n * assetManager.add(['http://img.jpg', './path/to/img.png']);\n *\n * // Using objects you could indicate the type and other meta informations\n * assetManager.add({\n * \tsrc: 'http://img.jpg',\n * \t//type: 'image',\t//image is default\n * \theight: 300,\n *\twidth: 200,\n * });\n * assetManager.add([{\n * \tsrc: 'http://img.jpg',\n * },{\n * \tsrc: './path/to/img.png',\n * }]);\n */\n add(asset, opts = {}) {\n // Put the model at the beginning\n if (typeof opts.at == 'undefined') {\n opts.at = 0;\n }\n\n return assets.add(asset, opts);\n },\n\n /**\n * Returns the asset by URL\n * @param {string} src URL of the asset\n * @return {Object} Object representing the asset\n * @example\n * var asset = assetManager.get('http://img.jpg');\n */\n get(src) {\n return assets.where({ src })[0];\n },\n\n /**\n * Return the global collection, containing all the assets\n * @return {Collection}\n */\n getAll() {\n return assets;\n },\n\n /**\n * Return the visible collection, which containes assets actually rendered\n * @return {Collection}\n */\n getAllVisible() {\n return am.collection;\n },\n\n /**\n * Remove the asset by its URL\n * @param {string} src URL of the asset\n * @return {this}\n * @example\n * assetManager.remove('http://img.jpg');\n */\n remove(src) {\n var asset = this.get(src);\n this.getAll().remove(asset);\n return this;\n },\n\n /**\n * Store assets data to the selected storage\n * @param {Boolean} noStore If true, won't store\n * @return {Object} Data to store\n * @example\n * var assets = assetManager.store();\n */\n store(noStore) {\n var obj = {};\n var assets = JSON.stringify(this.getAll().toJSON());\n obj[this.storageKey] = assets;\n if (!noStore && c.stm) c.stm.store(obj);\n return obj;\n },\n\n /**\n * Load data from the passed object.\n * The fetched data will be added to the collection.\n * @param {Object} data Object of data to load\n * @return {Object} Loaded assets\n * @example\n * var assets = assetManager.load({\n * \tassets: [...]\n * })\n *\n */\n load(data = {}) {\n const name = this.storageKey;\n let assets = data[name] || [];\n\n if (typeof assets == 'string') {\n try {\n assets = JSON.parse(data[name]);\n } catch (err) {}\n }\n\n if (assets && assets.length) {\n this.getAll().reset(assets);\n }\n\n return assets;\n },\n\n /**\n * Return the Asset Manager Container\n * @return {HTMLElement}\n */\n getContainer() {\n return am.el;\n },\n\n /**\n * Get assets element container\n * @return {HTMLElement}\n */\n getAssetsEl() {\n return am.el.querySelector('[data-el=assets]');\n },\n\n /**\n * Render assets\n * @param {array} assets Assets to render, without the argument will render\n * all global assets\n * @return {HTMLElement}\n * @example\n * // Render all assets\n * assetManager.render();\n *\n * // Render some of the assets\n * const assets = assetManager.getAll();\n * assetManager.render(assets.filter(\n * asset => asset.get('category') == 'cats'\n * ));\n */\n render(assets) {\n const toRender = assets || this.getAll().models;\n\n if (!am.rendered) {\n am.render();\n }\n\n am.collection.reset(toRender);\n return this.getContainer();\n },\n\n /**\n * Add new type. If you want to get more about type definition we suggest to read the [module's page](/modules/Assets.html)\n * @param {string} id Type ID\n * @param {Object} definition Definition of the type. Each definition contains\n * `model` (business logic), `view` (presentation logic)\n * and `isType` function which recognize the type of the\n * passed entity\n * @example\n * assetManager.addType('my-type', {\n * model: {},\n * view: {},\n * isType: (value) => {},\n * })\n */\n addType(id, definition) {\n this.getAll().addType(id, definition);\n },\n\n /**\n * Get type\n * @param {string} id Type ID\n * @return {Object} Type definition\n */\n getType(id) {\n return this.getAll().getType(id);\n },\n\n /**\n * Get types\n * @return {Array}\n */\n getTypes() {\n return this.getAll().getTypes();\n },\n\n //-------\n\n AssetsView() {\n return am;\n },\n\n FileUploader() {\n return fu;\n },\n\n onLoad() {\n this.getAll().reset(c.assets);\n },\n\n postRender(editorView) {\n c.dropzone && fu.initDropzone(editorView);\n },\n\n /**\n * Set new target\n * @param\t{Object}\tm Model\n * @private\n * */\n setTarget(m) {\n am.collection.target = m;\n },\n\n /**\n * Set callback after asset was selected\n * @param\t{Object}\tf Callback function\n * @private\n * */\n onSelect(f) {\n am.collection.onSelect = f;\n },\n\n /**\n * Set callback to fire when the asset is clicked\n * @param {function} func\n * @private\n */\n onClick(func) {\n c.onClick = func;\n },\n\n /**\n * Set callback to fire when the asset is double clicked\n * @param {function} func\n * @private\n */\n onDblClick(func) {\n c.onDblClick = func;\n }\n };\n};\n","export default {\n // Specify the element to use as a container, string (query) or HTMLElement\n // With the empty value, nothing will be rendered\n appendTo: '',\n\n // Append blocks to canvas on click\n appendOnClick: 0,\n\n blocks: []\n};\n","import Backbone from 'backbone';\n\nexport default Backbone.Model.extend({\n defaults: {\n id: '',\n label: '',\n open: true,\n attributes: {}\n }\n});\n","import Backbone from 'backbone';\nimport Category from './Category';\n\nexport default Backbone.Model.extend({\n defaults: {\n // If true, triggers an 'active' event on dropped component\n activate: 0,\n // If true, the dropped component will be selected\n select: 0,\n // If true, all IDs of dropped component and its style will be changed\n resetId: 0,\n // Block label\n label: '',\n // HTML string for the media of the block, eg. SVG icon, image, etc.\n media: '',\n content: '',\n category: '',\n attributes: {}\n },\n\n initialize(opts = {}) {\n let category = this.get('category');\n\n if (category) {\n if (typeof category == 'string') {\n var catObj = new Category({\n id: category,\n label: category\n });\n }\n }\n }\n});\n","import Backbone from 'backbone';\nimport Block from './Block';\n\nexport default Backbone.Collection.extend({\n model: Block\n});\n","import Backbone from 'backbone';\nimport Category from './Category';\n\nexport default Backbone.Collection.extend({\n model: Category\n});\n","import Backbone from 'backbone';\nimport { isObject } from 'underscore';\nimport { on, off, hasDnd } from 'utils/mixins';\n\nexport default Backbone.View.extend({\n events: {\n click: 'handleClick',\n mousedown: 'startDrag',\n dragstart: 'handleDragStart',\n drag: 'handleDrag',\n dragend: 'handleDragEnd'\n },\n\n initialize(o, config = {}) {\n const { model } = this;\n this.em = config.em;\n this.config = config;\n this.endDrag = this.endDrag.bind(this);\n this.ppfx = config.pStylePrefix || '';\n this.listenTo(model, 'destroy remove', this.remove);\n this.listenTo(model, 'change', this.render);\n },\n\n handleClick() {\n const { config, model, em } = this;\n if (!config.appendOnClick) return;\n const sorter = config.getSorter();\n const content = model.get('content');\n const selected = em.getSelected();\n sorter.setDropContent(content);\n let target, valid;\n\n // If there is a selected component, try first to append\n // the block inside, otherwise, try to place it as a next sibling\n if (selected) {\n valid = sorter.validTarget(selected.getEl(), content);\n\n if (valid.valid) {\n target = selected;\n } else {\n const parent = selected.parent();\n valid = sorter.validTarget(parent.getEl(), content);\n if (valid.valid) target = parent;\n }\n }\n\n // If no target found yet, try to append the block to the wrapper\n if (!target) {\n const wrapper = em.getWrapper();\n valid = sorter.validTarget(wrapper.getEl(), content);\n if (valid.valid) target = wrapper;\n }\n\n const result = target && target.append(content)[0];\n result && em.setSelected(result, { scroll: 1 });\n },\n\n /**\n * Start block dragging\n * @private\n */\n startDrag(e) {\n const { config, em } = this;\n //Right or middel click\n if (e.button !== 0 || !config.getSorter || this.el.draggable) return;\n em.refreshCanvas();\n const sorter = config.getSorter();\n sorter.setDragHelper(this.el, e);\n sorter.setDropContent(this.model.get('content'));\n sorter.startSort(this.el);\n on(document, 'mouseup', this.endDrag);\n },\n\n handleDragStart(ev) {\n const { em, model } = this;\n const content = model.get('content');\n const isObj = isObject(content);\n const data = isObj ? JSON.stringify(content) : content;\n em.set('dragResult');\n\n // Note: data are not available on dragenter for security reason,\n // we have to use dragContent as we need it for the Sorter context\n // IE11 supports only 'text' data type\n ev.dataTransfer.setData('text', data);\n em.set('dragContent', content);\n em.trigger('block:drag:start', model, ev);\n },\n\n handleDrag(ev) {\n this.em.trigger('block:drag', this.model, ev);\n },\n\n handleDragEnd() {\n const { em, model } = this;\n const result = em.get('dragResult');\n\n if (result) {\n const oldKey = 'activeOnRender';\n const oldActive = result.get && result.get(oldKey);\n\n if (model.get('activate') || oldActive) {\n result.trigger('active');\n result.set(oldKey, 0);\n }\n\n if (model.get('select')) {\n em.setSelected(result);\n }\n\n if (model.get('resetId')) {\n result.onAll(model => model.resetId());\n }\n }\n\n em.set({\n dragResult: null,\n dragContent: null\n });\n\n em.trigger('block:drag:stop', result, model);\n },\n\n /**\n * Drop block\n * @private\n */\n endDrag(e) {\n off(document, 'mouseup', this.endDrag);\n const sorter = this.config.getSorter();\n\n // After dropping the block in the canvas the mouseup event is not yet\n // triggerd on 'this.doc' and so clicking outside, the sorter, tries to move\n // things (throws false positives). As this method just need to drop away\n // the block helper I use the trick of 'moved = 0' to void those errors.\n sorter.moved = 0;\n sorter.endMove();\n },\n\n render() {\n const { em, el, ppfx, model } = this;\n const className = `${ppfx}block`;\n const label = model.get('label');\n const render = model.get('render');\n const media = model.get('media');\n el.className += ` ${className} ${ppfx}one-bg ${ppfx}four-color-h`;\n el.innerHTML = `\n ${media ? `
${media}
` : ''}\n
${label}
\n `;\n el.title = el.textContent.trim();\n hasDnd(em) && el.setAttribute('draggable', true);\n const result = render && render({ el, model, className, prefix: ppfx });\n if (result) el.innerHTML = result;\n return this;\n }\n});\n","import { template } from 'underscore';\nimport Backbone from 'backbone';\n\nexport default Backbone.View.extend({\n template: template(`\n
title\">\n caret-icon\">\n <%= label %>\n
\n
blocks-c\">
\n `),\n\n events: {},\n\n initialize(o = {}, config = {}) {\n this.config = config;\n const pfx = this.config.pStylePrefix || '';\n this.pfx = pfx;\n this.caretR = 'fa fa-caret-right';\n this.caretD = 'fa fa-caret-down';\n this.iconClass = `${pfx}caret-icon`;\n this.activeClass = `${pfx}open`;\n this.className = `${pfx}block-category`;\n this.events[`click .${pfx}title`] = 'toggle';\n this.listenTo(this.model, 'change:open', this.updateVisibility);\n this.delegateEvents();\n },\n\n updateVisibility() {\n if (this.model.get('open')) this.open();\n else this.close();\n },\n\n open() {\n this.el.className = `${this.className} ${this.activeClass}`;\n this.getIconEl().className = `${this.iconClass} ${this.caretD}`;\n this.getBlocksEl().style.display = '';\n },\n\n close() {\n this.el.className = this.className;\n this.getIconEl().className = `${this.iconClass} ${this.caretR}`;\n this.getBlocksEl().style.display = 'none';\n },\n\n toggle() {\n var model = this.model;\n model.set('open', !model.get('open'));\n },\n\n getIconEl() {\n if (!this.iconEl) {\n this.iconEl = this.el.querySelector('.' + this.iconClass);\n }\n\n return this.iconEl;\n },\n\n getBlocksEl() {\n if (!this.blocksEl) {\n this.blocksEl = this.el.querySelector('.' + this.pfx + 'blocks-c');\n }\n\n return this.blocksEl;\n },\n\n append(el) {\n this.getBlocksEl().appendChild(el);\n },\n\n render() {\n this.el.innerHTML = this.template({\n pfx: this.pfx,\n label: this.model.get('label')\n });\n this.el.className = this.className;\n this.$el.css({ order: this.model.get('order') });\n this.updateVisibility();\n return this;\n }\n});\n","import Backbone from 'backbone';\nimport { isString, isObject, bindAll } from 'underscore';\nimport BlockView from './BlockView';\nimport CategoryView from './CategoryView';\n\nexport default Backbone.View.extend({\n initialize(opts, config) {\n bindAll(this, 'getSorter', 'onDrag', 'onDrop');\n this.config = config || {};\n this.categories = opts.categories || '';\n this.renderedCategories = [];\n var ppfx = this.config.pStylePrefix || '';\n this.ppfx = ppfx;\n this.noCatClass = `${ppfx}blocks-no-cat`;\n this.blockContClass = `${ppfx}blocks-c`;\n this.catsClass = `${ppfx}block-categories`;\n const coll = this.collection;\n this.listenTo(coll, 'add', this.addTo);\n this.listenTo(coll, 'reset', this.render);\n this.em = this.config.em;\n this.tac = 'test-tac';\n this.grabbingCls = this.ppfx + 'grabbing';\n\n if (this.em) {\n this.config.getSorter = this.getSorter;\n this.canvas = this.em.get('Canvas');\n }\n },\n\n updateConfig(opts = {}) {\n this.config = {\n ...this.config,\n ...opts\n };\n },\n\n /**\n * Get sorter\n * @private\n */\n getSorter() {\n if (!this.em) return;\n if (!this.sorter) {\n var utils = this.em.get('Utils');\n var canvas = this.canvas;\n this.sorter = new utils.Sorter({\n container: canvas.getBody(),\n placer: canvas.getPlacerEl(),\n containerSel: '*',\n itemSel: '*',\n pfx: this.ppfx,\n onStart: this.onDrag,\n onEndMove: this.onDrop,\n onMove: this.onMove,\n document: canvas.getFrameEl().contentDocument,\n direction: 'a',\n wmargin: 1,\n nested: 1,\n em: this.em,\n canvasRelative: 1\n });\n }\n return this.sorter;\n },\n\n /**\n * Callback when block is on drag\n * @private\n */\n onDrag(e) {\n this.em.stopDefault();\n this.em.trigger('block:drag:start', e);\n },\n\n onMove(e) {\n this.em.trigger('block:drag:move', e);\n },\n\n /**\n * Callback when block is dropped\n * @private\n */\n onDrop(model) {\n const em = this.em;\n em.runDefault();\n\n if (model && model.get) {\n if (model.get('activeOnRender')) {\n model.trigger('active');\n model.set('activeOnRender', 0);\n }\n\n em.trigger('block:drag:stop', model);\n }\n },\n\n /**\n * Add new model to the collection\n * @param {Model} model\n * @private\n * */\n addTo(model) {\n this.add(model);\n },\n\n /**\n * Render new model inside the view\n * @param {Model} model\n * @param {Object} fragment Fragment collection\n * @private\n * */\n add(model, fragment) {\n const { config } = this;\n var frag = fragment || null;\n var view = new BlockView(\n {\n model,\n attributes: model.get('attributes')\n },\n config\n );\n var rendered = view.render().el;\n var category = model.get('category');\n\n // Check for categories\n if (category && this.categories && !config.ignoreCategories) {\n if (isString(category)) {\n category = {\n id: category,\n label: category\n };\n } else if (isObject(category) && !category.id) {\n category.id = category.label;\n }\n\n var catModel = this.categories.add(category);\n var catId = catModel.get('id');\n var catView = this.renderedCategories[catId];\n var categories = this.getCategoriesEl();\n model.set('category', catModel);\n\n if (!catView && categories) {\n catView = new CategoryView(\n {\n model: catModel\n },\n this.config\n ).render();\n this.renderedCategories[catId] = catView;\n categories.appendChild(catView.el);\n }\n\n catView && catView.append(rendered);\n return;\n }\n\n if (frag) frag.appendChild(rendered);\n else this.append(rendered);\n },\n\n getCategoriesEl() {\n if (!this.catsEl) {\n this.catsEl = this.el.querySelector(`.${this.catsClass}`);\n }\n\n return this.catsEl;\n },\n\n getBlocksEl() {\n if (!this.blocksEl) {\n this.blocksEl = this.el.querySelector(\n `.${this.noCatClass} .${this.blockContClass}`\n );\n }\n\n return this.blocksEl;\n },\n\n append(el) {\n let blocks = this.getBlocksEl();\n blocks && blocks.appendChild(el);\n },\n\n render() {\n const ppfx = this.ppfx;\n const frag = document.createDocumentFragment();\n this.catsEl = null;\n this.blocksEl = null;\n this.renderedCategories = [];\n this.el.innerHTML = `\n
\n
\n
\n
\n `;\n\n this.collection.each(model => this.add(model, frag));\n this.append(frag);\n const cls = `${this.blockContClass}s ${ppfx}one-bg ${ppfx}two-color`;\n this.$el.addClass(cls);\n return this;\n }\n});\n","/**\n * You can customize the initial state of the module from the editor initialization, by passing the following [Configuration Object](https://github.com/artf/grapesjs/blob/master/src/block_manager/config/config.js)\n * ```js\n * const editor = grapesjs.init({\n * blockManager: {\n * // options\n * }\n * })\n * ```\n *\n * Once the editor is instantiated you can use its API. Before using these methods you should get the module from the instance\n *\n * ```js\n * const blockManager = editor.BlockManager;\n * ```\n * * [add](#add)\n * * [get](#get)\n * * [getAll](#getall)\n * * [getAllVisible](#getallvisible)\n * * [remove](#remove)\n * * [getConfig](#getconfig)\n * * [getCategories](#getcategories)\n * * [getContainer](#getcontainer)\n * * [render](#render)\n *\n * @module BlockManager\n */\nimport { isElement } from 'underscore';\nimport defaults from './config/config';\nimport Blocks from './model/Blocks';\nimport BlockCategories from './model/Categories';\nimport BlocksView from './view/BlocksView';\n\nexport default () => {\n var c = {};\n var blocks, blocksVisible, blocksView;\n var categories = [];\n\n return {\n /**\n * Name of the module\n * @type {String}\n * @private\n */\n name: 'BlockManager',\n\n /**\n * Initialize module. Automatically called with a new instance of the editor\n * @param {Object} config Configurations\n * @return {this}\n * @private\n */\n init(config) {\n c = config || {};\n const em = c.em;\n\n for (let name in defaults) {\n if (!(name in c)) {\n c[name] = defaults[name];\n }\n }\n\n // Global blocks collection\n blocks = new Blocks([]);\n blocksVisible = new Blocks([]);\n categories = new BlockCategories();\n blocksView = new BlocksView(\n {\n collection: blocksVisible,\n categories\n },\n c\n );\n\n // Setup the sync between the global and public collections\n blocks.listenTo(blocks, 'add', model => {\n blocksVisible.add(model);\n em && em.trigger('block:add', model);\n });\n\n blocks.listenTo(blocks, 'remove', model => {\n blocksVisible.remove(model);\n em && em.trigger('block:remove', model);\n });\n\n blocks.listenTo(blocks, 'reset', coll => {\n blocksVisible.reset(coll.models);\n });\n\n return this;\n },\n\n /**\n * Get configuration object\n * @return {Object}\n */\n getConfig() {\n return c;\n },\n\n /**\n * Load default blocks if the collection is empty\n */\n onLoad() {\n const blocks = this.getAll();\n !blocks.length && blocks.reset(c.blocks);\n },\n\n postRender() {\n const elTo = this.getConfig().appendTo;\n\n if (elTo) {\n const el = isElement(elTo) ? elTo : document.querySelector(elTo);\n el.appendChild(this.render());\n }\n },\n\n /**\n * Add new block to the collection.\n * @param {string} id Block id\n * @param {Object} opts Options\n * @param {string} opts.label Name of the block\n * @param {string} opts.content HTML content\n * @param {string|Object} opts.category Group the block inside a catgegory.\n * You should pass objects with id property, eg:\n * {id: 'some-uid', label: 'My category'}\n * The string will be converted in:\n * 'someid' => {id: 'someid', label: 'someid'}\n * @param {Object} [opts.attributes={}] Block attributes\n * @return {Block} Added block\n * @example\n * blockManager.add('h1-block', {\n * label: 'Heading',\n * content: '

Put your title here

',\n * category: 'Basic',\n * attributes: {\n * title: 'Insert h1 block'\n * }\n * });\n */\n add(id, opts) {\n var obj = opts || {};\n obj.id = id;\n return blocks.add(obj);\n },\n\n /**\n * Return the block by id\n * @param {string} id Block id\n * @example\n * const block = blockManager.get('h1-block');\n * console.log(JSON.stringify(block));\n * // {label: 'Heading', content: '

Put your ...', ...}\n */\n get(id) {\n return blocks.get(id);\n },\n\n /**\n * Return all blocks\n * @return {Collection}\n * @example\n * const blocks = blockManager.getAll();\n * console.log(JSON.stringify(blocks));\n * // [{label: 'Heading', content: '

Put your ...'}, ...]\n */\n getAll() {\n return blocks;\n },\n\n /**\n * Return the visible collection, which containes blocks actually rendered\n * @return {Collection}\n */\n getAllVisible() {\n return blocksVisible;\n },\n\n /**\n * Remove a block by id\n * @param {string} id Block id\n * @return {Block} Removed block\n */\n remove(id) {\n return blocks.remove(id);\n },\n\n /**\n * Get all available categories.\n * It's possible to add categories only within blocks via 'add()' method\n * @return {Array|Collection}\n */\n getCategories() {\n return categories;\n },\n\n /**\n * Return the Blocks container element\n * @return {HTMLElement}\n */\n getContainer() {\n return blocksView.el;\n },\n\n /**\n * Render blocks\n * @param {Array} blocks Blocks to render, without the argument will render all global blocks\n * @param {Object} [opts={}] Options\n * @param {Boolean} [opts.external] Render blocks in a new container (HTMLElement will be returned)\n * @param {Boolean} [opts.ignoreCategories] Render blocks without categories\n * @return {HTMLElement} Rendered element\n * @example\n * // Render all blocks (inside the global collection)\n * blockManager.render();\n *\n * // Render new set of blocks\n * const blocks = blockManager.getAll();\n * const filtered = blocks.filter(block => block.get('category') == 'sections')\n *\n * blockManager.render(filtered);\n * // Or a new set from an array\n * blockManager.render([\n * {label: 'Label text', content: '
Content
'}\n * ]);\n *\n * // Back to blocks from the global collection\n * blockManager.render();\n *\n * // You can also render your blocks outside of the main block container\n * const newBlocksEl = blockManager.render(filtered, { external: true });\n * document.getElementById('some-id').appendChild(newBlocksEl);\n */\n render(blocks, opts = {}) {\n const toRender = blocks || this.getAll().models;\n\n if (opts.external) {\n return new BlocksView(\n {\n collection: new Blocks(toRender),\n categories\n },\n {\n ...c,\n ...opts\n }\n ).render().el;\n }\n\n if (!blocksView.rendered) {\n blocksView.render();\n blocksView.rendered = 1;\n }\n\n blocksView.updateConfig(opts);\n blocksView.collection.reset(toRender);\n return this.getContainer();\n }\n };\n};\n","var swv = 'sw-visibility';\nvar expt = 'export-template';\nvar osm = 'open-sm';\nvar otm = 'open-tm';\nvar ola = 'open-layers';\nvar obl = 'open-blocks';\nvar ful = 'fullscreen';\nvar prv = 'preview';\n\nexport default {\n stylePrefix: 'pn-',\n\n // Default panels fa-sliders for features\n defaults: [\n {\n id: 'commands',\n buttons: [{}]\n },\n {\n id: 'options',\n buttons: [\n {\n active: true,\n id: swv,\n className: 'fa fa-square-o',\n command: swv,\n context: swv,\n attributes: { title: 'View components' }\n },\n {\n id: prv,\n className: 'fa fa-eye',\n command: prv,\n context: prv,\n attributes: { title: 'Preview' }\n },\n {\n id: ful,\n className: 'fa fa-arrows-alt',\n command: ful,\n context: ful,\n attributes: { title: 'Fullscreen' }\n },\n {\n id: expt,\n className: 'fa fa-code',\n command: expt,\n attributes: { title: 'View code' }\n }\n ]\n },\n {\n id: 'views',\n buttons: [\n {\n id: osm,\n className: 'fa fa-paint-brush',\n command: osm,\n active: true,\n togglable: 0,\n attributes: { title: 'Open Style Manager' }\n },\n {\n id: otm,\n className: 'fa fa-cog',\n command: otm,\n togglable: 0,\n attributes: { title: 'Settings' }\n },\n {\n id: ola,\n className: 'fa fa-bars',\n command: ola,\n togglable: 0,\n attributes: { title: 'Open Layer Manager' }\n },\n {\n id: obl,\n className: 'fa fa-th-large',\n command: obl,\n togglable: 0,\n attributes: { title: 'Open Blocks' }\n }\n ]\n }\n ],\n\n // Editor model\n em: null,\n\n // Delay before show children buttons (in milliseconds)\n delayBtnsShow: 300\n};\n","import Backbone from 'backbone';\nimport Buttons from './Buttons';\n\nexport default Backbone.Model.extend({\n defaults: {\n id: '',\n content: '',\n visible: true,\n buttons: [],\n attributes: {}\n },\n\n initialize(options) {\n this.btn = this.get('buttons') || [];\n this.buttons = new Buttons(this.btn);\n this.set('buttons', this.buttons);\n }\n});\n","import Backbone from 'backbone';\nimport Panel from './Panel';\n\nexport default Backbone.Collection.extend({\n model: Panel\n});\n","import Backbone from 'backbone';\nimport { isString, isObject, isFunction } from 'underscore';\n\nconst $ = Backbone.$;\n\nexport default Backbone.View.extend({\n tagName() {\n return this.model.get('tagName');\n },\n\n events: {\n click: 'clicked'\n },\n\n initialize(o) {\n var cls = this.model.get('className');\n this.config = o.config || {};\n this.em = this.config.em || {};\n const pfx = this.config.stylePrefix || '';\n const ppfx = this.config.pStylePrefix || '';\n this.pfx = pfx;\n this.ppfx = this.config.pStylePrefix || '';\n this.id = pfx + this.model.get('id');\n this.activeCls = `${pfx}active ${ppfx}four-color`;\n this.disableCls = `${ppfx}disabled`;\n this.btnsVisCls = `${pfx}visible`;\n this.className = pfx + 'btn' + (cls ? ' ' + cls : '');\n this.listenTo(this.model, 'change', this.render);\n this.listenTo(this.model, 'change:active updateActive', this.updateActive);\n this.listenTo(this.model, 'checkActive', this.checkActive);\n this.listenTo(this.model, 'change:bntsVis', this.updateBtnsVis);\n this.listenTo(this.model, 'change:attributes', this.updateAttributes);\n this.listenTo(this.model, 'change:className', this.updateClassName);\n this.listenTo(this.model, 'change:disable', this.updateDisable);\n\n if (this.em && this.em.get) this.commands = this.em.get('Commands');\n },\n\n /**\n * Updates class name of the button\n *\n * @return void\n * */\n updateClassName() {\n const { model, pfx } = this;\n const cls = model.get('className');\n const attrCls = model.get('attributes').class;\n const classStr = `${attrCls ? attrCls : ''} ${pfx}btn ${cls ? cls : ''}`;\n this.$el.attr('class', classStr.trim());\n },\n\n /**\n * Updates attributes of the button\n *\n * @return void\n * */\n updateAttributes() {\n this.$el.attr(this.model.get('attributes'));\n this.updateClassName();\n },\n\n /**\n * Updates visibility of children buttons\n *\n * @return void\n * */\n updateBtnsVis() {\n if (!this.$buttons) return;\n\n if (this.model.get('bntsVis')) this.$buttons.addClass(this.btnsVisCls);\n else this.$buttons.removeClass(this.btnsVisCls);\n },\n\n /**\n * Update active status of the button\n *\n * @return void\n * */\n updateActive(opts = {}) {\n const { model, commands, $el, activeCls } = this;\n const { fromCollection } = opts;\n const context = model.get('context');\n const options = model.get('options');\n const commandName = model.get('command');\n let command = {};\n\n if (commands && isString(commandName)) {\n command = commands.get(commandName) || {};\n } else if (isFunction(commandName)) {\n command = commands.create({ run: commandName });\n } else if (commandName !== null && isObject(commandName)) {\n command = commands.create(commandName);\n }\n\n if (model.get('active')) {\n !fromCollection && model.collection.deactivateAll(context, model);\n model.set('active', true, { silent: true }).trigger('checkActive');\n commands.runCommand(command, { ...options, sender: model });\n\n // Disable button if the command has no stop method\n command.noStop && model.set('active', false);\n } else {\n $el.removeClass(activeCls);\n commands.stopCommand(command, { ...options, sender: model, force: 1 });\n }\n },\n\n updateDisable() {\n const { disableCls, model } = this;\n const disable = model.get('disable');\n this.$el[disable ? 'addClass' : 'removeClass'](disableCls);\n },\n\n /**\n * Update active style status\n *\n * @return void\n * */\n checkActive() {\n const { model, $el, activeCls } = this;\n model.get('active') ? $el.addClass(activeCls) : $el.removeClass(activeCls);\n },\n\n /**\n * Triggered when button is clicked\n * @param {Object} e Event\n *\n * @return void\n * */\n clicked(e) {\n if (this.model.get('bntsVis')) return;\n\n if (this.model.get('disable')) return;\n\n this.toogleActive();\n },\n\n toogleActive() {\n const { model } = this;\n const { active, togglable } = model.attributes;\n\n if (active && !togglable) return;\n\n model.set('active', !active);\n\n // If the stop is requested\n var command = this.em.get('Commands').get('select-comp');\n\n if (active) {\n if (model.get('runDefaultCommand')) this.em.runDefault();\n } else {\n if (model.get('stopDefaultCommand')) this.em.stopDefault();\n }\n },\n\n render() {\n const label = this.model.get('label');\n const { $el } = this;\n $el.empty();\n this.updateAttributes();\n label && $el.append(label);\n this.checkActive();\n this.updateDisable();\n\n return this;\n }\n});\n","import Backbone from 'backbone';\nimport ButtonView from './ButtonView';\nimport { result } from 'underscore';\n\nexport default Backbone.View.extend({\n initialize(o) {\n this.opt = o || {};\n this.config = this.opt.config || {};\n this.pfx = this.config.stylePrefix || '';\n this.parentM = this.opt.parentM || null;\n this.listenTo(this.collection, 'add', this.addTo);\n this.listenTo(this.collection, 'reset remove', this.render);\n this.className = this.pfx + 'buttons';\n },\n\n /**\n * Add to collection\n * @param Object Model\n *\n * @return Object\n * */\n addTo(model) {\n this.addToCollection(model);\n },\n\n /**\n * Add new object to collection\n * @param Object Model\n * @param Object Fragment collection\n *\n * @return Object Object created\n * */\n addToCollection(model, fragmentEl) {\n var fragment = fragmentEl || null;\n var viewObject = ButtonView;\n\n var view = new viewObject({\n model,\n config: this.config,\n parentM: this.parentM\n });\n var rendered = view.render().el;\n\n if (fragment) {\n fragment.appendChild(rendered);\n } else {\n this.$el.append(rendered);\n }\n\n return rendered;\n },\n\n render() {\n var fragment = document.createDocumentFragment();\n this.$el.empty();\n\n this.collection.each(function(model) {\n this.addToCollection(model, fragment);\n }, this);\n\n this.$el.append(fragment);\n this.$el.attr('class', result(this, 'className'));\n return this;\n }\n});\n","import Backbone from 'backbone';\nimport ButtonsView from './ButtonsView';\n\nexport default Backbone.View.extend({\n initialize(o) {\n const config = o.config || {};\n const model = this.model;\n this.config = config;\n this.pfx = config.stylePrefix || '';\n this.ppfx = config.pStylePrefix || '';\n this.buttons = model.get('buttons');\n this.className = this.pfx + 'panel';\n this.id = this.pfx + model.get('id');\n this.listenTo(model, 'change:appendContent', this.appendContent);\n this.listenTo(model, 'change:content', this.updateContent);\n this.listenTo(model, 'change:visible', this.toggleVisible);\n model.view = this;\n },\n\n /**\n * Append content of the panel\n * */\n appendContent() {\n this.$el.append(this.model.get('appendContent'));\n },\n\n /**\n * Update content\n * */\n updateContent() {\n this.$el.html(this.model.get('content'));\n },\n\n toggleVisible() {\n if (!this.model.get('visible')) {\n this.$el.addClass(`${this.ppfx}hidden`);\n return;\n }\n this.$el.removeClass(`${this.ppfx}hidden`);\n },\n\n attributes() {\n return this.model.get('attributes');\n },\n\n initResize() {\n const em = this.config.em;\n const editor = em ? em.get('Editor') : '';\n const resizable = this.model.get('resizable');\n\n if (editor && resizable) {\n var resz = resizable === true ? [1, 1, 1, 1] : resizable;\n var resLen = resz.length;\n var tc,\n cr,\n bc,\n cl = 0;\n\n // Choose which sides of the panel are resizable\n if (resLen == 2) {\n tc = resz[0];\n bc = resz[0];\n cr = resz[1];\n cl = resz[1];\n } else if (resLen == 4) {\n tc = resz[0];\n cr = resz[1];\n bc = resz[2];\n cl = resz[3];\n }\n\n var resizer = editor.Utils.Resizer.init({\n tc,\n cr,\n bc,\n cl,\n tl: 0,\n tr: 0,\n bl: 0,\n br: 0,\n appendTo: this.el,\n silentFrames: 1,\n avoidContainerUpdate: 1,\n prefix: editor.getConfig().stylePrefix,\n onEnd() {\n em && em.trigger('change:canvasOffset');\n },\n posFetcher: (el, { target }) => {\n const style = el.style;\n const config = resizer.getConfig();\n const keyWidth = config.keyWidth;\n const keyHeight = config.keyHeight;\n const rect = el.getBoundingClientRect();\n const forContainer = target == 'container';\n const styleWidth = style[keyWidth];\n const styleHeight = style[keyHeight];\n const width =\n styleWidth && !forContainer ? parseFloat(styleWidth) : rect.width;\n const height =\n styleHeight && !forContainer\n ? parseFloat(styleHeight)\n : rect.height;\n return {\n left: 0,\n top: 0,\n width,\n height\n };\n },\n ...resizable\n });\n resizer.blur = () => {};\n resizer.focus(this.el);\n }\n },\n\n render() {\n const $el = this.$el;\n const ppfx = this.ppfx;\n const cls = `${this.className} ${this.id} ${ppfx}one-bg ${ppfx}two-color`;\n $el.addClass(cls);\n\n if (this.buttons.length) {\n var buttons = new ButtonsView({\n collection: this.buttons,\n config: this.config\n });\n $el.append(buttons.render().el);\n }\n\n $el.append(this.model.get('content'));\n return this;\n }\n});\n","import Backbone from 'backbone';\nimport PanelView from './PanelView';\n\nexport default Backbone.View.extend({\n initialize(o) {\n this.opt = o || {};\n this.config = this.opt.config || {};\n this.pfx = this.config.stylePrefix || '';\n const items = this.collection;\n this.listenTo(items, 'add', this.addTo);\n this.listenTo(items, 'reset', this.render);\n this.listenTo(items, 'remove', this.onRemove);\n this.className = this.pfx + 'panels';\n },\n\n onRemove(model) {\n const view = model.view;\n view && view.remove();\n },\n\n /**\n * Add to collection\n * @param Object Model\n *\n * @return Object\n * @private\n * */\n addTo(model) {\n this.addToCollection(model);\n },\n\n /**\n * Add new object to collection\n * @param Object Model\n * @param Object Fragment collection\n * @param integer Index of append\n *\n * @return Object Object created\n * @private\n * */\n addToCollection(model, fragmentEl) {\n const fragment = fragmentEl || null;\n const config = this.config;\n const el = model.get('el');\n const view = new PanelView({\n el,\n model,\n config\n });\n const rendered = view.render().el;\n const appendTo = model.get('appendTo');\n\n // Do nothing if the panel was requested to be another element\n if (el) {\n } else if (appendTo) {\n var appendEl = document.querySelector(appendTo);\n appendEl.appendChild(rendered);\n } else {\n if (fragment) {\n fragment.appendChild(rendered);\n } else {\n this.$el.append(rendered);\n }\n }\n\n view.initResize();\n return rendered;\n },\n\n render() {\n const $el = this.$el;\n const frag = document.createDocumentFragment();\n $el.empty();\n this.collection.each(model => this.addToCollection(model, frag));\n $el.append(frag);\n $el.attr('class', this.className);\n return this;\n }\n});\n","/**\n * You can customize the initial state of the module from the editor initialization, by passing the following [Configuration Object](https://github.com/artf/grapesjs/blob/master/src/panels/config/config.js)\n * ```js\n * const editor = grapesjs.init({\n * panels: {\n * // options\n * }\n * })\n * ```\n *\n * Once the editor is instantiated you can use its API. Before using these methods you should get the module from the instance\n *\n * ```js\n * const panelManager = editor.Panels;\n * ```\n *\n * * [addPanel](#addpanel)\n * * [addButton](#addbutton)\n * * [getButton](#getbutton)\n * * [getPanel](#getpanel)\n * * [getPanels](#getpanels)\n * * [getPanelsEl](#getpanelsel)\n * * [removePanel](#removepanel)\n * * [removeButton](#removebutton)\n *\n * @module Panels\n */\nimport defaults from './config/config';\nimport Panel from './model/Panel';\nimport Panels from './model/Panels';\nimport PanelView from './view/PanelView';\nimport PanelsView from './view/PanelsView';\n\nexport default () => {\n var c = {};\n var panels, PanelsViewObj;\n\n return {\n /**\n * Name of the module\n * @type {String}\n * @private\n */\n name: 'Panels',\n\n /**\n * Initialize module. Automatically called with a new instance of the editor\n * @param {Object} config Configurations\n * @private\n */\n init(config) {\n c = config || {};\n for (var name in defaults) {\n if (!(name in c)) c[name] = defaults[name];\n }\n\n var ppfx = c.pStylePrefix;\n if (ppfx) c.stylePrefix = ppfx + c.stylePrefix;\n\n panels = new Panels(c.defaults);\n PanelsViewObj = new PanelsView({\n collection: panels,\n config: c\n });\n return this;\n },\n\n /**\n * Returns the collection of panels\n * @return {Collection} Collection of panel\n */\n getPanels() {\n return panels;\n },\n\n /**\n * Returns panels element\n * @return {HTMLElement}\n */\n getPanelsEl() {\n return PanelsViewObj.el;\n },\n\n /**\n * Add new panel to the collection\n * @param {Object|Panel} panel Object with right properties or an instance of Panel\n * @return {Panel} Added panel. Useful in case passed argument was an Object\n * @example\n * var newPanel = panelManager.addPanel({\n * id: 'myNewPanel',\n * visible : true,\n * buttons : [...],\n * });\n */\n addPanel(panel) {\n return panels.add(panel);\n },\n\n /**\n * Remove a panel from the collection\n * @param {Object|Panel|String} panel Object with right properties or an instance of Panel or Painel id\n * @return {Panel} Removed panel. Useful in case passed argument was an Object\n * @example\n * const newPanel = panelManager.removePanel({\n * id: 'myNewPanel',\n * visible : true,\n * buttons : [...],\n * });\n *\n * const newPanel = panelManager.removePanel('myNewPanel');\n *\n */\n removePanel(panel) {\n return panels.remove(panel);\n },\n\n /**\n * Get panel by ID\n * @param {string} id Id string\n * @return {Panel|null}\n * @example\n * var myPanel = panelManager.getPanel('myNewPanel');\n */\n getPanel(id) {\n var res = panels.where({ id });\n return res.length ? res[0] : null;\n },\n\n /**\n * Add button to the panel\n * @param {string} panelId Panel's ID\n * @param {Object|Button} button Button object or instance of Button\n * @return {Button|null} Added button. Useful in case passed button was an Object\n * @example\n * var newButton = panelManager.addButton('myNewPanel',{\n * id: 'myNewButton',\n * className: 'someClass',\n * command: 'someCommand',\n * attributes: { title: 'Some title'},\n * active: false,\n * });\n * // It's also possible to pass the command as an object\n * // with .run and .stop methods\n * ...\n * command: {\n * run: function(editor) {\n * ...\n * },\n * stop: function(editor) {\n * ...\n * }\n * },\n * // Or simply like a function which will be evaluated as a single .run command\n * ...\n * command: function(editor) {\n * ...\n * }\n */\n addButton(panelId, button) {\n var pn = this.getPanel(panelId);\n return pn ? pn.get('buttons').add(button) : null;\n },\n\n /**\n * Remove button from the panel\n * @param {String} panelId Panel's ID\n * @param {String} buttonId Button's ID\n * @return {Button|null} Removed button.\n * @example\n * const removedButton = panelManager.addButton('myNewPanel',{\n * id: 'myNewButton',\n * className: 'someClass',\n * command: 'someCommand',\n * attributes: { title: 'Some title'},\n * active: false,\n * });\n *\n * const removedButton = panelManager.removeButton('myNewPanel', 'myNewButton');\n *\n */\n removeButton(panelId, button) {\n var pn = this.getPanel(panelId);\n return pn && pn.get('buttons').remove(button);\n },\n\n /**\n * Get button from the panel\n * @param {string} panelId Panel's ID\n * @param {string} id Button's ID\n * @return {Button|null}\n * @example\n * var button = panelManager.getButton('myPanel','myButton');\n */\n getButton(panelId, id) {\n var pn = this.getPanel(panelId);\n if (pn) {\n var res = pn.get('buttons').where({ id });\n return res.length ? res[0] : null;\n }\n return null;\n },\n\n /**\n * Render panels and buttons\n * @return {HTMLElement}\n * @private\n */\n render() {\n return PanelsViewObj.render().el;\n },\n\n /**\n * Active activable buttons\n * @private\n */\n active() {\n this.getPanels().each(p => {\n p.get('buttons').each(btn => {\n btn.get('active') && btn.trigger('updateActive');\n });\n });\n },\n\n /**\n * Disable buttons flagged as disabled\n * @private\n */\n disableButtons() {\n this.getPanels().each(p => {\n p.get('buttons').each(btn => {\n if (btn.get('disable')) btn.trigger('change:disable');\n });\n });\n },\n\n Panel\n };\n};\n","export default {\n // Style prefix\n stylePrefix: 'cm-',\n\n inlineCss: false\n};\n","import Backbone from 'backbone';\n\nexport default Backbone.Model.extend({\n build(model, opts = {}) {\n const models = model.get('components');\n\n if (opts.exportWrapper) {\n return opts.wrapperIsBody\n ? `${this.buildModels(models)}`\n : model.toHTML();\n }\n\n return this.buildModels(models);\n },\n\n buildModels(models) {\n let code = '';\n models.each(model => {\n code += model.toHTML();\n });\n return code;\n }\n});\n","import Backbone from 'backbone';\nimport { isUndefined, each } from 'underscore';\n\nconst maxValue = Number.MAX_VALUE;\n\nexport default Backbone.Model.extend({\n initialize() {\n this.compCls = [];\n this.ids = [];\n },\n\n /**\n * Get CSS from a component\n * @param {Model} model\n * @return {String}\n */\n buildFromModel(model, opts = {}) {\n let code = '';\n const em = this.em;\n const avoidInline = em && em.getConfig('avoidInlineStyle');\n const style = model.styleToString();\n const classes = model.get('classes');\n const wrapperIsBody = opts.wrapperIsBody;\n const isWrapper = model.get('wrapper');\n this.ids.push(`#${model.getId()}`);\n\n // Let's know what classes I've found\n classes.each(model => this.compCls.push(model.getFullName()));\n\n if (!avoidInline && style) {\n let selector = `#${model.getId()}`;\n selector = wrapperIsBody && isWrapper ? 'body' : selector;\n code = `${selector}{${style}}`;\n }\n\n const components = model.components();\n components.each(model => (code += this.buildFromModel(model, opts)));\n return code;\n },\n\n build(model, opts = {}) {\n const cssc = opts.cssc;\n const em = opts.em || '';\n this.em = em;\n this.compCls = [];\n this.ids = [];\n var code = this.buildFromModel(model, opts);\n const clearStyles =\n isUndefined(opts.clearStyles) && em\n ? em.getConfig('clearStyles')\n : opts.clearStyles;\n\n if (cssc) {\n const rules = cssc.getAll();\n const atRules = {};\n const dump = [];\n\n rules.each(rule => {\n const atRule = rule.getAtRule();\n\n if (atRule) {\n const mRules = atRules[atRule];\n if (mRules) {\n mRules.push(rule);\n } else {\n atRules[atRule] = [rule];\n }\n return;\n }\n\n code += this.buildFromRule(rule, dump, opts);\n });\n\n this.sortMediaObject(atRules).forEach(item => {\n let rulesStr = '';\n const atRule = item.key;\n const mRules = item.value;\n\n mRules.forEach(rule => {\n const ruleStr = this.buildFromRule(rule, dump, opts);\n\n if (rule.get('singleAtRule')) {\n code += `${atRule}{${ruleStr}}`;\n } else {\n rulesStr += ruleStr;\n }\n });\n\n if (rulesStr) {\n code += `${atRule}{${rulesStr}}`;\n }\n });\n\n em && clearStyles && rules.remove(dump);\n }\n\n return code;\n },\n\n /**\n * Get CSS from the rule model\n * @param {Model} rule\n * @return {string} CSS string\n */\n buildFromRule(rule, dump, opts = {}) {\n let result = '';\n const selectorStrNoAdd = rule.selectorsToString({ skipAdd: 1 });\n const selectorsAdd = rule.get('selectorsAdd');\n const singleAtRule = rule.get('singleAtRule');\n let found;\n\n // This will not render a rule if there is no its component\n rule.get('selectors').each(selector => {\n const name = selector.getFullName();\n if (\n this.compCls.indexOf(name) >= 0 ||\n this.ids.indexOf(name) >= 0 ||\n opts.keepUnusedStyles\n ) {\n found = 1;\n }\n });\n\n if ((selectorStrNoAdd && found) || selectorsAdd || singleAtRule) {\n const block = rule.getDeclaration();\n block && (result += block);\n } else {\n dump.push(rule);\n }\n\n return result;\n },\n\n /**\n * Get the numeric length of the media query string\n * @param {String} mediaQuery Media query string\n * @return {Number}\n */\n getQueryLength(mediaQuery) {\n const length = /(-?\\d*\\.?\\d+)\\w{0,}/.exec(mediaQuery);\n if (!length) return maxValue;\n\n return parseFloat(length[1]);\n },\n\n /**\n * Return a sorted array from media query object\n * @param {Object} items\n * @return {Array}\n */\n sortMediaObject(items = {}) {\n const itemsArr = [];\n each(items, (value, key) => itemsArr.push({ key, value }));\n return itemsArr.sort((a, b) => {\n const isMobFirst = [a.key, b.key].every(\n mquery => mquery.indexOf('min-width') !== -1\n );\n const left = isMobFirst ? a.key : b.key;\n const right = isMobFirst ? b.key : a.key;\n return this.getQueryLength(left) - this.getQueryLength(right);\n });\n }\n});\n","import { each } from 'underscore';\nimport Backbone from 'backbone';\n\nexport default Backbone.Model.extend({\n /** @inheritdoc */\n build(model) {\n var json = model.toJSON();\n this.beforeEach(json);\n\n each(\n json,\n function(v, attr) {\n var obj = json[attr];\n if (obj instanceof Backbone.Model) {\n json[attr] = this.build(obj);\n } else if (obj instanceof Backbone.Collection) {\n var coll = obj;\n json[attr] = [];\n if (coll.length) {\n coll.each(function(el, index) {\n json[attr][index] = this.build(el);\n }, this);\n }\n }\n },\n this\n );\n\n return json;\n },\n\n /**\n * Execute on each object\n * @param {Object} obj\n */\n beforeEach(obj) {\n delete obj.status;\n }\n});\n","import { extend } from 'underscore';\nimport Backbone from 'backbone';\n\nexport default Backbone.Model.extend({\n mapModel(model) {\n var code = '';\n var script = model.get('script-export') || model.get('script');\n var type = model.get('type');\n var comps = model.get('components');\n var id = model.getId();\n\n if (script) {\n // If the component has scripts we need to expose his ID\n var attr = model.get('attributes');\n attr = extend({}, attr, { id });\n model.set('attributes', attr, { silent: 1 });\n var scrStr = model.getScriptString(script);\n\n // If the script was updated, I'll put its code in a separate container\n if (model.get('scriptUpdated')) {\n this.mapJs[type + '-' + id] = { ids: [id], code: scrStr };\n } else {\n var mapType = this.mapJs[type];\n\n if (mapType) {\n mapType.ids.push(id);\n } else {\n this.mapJs[type] = { ids: [id], code: scrStr };\n }\n }\n }\n\n comps.each(function(model) {\n code += this.mapModel(model);\n }, this);\n\n return code;\n },\n\n build(model) {\n this.mapJs = {};\n this.mapModel(model);\n\n var code = '';\n\n for (var type in this.mapJs) {\n var mapType = this.mapJs[type];\n var ids = '#' + mapType.ids.join(', #');\n code += `\n var items = document.querySelectorAll('${ids}');\n for (var i = 0, len = items.length; i < len; i++) {\n (function(){${mapType.code}}.bind(items[i]))();\n }`;\n }\n\n return code;\n }\n});\n","import { bindAll } from 'underscore';\nimport Backbone from 'backbone';\nimport CodeMirror from 'codemirror/lib/codemirror';\nimport 'codemirror/mode/htmlmixed/htmlmixed';\nimport 'codemirror/mode/css/css';\nimport 'codemirror-formatting';\n\nexport default Backbone.Model.extend({\n defaults: {\n input: '',\n label: '',\n codeName: '',\n theme: 'hopscotch',\n readOnly: true,\n lineNumbers: true\n },\n\n /** @inheritdoc */\n init(el) {\n bindAll(this, 'onChange');\n this.editor = CodeMirror.fromTextArea(el, {\n dragDrop: false,\n lineWrapping: true,\n mode: this.get('codeName'),\n ...this.attributes\n });\n this.element = el;\n this.editor.on('change', this.onChange);\n\n return this;\n },\n\n onChange() {\n this.trigger('update', this);\n },\n\n getEditor() {\n return this.editor;\n },\n\n /**\n * The element where the viewer is attached\n * @return {HTMLElement}\n */\n getElement() {\n return this.element;\n },\n\n /**\n * Set the element which contains the viewer attached.\n * Generally, it should be just a textarea, but some editor might require\n * a container for it some in that case this method can be used\n * @param {HTMLElement} el\n * @return {self}\n */\n setElement(el) {\n this.element = el;\n return this;\n },\n\n /**\n * Refresh the viewer\n * @return {self}\n */\n refresh() {\n this.getEditor().refresh();\n return this;\n },\n\n /**\n * Focus the viewer\n * @return {self}\n */\n focus() {\n this.getEditor().focus();\n return this;\n },\n\n getContent() {\n const ed = this.getEditor();\n return ed && ed.getValue();\n },\n\n /** @inheritdoc */\n setContent(v, opts = {}) {\n const { editor } = this;\n if (!editor) return;\n editor.setValue(v);\n\n if (editor.autoFormatRange) {\n CodeMirror.commands.selectAll(editor);\n editor.autoFormatRange(editor.getCursor(true), editor.getCursor(false));\n CodeMirror.commands.goDocStart(editor);\n }\n\n !opts.noRefresh && setTimeout(() => this.refresh());\n }\n});\n","import { template } from 'underscore';\nimport Backbone from 'backbone';\n\nexport default Backbone.View.extend({\n template: template(`\n
editor\" id=\"<%= pfx %><%= codeName %>\">\n \t
title\"><%= label %>
\n \t
code\">
\n
`),\n\n initialize(o) {\n this.config = o.config || {};\n this.pfx = this.config.stylePrefix;\n },\n\n render() {\n var obj = this.model.toJSON();\n obj.pfx = this.pfx;\n this.$el.html(this.template(obj));\n this.$el.attr('class', this.pfx + 'editor-c');\n this.$el.find('#' + this.pfx + 'code').append(this.model.get('input'));\n return this;\n }\n});\n","/**\n * - [addGenerator](#addgenerator)\n * - [getGenerator](#getgenerator)\n * - [getGenerators](#getgenerators)\n * - [addViewer](#addviewer)\n * - [getViewer](#getviewer)\n * - [getViewers](#getviewers)\n * - [updateViewer](#updateviewer)\n * - [getCode](#getcode)\n *\n *\n * Before using methods you should get first the module from the editor instance, in this way:\n *\n * ```js\n * var codeManager = editor.CodeManager;\n * ```\n *\n * @module CodeManager\n */\nimport { isUndefined } from 'underscore';\nimport defaults from './config/config';\nimport gHtml from './model/HtmlGenerator';\nimport gCss from './model/CssGenerator';\nimport gJson from './model/JsonGenerator';\nimport gJs from './model/JsGenerator';\nimport eCM from './model/CodeMirrorEditor';\nimport editorView from './view/EditorView';\n\nexport default () => {\n var c = {};\n var generators = {},\n defGenerators = {},\n viewers = {},\n defViewers = {};\n\n const defaultViewer = 'CodeMirror';\n\n return {\n getConfig() {\n return c;\n },\n\n config: c,\n\n EditorView: editorView,\n\n /**\n * Name of the module\n * @type {String}\n * @private\n */\n name: 'CodeManager',\n\n /**\n * Initialize module. Automatically called with a new instance of the editor\n * @param {Object} config Configurations\n */\n init(config) {\n c = config || {};\n for (var name in defaults) {\n if (!(name in c)) c[name] = defaults[name];\n }\n\n var ppfx = c.pStylePrefix;\n if (ppfx) c.stylePrefix = ppfx + c.stylePrefix;\n\n defGenerators.html = new gHtml();\n defGenerators.css = new gCss();\n defGenerators.json = new gJson();\n defGenerators.js = new gJs();\n defViewers.CodeMirror = new eCM();\n this.loadDefaultGenerators().loadDefaultViewers();\n\n return this;\n },\n\n /**\n * Add new code generator to the collection\n * @param {string} id Code generator ID\n * @param {Object} generator Code generator wrapper\n * @param {Function} generator.build Function that builds the code\n * @return {this}\n * @example\n * codeManager.addGenerator('html7',{\n * build: function(model){\n * return 'myCode';\n * }\n * });\n * */\n addGenerator(id, generator) {\n generators[id] = generator;\n return this;\n },\n\n /**\n * Get code generator by id\n * @param {string} id Code generator ID\n * @return {Object|null}\n * @example\n * var generator = codeManager.getGenerator('html7');\n * generator.build = function(model){\n * //extend\n * };\n * */\n getGenerator(id) {\n return generators[id] || null;\n },\n\n /**\n * Returns all code generators\n * @return {Array}\n * */\n getGenerators() {\n return generators;\n },\n\n /**\n * Add new code viewer\n * @param {string} id Code viewer ID\n * @param {Object} viewer Code viewer wrapper\n * @param {Function} viewer.init Set element on which viewer will be displayed\n * @param {Function} viewer.setContent Set content to the viewer\n * @return {this}\n * @example\n * codeManager.addViewer('ace',{\n * init: function(el){\n * var ace = require('ace-editor');\n * this.editor = ace.edit(el.id);\n * },\n * setContent: function(code){\n * this.editor.setValue(code);\n * }\n * });\n * */\n addViewer(id, viewer) {\n viewers[id] = viewer;\n return this;\n },\n\n /**\n * Get code viewer by id\n * @param {string} id Code viewer ID\n * @return {Object|null}\n * @example\n * var viewer = codeManager.getViewer('ace');\n * */\n getViewer(id) {\n return viewers[id] || null;\n },\n\n /**\n * Returns all code viewers\n * @return {Array}\n * */\n getViewers() {\n return viewers;\n },\n\n createViewer(opts = {}) {\n const type = !isUndefined(opts.type) ? opts.type : defaultViewer;\n const viewer = this.getViewer(type) && this.getViewer(type).clone();\n const cont = document.createElement('div');\n const txtarea = document.createElement('textarea');\n cont.appendChild(txtarea);\n viewer.set(opts);\n viewer.init(txtarea);\n viewer.setElement(cont);\n\n return viewer;\n },\n\n /**\n * Update code viewer content\n * @param {Object} viewer Viewer instance\n * @param {string} code Code string\n * @example\n * var AceViewer = codeManager.getViewer('ace');\n * // ...\n * var viewer = AceViewer.init(el);\n * // ...\n * codeManager.updateViewer(AceViewer, 'code');\n * */\n updateViewer(viewer, code) {\n viewer.setContent(code);\n },\n\n /**\n * Get code from model\n * @param {Object} model Any kind of model that will be passed to the build method of generator\n * @param {string} genId Code generator id\n * @param {Object} [opt] Options\n * @return {string}\n * @example\n * var codeStr = codeManager.getCode(model, 'html');\n * */\n getCode(model, genId, opt = {}) {\n opt.em = c.em;\n var generator = this.getGenerator(genId);\n return generator ? generator.build(model, opt) : '';\n },\n\n /**\n * Load default code generators\n * @return {this}\n * @private\n * */\n loadDefaultGenerators() {\n for (var id in defGenerators) this.addGenerator(id, defGenerators[id]);\n\n return this;\n },\n\n /**\n * Load default code viewers\n * @return {this}\n * @private\n * */\n loadDefaultViewers() {\n for (var id in defViewers) this.addViewer(id, defViewers[id]);\n\n return this;\n }\n };\n};\n","export default {\n // Style prefix\n stylePrefix: 'css-',\n\n // Custom CSS string to render on top\n staticRules: '',\n\n // Default CSS style\n rules: []\n};\n","import { map } from 'underscore';\nimport Backbone from 'backbone';\nimport Styleable from 'domain_abstract/model/Styleable';\nimport { isEmpty, forEach } from 'underscore';\nimport Selectors from 'selector_manager/model/Selectors';\n\nexport default Backbone.Model.extend(Styleable).extend({\n defaults: {\n // Css selectors\n selectors: {},\n\n // Additional string css selectors\n selectorsAdd: '',\n\n // Css properties style\n style: {},\n\n // On which device width this rule should be rendered, eg. @media (max-width: 1000px)\n mediaText: '',\n\n // State of the rule, eg: hover | pressed | focused\n state: '',\n\n // Indicates if the rule is stylable\n stylable: true,\n\n // Type of at-rule, eg. 'media', 'font-face', etc.\n atRuleType: '',\n\n // This particolar property is used only on at-rules, like 'page' or\n // 'font-face', where the block containes only style declarations\n singleAtRule: 0,\n\n // If true, sets '!important' on all properties\n // You can use an array to specify properties to set important\n // Used in view\n important: 0\n },\n\n initialize(c, opt = {}) {\n this.config = c || {};\n const em = opt.em;\n let selectors = this.config.selectors || [];\n this.em = em;\n\n if (em) {\n const sm = em.get('SelectorManager');\n const slct = [];\n selectors.forEach(selector => {\n slct.push(sm.add(selector));\n });\n selectors = slct;\n }\n\n this.set('selectors', new Selectors(selectors));\n },\n\n /**\n * Returns an at-rule statement if possible, eg. '@media (...)', '@keyframes'\n * @return {string}\n */\n getAtRule() {\n const type = this.get('atRuleType');\n const condition = this.get('mediaText');\n // Avoid breaks with the last condition\n const typeStr = type ? `@${type}` : condition ? '@media' : '';\n\n return typeStr + (condition && typeStr ? ` ${condition}` : '');\n },\n\n /**\n * Return selectors fo the rule as a string\n * @return {string}\n */\n selectorsToString(opts = {}) {\n const result = [];\n const { em } = this;\n const state = this.get('state');\n const wrapper = this.get('wrapper');\n const addSelector = this.get('selectorsAdd');\n const isBody = wrapper && em && em.getConfig('wrapperIsBody');\n const selectors = isBody ? 'body' : this.get('selectors').getFullString();\n const stateStr = state ? `:${state}` : '';\n selectors && result.push(`${selectors}${stateStr}`);\n addSelector && !opts.skipAdd && result.push(addSelector);\n return result.join(', ');\n },\n\n /**\n * Get declaration block\n * @param {Object} [opts={}] Options\n * @return {string}\n */\n getDeclaration(opts = {}) {\n let result = '';\n const selectors = this.selectorsToString();\n const style = this.styleToString(opts);\n const singleAtRule = this.get('singleAtRule');\n\n if ((selectors || singleAtRule) && style) {\n result = singleAtRule ? style : `${selectors}{${style}}`;\n }\n\n return result;\n },\n\n /**\n * Returns CSS string of the rule\n * @param {Object} [opts={}] Options\n * @return {string}\n */\n toCSS(opts = {}) {\n let result = '';\n const atRule = this.getAtRule();\n const block = this.getDeclaration(opts);\n block && (result = block);\n\n if (atRule && result) {\n result = `${atRule}{${result}}`;\n }\n\n return result;\n },\n\n toJSON(...args) {\n const obj = Backbone.Model.prototype.toJSON.apply(this, args);\n\n if (this.em.getConfig('avoidDefaults')) {\n const defaults = this.defaults;\n\n forEach(defaults, (value, key) => {\n if (obj[key] === value) {\n delete obj[key];\n }\n });\n\n if (isEmpty(obj.selectors)) delete obj.selectors;\n if (isEmpty(obj.style)) delete obj.style;\n }\n\n return obj;\n },\n\n /**\n * Compare the actual model with parameters\n * @param {Object} selectors Collection of selectors\n * @param {String} state Css rule state\n * @param {String} width For which device this style is oriented\n * @param {Object} ruleProps Other rule props\n * @return {Boolean}\n * @private\n */\n compare(selectors, state, width, ruleProps = {}) {\n var st = state || '';\n var wd = width || '';\n var selectorsAdd = ruleProps.selectorsAdd || '';\n var atRuleType = ruleProps.atRuleType || '';\n var cId = 'cid';\n //var a1 = _.pluck(selectors.models || selectors, cId);\n //var a2 = _.pluck(this.get('selectors').models, cId);\n if (!(selectors instanceof Array) && !selectors.models)\n selectors = [selectors];\n var a1 = map(selectors.models || selectors, model => model.get('name'));\n var a2 = map(this.get('selectors').models, model => model.get('name'));\n var f = false;\n\n if (a1.length !== a2.length) return f;\n\n for (var i = 0; i < a1.length; i++) {\n var re = 0;\n for (var j = 0; j < a2.length; j++) {\n if (a1[i] === a2[j]) re = 1;\n }\n if (re === 0) return f;\n }\n\n if (\n this.get('state') !== st ||\n this.get('mediaText') !== wd ||\n this.get('selectorsAdd') !== selectorsAdd ||\n this.get('atRuleType') !== atRuleType\n ) {\n return f;\n }\n\n return true;\n }\n});\n","import Backbone from 'backbone';\nimport CssRule from './CssRule';\n\nexport default Backbone.Collection.extend({\n initialize(models, opt) {\n // Inject editor\n if (opt && opt.em) this.editor = opt.em;\n\n // Not used\n this.model = (attrs, options) => {\n var model;\n\n if (!options.em && opt && opt.em) options.em = opt.em;\n\n switch (1) {\n default:\n model = new CssRule(attrs, options);\n }\n\n return model;\n };\n },\n\n add(models, opt = {}) {\n if (typeof models === 'string') {\n models = this.editor.get('Parser').parseCss(models);\n }\n opt.em = this.editor;\n return Backbone.Collection.prototype.add.apply(this, [models, opt]);\n }\n});\n","import Backbone from 'backbone';\n\nexport default Backbone.View.extend({\n tagName: 'style',\n\n initialize(o = {}) {\n this.config = o.config || {};\n const model = this.model;\n const toTrack = 'change:style change:state change:mediaText';\n this.listenTo(model, toTrack, this.render);\n this.listenTo(model, 'destroy remove', this.remove);\n this.listenTo(model.get('selectors'), 'change', this.render);\n },\n\n render() {\n const model = this.model;\n const important = model.get('important');\n this.el.innerHTML = this.model.toCSS({ important });\n return this;\n }\n});\n","import CssRuleView from './CssRuleView';\n\nexport default CssRuleView.extend({\n _createElement: function(tagName) {\n return document.createTextNode('');\n },\n\n render() {\n const model = this.model;\n const important = model.get('important');\n this.el.textContent = model.getDeclaration({ important });\n return this;\n }\n});\n","import Backbone from 'backbone';\nimport CssRuleView from './CssRuleView';\nimport CssGroupRuleView from './CssGroupRuleView';\n\nconst $ = Backbone.$;\n\nconst getBlockId = (pfx, order) =>\n `${pfx}${order ? `-${parseFloat(order)}` : ''}`;\n\nexport default Backbone.View.extend({\n initialize(o) {\n const config = o.config || {};\n this.atRules = {};\n this.config = config;\n this.em = config.em;\n this.pfx = config.stylePrefix || '';\n this.className = this.pfx + 'rules';\n const coll = this.collection;\n this.listenTo(coll, 'add', this.addTo);\n this.listenTo(coll, 'reset', this.render);\n },\n\n /**\n * Add to collection\n * @param {Object} model\n * @private\n * */\n addTo(model) {\n this.addToCollection(model);\n },\n\n /**\n * Add new object to collection\n * @param {Object} model\n * @param {Object} fragmentEl\n * @return {Object}\n * @private\n * */\n addToCollection(model, fragmentEl) {\n // If the render is not yet started\n if (!this.renderStarted) {\n return;\n }\n\n const fragment = fragmentEl || null;\n const { config } = this;\n const opts = { model, config };\n let rendered, view;\n\n // I have to render keyframes of the same name together\n // Unfortunately at the moment I didn't find the way of appending them\n // if not staticly, via appendData\n if (model.get('atRuleType') === 'keyframes') {\n const atRule = model.getAtRule();\n let atRuleEl = this.atRules[atRule];\n\n if (!atRuleEl) {\n const styleEl = document.createElement('style');\n atRuleEl = document.createTextNode('');\n styleEl.appendChild(document.createTextNode(`${atRule}{`));\n styleEl.appendChild(atRuleEl);\n styleEl.appendChild(document.createTextNode(`}`));\n this.atRules[atRule] = atRuleEl;\n rendered = styleEl;\n }\n\n view = new CssGroupRuleView(opts);\n atRuleEl.appendData(view.render().el.textContent);\n } else {\n view = new CssRuleView(opts);\n rendered = view.render().el;\n }\n\n const clsName = this.className;\n const mediaText = model.get('mediaText');\n const defaultBlockId = getBlockId(clsName);\n let blockId = defaultBlockId;\n\n // If the rule contains a media query it might have a different container\n // for it (eg. rules created with Device Manager)\n if (mediaText) {\n blockId = getBlockId(clsName, this.getMediaWidth(mediaText));\n }\n\n if (rendered) {\n const container = fragment || this.el;\n let contRules;\n\n // Try to find a specific container for the rule (if it\n // containes a media query), otherwise get the default one\n try {\n contRules = container.querySelector(`#${blockId}`);\n } catch (e) {}\n\n if (!contRules) {\n contRules = container.querySelector(`#${defaultBlockId}`);\n }\n\n contRules.appendChild(rendered);\n }\n\n return rendered;\n },\n\n getMediaWidth(mediaText) {\n return (\n mediaText &&\n mediaText\n .replace(`(${this.em.getConfig('mediaCondition')}: `, '')\n .replace(')', '')\n );\n },\n\n render() {\n this.renderStarted = 1;\n this.atRules = {};\n const { em, $el, className, collection } = this;\n const frag = document.createDocumentFragment();\n $el.empty();\n\n // Create devices related DOM structure, ensure also to have a default container\n const prs = em\n .get('DeviceManager')\n .getAll()\n .pluck('priority');\n prs.every(pr => pr) && prs.unshift(0);\n prs.forEach(pr =>\n $(`
`).appendTo(frag)\n );\n\n collection.each(model => this.addToCollection(model, frag));\n $el.append(frag);\n $el.attr('class', className);\n return this;\n }\n});\n","/**\n * This module contains and manage CSS rules for the template inside the canvas.\n * You can customize the initial state of the module from the editor initialization, by passing the following [Configuration Object](https://github.com/artf/grapesjs/blob/master/src/css_composer/config/config.js)\n * ```js\n * const editor = grapesjs.init({\n * cssComposer: {\n * // options\n * }\n * })\n * ```\n *\n * Once the editor is instantiated you can use its API. Before using these methods you should get the module from the instance\n *\n * ```js\n * const cssComposer = editor.CssComposer;\n * ```\n *\n * * [load](#load)\n * * [store](#store)\n * * [add](#add)\n * * [get](#get)\n * * [getAll](#getall)\n * * [clear](#clear)\n * * [setRule](#setrule)\n * * [getRule](#getrule)\n *\n * @module CssComposer\n */\n\nimport { isArray } from 'underscore';\nimport defaults from './config/config';\nimport CssRule from './model/CssRule';\nimport CssRules from './model/CssRules';\nimport CssRulesView from './view/CssRulesView';\nimport Selectors from 'selector_manager/model/Selectors';\nimport Selector from 'selector_manager/model/Selector';\n\nexport default () => {\n let em;\n var c = {};\n var rules, rulesView;\n\n return {\n Selectors,\n\n /**\n * Name of the module\n * @type {String}\n * @private\n */\n name: 'CssComposer',\n\n /**\n * Mandatory for the storage manager\n * @type {String}\n * @private\n */\n storageKey() {\n var keys = [];\n var smc = (c.stm && c.stm.getConfig()) || {};\n if (smc.storeCss) keys.push('css');\n if (smc.storeStyles) keys.push('styles');\n return keys;\n },\n\n /**\n * Initializes module. Automatically called with a new instance of the editor\n * @param {Object} config Configurations\n * @private\n */\n init(config) {\n c = config || {};\n for (var name in defaults) {\n if (!(name in c)) c[name] = defaults[name];\n }\n\n var ppfx = c.pStylePrefix;\n if (ppfx) c.stylePrefix = ppfx + c.stylePrefix;\n\n var elStyle = (c.em && c.em.config.style) || '';\n c.rules = elStyle || c.rules;\n\n em = c.em;\n rules = new CssRules([], c);\n rulesView = new CssRulesView({\n collection: rules,\n config: c\n });\n return this;\n },\n\n /**\n * On load callback\n * @private\n */\n onLoad() {\n rules.add(c.rules);\n },\n\n /**\n * Do stuff after load\n * @param {Editor} em\n * @private\n */\n postLoad(em) {\n const ev = 'add remove';\n const rules = this.getAll();\n const um = em.get('UndoManager');\n um && um.add(rules);\n em.stopListening(rules, ev, this.handleChange);\n em.listenTo(rules, ev, this.handleChange);\n rules.each(rule => this.handleChange(rule, { avoidStore: 1 }));\n },\n\n /**\n * Handle rule changes\n * @private\n */\n handleChange(model, opts = {}) {\n const ev = 'change:style';\n const um = em.get('UndoManager');\n um && um.add(model);\n const handleUpdates = em.handleUpdates.bind(em);\n em.stopListening(model, ev, handleUpdates);\n em.listenTo(model, ev, handleUpdates);\n !opts.avoidStore && handleUpdates('', '', opts);\n },\n\n /**\n * Load data from the passed object, if the object is empty will try to fetch them\n * autonomously from the storage manager.\n * The fetched data will be added to the collection\n * @param {Object} data Object of data to load\n * @return {Object} Loaded rules\n */\n load(data) {\n var d = data || '';\n\n if (!d && c.stm) {\n d = c.em.getCacheLoad();\n }\n\n var obj = d.styles || '';\n\n if (d.styles) {\n try {\n obj = JSON.parse(d.styles);\n } catch (err) {}\n } else if (d.css) {\n obj = c.em.get('Parser').parseCss(d.css);\n }\n\n if (isArray(obj)) {\n obj.length && rules.reset(obj);\n } else if (obj) {\n rules.reset(obj);\n }\n\n return obj;\n },\n\n /**\n * Store data to the selected storage\n * @param {Boolean} noStore If true, won't store\n * @return {Object} Data to store\n */\n store(noStore) {\n if (!c.stm) return;\n var obj = {};\n var keys = this.storageKey();\n if (keys.indexOf('css') >= 0) obj.css = c.em.getCss();\n if (keys.indexOf('styles') >= 0) obj.styles = JSON.stringify(rules);\n if (!noStore) c.stm.store(obj);\n return obj;\n },\n\n /**\n * Add new rule to the collection, if not yet exists with the same selectors\n * @param {Array} selectors Array of selectors\n * @param {String} state Css rule state\n * @param {String} width For which device this style is oriented\n * @param {Object} opts Other options for the rule\n * @return {Model}\n * @example\n * var sm = editor.SelectorManager;\n * var sel1 = sm.add('myClass1');\n * var sel2 = sm.add('myClass2');\n * var rule = cssComposer.add([sel1, sel2], 'hover');\n * rule.set('style', {\n * width: '100px',\n * color: '#fff',\n * });\n * */\n add(selectors, state, width, opts = {}) {\n var s = state || '';\n var w = width || '';\n var opt = { ...opts };\n var rule = this.get(selectors, s, w, opt);\n\n // do not create rules that were found before\n // unless this is a single at-rule, for which multiple declarations\n // make sense (e.g. multiple `@font-type`s)\n if (rule && rule.config && !rule.config.singleAtRule) {\n return rule;\n } else {\n opt.state = s;\n opt.mediaText = w;\n opt.selectors = '';\n rule = new CssRule(opt, c);\n rule.get('selectors').add(selectors);\n rules.add(rule);\n return rule;\n }\n },\n\n /**\n * Get the rule\n * @param {Array} selectors Array of selectors\n * @param {String} state Css rule state\n * @param {String} width For which device this style is oriented\n * @param {Object} ruleProps Other rule props\n * @return {Model|null}\n * @example\n * var sm = editor.SelectorManager;\n * var sel1 = sm.add('myClass1');\n * var sel2 = sm.add('myClass2');\n * var rule = cssComposer.get([sel1, sel2], 'hover');\n * // Update the style\n * rule.set('style', {\n * width: '300px',\n * color: '#000',\n * });\n * */\n get(selectors, state, width, ruleProps) {\n var rule = null;\n rules.each(m => {\n if (rule) return;\n if (m.compare(selectors, state, width, ruleProps)) rule = m;\n });\n return rule;\n },\n\n /**\n * Get the collection of rules\n * @return {Collection}\n * */\n getAll() {\n return rules;\n },\n\n /**\n * Remove all rules\n * @return {this}\n */\n clear() {\n this.getAll().reset();\n return this;\n },\n\n /**\n * Add a raw collection of rule objects\n * This method overrides styles, in case, of already defined rule\n * @param {Array} data Array of rule objects, eg . [{selectors: ['class1'], style: {....}}, ..]\n * @param {Object} opts Options\n * @return {Array}\n * @private\n */\n addCollection(data, opts = {}) {\n var result = [];\n var d = data instanceof Array ? data : [data];\n\n for (var i = 0, l = d.length; i < l; i++) {\n var rule = d[i] || {};\n if (!rule.selectors) continue;\n var sm = c.em && c.em.get('SelectorManager');\n if (!sm) console.warn('Selector Manager not found');\n var sl = rule.selectors;\n var sels = sl instanceof Array ? sl : [sl];\n var newSels = [];\n\n for (var j = 0, le = sels.length; j < le; j++) {\n var selec = sm.add(sels[j]);\n newSels.push(selec);\n }\n\n var modelExists = this.get(newSels, rule.state, rule.mediaText, rule);\n var model = this.add(newSels, rule.state, rule.mediaText, rule);\n var updateStyle = !modelExists || !opts.avoidUpdateStyle;\n const style = rule.style || {};\n\n if (updateStyle) {\n let styleUpdate = opts.extend\n ? { ...model.get('style'), ...style }\n : style;\n model.set('style', styleUpdate);\n }\n\n result.push(model);\n }\n\n return result;\n },\n\n /**\n * Add/update the CSS rule with a generic selector\n * @param {string} selectors Selector, eg. '.myclass'\n * @param {Object} style Style properties and values\n * @param {Object} [opts={}] Additional properties\n * @param {String} [opts.atRuleType=''] At-rule type, eg. 'media'\n * @param {String} [opts.atRuleParams=''] At-rule parameters, eg. '(min-width: 500px)'\n * @return {CssRule} The new/updated rule\n * @example\n * // Simple class-based rule\n * const rule = cc.setRule('.class1.class2', { color: 'red' });\n * console.log(rule.toCSS()) // output: .class1.class2 { color: red }\n * // With state and other mixed selector\n * const rule = cc.setRule('.class1.class2:hover, div#myid', { color: 'red' });\n * // output: .class1.class2:hover, div#myid { color: red }\n * // With media\n * const rule = cc.setRule('.class1:hover', { color: 'red' }, {\n * atRuleType: 'media',\n * atRuleParams: '(min-width: 500px)',\n * });\n * // output: @media (min-width: 500px) { .class1:hover { color: red } }\n */\n setRule(selectors, style, opts = {}) {\n const { atRuleType, atRuleParams } = opts;\n const node = em.get('Parser').parserCss.checkNode({\n selectors,\n style\n })[0];\n const { state, selectorsAdd } = node;\n const sm = em.get('SelectorManager');\n const selector = sm.add(node.selectors);\n const rule = this.add(selector, state, atRuleParams, {\n selectorsAdd,\n atRule: atRuleType\n });\n rule.setStyle(style, opts);\n return rule;\n },\n\n /**\n * Get the CSS rule by a generic selector\n * @param {string} selectors Selector, eg. '.myclass:hover'\n * @param {String} [opts.atRuleType=''] At-rule type, eg. 'media'\n * @param {String} [opts.atRuleParams=''] At-rule parameters, eg. '(min-width: 500px)'\n * @return {CssRule}\n * @example\n * const rule = cc.getRule('.myclass1:hover');\n * const rule2 = cc.getRule('.myclass1:hover, div#myid');\n * const rule3 = cc.getRule('.myclass1', {\n * atRuleType: 'media',\n * atRuleParams: '(min-width: 500px)',\n * });\n */\n getRule(selectors, opts = {}) {\n const sm = em.get('SelectorManager');\n const node = em.get('Parser').parserCss.checkNode({ selectors })[0];\n const selector = sm.get(node.selectors);\n const { state, selectorsAdd } = node;\n const { atRuleType, atRuleParams } = opts;\n return (\n selector &&\n this.get(selector, state, atRuleParams, {\n selectorsAdd,\n atRule: atRuleType\n })\n );\n },\n\n /**\n * Add/update the CSS rule with id selector\n * @param {string} name Id selector name, eg. 'my-id'\n * @param {Object} style Style properties and values\n * @param {Object} [opts={}] Custom options, like `state` and `mediaText`\n * @return {CssRule} The new/updated rule\n * @private\n * @example\n * const rule = cc.setIdRule('myid', { color: 'red' });\n * const ruleHover = cc.setIdRule('myid', { color: 'blue' }, { state: 'hover' });\n * // This will add current CSS:\n * // #myid { color: red }\n * // #myid:hover { color: blue }\n */\n setIdRule(name, style = {}, opts = {}) {\n const state = opts.state || '';\n const media = opts.mediaText || em.getCurrentMedia();\n const sm = em.get('SelectorManager');\n const selector = sm.add({ name, type: Selector.TYPE_ID });\n const rule = this.add(selector, state, media);\n rule.setStyle(style, opts);\n return rule;\n },\n\n /**\n * Get the CSS rule by id selector\n * @param {string} name Id selector name, eg. 'my-id'\n * @param {Object} [opts={}] Custom options, like `state` and `mediaText`\n * @return {CssRule}\n * @private\n * @example\n * const rule = cc.getIdRule('myid');\n * const ruleHover = cc.setIdRule('myid', { state: 'hover' });\n */\n getIdRule(name, opts = {}) {\n const state = opts.state || '';\n const media = opts.mediaText || em.getCurrentMedia();\n const selector = em.get('SelectorManager').get(name, Selector.TYPE_ID);\n return selector && this.get(selector, state, media);\n },\n\n /**\n * Add/update the CSS rule with class selector\n * @param {string} name Class selector name, eg. 'my-class'\n * @param {Object} style Style properties and values\n * @param {Object} [opts={}] Custom options, like `state` and `mediaText`\n * @return {CssRule} The new/updated rule\n * @private\n * @example\n * const rule = cc.setClassRule('myclass', { color: 'red' });\n * const ruleHover = cc.setClassRule('myclass', { color: 'blue' }, { state: 'hover' });\n * // This will add current CSS:\n * // .myclass { color: red }\n * // .myclass:hover { color: blue }\n */\n setClassRule(name, style = {}, opts = {}) {\n const state = opts.state || '';\n const media = opts.mediaText || em.getCurrentMedia();\n const sm = em.get('SelectorManager');\n const selector = sm.add({ name, type: Selector.TYPE_CLASS });\n const rule = this.add(selector, state, media);\n rule.setStyle(style, opts);\n return rule;\n },\n\n /**\n * Get the CSS rule by class selector\n * @param {string} name Class selector name, eg. 'my-class'\n * @param {Object} [opts={}] Custom options, like `state` and `mediaText`\n * @return {CssRule}\n * @private\n * @example\n * const rule = cc.getClassRule('myclass');\n * const ruleHover = cc.getClassRule('myclass', { state: 'hover' });\n */\n getClassRule(name, opts = {}) {\n const state = opts.state || '';\n const media = opts.mediaText || em.getCurrentMedia();\n const selector = em.get('SelectorManager').get(name, Selector.TYPE_CLASS);\n return selector && this.get(selector, state, media);\n },\n\n /**\n * Render the block of CSS rules\n * @return {HTMLElement}\n * @private\n */\n render() {\n return rulesView.render().el;\n }\n };\n};\n","import Backbone from 'backbone';\nimport { bindAll } from 'underscore';\nimport {\n on,\n off,\n getElement,\n getKeyChar,\n isTextNode,\n getElRect\n} from 'utils/mixins';\nimport FrameView from './FrameView';\n\nconst $ = Backbone.$;\nlet timerZoom;\n\nexport default Backbone.View.extend({\n events: {\n wheel: 'onWheel'\n },\n\n template() {\n const { pfx } = this;\n return `\n
\n
\n `;\n },\n\n initialize(o) {\n bindAll(this, 'renderBody', 'onFrameScroll', 'clearOff', 'onKeyPress');\n on(window, 'scroll resize', this.clearOff);\n const { model } = this;\n this.config = o.config || {};\n this.em = this.config.em || {};\n this.pfx = this.config.stylePrefix || '';\n this.ppfx = this.config.pStylePrefix || '';\n this.className = this.config.stylePrefix + 'canvas';\n this.listenTo(this.em, 'change:canvasOffset', this.clearOff);\n this.listenTo(model, 'change:zoom change:x change:y', this.updateFrames);\n this.toggleListeners(1);\n this.frame = new FrameView({\n model: this.model.get('frame'),\n config: this.config\n });\n },\n\n remove() {\n Backbone.View.prototype.remove.apply(this, arguments);\n this.toggleListeners();\n },\n\n preventDefault(ev) {\n if (ev) {\n ev.preventDefault();\n ev._parentEvent && ev._parentEvent.preventDefault();\n }\n },\n\n toggleListeners(enable) {\n const method = enable ? 'on' : 'off';\n const methods = { on, off };\n methods[method](document, 'keypress', this.onKeyPress);\n },\n\n onKeyPress(ev) {\n const { em } = this;\n const key = getKeyChar(ev);\n\n if (key === ' ' && em.getZoomDecimal() !== 1) {\n this.preventDefault(ev);\n em.get('Editor').runCommand('core:canvas-move');\n }\n },\n\n onWheel(ev) {\n if ((ev.ctrlKey || ev.metaKey) && this.em.getConfig('multiFrames')) {\n this.preventDefault(ev);\n const { model } = this;\n const delta = Math.max(-1, Math.min(1, ev.wheelDelta || -ev.detail));\n const zoom = model.get('zoom');\n model.set('zoom', zoom + delta * 2);\n }\n },\n\n updateFrames(ev) {\n const { em, model } = this;\n const { x, y } = model.attributes;\n const zoom = this.getZoom();\n const defOpts = { preserveSelected: 1 };\n const mpl = zoom ? 1 / zoom : 1;\n this.framesArea.style.transform = `scale(${zoom}) translate(${x *\n mpl}px, ${y * mpl}px)`;\n this.clearOff();\n this.onFrameScroll();\n em.stopDefault(defOpts);\n em.trigger('canvas:update', ev);\n timerZoom && clearTimeout(timerZoom);\n timerZoom = setTimeout(() => em.runDefault(defOpts));\n },\n\n getZoom() {\n return this.em.getZoomDecimal();\n },\n\n /**\n * Checks if the element is visible in the canvas's viewport\n * @param {HTMLElement} el\n * @return {Boolean}\n */\n isElInViewport(el) {\n const rect = getElRect(getElement(el));\n const frameRect = this.getFrameOffset();\n const rTop = rect.top;\n const rLeft = rect.left;\n return (\n rTop >= 0 &&\n rLeft >= 0 &&\n rTop <= frameRect.height &&\n rLeft <= frameRect.width\n );\n },\n\n /**\n * Update tools position\n * @private\n */\n onFrameScroll() {\n var u = 'px';\n var body = this.frame.el.contentDocument.body;\n const zoom = this.getZoom();\n this.toolsEl.style.top = '-' + body.scrollTop * zoom + u;\n this.toolsEl.style.left = '-' + body.scrollLeft * zoom + u;\n this.em.trigger('canvasScroll');\n },\n\n /**\n * Insert scripts into head, it will call renderBody after all scripts loaded or failed\n * @private\n */\n renderScripts() {\n var frame = this.frame;\n var that = this;\n\n frame.el.onload = () => {\n var scripts = that.config.scripts.slice(0), // clone\n counter = 0;\n\n function appendScript(scripts) {\n if (scripts.length > 0) {\n var script = document.createElement('script');\n script.type = 'text/javascript';\n script.src = scripts.shift();\n script.onerror = script.onload = appendScript.bind(null, scripts);\n frame.el.contentDocument.head.appendChild(script);\n } else {\n that.renderBody();\n }\n }\n appendScript(scripts);\n };\n },\n\n /**\n * Render inside frame's body\n * @private\n */\n renderBody() {\n const { config, model } = this;\n const wrap = this.model.get('frame').get('wrapper');\n const em = config.em;\n\n if (wrap) {\n const Canvas = em.get('Canvas');\n const ppfx = this.ppfx;\n const body = $(Canvas.getBody());\n const head = $(Canvas.getDocument().head);\n const cssc = em.get('CssComposer');\n const conf = em.get('Config');\n let externalStyles = '';\n\n config.styles.forEach(style => {\n externalStyles += ``;\n });\n\n const colorWarn = '#ffca6f';\n\n // I need all this styles to make the editor work properly\n // Remove `html { height: 100%;}` from the baseCss as it gives jumpings\n // effects (on ENTER) with RTE like CKEditor (maybe some bug there?!?)\n // With `body {height: auto;}` jumps in CKEditor are removed but in\n // Firefox is impossible to drag stuff in empty canvas, so bring back\n // `body {height: 100%;}`.\n // For the moment I give the priority to Firefox as it might be\n // CKEditor's issue\n var frameCss = `\n ${em.config.baseCss || ''}\n\n .${ppfx}dashed *[data-highlightable] {\n outline: 1px dashed rgba(170,170,170,0.7);\n outline-offset: -2px;\n }\n\n .${ppfx}comp-selected {\n outline: 3px solid #3b97e3 !important;\n outline-offset: -3px;\n }\n\n .${ppfx}comp-selected-parent {\n outline: 2px solid ${colorWarn} !important\n }\n\n .${ppfx}no-select {\n user-select: none;\n -webkit-user-select:none;\n -moz-user-select: none;\n }\n\n .${ppfx}freezed {\n opacity: 0.5;\n pointer-events: none;\n }\n\n .${ppfx}no-pointer {\n pointer-events: none;\n }\n\n .${ppfx}plh-image {\n background: #f5f5f5;\n border: none;\n height: 100px;\n width: 100px;\n display: block;\n outline: 3px solid #ffca6f;\n cursor: pointer;\n outline-offset: -2px\n }\n\n .${ppfx}grabbing {\n cursor: grabbing;\n cursor: -webkit-grabbing;\n }\n\n .${ppfx}is__grabbing {\n overflow-x: hidden;\n }\n\n .${ppfx}is__grabbing,\n .${ppfx}is__grabbing * {\n cursor: grabbing !important;\n }\n\n ${conf.canvasCss || ''}\n ${conf.protectedCss || ''}\n `;\n\n if (externalStyles) {\n head.append(externalStyles);\n }\n\n body.append('');\n body.append(wrap.render()).append(cssc.render());\n body.append(this.getJsContainer());\n em.trigger('loaded');\n this.frame.el.contentWindow.onscroll = this.onFrameScroll;\n this.frame.updateOffset();\n\n // Avoid the default link behaviour in the canvas\n body.on(\n 'click',\n ev => ev && ev.target.tagName == 'A' && ev.preventDefault()\n );\n // Avoid the default form behaviour\n body.on('submit', ev => ev && ev.preventDefault());\n\n // When the iframe is focused the event dispatcher is not the same so\n // I need to delegate all events to the parent document\n const doc = document;\n const fdoc = this.frame.el.contentDocument;\n\n // Unfortunately just creating `KeyboardEvent(e.type, e)` is not enough,\n // the keyCode/which will be always `0`. Even if it's an old/deprecated\n // property keymaster (and many others) still use it... using `defineProperty`\n // hack seems the only way\n const createCustomEvent = (e, cls) => {\n let oEvent;\n try {\n oEvent = new window[cls](e.type, e);\n } catch (e) {\n oEvent = document.createEvent(cls);\n oEvent.initEvent(e.type, true, true);\n }\n oEvent.keyCodeVal = e.keyCode;\n oEvent._parentEvent = e;\n ['keyCode', 'which'].forEach(prop => {\n Object.defineProperty(oEvent, prop, {\n get() {\n return this.keyCodeVal;\n }\n });\n });\n return oEvent;\n };\n\n [\n { event: 'keydown keyup keypress', class: 'KeyboardEvent' },\n { event: 'wheel', class: 'WheelEvent' }\n ].forEach(obj =>\n obj.event.split(' ').forEach(event => {\n fdoc.addEventListener(event, e =>\n this.el.dispatchEvent(createCustomEvent(e, obj.class))\n );\n })\n );\n }\n },\n\n /**\n * Get the offset of the element\n * @param {HTMLElement} el\n * @return {Object}\n */\n offset(el) {\n var rect = getElRect(el);\n var docBody = el.ownerDocument.body;\n return {\n top: rect.top + docBody.scrollTop,\n left: rect.left + docBody.scrollLeft,\n width: rect.width,\n height: rect.height\n };\n },\n\n /**\n * Cleare cached offsets\n * @private\n */\n clearOff() {\n this.frmOff = null;\n this.cvsOff = null;\n },\n\n /**\n * Return frame offset\n * @return {Object}\n * @private\n */\n getFrameOffset(force = 0) {\n if (!this.frmOff || force) this.frmOff = this.offset(this.frame.el);\n return this.frmOff;\n },\n\n /**\n * Return canvas offset\n * @return {Object}\n * @private\n */\n getCanvasOffset() {\n if (!this.cvsOff) this.cvsOff = this.offset(this.el);\n return this.cvsOff;\n },\n\n /**\n * Returns element's data info\n * @param {HTMLElement} el\n * @return {Object}\n * @private\n */\n getElementPos(el, opts) {\n const zoom = this.getZoom();\n var opt = opts || {};\n var frmOff = this.getFrameOffset();\n var cvsOff = this.getCanvasOffset();\n var eo = this.offset(el);\n\n var frmTop = opt.avoidFrameOffset ? 0 : frmOff.top;\n var frmLeft = opt.avoidFrameOffset ? 0 : frmOff.left;\n\n const top = eo.top * zoom + frmTop - cvsOff.top;\n const left = eo.left * zoom + frmLeft - cvsOff.left;\n const height = eo.height * zoom;\n const width = eo.width * zoom;\n\n return { top, left, height, width, zoom, rect: eo };\n },\n\n /**\n * Returns element's offsets like margins and paddings\n * @param {HTMLElement} el\n * @return {Object}\n * @private\n */\n getElementOffsets(el) {\n if (!el || isTextNode(el)) return {};\n const result = {};\n const styles = window.getComputedStyle(el);\n [\n 'marginTop',\n 'marginRight',\n 'marginBottom',\n 'marginLeft',\n 'paddingTop',\n 'paddingRight',\n 'paddingBottom',\n 'paddingLeft'\n ].forEach(offset => {\n result[offset] = parseFloat(styles[offset]) * this.getZoom();\n });\n\n return result;\n },\n\n /**\n * Returns position data of the canvas element\n * @return {Object} obj Position object\n * @private\n */\n getPosition() {\n const doc = this.frame.el.contentDocument;\n if (!doc) return;\n const bEl = doc.body;\n const zoom = this.getZoom();\n const fo = this.getFrameOffset();\n const co = this.getCanvasOffset();\n\n return {\n top: fo.top + bEl.scrollTop * zoom - co.top,\n left: fo.left + bEl.scrollLeft * zoom - co.left,\n width: co.width,\n height: co.height\n };\n },\n\n /**\n * Update javascript of a specific component passed by its View\n * @param {View} view Component's View\n * @private\n */\n updateScript(view) {\n const model = view.model;\n const id = model.getId();\n\n if (!view.scriptContainer) {\n view.scriptContainer = $(`
`);\n this.getJsContainer().appendChild(view.scriptContainer.get(0));\n }\n\n view.el.id = id;\n view.scriptContainer.html('');\n // In editor, I make use of setTimeout as during the append process of elements\n // those will not be available immediately, therefore 'item' variable\n const script = document.createElement('script');\n script.innerHTML = `\n setTimeout(function() {\n var item = document.getElementById('${id}');\n if (!item) return;\n (function(){\n ${model.getScriptString()};\n }.bind(item))()\n }, 1);`;\n // #873\n // Adding setTimeout will make js components work on init of the editor\n setTimeout(() => view.scriptContainer.get(0).appendChild(script), 0);\n },\n\n /**\n * Get javascript container\n * @private\n */\n getJsContainer() {\n if (!this.jsContainer) {\n this.jsContainer = $(`
`).get(0);\n }\n return this.jsContainer;\n },\n\n render() {\n const { el, $el, ppfx, model } = this;\n this.wrapper = model.get('wrapper');\n $el.html(this.template());\n const $frames = $el.find('[data-frames]');\n this.framesArea = $frames.get(0);\n\n if (this.wrapper && typeof this.wrapper.render == 'function') {\n model.get('frame').set('wrapper', this.wrapper);\n $frames.append(this.frame.render().el);\n var frame = this.frame;\n if (this.config.scripts.length === 0) {\n frame.el.onload = this.renderBody;\n } else {\n this.renderScripts(); // will call renderBody later\n }\n }\n $el.find('[data-tools]').append(`\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n
\n `);\n const toolsEl = el.querySelector(`#${ppfx}tools`);\n this.hlEl = el.querySelector(`.${ppfx}highlighter`);\n this.badgeEl = el.querySelector(`.${ppfx}badge`);\n this.placerEl = el.querySelector(`.${ppfx}placeholder`);\n this.ghostEl = el.querySelector(`.${ppfx}ghost`);\n this.toolbarEl = el.querySelector(`.${ppfx}toolbar`);\n this.resizerEl = el.querySelector(`.${ppfx}resizer`);\n this.offsetEl = el.querySelector(`.${ppfx}offset-v`);\n this.fixedOffsetEl = el.querySelector(`.${ppfx}offset-fixed-v`);\n this.toolsEl = toolsEl;\n this.el.className = this.className;\n return this;\n }\n});\n","/*\n This class makes the canvas droppable\n */\n\nimport { on } from 'utils/mixins';\nimport { bindAll, indexOf } from 'underscore';\n\nexport default class Droppable {\n constructor(em) {\n this.em = em;\n const el = em\n .get('DomComponents')\n .getWrapper()\n .getEl();\n this.el = el;\n this.counter = 0;\n bindAll(\n this,\n 'handleDragEnter',\n 'handleDragOver',\n 'handleDrop',\n 'handleDragLeave'\n );\n on(el, 'dragenter', this.handleDragEnter);\n on(el, 'dragover', this.handleDragOver);\n on(el, 'drop', this.handleDrop);\n on(el, 'dragleave', this.handleDragLeave);\n\n return this;\n }\n\n endDrop(cancel, ev) {\n const { em, dragStop } = this;\n this.counter = 0;\n this.over = 0;\n dragStop && dragStop(cancel);\n em.runDefault();\n em.trigger('canvas:dragend', ev);\n }\n\n handleDragLeave(ev) {\n this.updateCounter(-1, ev);\n }\n\n updateCounter(value, ev) {\n this.counter += value;\n this.counter === 0 && this.endDrop(1, ev);\n }\n\n handleDragEnter(ev) {\n const { em } = this;\n const dt = ev.dataTransfer;\n this.updateCounter(1, ev);\n if (this.over) return;\n this.over = 1;\n const utils = em.get('Utils');\n const canvas = em.get('Canvas');\n const container = canvas.getBody();\n // For security reason I can't read the drag data on dragenter, but\n // as I need it for the Sorter context I will use `dragContent` or just\n // any not empty element\n let content = em.get('dragContent') || '
';\n let dragStop, dragContent;\n em.stopDefault();\n\n if (em.inAbsoluteMode()) {\n const wrapper = em.get('DomComponents').getWrapper();\n const target = wrapper.append({})[0];\n const dragger = em.get('Commands').run('core:component-drag', {\n event: ev,\n guidesInfo: 1,\n center: 1,\n target,\n onEnd: (ev, dragger, { cancelled }) => {\n if (!cancelled) {\n const comp = wrapper.append(content)[0];\n const { left, top, position } = target.getStyle();\n comp.setStyle({ left, top, position });\n this.handleDragEnd(comp, dt);\n }\n target.remove();\n }\n });\n dragStop = cancel => dragger.stop(ev, { cancel });\n dragContent = cnt => (content = cnt);\n } else {\n const sorter = new utils.Sorter({\n em,\n wmargin: 1,\n nested: 1,\n canvasRelative: 1,\n direction: 'a',\n container,\n placer: canvas.getPlacerEl(),\n containerSel: '*',\n itemSel: '*',\n pfx: 'gjs-',\n onEndMove: model => this.handleDragEnd(model, dt),\n document: canvas.getFrameEl().contentDocument\n });\n sorter.setDropContent(content);\n sorter.startSort();\n this.sorter = sorter;\n dragStop = cancel => {\n cancel && (sorter.moved = 0);\n sorter.endMove();\n };\n dragContent = content => sorter.setDropContent(content);\n }\n\n this.dragStop = dragStop;\n this.dragContent = dragContent;\n em.trigger('canvas:dragenter', dt, content);\n }\n\n handleDragEnd(model, dt) {\n if (!model) return;\n const { em } = this;\n em.set('dragResult', model);\n em.trigger('canvas:drop', dt, model);\n }\n\n /**\n * Always need to have this handler active for enabling the drop\n * @param {Event} ev\n */\n handleDragOver(ev) {\n ev.preventDefault();\n this.em.trigger('canvas:dragover', ev);\n }\n\n handleDrop(ev) {\n ev.preventDefault();\n const { dragContent } = this;\n const dt = ev.dataTransfer;\n const content = this.getContentByData(dt).content;\n ev.target.style.border = '';\n content && dragContent && dragContent(content);\n this.endDrop(!content, ev);\n }\n\n getContentByData(dataTransfer) {\n const em = this.em;\n const types = dataTransfer.types;\n const files = dataTransfer.files || [];\n const dragContent = em.get('dragContent');\n let content = dataTransfer.getData('text');\n\n if (files.length) {\n content = [];\n for (let i = 0; i < files.length; i++) {\n const file = files[i];\n const type = file.type.split('/')[0];\n\n if (type == 'image') {\n content.push({\n type,\n file,\n attributes: { alt: file.name }\n });\n }\n }\n } else if (dragContent) {\n content = dragContent;\n } else if (indexOf(types, 'text/html') >= 0) {\n content = dataTransfer\n .getData('text/html')\n .replace(/<\\/?meta[^>]*>/g, '');\n } else if (indexOf(types, 'text/uri-list') >= 0) {\n content = {\n type: 'link',\n attributes: { href: content },\n content: content\n };\n } else if (indexOf(types, 'text/json') >= 0) {\n const json = dataTransfer.getData('text/json');\n json && (content = JSON.parse(json));\n }\n\n const result = { content };\n em.trigger('canvas:dragdata', dataTransfer, result);\n\n return result;\n }\n}\n","export default {\n stylePrefix: 'cv-',\n\n /*\n * Append external scripts to the `` of the iframe.\n * Be aware that these scripts will not be printed in the export code\n * @example\n * scripts: [ 'https://...1.js', 'https://...2.js' ]\n */\n scripts: [],\n\n /*\n * Append external styles to the `` of the iframe\n * Be aware that these styles will not be printed in the export code\n * @example\n * styles: [ 'https://...1.css', 'https://...2.css' ]\n */\n styles: [],\n\n /**\n * Add custom badge naming strategy\n * @example\n * customBadgeLabel: function(component) {\n * return component.getName();\n * }\n */\n customBadgeLabel: '',\n\n /**\n * Indicate when to start the auto scroll of the canvas on component/block dragging (value in px )\n */\n autoscrollLimit: 50,\n\n /**\n * When some textable component is selected and focused (eg. input or text component) the editor\n * stops some commands (eg. disables the copy/paste of components with CTRL+C/V to allow the copy/paste of the text).\n * This option allows to customize, by a selector, which element should not be considered textable\n */\n notTextable: ['button', 'a', 'input[type=checkbox]', 'input[type=radio]']\n};\n","import Backbone from 'backbone';\n\nexport default Backbone.Model.extend({\n defaults: {\n wrapper: '',\n width: '',\n height: '',\n head: '',\n attributes: {}\n },\n\n initialize() {\n this.set('head', []);\n },\n\n getHead() {\n return [...this.get('head')];\n },\n\n setHead(value) {\n return this.set('head', [...value]);\n },\n\n addHeadItem(item) {\n const head = this.getHead();\n head.push(item);\n this.setHead(head);\n },\n\n getHeadByAttr(attr, value, tag) {\n const head = this.getHead();\n return head.filter(\n item =>\n item.attributes &&\n item.attributes[attr] == value &&\n (!tag || tag === item.tag)\n )[0];\n },\n\n removeHeadByAttr(attr, value, tag) {\n const head = this.getHead();\n const item = this.getHeadByAttr(attr, value, tag);\n const index = head.indexOf(item);\n\n if (index >= 0) {\n head.splice(index, 1);\n this.setHead(head);\n }\n },\n\n addLink(href) {\n const tag = 'link';\n !this.getHeadByAttr('href', href, tag) &&\n this.addHeadItem({\n tag,\n attributes: {\n href,\n rel: 'stylesheet'\n }\n });\n },\n\n removeLink(href) {\n this.removeHeadByAttr('href', href, 'link');\n },\n\n addScript(src) {\n const tag = 'script';\n !this.getHeadByAttr('src', src, tag) &&\n this.addHeadItem({\n tag,\n attributes: { src }\n });\n },\n\n removeScript(src) {\n this.removeHeadByAttr('src', src, 'script');\n }\n});\n","import Backbone from 'backbone';\nimport Frame from './Frame';\n\nexport default Backbone.Model.extend({\n defaults: {\n frame: '',\n wrapper: '',\n rulers: false,\n zoom: 100,\n x: 0,\n y: 0\n },\n\n initialize(config = {}) {\n const { styles = [], scripts = [] } = config;\n const frame = new Frame();\n styles.forEach(style => frame.addLink(style));\n scripts.forEach(script => frame.addScript(script));\n this.set('frame', frame);\n this.listenTo(this, 'change:zoom', this.onZoomChange);\n },\n\n onZoomChange() {\n const zoom = this.get('zoom');\n zoom < 1 && this.set('zoom', 1);\n }\n});\n","import Backbone from 'backbone';\nimport { bindAll } from 'underscore';\nimport { appendVNodes, empty } from 'utils/dom';\n\nconst motionsEv =\n 'transitionend oTransitionEnd transitionend webkitTransitionEnd';\n\nexport default Backbone.View.extend({\n tagName: 'iframe',\n\n attributes: {\n allowfullscreen: 'allowfullscreen'\n },\n\n initialize(o) {\n bindAll(this, 'updateOffset');\n this.config = o.config || {};\n this.ppfx = this.config.pStylePrefix || '';\n this.em = this.config.em;\n this.listenTo(this.model, 'change:head', this.updateHead);\n this.listenTo(this.em, 'change:device', this.updateDim);\n },\n\n /**\n * Update `` content of the frame\n */\n updateHead() {\n const headEl = this.getHead();\n empty(headEl);\n appendVNodes(headEl, this.model.getHead());\n },\n\n /**\n * Update dimensions of the frame\n * @private\n */\n updateDim() {\n const { em, el, $el } = this;\n const { style } = el;\n const device = em.getDeviceModel();\n const currW = style.width || '';\n const currH = style.height || '';\n const newW = device ? device.get('width') : '';\n const newH = device ? device.get('height') : '';\n const noChanges = currW == newW && currH == newH;\n style.width = newW;\n style.height = newH;\n this.updateOffset();\n // Prevent fixed highlighting box which appears when on\n // component hover during the animation\n em.stopDefault({ preserveSelected: 1 });\n noChanges ? this.updateOffset() : $el.on(motionsEv, this.updateOffset);\n },\n\n updateOffset() {\n const em = this.em;\n const offset = em.get('Canvas').getOffset();\n em.set('canvasOffset', offset);\n em.runDefault({ preserveSelected: 1 });\n this.$el.off(motionsEv, this.updateOffset);\n },\n\n getDoc() {\n return this.$el.get(0).contentDocument;\n },\n\n getHead() {\n return this.getDoc().querySelector('head');\n },\n\n getBody() {\n return this.getDoc().querySelector('body');\n },\n\n getWrapper() {\n return this.$el.contents().find('body > div');\n },\n\n render() {\n this.$el.attr({ class: this.ppfx + 'frame' });\n return this;\n }\n});\n","/**\n * You can customize the initial state of the module from the editor initialization, by passing the following [Configuration Object](https://github.com/artf/grapesjs/blob/master/src/canvas/config/config.js)\n * ```js\n * const editor = grapesjs.init({\n * canvas: {\n * // options\n * }\n * })\n * ```\n *\n * Once the editor is instantiated you can use its API. Before using these methods you should get the module from the instance\n *\n * ```js\n * const canvas = editor.Canvas;\n * ```\n *\n * * [getConfig](#getconfig)\n * * [getElement](#getelement)\n * * [getFrameEl](#getframeel)\n * * [getWindow](#getwindow)\n * * [getDocument](#getdocument)\n * * [getBody](#getbody)\n * * [getWrapperEl](#getwrapperel)\n * * [setCustomBadgeLabel](#setcustombadgelabel)\n * * [hasFocus](#hasfocus)\n * * [scrollTo](#scrollto)\n * * [setZoom](#setzoom)\n * * [getZoom](#getzoom)\n *\n * @module Canvas\n */\n\nimport { on, off, hasDnd, getElement, getPointerEvent } from 'utils/mixins';\nimport Droppable from 'utils/Droppable';\nimport defaults from './config/config';\nimport Canvas from './model/Canvas';\nimport canvasView from './view/CanvasView';\n\nconst { requestAnimationFrame } = window;\n\nexport default () => {\n let c = {};\n let canvas;\n let frameRect;\n let CanvasView;\n\n return {\n /**\n * Used inside RTE\n * @private\n */\n getCanvasView() {\n return CanvasView;\n },\n\n /**\n * Name of the module\n * @type {String}\n * @private\n */\n name: 'Canvas',\n\n /**\n * Initialize module. Automatically called with a new instance of the editor\n * @param {Object} config Configurations\n * @private\n */\n init(config = {}) {\n c = {\n ...defaults,\n ...config\n };\n\n this.em = c.em;\n const ppfx = c.pStylePrefix;\n if (ppfx) c.stylePrefix = ppfx + c.stylePrefix;\n\n canvas = new Canvas(config);\n CanvasView = new canvasView({\n model: canvas,\n config: c\n });\n\n var cm = c.em.get('DomComponents');\n if (cm) this.setWrapper(cm);\n\n this.startAutoscroll = this.startAutoscroll.bind(this);\n this.stopAutoscroll = this.stopAutoscroll.bind(this);\n this.autoscroll = this.autoscroll.bind(this);\n this.updateClientY = this.updateClientY.bind(this);\n return this;\n },\n\n /**\n * Get the configuration object\n * @return {Object}\n */\n getConfig() {\n return c;\n },\n\n /**\n * Add wrapper\n * @param\t{Object}\twrp Wrapper\n * @private\n * */\n setWrapper(wrp) {\n canvas.set('wrapper', wrp);\n },\n\n /**\n * Get the canvas element\n * @return {HTMLElement}\n */\n getElement() {\n return CanvasView.el;\n },\n\n getFrame() {\n return canvas.get('frame');\n },\n\n /**\n * Get the iframe element of the canvas\n * @return {HTMLIFrameElement}\n */\n getFrameEl() {\n return CanvasView.frame.el;\n },\n\n /**\n * Get the window instance of the iframe element\n * @return {Window}\n */\n getWindow() {\n return this.getFrameEl().contentWindow;\n },\n\n /**\n * Get the document of the iframe element\n * @return {HTMLDocument}\n */\n getDocument() {\n return this.getFrameEl().contentDocument;\n },\n\n /**\n * Get the body of the iframe element\n * @return {HTMLBodyElement}\n */\n getBody() {\n const doc = this.getDocument();\n return doc && doc.body;\n },\n\n /**\n * Get the wrapper element containing all the components\n * @return {HTMLElement}\n */\n getWrapperEl() {\n const body = this.getBody();\n return body && body.querySelector('#wrapper');\n },\n\n /**\n * Returns element containing all canvas tools\n * @return {HTMLElement}\n * @private\n */\n getToolsEl() {\n return CanvasView.toolsEl;\n },\n\n /**\n * Returns highlighter element\n * @return {HTMLElement}\n * @private\n */\n getHighlighter() {\n return CanvasView.hlEl;\n },\n\n /**\n * Returns badge element\n * @return {HTMLElement}\n * @private\n */\n getBadgeEl() {\n return CanvasView.badgeEl;\n },\n\n /**\n * Returns placer element\n * @return {HTMLElement}\n * @private\n */\n getPlacerEl() {\n return CanvasView.placerEl;\n },\n\n /**\n * Returns ghost element\n * @return {HTMLElement}\n * @private\n */\n getGhostEl() {\n return CanvasView.ghostEl;\n },\n\n /**\n * Returns toolbar element\n * @return {HTMLElement}\n * @private\n */\n getToolbarEl() {\n return CanvasView.toolbarEl;\n },\n\n /**\n * Returns resizer element\n * @return {HTMLElement}\n * @private\n */\n getResizerEl() {\n return CanvasView.resizerEl;\n },\n\n /**\n * Returns offset viewer element\n * @return {HTMLElement}\n * @private\n */\n getOffsetViewerEl() {\n return CanvasView.offsetEl;\n },\n\n /**\n * Returns fixed offset viewer element\n * @return {HTMLElement}\n * @private\n */\n getFixedOffsetViewerEl() {\n return CanvasView.fixedOffsetEl;\n },\n\n /**\n * Render canvas\n * @private\n * */\n render() {\n return CanvasView.render().el;\n },\n\n /**\n * Get frame position\n * @return {Object}\n * @private\n */\n getOffset() {\n var frameOff = this.offset(this.getFrameEl());\n var canvasOff = this.offset(this.getElement());\n return {\n top: frameOff.top - canvasOff.top,\n left: frameOff.left - canvasOff.left\n };\n },\n\n /**\n * Get the offset of the passed component element\n * @param {HTMLElement} el\n * @return {Object}\n * @private\n */\n offset(el) {\n return CanvasView.offset(el);\n },\n\n /**\n * Set custom badge naming strategy\n * @param {Function} f\n * @example\n * canvas.setCustomBadgeLabel(function(component){\n * return component.getName();\n * });\n */\n setCustomBadgeLabel(f) {\n c.customBadgeLabel = f;\n },\n\n /**\n * Get element position relative to the canvas\n * @param {HTMLElement} el\n * @return {Object}\n * @private\n */\n getElementPos(el, opts) {\n return CanvasView.getElementPos(el, opts);\n },\n\n /**\n * Returns element's offsets like margins and paddings\n * @param {HTMLElement} el\n * @return {Object}\n * @private\n */\n getElementOffsets(el) {\n return CanvasView.getElementOffsets(el);\n },\n\n /**\n * Get canvas rectangular data\n * @returns {Object}\n */\n getRect() {\n const { top, left } = CanvasView.getPosition();\n return {\n ...CanvasView.getCanvasOffset(),\n topScroll: top,\n leftScroll: left\n };\n },\n\n /**\n * This method comes handy when you need to attach something like toolbars\n * to elements inside the canvas, dealing with all relative position,\n * offsets, etc. and returning as result the object with positions which are\n * viewable by the user (when the canvas is scrolled the top edge of the element\n * is not viewable by the user anymore so the new top edge is the one of the canvas)\n *\n * The target should be visible before being passed here as invisible elements\n * return empty string as width\n * @param {HTMLElement} target The target in this case could be the toolbar\n * @param {HTMLElement} element The element on which I'd attach the toolbar\n * @param {Object} options Custom options\n * @param {Boolean} options.toRight Set to true if you want the toolbar attached to the right\n * @return {Object}\n * @private\n */\n getTargetToElementDim(target, element, options = {}) {\n var opts = options || {};\n var canvasPos = CanvasView.getPosition();\n if (!canvasPos) return;\n var pos = opts.elPos || CanvasView.getElementPos(element);\n var toRight = options.toRight || 0;\n var targetHeight = opts.targetHeight || target.offsetHeight;\n var targetWidth = opts.targetWidth || target.offsetWidth;\n var eventToTrigger = opts.event || null;\n\n var elTop = pos.top - targetHeight;\n var elLeft = pos.left;\n elLeft += toRight ? pos.width : 0;\n elLeft = toRight ? elLeft - targetWidth : elLeft;\n\n var leftPos = elLeft < canvasPos.left ? canvasPos.left : elLeft;\n var topPos = elTop < canvasPos.top ? canvasPos.top : elTop;\n topPos = topPos > pos.top + pos.height ? pos.top + pos.height : topPos;\n\n var result = {\n top: topPos,\n left: leftPos,\n elementTop: pos.top,\n elementLeft: pos.left,\n elementWidth: pos.width,\n elementHeight: pos.height,\n targetWidth: target.offsetWidth,\n targetHeight: target.offsetHeight,\n canvasTop: canvasPos.top,\n canvasLeft: canvasPos.left,\n canvasWidth: canvasPos.width,\n canvasHeight: canvasPos.height\n };\n\n // In this way I can catch data and also change the position strategy\n if (eventToTrigger && c.em) {\n c.em.trigger(eventToTrigger, result);\n }\n\n return result;\n },\n\n /**\n * Instead of simply returning e.clientX and e.clientY this function\n * calculates also the offset based on the canvas. This is helpful when you\n * need to get X and Y position while moving between the editor area and\n * canvas area, which is in the iframe\n * @param {Event} e\n * @return {Object}\n * @private\n */\n getMouseRelativePos(e, options) {\n var opts = options || {};\n var addTop = 0;\n var addLeft = 0;\n var subWinOffset = opts.subWinOffset;\n var doc = e.target.ownerDocument;\n var win = doc.defaultView || doc.parentWindow;\n var frame = win.frameElement;\n var yOffset = subWinOffset ? win.pageYOffset : 0;\n var xOffset = subWinOffset ? win.pageXOffset : 0;\n\n if (frame) {\n var frameRect = frame.getBoundingClientRect();\n addTop = frameRect.top || 0;\n addLeft = frameRect.left || 0;\n }\n\n return {\n y: e.clientY + addTop - yOffset,\n x: e.clientX + addLeft - xOffset\n };\n },\n\n /**\n * X and Y mouse position relative to the canvas\n * @param {Event} ev\n * @return {Object}\n * @private\n */\n getMouseRelativeCanvas(ev) {\n const zoom = this.getZoomDecimal();\n const { top, left } = CanvasView.getPosition();\n\n return {\n y: ev.clientY * zoom + top,\n x: ev.clientX * zoom + left\n };\n },\n\n /**\n * Check if the canvas is focused\n * @return {Boolean}\n */\n hasFocus() {\n return this.getDocument().hasFocus();\n },\n\n /**\n * Detects if some input is focused (input elements, text components, etc.)\n * @return {Boolean}\n * @private\n */\n isInputFocused() {\n const doc = this.getDocument();\n const toIgnore = ['body', ...this.getConfig().notTextable];\n const focused = doc && doc.activeElement;\n\n return focused && !toIgnore.some(item => focused.matches(item));\n },\n\n /**\n * Scroll canvas to the element if it's not visible. The scrolling is\n * executed via `scrollIntoView` API and options of this method are\n * passed to it. For instance, you can scroll smoothly by using\n * `{ behavior: 'smooth' }`.\n * @param {HTMLElement|Component} el\n * @param {Object} [opts={}] Options, same as options for `scrollIntoView`\n * @param {Boolean} [opts.force=false] Force the scroll, even if the element is already visible\n * @example\n * const selected = editor.getSelected();\n * // Scroll smoothly (this behavior can be polyfilled)\n * canvas.scrollTo(selected, { behavior: 'smooth' });\n * // Force the scroll, even if the element is alredy visible\n * canvas.scrollTo(selected, { force: true });\n */\n scrollTo(el, opts = {}) {\n const elem = getElement(el);\n const cv = this.getCanvasView();\n if (!elem) return;\n\n if (!cv.isElInViewport(elem) || opts.force) {\n const opt =\n typeof opts === 'object'\n ? opts\n : { behavior: 'smooth', block: 'nearest' };\n elem.scrollIntoView(opt);\n }\n },\n\n /**\n * Start autoscroll\n * @private\n */\n startAutoscroll() {\n this.dragging = 1;\n let toListen = this.getScrollListeners();\n frameRect = CanvasView.getFrameOffset(1);\n\n // By detaching those from the stack avoid browsers lags\n // Noticeable with \"fast\" drag of blocks\n setTimeout(() => {\n on(toListen, 'mousemove dragover', this.updateClientY);\n on(toListen, 'mouseup', this.stopAutoscroll);\n requestAnimationFrame(this.autoscroll);\n }, 0);\n },\n\n updateClientY(ev) {\n ev.preventDefault();\n this.lastClientY = getPointerEvent(ev).clientY * this.getZoomDecimal();\n },\n\n /**\n * @private\n */\n autoscroll() {\n if (this.dragging) {\n let frameWindow = this.getFrameEl().contentWindow;\n let actualTop = frameWindow.document.body.scrollTop;\n let nextTop = actualTop;\n let clientY = this.lastClientY;\n let limitTop = this.getConfig().autoscrollLimit;\n let limitBottom = frameRect.height - limitTop;\n\n if (clientY < limitTop) {\n nextTop -= limitTop - clientY;\n }\n\n if (clientY > limitBottom) {\n nextTop += clientY - limitBottom;\n }\n\n frameWindow.scrollTo(0, nextTop);\n requestAnimationFrame(this.autoscroll);\n }\n },\n\n /**\n * Stop autoscroll\n * @private\n */\n stopAutoscroll() {\n this.dragging = 0;\n let toListen = this.getScrollListeners();\n off(toListen, 'mousemove dragover', this.updateClientY);\n off(toListen, 'mouseup', this.stopAutoscroll);\n },\n\n getScrollListeners() {\n return [this.getFrameEl().contentWindow];\n },\n\n postRender() {\n if (hasDnd(c.em)) this.droppable = new Droppable(c.em);\n },\n\n /**\n * Set zoom value\n * @param {Number} value The zoom value, from 0 to 100\n * @returns {this}\n */\n setZoom(value) {\n canvas.set('zoom', parseFloat(value));\n return this;\n },\n\n /**\n * Get zoom value\n * @returns {Number}\n */\n getZoom() {\n return parseFloat(canvas.get('zoom'));\n },\n\n getZoomDecimal() {\n return this.getZoom() / 100;\n },\n\n getZoomMultiplier() {\n const zoom = this.getZoomDecimal();\n return zoom ? 1 / zoom : 1;\n },\n\n /**\n * Returns wrapper element\n * @return {HTMLElement}\n * ????\n * @private\n */\n getFrameWrapperEl() {\n return CanvasView.frame.getWrapper();\n }\n };\n};\n","export default {\n devices: [],\n\n deviceLabel: 'Device'\n};\n","import Backbone from 'backbone';\n\nexport default Backbone.Model.extend({\n idAttribute: 'name',\n\n defaults: {\n name: '',\n\n // Width to set for the editor iframe\n width: null,\n\n // Height to set for the editor iframe\n height: '',\n\n // The width which will be used in media queries,\n // If empty the width will be used\n widthMedia: null,\n\n // Setup the order of media queries\n priority: null\n },\n\n initialize() {\n this.get('widthMedia') === null &&\n this.set('widthMedia', this.get('width'));\n this.get('width') === null && this.set('width', this.get('widthMedia'));\n !this.get('priority') &&\n this.set('priority', parseFloat(this.get('widthMedia')) || 0);\n const toCheck = ['width', 'height', 'widthMedia'];\n toCheck.forEach(prop => this.checkUnit(prop));\n },\n\n checkUnit(prop) {\n const pr = this.get(prop) || '';\n const noUnit = (parseFloat(pr) || 0).toString() === pr.toString();\n noUnit && this.set(prop, `${pr}px`);\n }\n});\n","import Backbone from 'backbone';\nimport Device from './Device';\n\nexport default Backbone.Collection.extend({\n model: Device,\n\n comparator: (left, right) => {\n const max = Number.MAX_VALUE;\n return (right.get('priority') || max) - (left.get('priority') || max);\n },\n\n getSorted() {\n return this.sort();\n }\n});\n","import { template } from 'underscore';\nimport Backbone from 'backbone';\n\nexport default Backbone.View.extend({\n template: template(`\n
device-label\"><%= deviceLabel %>
\n
field <%= ppfx %>select\">\n input-holder\">\n \n \n
sel-arrow\">\n
d-s-arrow\">
\n
\n
\n `),\n\n events: {\n change: 'updateDevice'\n },\n\n initialize(o) {\n this.config = o.config || {};\n this.em = this.config.em;\n this.ppfx = this.config.pStylePrefix || '';\n this.events['click .' + this.ppfx + 'add-trasp'] = this.startAdd;\n this.listenTo(this.em, 'change:device', this.updateSelect);\n this.delegateEvents();\n },\n\n /**\n * Start adding new device\n * @return {[type]} [description]\n * @private\n */\n startAdd() {},\n\n /**\n * Update device of the editor\n * @private\n */\n updateDevice() {\n var em = this.em;\n if (em) {\n var devEl = this.devicesEl;\n var val = devEl ? devEl.val() : '';\n em.set('device', val);\n }\n },\n\n /**\n * Update select value on device update\n * @private\n */\n updateSelect() {\n var em = this.em;\n var devEl = this.devicesEl;\n if (em && em.getDeviceModel && devEl) {\n var device = em.getDeviceModel();\n var name = device ? device.get('name') : '';\n devEl.val(name);\n }\n },\n\n /**\n * Return devices options\n * @return {string} String of options\n * @private\n */\n getOptions() {\n var result = '';\n this.collection.each(device => {\n var name = device.get('name');\n result += '';\n });\n return result;\n },\n\n render() {\n var pfx = this.ppfx;\n this.$el.html(\n this.template({\n ppfx: pfx,\n deviceLabel: this.config.deviceLabel\n })\n );\n this.devicesEl = this.$el.find('.' + pfx + 'devices');\n this.devicesEl.append(this.getOptions());\n this.el.className = pfx + 'devices-c';\n return this;\n }\n});\n","/**\n * You can customize the initial state of the module from the editor initialization, by passing the following [Configuration Object](https://github.com/artf/grapesjs/blob/master/src/device_manager/config/config.js)\n * ```js\n * const editor = grapesjs.init({\n * deviceManager: {\n * // options\n * }\n * })\n * ```\n *\n * Once the editor is instantiated you can use its API. Before using these methods you should get the module from the instance\n *\n * ```js\n * const deviceManager = editor.DeviceManager;\n * ```\n *\n * * [add](#add)\n * * [get](#get)\n * * [getAll](#getAll)\n *\n * @module DeviceManager\n */\nimport defaults from './config/config';\nimport Devices from './model/Devices';\nimport DevicesView from './view/DevicesView';\n\nexport default () => {\n var c = {};\n var devices, view;\n\n return {\n /**\n * Name of the module\n * @type {String}\n * @private\n */\n name: 'DeviceManager',\n\n /**\n * Initialize module. Automatically called with a new instance of the editor\n * @param {Object} config Configurations\n * @param {Array} [config.devices=[]] Default devices\n * @example\n * ...\n * {\n * devices: [\n * {name: 'Desktop', width: ''}\n * {name: 'Tablet', width: '991px'}\n * ],\n * }\n * ...\n * @return {this}\n * @private\n */\n init(config) {\n c = config || {};\n for (var name in defaults) {\n if (!(name in c)) c[name] = defaults[name];\n }\n\n devices = new Devices(c.devices);\n view = new DevicesView({\n collection: devices,\n config: c\n });\n return this;\n },\n\n /**\n * Add new device to the collection. URLs are supposed to be unique\n * @param {string} name Device name\n * @param {string} width Width of the device\n * @param {Object} opts Custom options\n * @return {Device} Added device\n * @example\n * deviceManager.add('Tablet', '900px');\n * deviceManager.add('Tablet2', '900px', {\n * height: '300px',\n * widthMedia: '810px', // the width that will be used for the CSS media\n * });\n */\n add(name, width, opts) {\n var obj = opts || {};\n obj.name = name;\n obj.width = width;\n return devices.add(obj);\n },\n\n /**\n * Return device by name\n * @param {string} name Name of the device\n * @example\n * var device = deviceManager.get('Tablet');\n * console.log(JSON.stringify(device));\n * // {name: 'Tablet', width: '900px'}\n */\n get(name) {\n return devices.get(name);\n },\n\n /**\n * Return all devices\n * @return {Collection}\n * @example\n * var devices = deviceManager.getAll();\n * console.log(JSON.stringify(devices));\n * // [{name: 'Desktop', width: ''}, ...]\n */\n getAll() {\n return devices;\n },\n\n /**\n * Render devices\n * @return {string} HTML string\n * @private\n */\n render() {\n return view.render().el;\n }\n };\n};\n","export default {\n stylePrefix: 'mdl-',\n\n title: '',\n\n content: '',\n\n backdrop: true\n};\n","import Backbone from 'backbone';\n\nexport default Backbone.Model.extend({\n defaults: {\n title: '',\n content: '',\n open: false\n }\n});\n","import Backbone from 'backbone';\n\nexport default Backbone.View.extend({\n template({ pfx, ppfx, content, title }) {\n return `
\n
\n
${title}
\n
\n
\n
\n
${content}
\n
\n
\n
\n
`;\n },\n\n events: {\n click: 'onClick',\n 'click [data-close-modal]': 'hide'\n },\n\n initialize(o) {\n const model = this.model;\n const config = o.config || {};\n const pfx = config.stylePrefix || '';\n this.config = config;\n this.pfx = pfx;\n this.ppfx = config.pStylePrefix || '';\n this.listenTo(model, 'change:open', this.updateOpen);\n this.listenTo(model, 'change:title', this.updateTitle);\n this.listenTo(model, 'change:content', this.updateContent);\n },\n\n onClick(e) {\n const bkd = this.config.backdrop;\n bkd && e.target === this.el && this.hide();\n },\n\n /**\n * Returns collector element\n * @return {HTMLElement}\n * @private\n */\n getCollector() {\n if (!this.$collector)\n this.$collector = this.$el.find('.' + this.pfx + 'collector');\n return this.$collector;\n },\n\n /**\n * Returns content element\n * @return {HTMLElement}\n * @private\n */\n getContent() {\n const pfx = this.pfx;\n\n if (!this.$content) {\n this.$content = this.$el.find(`.${pfx}content #${pfx}c`);\n }\n\n return this.$content;\n },\n\n /**\n * Returns title element\n * @return {HTMLElement}\n * @private\n */\n getTitle() {\n if (!this.$title) this.$title = this.$el.find('.' + this.pfx + 'title');\n return this.$title.get(0);\n },\n\n /**\n * Update content\n * @private\n * */\n updateContent() {\n var content = this.getContent();\n const children = content.children();\n const coll = this.getCollector();\n const body = this.model.get('content');\n children.length && coll.append(children);\n content.empty().append(body);\n },\n\n /**\n * Update title\n * @private\n * */\n updateTitle() {\n var title = this.getTitle();\n if (title) title.innerHTML = this.model.get('title');\n },\n\n /**\n * Update open\n * @private\n * */\n updateOpen() {\n this.el.style.display = this.model.get('open') ? '' : 'none';\n },\n\n /**\n * Hide modal\n * @private\n * */\n hide() {\n this.model.set('open', 0);\n },\n\n /**\n * Show modal\n * @private\n * */\n show() {\n this.model.set('open', 1);\n },\n\n render() {\n const el = this.$el;\n const pfx = this.pfx;\n const ppfx = this.ppfx;\n const obj = this.model.toJSON();\n obj.pfx = this.pfx;\n obj.ppfx = this.ppfx;\n el.html(this.template(obj));\n el.attr('class', `${pfx}container`);\n this.updateOpen();\n return this;\n }\n});\n","/**\n * You can customize the initial state of the module from the editor initialization, by passing the following [Configuration Object](https://github.com/artf/grapesjs/blob/master/src/modal_dialog/config/config.js)\n * ```js\n * const editor = grapesjs.init({\n * modal: {\n * // options\n * }\n * })\n * ```\n *\n * Once the editor is instantiated you can use its API. Before using these methods you should get the module from the instance\n *\n * ```js\n * const modal = editor.Modal;\n * ```\n *\n * * [open](#open)\n * * [close](#close)\n * * [isOpen](#isopen)\n * * [setTitle](#settitle)\n * * [getTitle](#gettitle)\n * * [setContent](#setcontent)\n * * [getContent](#getcontent)\n * * [onceClose](#onceclose)\n * * [onceOpen](#onceopen)\n *\n * @module Modal\n */\n\nimport defaults from './config/config';\nimport ModalM from './model/Modal';\nimport ModalView from './view/ModalView';\n\nexport default () => {\n var c = {};\n var model, modal;\n\n const triggerEvent = (enable, em) => {\n em && em.trigger(`modal:${enable ? 'open' : 'close'}`);\n };\n\n return {\n /**\n * Name of the module\n * @type {String}\n * @private\n */\n name: 'Modal',\n\n getConfig() {\n return c;\n },\n\n /**\n * Initialize module. Automatically called with a new instance of the editor\n * @param {Object} config Configurations\n * @private\n */\n init(config = {}) {\n c = {\n ...defaults,\n ...config\n };\n\n const em = c.em;\n this.em = em;\n var ppfx = c.pStylePrefix;\n if (ppfx) c.stylePrefix = ppfx + c.stylePrefix;\n\n model = new ModalM(c);\n model.on('change:open', (m, enb) => triggerEvent(enb, em));\n modal = new ModalView({\n model,\n config: c\n });\n\n return this;\n },\n\n postRender(view) {\n const el = view.model.getConfig().el || view.el;\n this.render().appendTo(el);\n },\n\n /**\n * Open the modal window\n * @param {Object} [opts={}] Options\n * @param {String|HTMLElement} [opts.title] Title to set for the modal\n * @param {String|HTMLElement} [opts.content] Content to set for the modal\n * @return {this}\n */\n open(opts = {}) {\n opts.title && this.setTitle(opts.title);\n opts.content && this.setContent(opts.content);\n modal.show();\n return this;\n },\n\n /**\n * Close the modal window\n * @return {this}\n */\n close() {\n modal.hide();\n return this;\n },\n\n /**\n * Execute callback when the modal will be closed.\n * The callback will be called one only time\n * @param {Function} clb\n * @returns {this}\n */\n onceClose(clb) {\n this.em.once('modal:close', clb);\n return this;\n },\n\n /**\n * Execute callback when the modal will be opened.\n * The callback will be called one only time\n * @param {Function} clb\n * @returns {this}\n */\n onceOpen(clb) {\n this.em.once('modal:open', clb);\n return this;\n },\n\n /**\n * Checks if the modal window is open\n * @return {Boolean}\n */\n isOpen() {\n return !!model.get('open');\n },\n\n /**\n * Set the title to the modal window\n * @param {string} title Title\n * @return {this}\n * @example\n * modal.setTitle('New title');\n */\n setTitle(title) {\n model.set('title', title);\n return this;\n },\n\n /**\n * Returns the title of the modal window\n * @return {string}\n */\n getTitle() {\n return model.get('title');\n },\n\n /**\n * Set the content of the modal window\n * @param {string|HTMLElement} content Content\n * @return {this}\n * @example\n * modal.setContent('
Some HTML content
');\n */\n setContent(content) {\n model.set('content', ' ');\n model.set('content', content);\n return this;\n },\n\n /**\n * Get the content of the modal window\n * @return {string}\n */\n getContent() {\n return model.get('content');\n },\n\n /**\n * Returns content element\n * @return {HTMLElement}\n * @private\n */\n getContentEl() {\n return modal.getContent().get(0);\n },\n\n /**\n * Returns modal model\n * @return {Model}\n * @private\n */\n getModel() {\n return model;\n },\n\n /**\n * Render the modal window\n * @return {HTMLElement}\n * @private\n */\n render() {\n return modal.render().$el;\n }\n };\n};\n","export default {\n // Style prefix\n stylePrefix: 'clm-',\n\n // Specify the element to use as a container, string (query) or HTMLElement\n // With the empty value, nothing will be rendered\n appendTo: '',\n\n // Default selectors\n selectors: [],\n\n // Label for selectors\n label: 'Classes',\n\n // Label for states\n statesLabel: '- State -',\n\n selectedLabel: 'Selected',\n\n // States\n states: [\n { name: 'hover', label: 'Hover' },\n { name: 'active', label: 'Click' },\n { name: 'nth-of-type(2n)', label: 'Even/Odd' }\n ],\n\n // Custom selector name escaping strategy, eg.\n // name => name.replace(' ', '_')\n escapeName: 0\n};\n","import Backbone from 'backbone';\n\nconst inputProp = 'contentEditable';\n\nexport default Backbone.View.extend({\n template() {\n const pfx = this.pfx;\n const ppfx = this.ppfx;\n const label = this.model.get('label') || '';\n return `\n \n ${label}\n \n ⨯\n \n `;\n },\n\n events: {\n 'click [data-tag-remove]': 'removeTag',\n 'click [data-tag-status]': 'changeStatus',\n 'dblclick [data-tag-name]': 'startEditTag',\n 'focusout [data-tag-name]': 'endEditTag'\n },\n\n initialize(o) {\n const config = o.config || {};\n this.config = config;\n this.coll = o.coll || null;\n this.pfx = config.stylePrefix || '';\n this.ppfx = config.pStylePrefix || '';\n this.em = config.em;\n this.listenTo(this.model, 'change:active', this.updateStatus);\n },\n\n /**\n * Returns the element which containes the anme of the tag\n * @return {HTMLElement}\n */\n getInputEl() {\n if (!this.inputEl) {\n this.inputEl = this.el.querySelector('[data-tag-name]');\n }\n\n return this.inputEl;\n },\n\n /**\n * Start editing tag\n * @private\n */\n startEditTag() {\n const { em } = this;\n const inputEl = this.getInputEl();\n inputEl[inputProp] = true;\n inputEl.focus();\n em && em.setEditing(1);\n },\n\n /**\n * End editing tag. If the class typed already exists the\n * old one will be restored otherwise will be changed\n * @private\n */\n endEditTag() {\n const model = this.model;\n const inputEl = this.getInputEl();\n const label = inputEl.textContent;\n const em = this.em;\n const sm = em && em.get('SelectorManager');\n inputEl[inputProp] = false;\n em && em.setEditing(0);\n\n if (sm) {\n const name = sm.escapeName(label);\n\n if (sm.get(name)) {\n inputEl.innerText = model.get('label');\n } else {\n model.set({ name, label });\n }\n }\n },\n\n /**\n * Update status of the tag\n * @private\n */\n changeStatus() {\n const { model } = this;\n model.set('active', !model.get('active'));\n },\n\n /**\n * Remove tag from the selected component\n * @param {Object} e\n * @private\n */\n removeTag() {\n const { em, model } = this;\n const sel = em && em.getSelected();\n if (!model.get('protected') && sel) sel.getSelectors().remove(model);\n },\n\n /**\n * Update status of the checkbox\n * @private\n */\n updateStatus() {\n const { model, $el } = this;\n const chkOn = 'fa-check-square-o';\n const chkOff = 'fa-square-o';\n const $chk = $el.find('[data-tag-status]');\n\n if (model.get('active')) {\n $chk.removeClass(chkOff).addClass(chkOn);\n $el.removeClass('opac50');\n } else {\n $chk.removeClass(chkOn).addClass(chkOff);\n $el.addClass('opac50');\n }\n },\n\n render() {\n const pfx = this.pfx;\n const ppfx = this.ppfx;\n this.$el.html(this.template());\n this.$el.attr('class', `${pfx}tag ${ppfx}three-bg`);\n this.updateStatus();\n return this;\n }\n});\n","import { template, debounce } from 'underscore';\nimport Backbone from 'backbone';\nimport ClassTagView from './ClassTagView';\n\nexport default Backbone.View.extend({\n template: template(`\n
up\">\n
label\"><%= label %>
\n
status-c\">\n input-c\">\n
field <%= ppfx %>select\">\n input-holder\">\n \n \n
sel-arrow\">\n
d-s-arrow\">
\n
\n
\n
\n
\n
\n
tags-field\" class=\"<%= ppfx %>field\">\n
tags-c\">
\n new\" />\n add-tag\" class=\"fa fa-plus\">\n
\n
sel-help\">\n
label\"><%= selectedLabel %>
\n
sel\">
\n
\n
`),\n\n events: {},\n\n initialize(o = {}) {\n this.config = o.config || {};\n this.pfx = this.config.stylePrefix || '';\n this.ppfx = this.config.pStylePrefix || '';\n this.className = this.pfx + 'tags';\n this.addBtnId = this.pfx + 'add-tag';\n this.newInputId = this.pfx + 'new';\n this.stateInputId = this.pfx + 'states';\n this.stateInputC = this.pfx + 'input-c';\n this.states = this.config.states || [];\n this.events['click #' + this.addBtnId] = 'startNewTag';\n this.events['blur #' + this.newInputId] = 'endNewTag';\n this.events['keyup #' + this.newInputId] = 'onInputKeyUp';\n this.events['change #' + this.stateInputId] = 'stateChanged';\n const { em } = this.config;\n const emitter = this.getStyleEmitter();\n this.target = this.config.em;\n this.em = em;\n\n this.listenTo(emitter, 'styleManager:update', this.componentChanged);\n this.listenTo(\n em,\n 'component:toggled component:update:classes',\n this.componentChanged\n );\n this.listenTo(em, 'component:update:classes', this.updateSelector);\n\n this.listenTo(this.collection, 'add', this.addNew);\n this.listenTo(this.collection, 'reset', this.renderClasses);\n this.listenTo(this.collection, 'remove', this.tagRemoved);\n\n this.delegateEvents();\n },\n\n getStyleEmitter() {\n const { em } = this;\n const sm = em && em.get('StyleManager');\n const emitter = sm && sm.getEmitter();\n return emitter || {};\n },\n\n /**\n * Triggered when a tag is removed from collection\n * @param {Object} model Removed model\n * @private\n */\n tagRemoved(model) {\n this.updateStateVis();\n },\n\n /**\n * Create select input with states\n * @return {string} String of options\n * @private\n */\n getStateOptions() {\n var strInput = '';\n for (var i = 0; i < this.states.length; i++) {\n strInput +=\n '';\n }\n return strInput;\n },\n\n /**\n * Add new model\n * @param {Object} model\n * @private\n */\n addNew(model) {\n this.addToClasses(model);\n },\n\n /**\n * Start tag creation\n * @param {Object} e\n * @private\n */\n startNewTag(e) {\n this.$addBtn.get(0).style.display = 'none';\n this.$input.show().focus();\n },\n\n /**\n * End tag creation\n * @param {Object} e\n * @private\n */\n endNewTag(e) {\n this.$addBtn.get(0).style.display = '';\n this.$input.hide().val('');\n },\n\n /**\n * Checks what to do on keyup event\n * @param {Object} e\n * @private\n */\n onInputKeyUp(e) {\n if (e.keyCode === 13) this.addNewTag(this.$input.val());\n else if (e.keyCode === 27) this.endNewTag();\n },\n\n /**\n * Triggered when component is changed\n * @param {Object} e\n * @private\n */\n componentChanged: debounce(function(target) {\n target = target || this.getTarget();\n this.compTarget = target;\n let validSelectors = [];\n\n if (target) {\n const state = target.get('state');\n state && this.getStates().val(state);\n const selectors = target.getSelectors();\n validSelectors = selectors.getValid();\n }\n\n this.collection.reset(validSelectors);\n this.updateStateVis(target);\n }),\n\n getTarget() {\n return this.target.getSelected();\n },\n\n /**\n * Update states visibility. Hides states in case there is no tags\n * inside collection\n * @private\n */\n updateStateVis(target) {\n const em = this.em;\n const avoidInline = em && em.getConfig('avoidInlineStyle');\n const display = this.collection.length || avoidInline ? 'block' : 'none';\n this.getStatesC().css('display', display);\n this.updateSelector(target);\n },\n\n /**\n * Update selector helper\n * @return {this}\n * @private\n */\n updateSelector(target) {\n const { pfx, collection, el } = this;\n const selected = target || this.getTarget();\n this.compTarget = selected;\n if (!selected || !selected.get) return;\n\n const state = selected.get('state');\n const coll = collection;\n let result = coll.getFullString(selected.getSelectors().getStyleable());\n result =\n result ||\n selected.get('selectorsAdd') ||\n (selected.getId ? `#${selected.getId()}` : '');\n result += state ? `:${state}` : '';\n const elSel = el.querySelector(`#${pfx}sel`);\n elSel && (elSel.innerHTML = result);\n },\n\n /**\n * Triggered when the select with states is changed\n * @param {Object} e\n * @private\n */\n stateChanged(e) {\n if (this.compTarget) {\n this.compTarget.set('state', this.$states.val());\n this.updateSelector();\n }\n },\n\n /**\n * Add new tag to collection, if possible, and to the component\n * @param {Object} e\n * @private\n */\n addNewTag(label) {\n const target = this.target;\n const component = this.compTarget;\n\n if (!label.trim()) {\n return;\n }\n\n if (target) {\n const sm = target.get('SelectorManager');\n const model = sm.add({ label });\n\n if (component) {\n const compCls = component.getSelectors();\n compCls.add(model);\n this.collection.add(model);\n this.updateStateVis();\n }\n }\n this.endNewTag();\n },\n\n /**\n * Add new object to collection\n * @param {Object} model Model\n * @param {Object} fragmentEl Fragment collection\n * @return {Object} Object created\n * @private\n * */\n addToClasses(model, fragmentEl = null) {\n const fragment = fragmentEl;\n const classes = this.getClasses();\n const rendered = new ClassTagView({\n model,\n config: this.config,\n coll: this.collection\n }).render().el;\n\n fragment ? fragment.appendChild(rendered) : classes.append(rendered);\n\n return rendered;\n },\n\n /**\n * Render the collection of classes\n * @private\n */\n renderClasses() {\n const frag = document.createDocumentFragment();\n const classes = this.getClasses();\n classes.empty();\n this.collection.each(model => this.addToClasses(model, frag));\n classes.append(frag);\n },\n\n /**\n * Return classes element\n * @return {HTMLElement}\n * @private\n */\n getClasses() {\n return this.$el.find(`#${this.pfx}tags-c`);\n },\n\n /**\n * Return states element\n * @return {HTMLElement}\n * @private\n */\n getStates() {\n if (!this.$states) this.$states = this.$el.find('#' + this.stateInputId);\n return this.$states;\n },\n\n /**\n * Return states container element\n * @return {HTMLElement}\n * @private\n */\n getStatesC() {\n if (!this.$statesC) this.$statesC = this.$el.find('#' + this.stateInputC);\n return this.$statesC;\n },\n\n render() {\n const ppfx = this.ppfx;\n const config = this.config;\n const $el = this.$el;\n $el.html(\n this.template({\n selectedLabel: config.selectedLabel,\n statesLabel: config.statesLabel,\n label: config.label,\n pfx: this.pfx,\n ppfx: this.ppfx\n })\n );\n this.$input = $el.find('input#' + this.newInputId);\n this.$addBtn = $el.find('#' + this.addBtnId);\n this.$classes = $el.find('#' + this.pfx + 'tags-c');\n this.$states = $el.find('#' + this.stateInputId);\n this.$statesC = $el.find('#' + this.stateInputC);\n this.$states.append(this.getStateOptions());\n this.renderClasses();\n $el.attr('class', `${this.className} ${ppfx}one-bg ${ppfx}two-color`);\n return this;\n }\n});\n","/**\n * Selectors in GrapesJS are used in CSS Composer inside Rules and in Components as classes. To illustrate this concept let's take\n * a look at this code:\n *\n * ```css\n * span > #send-btn.btn{\n * ...\n * }\n * ```\n * ```html\n * \n * \n * \n * ```\n *\n * In this scenario we get:\n * * span -> selector of type `tag`\n * * send-btn -> selector of type `id`\n * * btn -> selector of type `class`\n *\n * So, for example, being `btn` the same class entity it'll be easier to refactor and track things.\n *\n * You can customize the initial state of the module from the editor initialization, by passing the following [Configuration Object](https://github.com/artf/grapesjs/blob/master/src/selector_manager/config/config.js)\n * ```js\n * const editor = grapesjs.init({\n * selectorManager: {\n * // options\n * }\n * })\n * ```\n *\n * Once the editor is instantiated you can use its API. Before using these methods you should get the module from the instance\n *\n * ```js\n * const selectorManager = editor.SelectorManager;\n * ```\n *\n * * [getConfig](#getconfig)\n * * [add](#add)\n * * [addClass](#addclass)\n * * [get](#get)\n * * [getAll](#getAll)\n *\n * @module SelectorManager\n */\n\nimport { isString, isElement, isObject, isArray } from 'underscore';\nimport defaults from './config/config';\nimport Selector from './model/Selector';\nimport Selectors from './model/Selectors';\nimport ClassTagsView from './view/ClassTagsView';\n\nconst isId = str => isString(str) && str[0] == '#';\nconst isClass = str => isString(str) && str[0] == '.';\n\nexport default config => {\n var c = config || {};\n var selectors, selectorTags;\n\n return {\n Selector,\n\n Selectors,\n\n /**\n * Name of the module\n * @type {String}\n * @private\n */\n name: 'SelectorManager',\n\n /**\n * Get configuration object\n * @return {Object}\n */\n getConfig() {\n return c;\n },\n\n /**\n * Initialize module. Automatically called with a new instance of the editor\n * @param {Object} config Configurations\n * @return {this}\n * @private\n */\n init(conf = {}) {\n c = {\n ...defaults,\n ...conf\n };\n const em = c.em;\n const ppfx = c.pStylePrefix;\n\n if (ppfx) {\n c.stylePrefix = ppfx + c.stylePrefix;\n }\n\n selectorTags = new ClassTagsView({\n collection: new Selectors([], { em, config: c }),\n config: c\n });\n\n // Global selectors container\n selectors = new Selectors(c.selectors);\n selectors.on('add', model => em.trigger('selector:add', model));\n\n return this;\n },\n\n postRender() {\n const elTo = this.getConfig().appendTo;\n\n if (elTo) {\n const el = isElement(elTo) ? elTo : document.querySelector(elTo);\n el.appendChild(this.render([]));\n }\n },\n\n addSelector(name, opt = {}) {\n let opts = { ...opt };\n\n if (isObject(name)) {\n opts = name;\n } else {\n opts.name = name;\n }\n\n if (isId(opts.name)) {\n opts.name = opts.name.substr(1);\n opts.type = Selector.TYPE_ID;\n } else if (isClass(opts.name)) {\n opts.name = opts.name.substr(1);\n }\n\n if (opts.label && !opts.name) {\n opts.name = this.escapeName(opts.label);\n }\n\n const cname = opts.name;\n const selector = cname\n ? this.get(cname, opts.type)\n : selectors.where(opts)[0];\n\n if (!selector) {\n return selectors.add(opts, { config: c });\n }\n\n return selector;\n },\n\n getSelector(name, type = Selector.TYPE_CLASS) {\n if (isId(name)) {\n name = name.substr(1);\n type = Selector.TYPE_ID;\n } else if (isClass(name)) {\n name = name.substr(1);\n }\n\n return selectors.where({ name, type })[0];\n },\n\n /**\n * Add a new selector to collection if it's not already exists. Class type is a default one\n * @param {String|Array} name Selector/s name\n * @param {Object} opts Selector options\n * @param {String} [opts.label=''] Label for the selector, if it's not provided the label will be the same as the name\n * @param {String} [opts.type=1] Type of the selector. At the moment, only 'class' (1) is available\n * @return {Model|Array}\n * @example\n * const selector = selectorManager.add('selectorName');\n * // Same as\n * const selector = selectorManager.add('selectorName', {\n * type: 1,\n * label: 'selectorName'\n * });\n * // Multiple selectors\n * const selectors = selectorManager.add(['.class1', '.class2', '#id1']);\n * */\n add(name, opts = {}) {\n if (isArray(name)) {\n return name.map(item => this.addSelector(item, opts));\n } else {\n return this.addSelector(name, opts);\n }\n },\n\n /**\n * Add class selectors\n * @param {Array|string} classes Array or string of classes\n * @return {Array} Array of added selectors\n * @example\n * sm.addClass('class1');\n * sm.addClass('class1 class2');\n * sm.addClass(['class1', 'class2']);\n * // -> [SelectorObject, ...]\n */\n addClass(classes) {\n const added = [];\n\n if (isString(classes)) {\n classes = classes.trim().split(' ');\n }\n\n classes.forEach(name => added.push(this.addSelector(name)));\n return added;\n },\n\n /**\n * Get the selector by its name\n * @param {String|Array} name Selector name\n * @param {String} type Selector type\n * @return {Model|Array}\n * @example\n * const selector = selectorManager.get('selectorName');\n * // or get an array\n * const selectors = selectorManager.get(['class1', 'class2']);\n * */\n get(name, type) {\n if (isArray(name)) {\n const result = [];\n const selectors = name\n .map(item => this.getSelector(item))\n .filter(item => item);\n selectors.forEach(\n item => result.indexOf(item) < 0 && result.push(item)\n );\n return result;\n } else {\n return this.getSelector(name, type);\n }\n },\n\n /**\n * Get all selectors\n * @return {Collection}\n * */\n getAll() {\n return selectors;\n },\n\n /**\n * Return escaped selector name\n * @param {String} name Selector name to escape\n * @returns {String} Escaped name\n */\n escapeName(name) {\n const { escapeName } = c;\n return escapeName ? escapeName(name) : Selector.escapeName(name);\n },\n\n /**\n * Render class selectors. If an array of selectors is provided a new instance of the collection will be rendered\n * @param {Array} selectors\n * @return {HTMLElement}\n * @private\n */\n render(selectors) {\n if (selectors) {\n var view = new ClassTagsView({\n collection: new Selectors(selectors),\n config: c\n });\n return view.render().el;\n } else return selectorTags.render().el;\n }\n };\n};\n","export default {\n textTags: ['br', 'b', 'i', 'u', 'a', 'ul', 'ol'],\n\n // Custom CSS parser\n parserCss: null,\n\n // Custom HTML parser\n parserHtml: null\n};\n","import { keys } from 'underscore';\n\n// At-rules\n// https://developer.mozilla.org/it/docs/Web/API/CSSRule#Type_constants\nconst atRules = {\n 4: 'media',\n 5: 'font-face',\n 6: 'page',\n 7: 'keyframes',\n 11: 'counter-style',\n 12: 'supports',\n 13: 'document',\n 14: 'font-feature-values',\n 15: 'viewport'\n};\nconst atRuleKeys = keys(atRules);\nconst singleAtRules = ['5', '6', '11', '15'];\nconst singleAtRulesNames = ['font-face', 'page', 'counter-style', 'viewport'];\n\n/**\n * Parse selector string to array.\n * Only classe based are valid as CSS rules inside editor, not valid\n * selectors will be dropped as additional\n * It's ok with the last part of the string as state (:hover, :active)\n * @param {string} str Selectors string\n * @return {Object}\n * @example\n * var res = parseSelector('.test1, .test1.test2, .test2 .test3');\n * console.log(res);\n * // {\n * //result: [['test1'], ['test1', 'test2']],\n * //add: ['.test2 .test3']\n * //}\n */\nexport const parseSelector = (str = '') => {\n const add = [];\n const result = [];\n const sels = str.split(',');\n\n for (var i = 0, len = sels.length; i < len; i++) {\n var sel = sels[i].trim();\n\n // Will accept only concatenated classes and last\n // class might be with state (eg. :hover), nothing else.\n // Can also accept SINGLE ID selectors, eg. `#myid`, `#myid:hover`\n // Composed are not valid: `#myid.some-class`, `#myid.some-class:hover`\n if (\n /^(\\.{1}[\\w\\-]+)+(:{1,2}[\\w\\-()]+)?$/gi.test(sel) ||\n /^(#{1}[\\w\\-]+){1}(:{1,2}[\\w\\-()]+)?$/gi.test(sel)\n ) {\n var cls = sel.split('.').filter(Boolean);\n result.push(cls);\n } else {\n add.push(sel);\n }\n }\n\n return {\n result,\n add\n };\n};\n\n/**\n * Parse style declarations of the node\n * @param {CSSRule} node\n * @return {Object}\n */\nexport const parseStyle = node => {\n const stl = node.style;\n const style = {};\n\n for (var i = 0, len = stl.length; i < len; i++) {\n const propName = stl[i];\n const propValue = stl.getPropertyValue(propName);\n const important = stl.getPropertyPriority(propName);\n style[propName] = `${propValue}${important ? ` !${important}` : ''}`;\n }\n\n return style;\n};\n\n/**\n * Get the condition when possible\n * @param {CSSRule} node\n * @return {string}\n */\nexport const parseCondition = node => {\n const condition =\n node.conditionText ||\n (node.media && node.media.mediaText) ||\n node.name ||\n node.selectorText ||\n '';\n return condition.trim();\n};\n\n/**\n * Create node for the editor\n * @param {Array} selectors Array containing strings of classes\n * @param {Object} style Key-value object of style declarations\n * @return {Object}\n */\nexport const createNode = (selectors, style = {}, opts = {}) => {\n const node = {};\n const selLen = selectors.length;\n const lastClass = selectors[selLen - 1];\n const stateArr = lastClass ? lastClass.split(/:(.+)/) : [];\n const state = stateArr[1];\n const { atRule, selectorsAdd, mediaText } = opts;\n const singleAtRule = singleAtRulesNames.indexOf(atRule) >= 0;\n singleAtRule && (node.singleAtRule = 1);\n atRule && (node.atRuleType = atRule);\n selectorsAdd && (node.selectorsAdd = selectorsAdd);\n mediaText && (node.mediaText = mediaText);\n\n // Isolate the state from selectors\n if (state) {\n selectors[selLen - 1] = stateArr[0];\n node.state = state;\n stateArr.splice(stateArr.length - 1, 1);\n }\n\n node.selectors = selectors;\n node.style = style;\n\n return node;\n};\n\n/**\n * Fetch data from node\n * @param {StyleSheet|CSSRule} el\n * @return {Array}\n */\nexport const parseNode = el => {\n var result = [];\n var nodes = el.cssRules || [];\n\n for (var i = 0, len = nodes.length; i < len; i++) {\n const node = nodes[i];\n const type = node.type.toString();\n let singleAtRule = 0;\n let atRuleType = '';\n let condition = '';\n // keyText is for CSSKeyframeRule\n let sels = node.selectorText || node.keyText;\n const isSingleAtRule = singleAtRules.indexOf(type) >= 0;\n\n // Check if the node is an at-rule\n if (isSingleAtRule) {\n singleAtRule = 1;\n atRuleType = atRules[type];\n condition = parseCondition(node);\n } else if (atRuleKeys.indexOf(type) >= 0) {\n var subRules = parseNode(node);\n condition = parseCondition(node);\n\n for (var s = 0, lens = subRules.length; s < lens; s++) {\n var subRule = subRules[s];\n condition && (subRule.mediaText = condition);\n subRule.atRuleType = atRules[type];\n }\n result = result.concat(subRules);\n }\n\n if (!sels && !isSingleAtRule) continue;\n const style = parseStyle(node);\n const selsParsed = parseSelector(sels);\n const selsAdd = selsParsed.add;\n sels = selsParsed.result;\n\n let lastRule;\n // For each group of selectors\n for (var k = 0, len3 = sels.length; k < len3; k++) {\n const model = createNode(sels[k], style, {\n atRule: atRules[type]\n });\n result.push(model);\n lastRule = model;\n }\n\n // Need to push somewhere not class-based selectors, if some rule was\n // created will push them there, otherwise will create a new rule\n if (selsAdd.length) {\n var selsAddStr = selsAdd.join(', ');\n if (lastRule) {\n lastRule.selectorsAdd = selsAddStr;\n } else {\n const model = {\n selectors: [],\n selectorsAdd: selsAddStr,\n style\n };\n singleAtRule && (model.singleAtRule = singleAtRule);\n atRuleType && (model.atRuleType = atRuleType);\n condition && (model.mediaText = condition);\n result.push(model);\n }\n }\n // console.log('LAST PUSH', result[result.length - 1]);\n }\n\n return result;\n};\n\n/**\n * Parse CSS string and return the array of objects\n * @param {String} str CSS string\n * @return {Array} Array of objects for the definition of CSSRules\n */\nexport default str => {\n const el = document.createElement('style');\n el.innerHTML = str;\n\n // There is no .sheet before adding it to the \n document.head.appendChild(el);\n const sheet = el.sheet;\n document.head.removeChild(el);\n\n return parseNode(sheet);\n};\n","import { isString } from 'underscore';\nimport BrowserCssParser, {\n parseSelector,\n createNode\n} from './BrowserParserCss';\n\nexport default (config = {}) => ({\n /**\n * Parse CSS string to a desired model object\n * @param {String} str CSS string\n * @return {Array}\n */\n parse(str) {\n let result = [];\n const { parserCss, em = {} } = config;\n const editor = em && em.get && em.get('Editor');\n const nodes = parserCss ? parserCss(str, editor) : BrowserCssParser(str);\n nodes.forEach(node => (result = result.concat(this.checkNode(node))));\n\n return result;\n },\n\n /**\n * Check the returned node from a custom parser and transforms it to\n * a valid object for the CSS composer\n * @return {[type]}\n */\n checkNode(node) {\n const { selectors, style } = node;\n\n if (isString(selectors)) {\n const nodes = [];\n const selsParsed = parseSelector(selectors);\n const classSets = selsParsed.result;\n const selectorsAdd = selsParsed.add.join(', ');\n const opts = {\n atRule: node.atRule,\n mediaText: node.params\n };\n\n if (classSets.length) {\n classSets.forEach(classSet => {\n nodes.push(createNode(classSet, style, opts));\n });\n } else {\n nodes.push(createNode([], style, opts));\n }\n\n if (selectorsAdd) {\n const lastNode = nodes[nodes.length - 1];\n lastNode.selectorsAdd = selectorsAdd;\n }\n\n node = nodes;\n }\n\n return node;\n }\n});\n","import defaults from './config/config';\nimport parserCss from './model/ParserCss';\nimport parserHtml from './model/ParserHtml';\n\nexport default () => {\n let conf = {};\n let pHtml, pCss;\n\n return {\n compTypes: '',\n\n parserCss: null,\n\n parserHtml: null,\n\n /**\n * Name of the module\n * @type {String}\n * @private\n */\n name: 'Parser',\n\n /**\n * Get config object\n * @return {Object}\n */\n getConfig() {\n return conf;\n },\n\n /**\n * Initialize module. Automatically called with a new instance of the editor\n * @param {Object} config Configurations\n * @param {Array} [config.blocks=[]] Default blocks\n * @return {this}\n * @example\n * ...\n * {\n * blocks: [\n * {id:'h1-block' label: 'Heading', content:'

...

'},\n * ...\n * ],\n * }\n * ...\n */\n init(config = {}) {\n conf = { ...defaults, ...config };\n conf.Parser = this;\n pHtml = new parserHtml(conf);\n pCss = new parserCss(conf);\n this.em = conf.em;\n this.parserCss = pCss;\n this.parserHtml = pHtml;\n return this;\n },\n\n /**\n * Parse HTML string and return valid model\n * @param {string} str HTML string\n * @return {Object}\n */\n parseHtml(str) {\n const { em, compTypes } = this;\n pHtml.compTypes = em ? em.get('DomComponents').getTypes() : compTypes;\n return pHtml.parse(str, pCss);\n },\n\n /**\n * Parse CSS string and return valid model\n * @param {string} str CSS string\n * @return {Array}\n */\n parseCss(str) {\n return pCss.parse(str);\n }\n };\n};\n","export default {\n // Prefix identifier that will be used inside storing and loading\n id: 'gjs-',\n\n // Enable/Disable autosaving\n autosave: 1,\n\n // Indicates if load data inside editor after init\n autoload: 1,\n\n // Indicates which storage to use. Available: local | remote\n type: 'local',\n\n // If autosave enabled, indicates how many steps (general changes to structure)\n // need to be done before save. Useful with remoteStorage to reduce remote calls\n stepsBeforeSave: 1,\n\n //Enable/Disable components model (JSON format)\n storeComponents: 1,\n\n //Enable/Disable styles model (JSON format)\n storeStyles: 1,\n\n //Enable/Disable saving HTML template\n storeHtml: 1,\n\n //Enable/Disable saving CSS template\n storeCss: 1,\n\n // ONLY FOR LOCAL STORAGE\n // If enabled, checks if browser supports Local Storage\n checkLocal: 1,\n\n // ONLY FOR REMOTE STORAGE\n // Custom parameters to pass with the remote storage request, eg. csrf token\n params: {},\n\n // Custom headers for the remote storage request\n headers: {},\n\n // Endpoint where to save all stuff\n urlStore: '',\n\n // Endpoint where to fetch data\n urlLoad: '',\n\n //Callback before request\n beforeSend(jqXHR, settings) {},\n\n //Callback after request\n onComplete(jqXHR, status) {},\n\n // set contentType paramater of $.ajax\n // true: application/json; charset=utf-8'\n // false: 'x-www-form-urlencoded'\n contentTypeJson: true,\n\n credentials: 'include',\n\n // Pass custom options to fetch API (remote storage)\n // You can pass a simple object: { someOption: 'someValue' }\n // or a function wich returns and object to add:\n // currentOpts => {\n // return currentOpts.method === 'post' ? { method: 'patch' } : {};\n // }\n fetchOptions: ''\n};\n","import Backbone from 'backbone';\n\nexport default Backbone.Model.extend({\n defaults: {\n checkLocal: true\n },\n\n /**\n * @private\n */\n store(data, clb) {\n this.checkStorageEnvironment();\n\n for (var key in data) localStorage.setItem(key, data[key]);\n\n if (typeof clb == 'function') {\n clb();\n }\n },\n\n /**\n * @private\n */\n load(keys, clb) {\n this.checkStorageEnvironment();\n var result = {};\n\n for (var i = 0, len = keys.length; i < len; i++) {\n var value = localStorage.getItem(keys[i]);\n if (value) result[keys[i]] = value;\n }\n\n if (typeof clb == 'function') {\n clb(result);\n }\n\n return result;\n },\n\n /**\n * @private\n */\n remove(keys) {\n this.checkStorageEnvironment();\n\n for (var i = 0, len = keys.length; i < len; i++)\n localStorage.removeItem(keys[i]);\n },\n\n /**\n * Check storage environment\n * @private\n * */\n checkStorageEnvironment() {\n if (this.get('checkLocal') && !localStorage)\n console.warn(\"Your browser doesn't support localStorage\");\n }\n});\n","import Backbone from 'backbone';\nimport fetch from 'utils/fetch';\nimport { isUndefined, isFunction } from 'underscore';\n\nexport default Backbone.Model.extend({\n fetch,\n\n defaults: {\n urlStore: '',\n urlLoad: '',\n params: {},\n beforeSend() {},\n onComplete() {},\n contentTypeJson: false,\n credentials: 'include',\n fetchOptions: ''\n },\n\n /**\n * Triggered before the request is started\n * @private\n */\n onStart() {\n const em = this.get('em');\n const before = this.get('beforeSend');\n before && before();\n },\n\n /**\n * Triggered on request error\n * @param {Object} err Error\n * @param {Function} [clbErr] Error callback\n * @private\n */\n onError(err, clbErr) {\n if (clbErr) {\n clbErr(err);\n } else {\n const em = this.get('em');\n console.error(err);\n em && em.trigger('storage:error', err);\n }\n },\n\n /**\n * Triggered on request response\n * @param {string} text Response text\n * @private\n */\n onResponse(text, clb) {\n const em = this.get('em');\n const complete = this.get('onComplete');\n const typeJson = this.get('contentTypeJson');\n const parsable = text && typeof text === 'string';\n const res = typeJson && parsable ? JSON.parse(text) : text;\n complete && complete(res);\n clb && clb(res);\n em && em.trigger('storage:response', res);\n },\n\n store(data, clb, clbErr) {\n const body = {};\n\n for (let key in data) {\n body[key] = data[key];\n }\n\n this.request(this.get('urlStore'), { body }, clb, clbErr);\n },\n\n load(keys, clb, clbErr) {\n this.request(this.get('urlLoad'), { method: 'get' }, clb, clbErr);\n },\n\n /**\n * Execute remote request\n * @param {string} url Url\n * @param {Object} [opts={}] Options\n * @param {Function} [clb=null] Callback\n * @param {Function} [clbErr=null] Error callback\n * @private\n */\n request(url, opts = {}, clb = null, clbErr = null) {\n const typeJson = this.get('contentTypeJson');\n const headers = this.get('headers') || {};\n const params = this.get('params');\n const reqHead = 'X-Requested-With';\n const typeHead = 'Content-Type';\n const bodyObj = opts.body || {};\n let fetchOptions;\n let body;\n\n for (let param in params) {\n bodyObj[param] = params[param];\n }\n\n if (isUndefined(headers[reqHead])) {\n headers[reqHead] = 'XMLHttpRequest';\n }\n\n // With `fetch`, have to send FormData without any 'Content-Type'\n // https://stackoverflow.com/questions/39280438/fetch-missing-boundary-in-multipart-form-data-post\n\n if (isUndefined(headers[typeHead]) && typeJson) {\n headers[typeHead] = 'application/json; charset=utf-8';\n }\n\n if (typeJson) {\n body = JSON.stringify(bodyObj);\n } else {\n body = new FormData();\n\n for (let bodyKey in bodyObj) {\n body.append(bodyKey, bodyObj[bodyKey]);\n }\n }\n fetchOptions = {\n method: opts.method || 'post',\n credentials: this.get('credentials'),\n headers\n };\n\n // Body should only be included on POST method\n if (fetchOptions.method === 'post') {\n fetchOptions.body = body;\n }\n\n const fetchOpts = this.get('fetchOptions') || {};\n const addOpts = isFunction(fetchOpts)\n ? fetchOpts(fetchOptions)\n : fetchOptions;\n\n this.onStart();\n this.fetch(url, {\n ...fetchOptions,\n ...(addOpts || {})\n })\n .then(res =>\n ((res.status / 200) | 0) == 1\n ? res.text()\n : res.text().then(text => Promise.reject(text))\n )\n .then(text => this.onResponse(text, clb))\n .catch(err => this.onError(err, clbErr));\n }\n});\n","/**\n * You can customize the initial state of the module from the editor initialization, by passing the following [Configuration Object](https://github.com/artf/grapesjs/blob/master/src/storage_manager/config/config.js)\n * ```js\n * const editor = grapesjs.init({\n * storageManager: {\n * // options\n * }\n * })\n * ```\n *\n * Once the editor is instantiated you can use its API. Before using these methods you should get the module from the instance\n *\n * ```js\n * const storageManager = editor.StorageManager;\n * ```\n *\n * * [getConfig](#getconfig)\n * * [isAutosave](#isautosave)\n * * [setAutosave](#setautosave)\n * * [getStepsBeforeSave](#getstepsbeforesave)\n * * [setStepsBeforeSave](#setstepsbeforesave)\n * * [setStepsBeforeSave](#setstepsbeforesave)\n * * [getStorages](#getstorages)\n * * [getCurrent](#getcurrent)\n * * [getCurrentStorage](#getcurrentstorage)\n * * [setCurrent](#setcurrent)\n * * [add](#add)\n * * [get](#get)\n * * [store](#store)\n * * [load](#load)\n *\n * @module StorageManager\n */\n\nimport defaults from './config/config';\nimport LocalStorage from './model/LocalStorage';\nimport RemoteStorage from './model/RemoteStorage';\n\nexport default () => {\n var c = {};\n let em;\n var storages = {};\n var defaultStorages = {};\n const eventStart = 'storage:start';\n const eventEnd = 'storage:end';\n const eventError = 'storage:error';\n\n return {\n /**\n * Name of the module\n * @type {String}\n * @private\n */\n name: 'StorageManager',\n\n /**\n * Initialize module. Automatically called with a new instance of the editor\n * @param {Object} config Configurations\n * @param {string} [config.id='gjs-'] The prefix for the fields, useful to differentiate storing/loading\n * with multiple editors on the same page. For example, in local storage, the item of HTML will be saved like 'gjs-html'\n * @param {Boolean} [config.autosave=true] Indicates if autosave mode is enabled, works in conjunction with stepsBeforeSave\n * @param {number} [config.stepsBeforeSave=1] If autosave enabled, indicates how many steps/changes are necessary\n * before autosave is triggered\n * @param {string} [config.type='local'] Default storage type. Available: 'local' | 'remote' | ''(do not store)\n * @private\n * @example\n * ...\n * {\n * autosave: false,\n * type: 'remote',\n * }\n * ...\n */\n init(config = {}) {\n c = { ...defaults, ...config };\n em = c.em;\n if (c._disable) c.type = 0;\n defaultStorages.remote = new RemoteStorage(c);\n defaultStorages.local = new LocalStorage(c);\n c.currentStorage = c.type;\n this.loadDefaultProviders().setCurrent(c.type);\n return this;\n },\n\n /**\n * Get configuration object\n * @return {Object}\n * */\n getConfig() {\n return c;\n },\n\n /**\n * Checks if autosave is enabled\n * @return {Boolean}\n * */\n isAutosave() {\n return !!c.autosave;\n },\n\n /**\n * Set autosave value\n * @param {Boolean} v\n * @return {this}\n * */\n setAutosave(v) {\n c.autosave = !!v;\n return this;\n },\n\n /**\n * Returns number of steps required before trigger autosave\n * @return {number}\n * */\n getStepsBeforeSave() {\n return c.stepsBeforeSave;\n },\n\n /**\n * Set steps required before trigger autosave\n * @param {number} v\n * @return {this}\n * */\n setStepsBeforeSave(v) {\n c.stepsBeforeSave = v;\n return this;\n },\n\n /**\n * Add new storage\n * @param {string} id Storage ID\n * @param {Object} storage Storage wrapper\n * @param {Function} storage.load Load method\n * @param {Function} storage.store Store method\n * @return {this}\n * @example\n * storageManager.add('local2', {\n * load: function(keys, clb, clbErr) {\n * var res = {};\n * for (var i = 0, len = keys.length; i < len; i++){\n * var v = localStorage.getItem(keys[i]);\n * if(v) res[keys[i]] = v;\n * }\n * clb(res); // might be called inside some async method\n * // In case of errors...\n * // clbErr('Went something wrong');\n * },\n * store: function(data, clb, clbErr) {\n * for(var key in data)\n * localStorage.setItem(key, data[key]);\n * clb(); // might be called inside some async method\n * }\n * });\n * */\n add(id, storage) {\n storages[id] = storage;\n return this;\n },\n\n /**\n * Returns storage by id\n * @param {string} id Storage ID\n * @return {Object|null}\n * */\n get(id) {\n return storages[id] || null;\n },\n\n /**\n * Returns all storages\n * @return {Array}\n * */\n getStorages() {\n return storages;\n },\n\n /**\n * Returns current storage type\n * @return {string}\n * */\n getCurrent() {\n return c.currentStorage;\n },\n\n /**\n * Set current storage type\n * @param {string} id Storage ID\n * @return {this}\n * */\n setCurrent(id) {\n c.currentStorage = id;\n return this;\n },\n\n /**\n * Store key-value resources in the current storage\n * @param {Object} data Data in key-value format, eg. {item1: value1, item2: value2}\n * @param {Function} clb Callback function\n * @return {Object|null}\n * @example\n * storageManager.store({item1: value1, item2: value2});\n * */\n store(data, clb) {\n const st = this.get(this.getCurrent());\n const toStore = {};\n this.onStart('store', data);\n\n for (let key in data) {\n toStore[c.id + key] = data[key];\n }\n\n return st\n ? st.store(\n toStore,\n res => {\n clb && clb(res);\n this.onEnd('store', res);\n },\n err => {\n this.onError('store', err);\n }\n )\n : null;\n },\n\n /**\n * Load resource from the current storage by keys\n * @param {string|Array} keys Keys to load\n * @param {Function} clb Callback function\n * @example\n * storageManager.load(['item1', 'item2'], res => {\n * // res -> {item1: value1, item2: value2}\n * });\n * storageManager.load('item1', res => {\n * // res -> {item1: value1}\n * });\n * */\n load(keys, clb) {\n var st = this.get(this.getCurrent());\n var keysF = [];\n var result = {};\n\n if (typeof keys === 'string') keys = [keys];\n this.onStart('load', keys);\n\n for (var i = 0, len = keys.length; i < len; i++) {\n keysF.push(c.id + keys[i]);\n }\n\n if (st) {\n st.load(\n keysF,\n res => {\n // Restore keys name\n var reg = new RegExp('^' + c.id + '');\n for (var itemKey in res) {\n var itemKeyR = itemKey.replace(reg, '');\n result[itemKeyR] = res[itemKey];\n }\n\n clb && clb(result);\n this.onEnd('load', result);\n },\n err => {\n clb && clb(result);\n this.onError('load', err);\n }\n );\n } else {\n clb && clb(result);\n }\n },\n\n /**\n * Load default storages\n * @return {this}\n * @private\n * */\n loadDefaultProviders() {\n for (var id in defaultStorages) this.add(id, defaultStorages[id]);\n return this;\n },\n\n /**\n * Get current storage\n * @return {Storage}\n * */\n getCurrentStorage() {\n return this.get(this.getCurrent());\n },\n\n /**\n * On start callback\n * @private\n */\n onStart(ctx, data) {\n if (em) {\n em.trigger(eventStart);\n ctx && em.trigger(`${eventStart}:${ctx}`, data);\n }\n },\n\n /**\n * On end callback\n * @private\n */\n onEnd(ctx, data) {\n if (em) {\n em.trigger(eventEnd);\n ctx && em.trigger(`${eventEnd}:${ctx}`, data);\n }\n },\n\n /**\n * On error callback\n * @private\n */\n onError(ctx, data) {\n if (em) {\n em.trigger(eventError, data);\n ctx && em.trigger(`${eventError}:${ctx}`, data);\n this.onEnd(ctx, data);\n }\n },\n\n /**\n * Check if autoload is possible\n * @return {Boolean}\n * @private\n * */\n canAutoload() {\n const storage = this.getCurrentStorage();\n return storage && this.getConfig().autoload;\n }\n };\n};\n","// The initial version of this RTE was borrowed from https://github.com/jaredreich/pell\n// and adapted to the GrapesJS's need\n\nimport { on, off } from 'utils/mixins';\n\nconst RTE_KEY = '_rte';\n\nconst defActions = {\n bold: {\n name: 'bold',\n icon: 'B',\n attributes: { title: 'Bold' },\n result: rte => rte.exec('bold')\n },\n italic: {\n name: 'italic',\n icon: 'I',\n attributes: { title: 'Italic' },\n result: rte => rte.exec('italic')\n },\n underline: {\n name: 'underline',\n icon: 'U',\n attributes: { title: 'Underline' },\n result: rte => rte.exec('underline')\n },\n strikethrough: {\n name: 'strikethrough',\n icon: 'S',\n attributes: { title: 'Strike-through' },\n result: rte => rte.exec('strikeThrough')\n },\n link: {\n icon: ``,\n name: 'link',\n attributes: {\n style: 'font-size:1.4rem;padding:0 4px 2px;',\n title: 'Link'\n },\n result: rte => {\n const anchor = rte.selection().anchorNode;\n const nextSibling = anchor && anchor.nextSibling;\n if (nextSibling && nextSibling.nodeName == 'A') {\n rte.exec('unlink');\n } else {\n rte.insertHTML(`${rte.selection()}`);\n }\n }\n }\n};\n\nexport default class RichTextEditor {\n constructor(settings = {}) {\n const el = settings.el;\n\n if (el[RTE_KEY]) {\n return el[RTE_KEY];\n }\n\n el[RTE_KEY] = this;\n this.setEl(el);\n this.updateActiveActions = this.updateActiveActions.bind(this);\n\n const settAct = settings.actions || [];\n settAct.forEach((action, i) => {\n if (typeof action === 'string') {\n action = defActions[action];\n } else if (defActions[action.name]) {\n action = { ...defActions[action.name], ...action };\n }\n settAct[i] = action;\n });\n const actions = settAct.length\n ? settAct\n : Object.keys(defActions).map(action => defActions[action]);\n\n settings.classes = {\n ...{\n actionbar: 'actionbar',\n button: 'action',\n active: 'active'\n },\n ...settings.classes\n };\n\n const classes = settings.classes;\n let actionbar = settings.actionbar;\n this.actionbar = actionbar;\n this.settings = settings;\n this.classes = classes;\n this.actions = actions;\n\n if (!actionbar) {\n const actionbarCont = settings.actionbarContainer;\n actionbar = document.createElement('div');\n actionbar.className = classes.actionbar;\n actionbarCont.appendChild(actionbar);\n this.actionbar = actionbar;\n actions.forEach(action => this.addAction(action));\n }\n\n settings.styleWithCSS && this.exec('styleWithCSS');\n this.syncActions();\n\n return this;\n }\n\n setEl(el) {\n this.el = el;\n this.doc = el.ownerDocument;\n }\n\n updateActiveActions() {\n this.getActions().forEach(action => {\n const btn = action.btn;\n const update = action.update;\n const active = this.classes.active;\n const name = action.name;\n const doc = this.doc;\n btn.className = btn.className.replace(active, '').trim();\n\n // doc.queryCommandValue(name) != 'false'\n if (doc.queryCommandSupported(name) && doc.queryCommandState(name)) {\n btn.className += ` ${active}`;\n }\n\n update && update(this, action);\n });\n }\n\n enable() {\n if (this.enabled) {\n return this;\n }\n\n this.actionbarEl().style.display = '';\n this.el.contentEditable = true;\n on(this.el, 'mouseup keyup', this.updateActiveActions);\n this.syncActions();\n this.updateActiveActions();\n this.el.focus();\n this.enabled = 1;\n return this;\n }\n\n disable() {\n this.actionbarEl().style.display = 'none';\n this.el.contentEditable = false;\n off(this.el, 'mouseup keyup', this.updateActiveActions);\n this.enabled = 0;\n return this;\n }\n\n /**\n * Sync actions with the current RTE\n */\n syncActions() {\n this.getActions().forEach(action => {\n const event = action.event || 'click';\n action.btn[`on${event}`] = e => {\n action.result(this, action);\n this.updateActiveActions();\n };\n });\n }\n\n /**\n * Add new action to the actionbar\n * @param {Object} action\n * @param {Object} [opts={}]\n */\n addAction(action, opts = {}) {\n const sync = opts.sync;\n const btn = document.createElement('span');\n const icon = action.icon;\n const attr = action.attributes || {};\n btn.className = this.classes.button;\n action.btn = btn;\n\n for (let key in attr) {\n btn.setAttribute(key, attr[key]);\n }\n\n if (typeof icon == 'string') {\n btn.innerHTML = icon;\n } else {\n btn.appendChild(icon);\n }\n\n this.actionbarEl().appendChild(btn);\n\n if (sync) {\n this.actions.push(action);\n this.syncActions();\n }\n }\n\n /**\n * Get the array of current actions\n * @return {Array}\n */\n getActions() {\n return this.actions;\n }\n\n /**\n * Returns the Selection instance\n * @return {Selection}\n */\n selection() {\n return this.doc.getSelection();\n }\n\n /**\n * Execute the command\n * @param {string} command Command name\n * @param {any} [value=null Command's arguments\n */\n exec(command, value = null) {\n this.doc.execCommand(command, false, value);\n }\n\n /**\n * Get the actionbar element\n * @return {HTMLElement}\n */\n actionbarEl() {\n return this.actionbar;\n }\n\n /**\n * Set custom HTML to the selection, useful as the default 'insertHTML' command\n * doesn't work in the same way on all browsers\n * @param {string} value HTML string\n */\n insertHTML(value) {\n let lastNode;\n const doc = this.doc;\n const sel = doc.getSelection();\n\n if (sel && sel.rangeCount) {\n const node = doc.createElement('div');\n const range = sel.getRangeAt(0);\n range.deleteContents();\n node.innerHTML = value;\n Array.prototype.slice.call(node.childNodes).forEach(nd => {\n range.insertNode(nd);\n lastNode = nd;\n });\n\n sel.removeAllRanges();\n sel.addRange(range);\n this.el.focus();\n }\n }\n}\n","export default {\n stylePrefix: 'rte-',\n\n // If true, moves the toolbar below the element when the top canvas\n // edge is reached\n adjustToolbar: 1,\n\n // Default RTE actions\n actions: ['bold', 'italic', 'underline', 'strikethrough', 'link']\n};\n","/**\n * This module allows to customize the built-in toolbar of the Rich Text Editor and use commands from the [HTML Editing APIs](https://developer.mozilla.org/en-US/docs/Web/API/Document/execCommand).\n * It's highly recommended to keep this toolbar as small as possible, especially from styling commands (eg. 'fontSize') and leave this task to the Style Manager\n *\n * You can customize the initial state of the module from the editor initialization, by passing the following [Configuration Object](https://github.com/artf/grapesjs/blob/master/src/rich_text_editor/config/config.js)\n * ```js\n * const editor = grapesjs.init({\n * richTextEditor: {\n * // options\n * }\n * })\n * ```\n *\n * Once the editor is instantiated you can use its API. Before using these methods you should get the module from the instance\n *\n * ```js\n * const rte = editor.RichTextEditor;\n * ```\n *\n * * [add](#add)\n * * [get](#get)\n * * [getAll](#getall)\n * * [remove](#remove)\n * * [getToolbarEl](#gettoolbarel)\n *\n * @module RichTextEditor\n */\n\nimport RichTextEditor from './model/RichTextEditor';\nimport { on, off } from 'utils/mixins';\nimport defaults from './config/config';\n\nexport default () => {\n let config = {};\n let toolbar, actions, lastEl, globalRte;\n\n const hideToolbar = () => {\n const style = toolbar.style;\n const size = '-1000px';\n style.top = size;\n style.left = size;\n style.display = 'none';\n };\n\n return {\n customRte: null,\n\n /**\n * Name of the module\n * @type {String}\n * @private\n */\n name: 'RichTextEditor',\n\n getConfig() {\n return config;\n },\n\n /**\n * Initialize module. Automatically called with a new instance of the editor\n * @param {Object} opts Options\n * @private\n */\n init(opts = {}) {\n config = {\n ...defaults,\n ...opts\n };\n const ppfx = config.pStylePrefix;\n\n if (ppfx) {\n config.stylePrefix = ppfx + config.stylePrefix;\n }\n\n this.pfx = config.stylePrefix;\n actions = config.actions || [];\n toolbar = document.createElement('div');\n toolbar.className = `${ppfx}rte-toolbar ${ppfx}one-bg`;\n globalRte = this.initRte(document.createElement('div'));\n\n //Avoid closing on toolbar clicking\n on(toolbar, 'mousedown', e => e.stopPropagation());\n return this;\n },\n\n /**\n * Post render callback\n * @param {View} ev\n * @private\n */\n postRender(ev) {\n const canvas = ev.model.get('Canvas');\n toolbar.style.pointerEvents = 'all';\n hideToolbar();\n canvas.getToolsEl().appendChild(toolbar);\n },\n\n /**\n * Init the built-in RTE\n * @param {HTMLElement} el\n * @return {RichTextEditor}\n * @private\n */\n initRte(el) {\n const pfx = this.pfx;\n const actionbarContainer = toolbar;\n const actionbar = this.actionbar;\n const actions = this.actions || config.actions;\n const classes = {\n actionbar: `${pfx}actionbar`,\n button: `${pfx}action`,\n active: `${pfx}active`\n };\n const rte = new RichTextEditor({\n el,\n classes,\n actions,\n actionbar,\n actionbarContainer\n });\n globalRte && globalRte.setEl(el);\n\n if (rte.actionbar) {\n this.actionbar = rte.actionbar;\n }\n\n if (rte.actions) {\n this.actions = rte.actions;\n }\n\n return rte;\n },\n\n /**\n * Add a new action to the built-in RTE toolbar\n * @param {string} name Action name\n * @param {Object} action Action options\n * @example\n * rte.add('bold', {\n * icon: 'B',\n * attributes: {title: 'Bold'},\n * result: rte => rte.exec('bold')\n * });\n * rte.add('link', {\n * icon: document.getElementById('t'),\n * attributes: {title: 'Link',}\n * // Example on it's easy to wrap a selected content\n * result: rte => rte.insertHTML(`${rte.selection()}`)\n * });\n * // An example with fontSize\n * rte.add('fontSize', {\n * icon: ``,\n * // Bind the 'result' on 'change' listener\n * event: 'change',\n * result: (rte, action) => rte.exec('fontSize', action.btn.firstChild.value),\n * // Callback on any input change (mousedown, keydown, etc..)\n * update: (rte, action) => {\n * const value = rte.doc.queryCommandValue(action.name);\n * if (value != 'false') { // value is a string\n * action.btn.firstChild.value = value;\n * }\n * }\n * })\n */\n add(name, action = {}) {\n action.name = name;\n globalRte.addAction(action, { sync: 1 });\n },\n\n /**\n * Get the action by its name\n * @param {string} name Action name\n * @return {Object}\n * @example\n * const action = rte.get('bold');\n * // {name: 'bold', ...}\n */\n get(name) {\n let result;\n globalRte.getActions().forEach(action => {\n if (action.name == name) {\n result = action;\n }\n });\n return result;\n },\n\n /**\n * Get all actions\n * @return {Array}\n */\n getAll() {\n return globalRte.getActions();\n },\n\n /**\n * Remove the action from the toolbar\n * @param {string} name\n * @return {Object} Removed action\n * @example\n * const action = rte.remove('bold');\n * // {name: 'bold', ...}\n */\n remove(name) {\n const actions = this.getAll();\n const action = this.get(name);\n\n if (action) {\n const btn = action.btn;\n const index = actions.indexOf(action);\n btn.parentNode.removeChild(btn);\n actions.splice(index, 1);\n }\n\n return action;\n },\n\n /**\n * Get the toolbar element\n * @return {HTMLElement}\n */\n getToolbarEl() {\n return toolbar;\n },\n\n /**\n * Triggered when the offset of the editor is changed\n * @private\n */\n updatePosition() {\n const un = 'px';\n const canvas = config.em.get('Canvas');\n const pos = canvas.getTargetToElementDim(toolbar, lastEl, {\n event: 'rteToolbarPosUpdate'\n });\n\n if (pos) {\n if (config.adjustToolbar) {\n const frameOffset = canvas.getCanvasView().getFrameOffset();\n // Move the toolbar down when the top canvas edge is reached\n if (\n pos.top <= pos.canvasTop &&\n !(pos.elementHeight + pos.targetHeight >= frameOffset.height)\n ) {\n pos.top = pos.elementTop + pos.elementHeight;\n }\n }\n\n const toolbarStyle = toolbar.style;\n toolbarStyle.top = pos.top + un;\n toolbarStyle.left = pos.left + un;\n }\n },\n\n /**\n * Enable rich text editor on the element\n * @param {View} view Component view\n * @param {Object} rte The instance of already defined RTE\n * @private\n * */\n enable(view, rte) {\n lastEl = view.el;\n const em = config.em;\n const el = view.getChildrenContainer();\n const customRte = this.customRte;\n\n toolbar.style.display = '';\n rte = customRte ? customRte.enable(el, rte) : this.initRte(el).enable();\n\n if (em) {\n setTimeout(this.updatePosition.bind(this), 0);\n const event = 'change:canvasOffset canvasScroll';\n em.off(event, this.updatePosition, this);\n em.on(event, this.updatePosition, this);\n em.trigger('rte:enable', view, rte);\n }\n\n return rte;\n },\n\n /**\n * Unbind rich text editor from the element\n * @param {View} view\n * @param {Object} rte The instance of already defined RTE\n * @private\n * */\n disable(view, rte) {\n const em = config.em;\n const customRte = this.customRte;\n var el = view.getChildrenContainer();\n\n if (customRte) {\n customRte.disable(el, rte);\n } else {\n rte && rte.disable();\n }\n\n hideToolbar();\n em && em.trigger('rte:disable', view, rte);\n }\n };\n};\n","import Backbone from 'backbone';\nimport {\n isString,\n isFunction,\n isArray,\n result,\n each,\n bindAll\n} from 'underscore';\nimport {\n on,\n off,\n matches,\n getElement,\n getPointerEvent,\n isTextNode,\n getModel\n} from 'utils/mixins';\nconst $ = Backbone.$;\n\nexport default Backbone.View.extend({\n initialize(opt) {\n this.opt = opt || {};\n bindAll(\n this,\n 'startSort',\n 'onMove',\n 'endMove',\n 'rollback',\n 'updateOffset',\n 'moveDragHelper'\n );\n var o = opt || {};\n this.elT = 0;\n this.elL = 0;\n this.borderOffset = o.borderOffset || 10;\n\n var el = o.container;\n this.el = typeof el === 'string' ? document.querySelector(el) : el;\n this.$el = $(this.el);\n\n this.containerSel = o.containerSel || 'div';\n this.itemSel = o.itemSel || 'div';\n this.draggable = o.draggable || true;\n this.nested = o.nested || 0;\n this.pfx = o.pfx || '';\n this.ppfx = o.ppfx || '';\n this.freezeClass = o.freezeClass || this.pfx + 'freezed';\n this.onStart = o.onStart || '';\n this.onEndMove = o.onEndMove || '';\n this.direction = o.direction || 'v'; // v (vertical), h (horizontal), a (auto)\n this.onMoveClb = o.onMove || '';\n this.relative = o.relative || 0;\n this.ignoreViewChildren = o.ignoreViewChildren || 0;\n this.ignoreModels = o.ignoreModels || 0;\n this.plh = o.placer || '';\n // Frame offset\n this.wmargin = o.wmargin || 0;\n this.offTop = o.offsetTop || 0;\n this.offLeft = o.offsetLeft || 0;\n this.document = o.document || document;\n this.$document = $(this.document);\n this.dropContent = null;\n this.em = o.em || '';\n this.dragHelper = null;\n this.canvasRelative = o.canvasRelative || 0;\n this.selectOnEnd = !o.avoidSelectOnEnd;\n this.scale = o.scale;\n this.activeTextModel = null;\n\n if (this.em && this.em.on) {\n this.em.on('change:canvasOffset', this.updateOffset);\n this.updateOffset();\n }\n },\n\n getScale() {\n return result(this, scale) || 1;\n },\n\n getContainerEl() {\n if (!this.el) {\n var el = this.opt.container;\n this.el = typeof el === 'string' ? document.querySelector(el) : el;\n this.$el = $(this.el);\n }\n return this.el;\n },\n\n getDocuments() {\n const em = this.em;\n const canvasDoc = em && em.get('Canvas').getBody().ownerDocument;\n const docs = [document];\n canvasDoc && docs.push(canvasDoc);\n return docs;\n },\n\n /**\n * Triggered when the offset of the editro is changed\n */\n updateOffset() {\n const offset = this.em.get('canvasOffset') || {};\n this.offTop = offset.top;\n this.offLeft = offset.left;\n },\n\n /**\n * Set content to drop\n * @param {String|Object} content\n */\n setDropContent(content) {\n this.dropModel = null;\n this.dropContent = content;\n },\n\n updateTextViewCursorPosition(e) {\n const Canvas = this.em.get('Canvas');\n const targetDoc = Canvas.getDocument();\n let range = null;\n\n if (targetDoc.caretRangeFromPoint) {\n // Chrome\n const poiner = getPointerEvent(e);\n range = targetDoc.caretRangeFromPoint(poiner.clientX, poiner.clientY);\n } else if (e.rangeParent) {\n // Firefox\n range = targetDoc.createRange();\n range.setStart(e.rangeParent, e.rangeOffset);\n }\n\n const sel = Canvas.getWindow().getSelection();\n Canvas.getFrameEl().focus();\n sel.removeAllRanges();\n range && sel.addRange(range);\n },\n\n setContentEditable(model, mode) {\n if (model) {\n const el = model.getEl();\n if (el.contentEditable != mode) el.contentEditable = mode;\n }\n },\n\n /**\n * Toggle cursor while sorting\n * @param {Boolean} active\n */\n toggleSortCursor(active) {\n var em = this.em;\n var body = document.body;\n var pfx = this.ppfx || this.pfx;\n var sortCls = pfx + 'grabbing';\n var emBody = em ? em.get('Canvas').getBody() : '';\n\n // Avoid updating body className as it causes a huge repaint\n // Noticeable with \"fast\" drag of blocks\n if (active) {\n em && em.get('Canvas').startAutoscroll();\n //body.className += ' ' + sortCls;\n //if (em) emBody.className += ' ' + sortCls;\n } else {\n em && em.get('Canvas').stopAutoscroll();\n //body.className = body.className.replace(sortCls, '').trim();\n //if(em) emBody.className = emBody.className.replace(sortCls, '').trim();\n }\n },\n\n /**\n * Set drag helper\n * @param {HTMLElement} el\n * @param {Event} event\n */\n setDragHelper(el, event) {\n const ev = event || '';\n const clonedEl = el.cloneNode(1);\n const rect = el.getBoundingClientRect();\n const computed = getComputedStyle(el);\n let style = '';\n\n for (var i = 0; i < computed.length; i++) {\n const prop = computed[i];\n style += `${prop}:${computed.getPropertyValue(prop)};`;\n }\n\n document.body.appendChild(clonedEl);\n clonedEl.className += ` ${this.pfx}bdrag`;\n clonedEl.setAttribute('style', style);\n this.dragHelper = clonedEl;\n clonedEl.style.width = `${rect.width}px`;\n clonedEl.style.height = `${rect.height}px`;\n ev && this.moveDragHelper(ev);\n\n // Listen mouse move events\n if (this.em) {\n $(this.em.get('Canvas').getBody().ownerDocument)\n .off('mousemove', this.moveDragHelper)\n .on('mousemove', this.moveDragHelper);\n }\n $(document)\n .off('mousemove', this.moveDragHelper)\n .on('mousemove', this.moveDragHelper);\n },\n\n /**\n * Update the position of the helper\n * @param {Event} e\n */\n moveDragHelper(e) {\n const doc = e.target.ownerDocument;\n\n if (!this.dragHelper || !doc) {\n return;\n }\n\n let posY = e.pageY;\n let posX = e.pageX;\n let addTop = 0;\n let addLeft = 0;\n const window = doc.defaultView || doc.parentWindow;\n const frame = window.frameElement;\n const dragHelperStyle = this.dragHelper.style;\n\n // If frame is present that means mouse has moved over the editor's canvas,\n // which is rendered inside the iframe and the mouse move event comes from\n // the iframe, not the parent window. Mouse position relative to the frame's\n // parent window needs to account for the frame's position relative to the\n // parent window.\n if (frame) {\n const frameRect = frame.getBoundingClientRect();\n addTop = frameRect.top + document.documentElement.scrollTop;\n addLeft = frameRect.left + document.documentElement.scrollLeft;\n posY = e.clientY;\n posX = e.clientX;\n }\n\n dragHelperStyle.top = posY + addTop + 'px';\n dragHelperStyle.left = posX + addLeft + 'px';\n },\n\n /**\n * Returns true if the element matches with selector\n * @param {Element} el\n * @param {String} selector\n * @return {Boolean}\n */\n matches(el, selector, useBody) {\n return matches.call(el, selector);\n },\n\n /**\n * Closest parent\n * @param {Element} el\n * @param {String} selector\n * @return {Element|null}\n */\n closest(el, selector) {\n if (!el) return;\n var elem = el.parentNode;\n while (elem && elem.nodeType === 1) {\n if (this.matches(elem, selector)) return elem;\n elem = elem.parentNode;\n }\n return null;\n },\n\n /**\n * Get the offset of the element\n * @param {HTMLElement} el\n * @return {Object}\n */\n offset(el) {\n var rect = el.getBoundingClientRect();\n return {\n top: rect.top + document.body.scrollTop,\n left: rect.left + document.body.scrollLeft\n };\n },\n\n /**\n * Create placeholder\n * @return {HTMLElement}\n */\n createPlaceholder() {\n var pfx = this.pfx;\n var el = document.createElement('div');\n var ins = document.createElement('div');\n el.className = pfx + 'placeholder';\n el.style.display = 'none';\n el.style['pointer-events'] = 'none';\n ins.className = pfx + 'placeholder-int';\n el.appendChild(ins);\n return el;\n },\n\n /**\n * Picking component to move\n * @param {HTMLElement} src\n * */\n startSort(src) {\n const em = this.em;\n const itemSel = this.itemSel;\n const contSel = this.containerSel;\n const container = this.getContainerEl();\n const docs = this.getDocuments();\n const onStart = this.onStart;\n let srcModel;\n let plh = this.plh;\n this.dropModel = null;\n this.moved = 0;\n\n // Check if the start element is a valid one, if not get the\n // closest valid one\n if (src && !this.matches(src, `${itemSel}, ${contSel}`)) {\n src = this.closest(src, itemSel);\n }\n\n this.eV = src;\n\n // Create placeholder if not yet exists\n if (!plh) {\n plh = this.createPlaceholder();\n container.appendChild(plh);\n this.plh = plh;\n }\n\n if (src) {\n srcModel = this.getSourceModel(src);\n srcModel && srcModel.set && srcModel.set('status', 'freezed');\n }\n\n on(container, 'mousemove dragover', this.onMove);\n on(docs, 'mouseup dragend touchend', this.endMove);\n on(docs, 'keydown', this.rollback);\n onStart && onStart();\n\n // Avoid strange effects on dragging\n em && em.clearSelection();\n this.toggleSortCursor(1);\n\n em && em.trigger('sorter:drag:start', src, srcModel);\n },\n\n /**\n * Get the model from HTMLElement target\n * @return {Model|null}\n */\n getTargetModel(el) {\n let elem = el || this.target;\n return $(elem).data('model');\n },\n\n /**\n * Get the model of the current source element (element to drag)\n * @return {Model}\n */\n getSourceModel(source, { target, avoidChildren = 1 } = {}) {\n const { em, eV } = this;\n const src = source || eV;\n let { dropModel, dropContent } = this;\n const isTextable = src =>\n src &&\n target &&\n src.opt &&\n src.opt.avoidChildren &&\n this.isTextableActive(src, target);\n\n if (dropContent && em) {\n if (isTextable(dropModel)) {\n dropModel = null;\n }\n\n if (!dropModel) {\n const comps = em.get('DomComponents').getComponents();\n const opts = {\n avoidChildren,\n avoidStore: 1,\n avoidUpdateStyle: 1\n };\n const tempModel = comps.add(dropContent, { ...opts, temporary: 1 });\n dropModel = comps.remove(tempModel, opts);\n dropModel = dropModel instanceof Array ? dropModel[0] : dropModel;\n this.dropModel = dropModel;\n\n if (isTextable(dropModel)) {\n return this.getSourceModel(src, { target, avoidChildren: 0 });\n }\n }\n\n return dropModel;\n }\n\n return src && $(src).data('model');\n },\n\n /**\n * Highlight target\n * @param {Model|null} model\n */\n selectTargetModel(model) {\n if (model instanceof Backbone.Collection) {\n return;\n }\n\n var prevModel = this.targetModel;\n if (prevModel) {\n prevModel.set('status', '');\n }\n\n if (model && model.set) {\n model.set('status', 'selected-parent');\n this.targetModel = model;\n }\n },\n\n /**\n * During move\n * @param {Event} e\n * */\n onMove(e) {\n const ev = e;\n const { em, onMoveClb, plh } = this;\n this.moved = 1;\n\n // Turn placeholder visibile\n var dsp = plh.style.display;\n if (!dsp || dsp === 'none') plh.style.display = 'block';\n\n // Cache all necessary positions\n var eO = this.offset(this.el);\n this.elT = this.wmargin ? Math.abs(eO.top) : eO.top;\n this.elL = this.wmargin ? Math.abs(eO.left) : eO.left;\n var rY = e.pageY - this.elT + this.el.scrollTop;\n var rX = e.pageX - this.elL + this.el.scrollLeft;\n\n if (this.canvasRelative && em) {\n var mousePos = em.get('Canvas').getMouseRelativeCanvas(e);\n rX = mousePos.x;\n rY = mousePos.y;\n }\n\n this.rX = rX;\n this.rY = rY;\n this.eventMove = e;\n\n //var targetNew = this.getTargetFromEl(e.target);\n const sourceModel = this.getSourceModel();\n const dims = this.dimsFromTarget(e.target, rX, rY);\n const target = this.target;\n const targetModel = this.getTargetModel(target);\n this.selectTargetModel(targetModel);\n if (!targetModel) plh.style.display = 'none';\n\n this.lastDims = dims;\n const pos = this.findPosition(dims, rX, rY);\n\n if (this.isTextableActive(sourceModel, targetModel)) {\n this.activeTextModel = targetModel;\n this.setContentEditable(targetModel, true);\n\n plh.style.display = 'none';\n this.lastPos = pos;\n this.updateTextViewCursorPosition(ev);\n } else {\n this.disableTextable();\n this.activeTextModel = null;\n\n // If there is a significant changes with the pointer\n if (\n !this.lastPos ||\n (this.lastPos.index != pos.index || this.lastPos.method != pos.method)\n ) {\n this.movePlaceholder(this.plh, dims, pos, this.prevTargetDim);\n if (!this.$plh) this.$plh = $(this.plh);\n\n // With canvasRelative the offset is calculated automatically for\n // each element\n if (!this.canvasRelative) {\n if (this.offTop) this.$plh.css('top', '+=' + this.offTop + 'px');\n if (this.offLeft) this.$plh.css('left', '+=' + this.offLeft + 'px');\n }\n\n this.lastPos = pos;\n }\n }\n\n isFunction(onMoveClb) && onMoveClb(e);\n\n em &&\n em.trigger('sorter:drag', {\n target,\n targetModel,\n sourceModel,\n dims,\n pos,\n x: rX,\n y: rY\n });\n },\n\n isTextableActive(src, trg) {\n return src && src.get && src.get('textable') && trg && trg.is('text');\n },\n\n disableTextable() {\n const { activeTextModel } = this;\n activeTextModel && activeTextModel.getView().disableEditing();\n },\n\n /**\n * Returns true if the elements is in flow, so is not in flow where\n * for example the component is with float:left\n * @param {HTMLElement} el\n * @param {HTMLElement} parent\n * @return {Boolean}\n * @private\n * */\n isInFlow(el, parent) {\n if (!el) return false;\n\n parent = parent || document.body;\n var ch = -1,\n h;\n var elem = el;\n h = elem.offsetHeight;\n if (/*h < ch || */ !this.styleInFlow(elem, parent)) return false;\n else return true;\n },\n\n /**\n * Check if el has style to be in flow\n * @param {HTMLElement} el\n * @param {HTMLElement} parent\n * @return {Boolean}\n * @private\n */\n styleInFlow(el, parent) {\n if (isTextNode(el)) return;\n const style = el.style || {};\n const $el = $(el);\n const $parent = parent && $(parent);\n\n if (style.overflow && style.overflow !== 'visible') return;\n if ($el.css('float') !== 'none') return;\n if (\n $parent &&\n $parent.css('display') == 'flex' &&\n $parent.css('flex-direction') !== 'column'\n )\n return;\n switch (style.position) {\n case 'static':\n case 'relative':\n case '':\n break;\n default:\n return;\n }\n switch (el.tagName) {\n case 'TR':\n case 'TBODY':\n case 'THEAD':\n case 'TFOOT':\n return true;\n }\n switch ($el.css('display')) {\n case 'block':\n case 'list-item':\n case 'table':\n case 'flex':\n return true;\n }\n return;\n },\n\n /**\n * Check if the target is valid with the actual source\n * @param {HTMLElement} trg\n * @return {Boolean}\n */\n validTarget(trg, src) {\n const trgModel = this.getTargetModel(trg);\n const srcModel = this.getSourceModel(src, { target: trgModel });\n src = srcModel && srcModel.view && srcModel.view.el;\n trg = trgModel && trgModel.view && trgModel.view.el;\n let result = {\n valid: true,\n src,\n srcModel,\n trg,\n trgModel\n };\n\n if (!src || !trg) {\n result.valid = false;\n return result;\n }\n\n // check if the source is draggable in target\n let draggable = srcModel.get('draggable');\n draggable = draggable instanceof Array ? draggable.join(', ') : draggable;\n result.dragInfo = draggable;\n draggable = isString(draggable) ? this.matches(trg, draggable) : draggable;\n result.draggable = draggable;\n\n // Check if the target could accept the source\n let droppable = trgModel.get('droppable');\n droppable = droppable instanceof Backbone.Collection ? 1 : droppable;\n droppable = droppable instanceof Array ? droppable.join(', ') : droppable;\n result.dropInfo = droppable;\n droppable = isString(droppable) ? this.matches(src, droppable) : droppable;\n droppable =\n draggable && this.isTextableActive(srcModel, trgModel) ? 1 : droppable;\n result.droppable = droppable;\n\n if (!droppable || !draggable) {\n result.valid = false;\n }\n\n return result;\n },\n\n /**\n * Get dimensions of nodes relative to the coordinates\n * @param {HTMLElement} target\n * @param {number} rX Relative X position\n * @param {number} rY Relative Y position\n * @return {Array}\n */\n dimsFromTarget(target, rX, rY) {\n const em = this.em;\n var dims = [];\n\n if (!target) {\n return dims;\n }\n\n // Select the first valuable target\n if (!this.matches(target, `${this.itemSel}, ${this.containerSel}`)) {\n target = this.closest(target, this.itemSel);\n }\n\n // If draggable is an array the target will be one of those\n if (this.draggable instanceof Array) {\n target = this.closest(target, this.draggable.join(','));\n }\n\n if (!target) {\n return dims;\n }\n\n // Check if the target is different from the previous one\n if (this.prevTarget && this.prevTarget != target) {\n this.prevTarget = null;\n }\n\n // New target found\n if (!this.prevTarget) {\n this.targetP = this.closest(target, this.containerSel);\n\n // Check if the source is valid with the target\n let validResult = this.validTarget(target);\n em && em.trigger('sorter:drag:validation', validResult);\n\n if (!validResult.valid && this.targetP) {\n return this.dimsFromTarget(this.targetP, rX, rY);\n }\n\n this.prevTarget = target;\n this.prevTargetDim = this.getDim(target);\n this.cacheDimsP = this.getChildrenDim(this.targetP);\n this.cacheDims = this.getChildrenDim(target);\n }\n\n // If the target is the previous one will return the cached dims\n if (this.prevTarget == target) dims = this.cacheDims;\n\n // Target when I will drop element to sort\n this.target = this.prevTarget;\n\n // Generally, on any new target the poiner enters inside its area and\n // triggers nearBorders(), so have to take care of this\n if (\n this.nearBorders(this.prevTargetDim, rX, rY) ||\n (!this.nested && !this.cacheDims.length)\n ) {\n const targetParent = this.targetP;\n\n if (targetParent && this.validTarget(targetParent).valid) {\n dims = this.cacheDimsP;\n this.target = targetParent;\n }\n }\n\n this.lastPos = null;\n return dims;\n },\n\n /**\n * Get valid target from element\n * This method should replace dimsFromTarget()\n * @param {HTMLElement} el\n * @return {HTMLElement}\n */\n getTargetFromEl(el) {\n let target = el;\n let targetParent;\n let targetPrev = this.targetPrev;\n const em = this.em;\n const containerSel = this.containerSel;\n const itemSel = this.itemSel;\n\n // Select the first valuable target\n if (!this.matches(target, `${itemSel}, ${containerSel}`)) {\n target = this.closest(target, itemSel);\n }\n\n // If draggable is an array the target will be one of those\n // TODO check if this options is used somewhere\n if (this.draggable instanceof Array) {\n target = this.closest(target, this.draggable.join(','));\n }\n\n // Check if the target is different from the previous one\n if (targetPrev && targetPrev != target) {\n this.targetPrev = '';\n }\n\n // New target found\n if (!this.targetPrev) {\n targetParent = this.closest(target, containerSel);\n\n // If the current target is not valid (src/trg reasons) try with\n // the parent one (if exists)\n const validResult = this.validTarget(target);\n em && em.trigger('sorter:drag:validation', validResult);\n\n if (!validResult.valid && targetParent) {\n return this.getTargetFromEl(targetParent);\n }\n\n this.targetPrev = target;\n }\n\n // Generally, on any new target the poiner enters inside its area and\n // triggers nearBorders(), so have to take care of this\n if (this.nearElBorders(target)) {\n targetParent = this.closest(target, containerSel);\n\n if (targetParent && this.validTarget(targetParent).valid) {\n target = targetParent;\n }\n }\n\n return target;\n },\n\n /**\n * Check if the current pointer is neare to element borders\n * @return {Boolen}\n */\n nearElBorders(el) {\n const off = 10;\n const rect = el.getBoundingClientRect();\n const body = el.ownerDocument.body;\n const { x, y } = this.getCurrentPos();\n const top = rect.top + body.scrollTop;\n const left = rect.left + body.scrollLeft;\n const width = rect.width;\n const height = rect.height;\n\n if (\n y < top + off || // near top edge\n y > top + height - off || // near bottom edge\n x < left + off || // near left edge\n x > left + width - off // near right edge\n ) {\n return 1;\n }\n },\n\n getCurrentPos() {\n const ev = this.eventMove;\n const x = ev.pageX || 0;\n const y = ev.pageY || 0;\n return { x, y };\n },\n\n /**\n * Returns dimensions and positions about the element\n * @param {HTMLElement} el\n * @return {Array}\n */\n getDim(el) {\n const { em, canvasRelative } = this;\n var top, left, height, width;\n\n if (canvasRelative && em) {\n const canvas = em.get('Canvas');\n const pos = canvas.getElementPos(el);\n const elOffsets = canvas.getElementOffsets(el);\n top = pos.top - elOffsets.marginTop;\n left = pos.left - elOffsets.marginLeft;\n height = pos.height + elOffsets.marginTop + elOffsets.marginBottom;\n width = pos.width + elOffsets.marginLeft + elOffsets.marginRight;\n } else {\n var o = this.offset(el);\n top = this.relative\n ? el.offsetTop\n : o.top - (this.wmargin ? -1 : 1) * this.elT;\n left = this.relative\n ? el.offsetLeft\n : o.left - (this.wmargin ? -1 : 1) * this.elL;\n height = el.offsetHeight;\n width = el.offsetWidth;\n }\n\n return [top, left, height, width];\n },\n\n /**\n * Get children dimensions\n * @param {HTMLELement} el Element root\n * @retun {Array}\n * */\n getChildrenDim(trg) {\n const dims = [];\n if (!trg) return dims;\n\n // Get children based on getChildrenContainer\n const trgModel = this.getTargetModel(trg);\n if (trgModel && trgModel.view && !this.ignoreViewChildren) {\n trg = trgModel.view.getChildrenContainer();\n }\n\n each(trg.children, (el, i) => {\n const model = getModel(el, $);\n const elIndex = model && model.index ? model.index() : i;\n\n if (!isTextNode(el) && !this.matches(el, this.itemSel)) {\n return;\n }\n\n const dim = this.getDim(el);\n let dir = this.direction;\n\n if (dir == 'v') dir = true;\n else if (dir == 'h') dir = false;\n else dir = this.isInFlow(el, trg);\n\n dim.push(dir, el, elIndex);\n dims.push(dim);\n });\n\n return dims;\n },\n\n /**\n * Check if the coordinates are near to the borders\n * @param {Array} dim\n * @param {number} rX Relative X position\n * @param {number} rY Relative Y position\n * @return {Boolean}\n * */\n nearBorders(dim, rX, rY) {\n var result = 0;\n var off = this.borderOffset;\n var x = rX || 0;\n var y = rY || 0;\n var t = dim[0];\n var l = dim[1];\n var h = dim[2];\n var w = dim[3];\n if (t + off > y || y > t + h - off || l + off > x || x > l + w - off)\n result = 1;\n\n return !!result;\n },\n\n /**\n * Find the position based on passed dimensions and coordinates\n * @param {Array} dims Dimensions of nodes to parse\n * @param {number} posX X coordindate\n * @param {number} posY Y coordindate\n * @retun {Object}\n * */\n findPosition(dims, posX, posY) {\n var result = { index: 0, indexEl: 0, method: 'before' };\n var leftLimit = 0,\n xLimit = 0,\n dimRight = 0,\n yLimit = 0,\n xCenter = 0,\n yCenter = 0,\n dimDown = 0,\n dim = 0;\n // Each dim is: Top, Left, Height, Width\n for (var i = 0, len = dims.length; i < len; i++) {\n dim = dims[i];\n // Right position of the element. Left + Width\n dimRight = dim[1] + dim[3];\n // Bottom position of the element. Top + Height\n dimDown = dim[0] + dim[2];\n // X center position of the element. Left + (Width / 2)\n xCenter = dim[1] + dim[3] / 2;\n // Y center position of the element. Top + (Height / 2)\n yCenter = dim[0] + dim[2] / 2;\n // Skip if over the limits\n if (\n (xLimit && dim[1] > xLimit) ||\n (yLimit && yCenter >= yLimit) || // >= avoid issue with clearfixes\n (leftLimit && dimRight < leftLimit)\n )\n continue;\n result.index = i;\n result.indexEl = dim[6];\n // If it's not in flow (like 'float' element)\n if (!dim[4]) {\n if (posY < dimDown) yLimit = dimDown;\n //If x lefter than center\n if (posX < xCenter) {\n xLimit = xCenter;\n result.method = 'before';\n } else {\n leftLimit = xCenter;\n result.method = 'after';\n }\n } else {\n // If y upper than center\n if (posY < yCenter) {\n result.method = 'before';\n break;\n } else result.method = 'after'; // After last element\n }\n }\n return result;\n },\n\n /**\n * Updates the position of the placeholder\n * @param {HTMLElement} phl\n * @param {Array} dims\n * @param {Object} pos Position object\n * @param {Array} trgDim target dimensions\n * */\n movePlaceholder(plh, dims, pos, trgDim) {\n var marg = 0,\n t = 0,\n l = 0,\n w = 0,\n h = 0,\n un = 'px',\n margI = 5,\n brdCol = '#62c462',\n brd = 3,\n method = pos.method;\n var elDim = dims[pos.index];\n plh.style.borderColor = 'transparent ' + brdCol;\n plh.style.borderWidth = brd + un + ' ' + (brd + 2) + un;\n plh.style.margin = '-' + brd + 'px 0 0';\n if (elDim) {\n // If it's not in flow (like 'float' element)\n if (!elDim[4]) {\n w = 'auto';\n h = elDim[2] - marg * 2 + un;\n t = elDim[0] + marg;\n l = method == 'before' ? elDim[1] - marg : elDim[1] + elDim[3] - marg;\n plh.style.borderColor = brdCol + ' transparent';\n plh.style.borderWidth = brd + 2 + un + ' ' + brd + un;\n plh.style.margin = '0 0 0 -' + brd + 'px';\n } else {\n w = elDim[3] + un;\n h = 'auto';\n t = method == 'before' ? elDim[0] - marg : elDim[0] + elDim[2] - marg;\n l = elDim[1];\n }\n } else {\n if (!this.nested) {\n plh.style.display = 'none';\n return;\n }\n if (trgDim) {\n t = trgDim[0] + margI;\n l = trgDim[1] + margI;\n w = parseInt(trgDim[3]) - margI * 2 + un;\n h = 'auto';\n }\n }\n plh.style.top = t + un;\n plh.style.left = l + un;\n if (w) plh.style.width = w;\n if (h) plh.style.height = h;\n },\n\n /**\n * Leave item\n * @param event\n *\n * @return void\n * */\n endMove(e) {\n const moved = [null];\n const docs = this.getDocuments();\n const container = this.getContainerEl();\n const onEndMove = this.onEndMove;\n const { target, lastPos } = this;\n off(container, 'mousemove dragover', this.onMove);\n off(docs, 'mouseup dragend touchend', this.endMove);\n off(docs, 'keydown', this.rollback);\n this.plh.style.display = 'none';\n let src = this.eV;\n\n if (src && this.selectOnEnd) {\n var srcModel = this.getSourceModel();\n if (srcModel && srcModel.set) {\n srcModel.set('status', '');\n srcModel.set('status', 'selected');\n }\n }\n\n if (this.moved) {\n const toMove = this.toMove;\n const toMoveArr = isArray(toMove) ? toMove : toMove ? [toMove] : [src];\n toMoveArr.forEach(model => {\n moved.push(this.move(target, model, lastPos));\n });\n }\n\n if (this.plh) this.plh.style.display = 'none';\n var dragHelper = this.dragHelper;\n\n if (dragHelper) {\n dragHelper.parentNode.removeChild(dragHelper);\n this.dragHelper = null;\n }\n\n this.disableTextable();\n this.selectTargetModel();\n this.toggleSortCursor();\n\n this.toMove = null;\n isFunction(onEndMove) && moved.forEach(m => onEndMove(m, this));\n },\n\n /**\n * Move component to new position\n * @param {HTMLElement} dst Destination target\n * @param {HTMLElement} src Element to move\n * @param {Object} pos Object with position coordinates\n * */\n move(dst, src, pos) {\n const { em, activeTextModel, dropContent } = this;\n const srcEl = getElement(src);\n em && em.trigger('component:dragEnd:before', dst, srcEl, pos); // @depricated\n var warns = [];\n var index = pos.indexEl;\n var modelToDrop, modelTemp, created;\n var validResult = this.validTarget(dst, srcEl);\n var targetCollection = $(dst).data('collection');\n var model = validResult.srcModel;\n var droppable = validResult.droppable;\n var draggable = validResult.draggable;\n var dropInfo = validResult.dropInfo;\n var dragInfo = validResult.dragInfo;\n const { trgModel } = validResult;\n droppable = trgModel instanceof Backbone.Collection ? 1 : droppable;\n const isTextableActive = this.isTextableActive(model, trgModel);\n\n if (targetCollection && droppable && draggable) {\n index = pos.method === 'after' ? index + 1 : index;\n var opts = { at: index, noIncrement: 1 };\n\n if (!dropContent) {\n // Putting `avoidStore` here will make the UndoManager behave wrong\n opts.temporary = 1;\n modelTemp = targetCollection.add({}, { ...opts });\n\n if (model.collection) {\n modelToDrop = model.collection.remove(model, { temporary: 1 });\n }\n } else {\n modelToDrop = dropContent;\n opts.silent = false;\n opts.avoidUpdateStyle = 1;\n }\n\n if (isTextableActive) {\n const viewActive = activeTextModel.getView();\n activeTextModel.trigger('active');\n const { activeRte } = viewActive;\n const modelEl = model.getEl();\n delete model.opt.temporary;\n model.getView().render();\n modelEl.setAttribute('data-gjs-textable', 'true');\n const { outerHTML } = modelEl;\n activeRte.insertHTML && activeRte.insertHTML(outerHTML);\n } else {\n created = targetCollection.add(modelToDrop, opts);\n }\n\n if (!dropContent) {\n targetCollection.remove(modelTemp);\n } else {\n this.dropContent = null;\n }\n\n // This will cause to recalculate children dimensions\n this.prevTarget = null;\n } else {\n if (!targetCollection) {\n warns.push('Target collection not found');\n }\n\n if (!droppable) {\n warns.push(`Target is not droppable, accepts [${dropInfo}]`);\n }\n\n if (!draggable) {\n warns.push(`Component not draggable, acceptable by [${dragInfo}]`);\n }\n\n console.warn('Invalid target position: ' + warns.join(', '));\n }\n\n em && em.trigger('component:dragEnd', targetCollection, modelToDrop, warns); // @depricated\n em &&\n em.trigger('sorter:drag:end', {\n targetCollection,\n modelToDrop,\n warns,\n validResult,\n dst,\n srcEl\n });\n\n return created;\n },\n\n /**\n * Rollback to previous situation\n * @param {Event}\n * @param {Bool} Indicates if rollback in anycase\n * */\n rollback(e) {\n off(this.getDocuments(), 'keydown', this.rollback);\n const key = e.which || e.keyCode;\n\n if (key == 27) {\n this.moved = 0;\n this.endMove();\n }\n }\n});\n","import { bindAll, defaults, isFunction, each } from 'underscore';\nimport { on, off, normalizeFloat } from 'utils/mixins';\n\nvar defaultOpts = {\n // Function which returns custom X and Y coordinates of the mouse\n mousePosFetcher: null,\n // Indicates custom target updating strategy\n updateTarget: null,\n // Function which gets HTMLElement as an arg and returns it relative position\n ratioDefault: 0,\n posFetcher: null,\n onStart: null,\n onMove: null,\n onEnd: null,\n\n // Resize unit step\n step: 1,\n\n // Minimum dimension\n minDim: 32,\n\n // Maximum dimension\n maxDim: '',\n\n // Unit used for height resizing\n unitHeight: 'px',\n\n // Unit used for width resizing\n unitWidth: 'px',\n\n // The key used for height resizing\n keyHeight: 'height',\n\n // The key used for width resizing\n keyWidth: 'width',\n\n // If true, will override unitHeight and unitWidth, on start, with units\n // from the current focused element (currently used only in SelectComponent)\n currentUnit: 1,\n\n // With this option active the mousemove event won't be altered when\n // the pointer comes over iframes\n silentFrames: 0,\n\n // If true the container of handlers won't be updated\n avoidContainerUpdate: 0,\n\n // If height is 'auto', this setting will preserve it and only update width\n keepAutoHeight: false,\n\n // If width is 'auto', this setting will preserve it and only update height\n keepAutoWidth: false,\n\n // When keepAutoHeight is true and the height has the value 'auto', this is set to true and height isn't updated\n autoHeight: false,\n\n // When keepAutoWidth is true and the width has the value 'auto', this is set to true and width isn't updated\n autoWidth: false,\n\n // Handlers\n tl: 1, // Top left\n tc: 1, // Top center\n tr: 1, // Top right\n cl: 1, // Center left\n cr: 1, // Center right\n bl: 1, // Bottom left\n bc: 1, // Bottom center\n br: 1 // Bottom right\n};\n\nvar createHandler = (name, opts) => {\n var pfx = opts.prefix || '';\n var el = document.createElement('i');\n el.className = pfx + 'resizer-h ' + pfx + 'resizer-h-' + name;\n el.setAttribute('data-' + pfx + 'handler', name);\n return el;\n};\n\nvar getBoundingRect = (el, win) => {\n var w = win || window;\n var rect = el.getBoundingClientRect();\n return {\n left: rect.left + w.pageXOffset,\n top: rect.top + w.pageYOffset,\n width: rect.width,\n height: rect.height\n };\n};\n\nclass Resizer {\n /**\n * Init the Resizer with options\n * @param {Object} options\n */\n constructor(opts = {}) {\n this.setOptions(opts);\n bindAll(this, 'handleKeyDown', 'handleMouseDown', 'move', 'stop');\n return this;\n }\n\n /**\n * Get current connfiguration options\n * @return {Object}\n */\n getConfig() {\n return this.opts;\n }\n\n /**\n * Setup options\n * @param {Object} options\n */\n setOptions(options = {}) {\n this.opts = defaults(options, defaultOpts);\n this.setup();\n }\n\n /**\n * Setup resizer\n */\n setup() {\n const opts = this.opts;\n const pfx = opts.prefix || '';\n const appendTo = opts.appendTo || document.body;\n let container = this.container;\n\n // Create container if not yet exist\n if (!container) {\n container = document.createElement('div');\n container.className = `${pfx}resizer-c`;\n appendTo.appendChild(container);\n this.container = container;\n }\n\n while (container.firstChild) {\n container.removeChild(container.firstChild);\n }\n\n // Create handlers\n const handlers = {};\n ['tl', 'tc', 'tr', 'cl', 'cr', 'bl', 'bc', 'br'].forEach(\n hdl => (handlers[hdl] = opts[hdl] ? createHandler(hdl, opts) : '')\n );\n\n for (let n in handlers) {\n const handler = handlers[n];\n handler && container.appendChild(handler);\n }\n\n this.handlers = handlers;\n this.mousePosFetcher = opts.mousePosFetcher;\n this.updateTarget = opts.updateTarget;\n this.posFetcher = opts.posFetcher;\n this.onStart = opts.onStart;\n this.onMove = opts.onMove;\n this.onEnd = opts.onEnd;\n }\n\n /**\n * Toggle iframes pointer event\n * @param {Boolean} silent If true, iframes will be silented\n */\n toggleFrames(silent) {\n if (this.opts.silentFrames) {\n const frames = document.querySelectorAll('iframe');\n each(frames, frame => (frame.style.pointerEvents = silent ? 'none' : ''));\n }\n }\n\n /**\n * Detects if the passed element is a resize handler\n * @param {HTMLElement} el\n * @return {Boolean}\n */\n isHandler(el) {\n var handlers = this.handlers;\n\n for (var n in handlers) {\n if (handlers[n] === el) return true;\n }\n\n return false;\n }\n\n /**\n * Returns the focused element\n * @return {HTMLElement}\n */\n getFocusedEl() {\n return this.el;\n }\n\n /**\n * Returns documents\n */\n getDocumentEl() {\n return [this.el.ownerDocument, document];\n }\n\n /**\n * Return element position\n * @param {HTMLElement} el\n * @param {Object} opts Custom options\n * @return {Object}\n */\n getElementPos(el, opts = {}) {\n var posFetcher = this.posFetcher || '';\n return posFetcher ? posFetcher(el, opts) : getBoundingRect(el);\n }\n\n /**\n * Focus resizer on the element, attaches handlers to it\n * @param {HTMLElement} el\n */\n focus(el) {\n // Avoid focusing on already focused element\n if (el && el === this.el) {\n return;\n }\n\n this.el = el;\n this.updateContainer({ forceShow: 1 });\n on(this.getDocumentEl(), 'mousedown', this.handleMouseDown);\n }\n\n /**\n * Blur from element\n */\n blur() {\n this.container.style.display = 'none';\n\n if (this.el) {\n off(this.getDocumentEl(), 'mousedown', this.handleMouseDown);\n this.el = null;\n }\n }\n\n /**\n * Start resizing\n * @param {Event} e\n */\n start(e) {\n //Right or middel click\n if (e.button !== 0) return;\n e.preventDefault();\n e.stopPropagation();\n const el = this.el;\n const resizer = this;\n const config = this.opts || {};\n var attrName = 'data-' + config.prefix + 'handler';\n var rect = this.getElementPos(el, { target: 'el' });\n this.handlerAttr = e.target.getAttribute(attrName);\n this.clickedHandler = e.target;\n this.startDim = {\n t: rect.top,\n l: rect.left,\n w: rect.width,\n h: rect.height\n };\n this.rectDim = {\n t: rect.top,\n l: rect.left,\n w: rect.width,\n h: rect.height\n };\n this.startPos = {\n x: e.clientX,\n y: e.clientY\n };\n\n // Listen events\n var doc = this.getDocumentEl();\n on(doc, 'mousemove', this.move);\n on(doc, 'keydown', this.handleKeyDown);\n on(doc, 'mouseup', this.stop);\n isFunction(this.onStart) &&\n this.onStart(e, { docs: doc, config, el, resizer });\n this.toggleFrames(1);\n this.move(e);\n }\n\n /**\n * While resizing\n * @param {Event} e\n */\n move(e) {\n const onMove = this.onMove;\n var mouseFetch = this.mousePosFetcher;\n var currentPos = mouseFetch\n ? mouseFetch(e)\n : {\n x: e.clientX,\n y: e.clientY\n };\n\n this.currentPos = currentPos;\n this.delta = {\n x: currentPos.x - this.startPos.x,\n y: currentPos.y - this.startPos.y\n };\n this.keys = {\n shift: e.shiftKey,\n ctrl: e.ctrlKey,\n alt: e.altKey\n };\n\n this.rectDim = this.calc(this);\n this.updateRect(0);\n\n // Move callback\n onMove && onMove(e);\n\n // In case the mouse button was released outside of the window\n if (e.which === 0) {\n this.stop(e);\n }\n }\n\n /**\n * Stop resizing\n * @param {Event} e\n */\n stop(e) {\n const config = this.opts;\n var doc = this.getDocumentEl();\n off(doc, 'mousemove', this.move);\n off(doc, 'keydown', this.handleKeyDown);\n off(doc, 'mouseup', this.stop);\n this.updateRect(1);\n this.toggleFrames();\n isFunction(this.onEnd) && this.onEnd(e, { docs: doc, config });\n }\n\n /**\n * Update rect\n */\n updateRect(store) {\n const el = this.el;\n const resizer = this;\n const config = this.opts;\n const rect = this.rectDim;\n const updateTarget = this.updateTarget;\n const selectedHandler = this.getSelectedHandler();\n const { unitHeight, unitWidth, keyWidth, keyHeight } = config;\n\n // Use custom updating strategy if requested\n if (isFunction(updateTarget)) {\n updateTarget(el, rect, {\n store,\n selectedHandler,\n resizer,\n config\n });\n } else {\n const elStyle = el.style;\n elStyle[keyWidth] = rect.w + unitWidth;\n elStyle[keyHeight] = rect.h + unitHeight;\n }\n\n this.updateContainer();\n }\n\n updateContainer(opt = {}) {\n const { opts, container, el } = this;\n const { style } = container;\n\n if (!opts.avoidContainerUpdate && el) {\n const toUpdate = ['left', 'top', 'width', 'height'];\n const rectEl = this.getElementPos(el, { target: 'container' });\n toUpdate.forEach(pos => (style[pos] = `${rectEl[pos]}px`));\n if (opt.forceShow) style.display = 'block';\n }\n }\n\n /**\n * Get selected handler name\n * @return {string}\n */\n getSelectedHandler() {\n var handlers = this.handlers;\n\n if (!this.selectedHandler) {\n return;\n }\n\n for (let n in handlers) {\n if (handlers[n] === this.selectedHandler) return n;\n }\n }\n\n /**\n * Handle ESC key\n * @param {Event} e\n */\n handleKeyDown(e) {\n if (e.keyCode === 27) {\n // Rollback to initial dimensions\n this.rectDim = this.startDim;\n this.stop(e);\n }\n }\n\n /**\n * Handle mousedown to check if it's possible to start resizing\n * @param {Event} e\n */\n handleMouseDown(e) {\n var el = e.target;\n if (this.isHandler(el)) {\n this.selectedHandler = el;\n this.start(e);\n } else if (el !== this.el) {\n this.selectedHandler = '';\n this.blur();\n }\n }\n\n /**\n * All positioning logic\n * @return {Object}\n */\n calc(data) {\n let value;\n const opts = this.opts || {};\n const step = opts.step;\n const startDim = this.startDim;\n const minDim = opts.minDim;\n const maxDim = opts.maxDim;\n const deltaX = data.delta.x;\n const deltaY = data.delta.y;\n const startW = startDim.w;\n const startH = startDim.h;\n var box = {\n t: 0,\n l: 0,\n w: startW,\n h: startH\n };\n\n if (!data) return;\n\n var attr = data.handlerAttr;\n if (~attr.indexOf('r')) {\n value = normalizeFloat(startW + deltaX * step, step);\n value = Math.max(minDim, value);\n maxDim && (value = Math.min(maxDim, value));\n box.w = value;\n }\n if (~attr.indexOf('b')) {\n value = normalizeFloat(startH + deltaY * step, step);\n value = Math.max(minDim, value);\n maxDim && (value = Math.min(maxDim, value));\n box.h = value;\n }\n if (~attr.indexOf('l')) {\n value = normalizeFloat(startW - deltaX * step, step);\n value = Math.max(minDim, value);\n maxDim && (value = Math.min(maxDim, value));\n box.w = value;\n }\n if (~attr.indexOf('t')) {\n value = normalizeFloat(startH - deltaY * step, step);\n value = Math.max(minDim, value);\n maxDim && (value = Math.min(maxDim, value));\n box.h = value;\n }\n\n // Enforce aspect ratio (unless shift key is being held)\n var ratioActive = opts.ratioDefault ? !data.keys.shift : data.keys.shift;\n if (attr.indexOf('c') < 0 && ratioActive) {\n var ratio = startDim.w / startDim.h;\n if (box.w / box.h > ratio) {\n box.h = Math.round(box.w / ratio);\n } else {\n box.w = Math.round(box.h * ratio);\n }\n }\n\n if (~attr.indexOf('l')) {\n box.l = startDim.w - box.w;\n }\n if (~attr.indexOf('t')) {\n box.t = startDim.h - box.h;\n }\n\n return box;\n }\n}\n\nexport default {\n init(opts) {\n return new Resizer(opts);\n }\n};\n","import Dragger from './Dragger';\nimport Sorter from './Sorter';\nimport Resizer from './Resizer';\n\nexport default () => {\n return {\n /**\n * Name of the module\n * @type {String}\n * @private\n */\n name: 'Utils',\n\n /**\n * Initialize module\n */\n init() {\n return this;\n },\n\n Sorter,\n Resizer,\n Dragger\n };\n};\n","export default {\n stylePrefix: 'com-',\n\n // Default array of commands\n defaults: [],\n\n // If true, stateful commands (with `run` and `stop` methods) can't be runned multiple times.\n // So, if the command is already active, running it again will not execute the `run` method\n strict: 1\n};\n","/**\n * You can customize the initial state of the module from the editor initialization, by passing the following [Configuration Object](https://github.com/artf/grapesjs/blob/master/src/commands/config/config.js)\n * ```js\n * const editor = grapesjs.init({\n * commands: {\n * // options\n * }\n * })\n * ```\n *\n * Once the editor is instantiated you can use its API. Before using these methods you should get the module from the instance\n *\n * ```js\n * const commands = editor.Commands;\n * ```\n *\n * * [add](#add)\n * * [get](#get)\n * * [getAll](#getall)\n * * [extend](#extend)\n * * [has](#has)\n * * [run](#run)\n * * [stop](#stop)\n * * [isActive](#isactive)\n * * [getActive](#getactive)\n *\n * @module Commands\n */\n\nimport { isFunction, includes } from 'underscore';\nimport CommandAbstract from './view/CommandAbstract';\nimport defaults from './config/config';\n\nexport default () => {\n let em;\n let c = {};\n const commands = {};\n const defaultCommands = {};\n const active = {};\n const commandsDef = [\n ['preview', 'Preview', 'preview'],\n ['resize', 'Resize', 'resize'],\n ['fullscreen', 'Fullscreen', 'fullscreen'],\n ['copy', 'CopyComponent'],\n ['paste', 'PasteComponent'],\n ['canvas-move', 'CanvasMove'],\n ['canvas-clear', 'CanvasClear'],\n ['open-code', 'ExportTemplate', 'export-template'],\n ['open-layers', 'OpenLayers', 'open-layers'],\n ['open-styles', 'OpenStyleManager', 'open-sm'],\n ['open-traits', 'OpenTraitManager', 'open-tm'],\n ['open-blocks', 'OpenBlocks', 'open-blocks'],\n ['open-assets', 'OpenAssets', 'open-assets'],\n ['component-select', 'SelectComponent', 'select-comp'],\n ['component-outline', 'SwitchVisibility', 'sw-visibility'],\n ['component-offset', 'ShowOffset', 'show-offset'],\n ['component-move', 'MoveComponent', 'move-comp'],\n ['component-next', 'ComponentNext'],\n ['component-prev', 'ComponentPrev'],\n ['component-enter', 'ComponentEnter'],\n ['component-exit', 'ComponentExit', 'select-parent'],\n ['component-delete', 'ComponentDelete'],\n ['component-style-clear', 'ComponentStyleClear'],\n ['component-drag', 'ComponentDrag']\n ];\n\n // Need it here as it would be used below\n const add = function(id, obj) {\n if (isFunction(obj)) obj = { run: obj };\n if (!obj.stop) obj.noStop = 1;\n delete obj.initialize;\n obj.id = id;\n commands[id] = CommandAbstract.extend(obj);\n return this;\n };\n\n return {\n CommandAbstract,\n\n /**\n * Name of the module\n * @type {String}\n * @private\n */\n name: 'Commands',\n\n /**\n * Initialize module. Automatically called with a new instance of the editor\n * @param {Object} config Configurations\n * @private\n */\n init(config = {}) {\n c = {\n ...defaults,\n ...config\n };\n em = c.em;\n const ppfx = c.pStylePrefix;\n if (ppfx) c.stylePrefix = ppfx + c.stylePrefix;\n\n // Load commands passed via configuration\n for (let k in c.defaults) {\n const obj = c.defaults[k];\n if (obj.id) this.add(obj.id, obj);\n }\n\n defaultCommands['tlb-delete'] = {\n run(ed) {\n return ed.runCommand('core:component-delete');\n }\n };\n\n defaultCommands['tlb-clone'] = {\n run(ed) {\n ed.runCommand('core:copy');\n ed.runCommand('core:paste');\n }\n };\n\n defaultCommands['tlb-move'] = {\n run(ed, sender, opts = {}) {\n let dragger;\n const em = ed.getModel();\n const event = opts && opts.event;\n const { target } = opts;\n const sel = target || ed.getSelected();\n const selAll = target ? [target] : [...ed.getSelectedAll()];\n const nativeDrag = event && event.type == 'dragstart';\n const defComOptions = { preserveSelected: 1 };\n const modes = ['absolute', 'translate'];\n const hideTlb = () => em.stopDefault(defComOptions);\n\n // Dirty patch to prevent parent selection on drop (in absolute mode)\n em.set('_cmpDrag', 1);\n\n if (!sel || !sel.get('draggable')) {\n console.warn('The element is not draggable');\n return;\n }\n\n const mode = sel.get('dmode') || em.get('dmode');\n\n // Without setTimeout the ghost image disappears\n nativeDrag ? setTimeout(hideTlb, 0) : hideTlb();\n\n const onEnd = (e, opts) => {\n em.runDefault(defComOptions);\n selAll.forEach(sel => sel.set('status', 'selected'));\n ed.select(selAll);\n sel.emitUpdate();\n };\n\n if (includes(modes, mode)) {\n // TODO move grabbing func in editor/canvas from the Sorter\n dragger = ed.runCommand('core:component-drag', {\n guidesInfo: 1,\n mode,\n target: sel,\n onEnd,\n event\n });\n } else {\n if (nativeDrag) {\n event.dataTransfer.setDragImage(sel.view.el, 0, 0);\n //sel.set('status', 'freezed');\n }\n\n const cmdMove = ed.Commands.get('move-comp');\n cmdMove.onEndMoveFromModel = onEnd;\n cmdMove.initSorterFromModels(selAll);\n }\n\n selAll.forEach(sel => sel.set('status', 'freezed-selected'));\n }\n };\n\n // Core commands\n defaultCommands['core:undo'] = e => e.UndoManager.undo();\n defaultCommands['core:redo'] = e => e.UndoManager.redo();\n commandsDef.forEach(item => {\n const oldCmd = item[2];\n const cmd = require(`./view/${item[1]}`).default;\n const cmdName = `core:${item[0]}`;\n defaultCommands[cmdName] = cmd;\n if (oldCmd) {\n defaultCommands[oldCmd] = cmd;\n // Propogate old commands (can be removed once we stop to call old commands)\n ['run', 'stop'].forEach(name => {\n em.on(`${name}:${oldCmd}`, (...args) =>\n em.trigger(`${name}:${cmdName}`, ...args)\n );\n });\n }\n });\n\n if (c.em) c.model = c.em.get('Canvas');\n\n this.loadDefaultCommands();\n\n return this;\n },\n\n /**\n * Add new command to the collection\n * @param\t{string} id Command's ID\n * @param\t{Object|Function} command Object representing your command,\n * By passing just a function it's intended as a stateless command\n * (just like passing an object with only `run` method).\n * @return {this}\n * @example\n * commands.add('myCommand', {\n * \trun(editor, sender) {\n * \t\talert('Hello world!');\n * \t},\n * \tstop(editor, sender) {\n * \t},\n * });\n * // As a function\n * commands.add('myCommand2', editor => { ... });\n * */\n add,\n\n /**\n * Get command by ID\n * @param\t{string}\tid Command's ID\n * @return {Object} Object representing the command\n * @example\n * var myCommand = commands.get('myCommand');\n * myCommand.run();\n * */\n get(id) {\n let el = commands[id];\n\n if (isFunction(el)) {\n el = new el(c);\n commands[id] = el;\n } else if (!el) {\n em.logWarning(`'${id}' command not found`);\n }\n\n return el;\n },\n\n /**\n * Extend the command. The command to extend should be defined as an object\n * @param\t{string}\tid Command's ID\n * @param {Object} Object with the new command functions\n * @returns {this}\n * @example\n * commands.extend('old-command', {\n * someInnerFunction() {\n * // ...\n * }\n * });\n * */\n extend(id, cmd = {}) {\n const command = this.get(id);\n if (command) {\n const cmdObj = {\n ...command.constructor.prototype,\n ...cmd\n };\n this.add(id, cmdObj);\n // Extend also old name commands if exist\n const oldCmd = commandsDef.filter(\n cmd => `core:${cmd[0]}` === id && cmd[2]\n )[0];\n oldCmd && this.add(oldCmd[2], cmdObj);\n }\n return this;\n },\n\n /**\n * Check if command exists\n * @param\t{string}\tid Command's ID\n * @return {Boolean}\n * */\n has(id) {\n return !!commands[id];\n },\n\n /**\n * Get an object containing all the commands\n * @return {Object}\n */\n getAll() {\n return commands;\n },\n\n /**\n * Execute the command\n * @param {String} id Command ID\n * @param {Object} [options={}] Options\n * @return {*} The return is defined by the command\n * @example\n * commands.run('myCommand', { someOption: 1 });\n */\n run(id, options = {}) {\n return this.runCommand(this.get(id), options);\n },\n\n /**\n * Stop the command\n * @param {String} id Command ID\n * @param {Object} [options={}] Options\n * @return {*} The return is defined by the command\n * @example\n * commands.stop('myCommand', { someOption: 1 });\n */\n stop(id, options = {}) {\n return this.stopCommand(this.get(id), options);\n },\n\n /**\n * Check if the command is active. You activate commands with `run`\n * and disable them with `stop`. If the command was created without `stop`\n * method it can't be registered as active\n * @param {String} id Command id\n * @return {Boolean}\n * @example\n * const cId = 'some-command';\n * commands.run(cId);\n * commands.isActive(cId);\n * // -> true\n * commands.stop(cId);\n * commands.isActive(cId);\n * // -> false\n */\n isActive(id) {\n return this.getActive().hasOwnProperty(id);\n },\n\n /**\n * Get all active commands\n * @return {Object}\n * @example\n * console.log(commands.getActive());\n * // -> { someCommand: itsLastReturn, anotherOne: ... };\n */\n getActive() {\n return active;\n },\n\n /**\n * Load default commands\n * @return {this}\n * @private\n * */\n loadDefaultCommands() {\n for (var id in defaultCommands) {\n this.add(id, defaultCommands[id]);\n }\n\n return this;\n },\n\n /**\n * Run command via its object\n * @param {Object} command\n * @param {Object} options\n * @return {*} Result of the command\n * @private\n */\n runCommand(command, options = {}) {\n let result;\n\n if (command && command.run) {\n const id = command.id;\n const editor = em.get('Editor');\n\n if (!this.isActive(id) || options.force || !c.strict) {\n result = command.callRun(editor, options);\n if (id && command.stop && !command.noStop && !options.abort) {\n active[id] = result;\n }\n }\n }\n\n return result;\n },\n\n /**\n * Stop the command\n * @param {Object} command\n * @param {Object} options\n * @return {*} Result of the command\n * @private\n */\n stopCommand(command, options = {}) {\n let result;\n\n if (command && command.run) {\n const id = command.id;\n const editor = em.get('Editor');\n\n if (this.isActive(id) || options.force || !c.strict) {\n if (id) delete active[id];\n result = command.callStop(editor, options);\n }\n }\n\n return result;\n },\n\n /**\n * Create anonymous Command instance\n * @param {Object} command Command object\n * @return {Command}\n * @private\n * */\n create(command) {\n if (!command.stop) command.noStop = 1;\n const cmd = CommandAbstract.extend(command);\n return new cmd(c);\n }\n };\n};\n"],"sourceRoot":""} \ No newline at end of file diff --git a/docs/.vuepress/components/Demo.vue b/docs/.vuepress/components/Demo.vue new file mode 100644 index 000000000..cf3a36a95 --- /dev/null +++ b/docs/.vuepress/components/Demo.vue @@ -0,0 +1,14 @@ + + + diff --git a/docs/.vuepress/components/DemoBasicBlocks.vue b/docs/.vuepress/components/DemoBasicBlocks.vue new file mode 100644 index 000000000..3610a7f95 --- /dev/null +++ b/docs/.vuepress/components/DemoBasicBlocks.vue @@ -0,0 +1,29 @@ + + + + + diff --git a/docs/.vuepress/components/DemoCanvasOnly.vue b/docs/.vuepress/components/DemoCanvasOnly.vue new file mode 100644 index 000000000..12148197a --- /dev/null +++ b/docs/.vuepress/components/DemoCanvasOnly.vue @@ -0,0 +1,15 @@ + + + + + diff --git a/docs/.vuepress/components/DemoCustomPanels.vue b/docs/.vuepress/components/DemoCustomPanels.vue new file mode 100644 index 000000000..a289d5096 --- /dev/null +++ b/docs/.vuepress/components/DemoCustomPanels.vue @@ -0,0 +1,48 @@ + + + + + diff --git a/docs/.vuepress/components/DemoDevices.vue b/docs/.vuepress/components/DemoDevices.vue new file mode 100644 index 000000000..44eb227ec --- /dev/null +++ b/docs/.vuepress/components/DemoDevices.vue @@ -0,0 +1,56 @@ + + + + + diff --git a/docs/.vuepress/components/DemoLayers.vue b/docs/.vuepress/components/DemoLayers.vue new file mode 100644 index 000000000..8cec334d6 --- /dev/null +++ b/docs/.vuepress/components/DemoLayers.vue @@ -0,0 +1,40 @@ + + + + + diff --git a/docs/.vuepress/components/DemoStyle.vue b/docs/.vuepress/components/DemoStyle.vue new file mode 100644 index 000000000..bc16df648 --- /dev/null +++ b/docs/.vuepress/components/DemoStyle.vue @@ -0,0 +1,51 @@ + + + + + diff --git a/docs/.vuepress/components/DemoTheme.vue b/docs/.vuepress/components/DemoTheme.vue new file mode 100644 index 000000000..eddd25a19 --- /dev/null +++ b/docs/.vuepress/components/DemoTheme.vue @@ -0,0 +1,80 @@ + + + + + diff --git a/docs/.vuepress/components/DemoTraits.vue b/docs/.vuepress/components/DemoTraits.vue new file mode 100644 index 000000000..d2beae9e7 --- /dev/null +++ b/docs/.vuepress/components/DemoTraits.vue @@ -0,0 +1,52 @@ + + + + + diff --git a/docs/.vuepress/components/DemoViewer.vue b/docs/.vuepress/components/DemoViewer.vue new file mode 100644 index 000000000..bec815183 --- /dev/null +++ b/docs/.vuepress/components/DemoViewer.vue @@ -0,0 +1,33 @@ +