diff options
| author | stephanchrst <stephanchrst@gmail.com> | 2022-05-10 21:51:50 +0700 |
|---|---|---|
| committer | stephanchrst <stephanchrst@gmail.com> | 2022-05-10 21:51:50 +0700 |
| commit | 3751379f1e9a4c215fb6eb898b4ccc67659b9ace (patch) | |
| tree | a44932296ef4a9b71d5f010906253d8c53727726 /addons/website/static/src/js/editor/widget_link.js | |
| parent | 0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff) | |
initial commit 2
Diffstat (limited to 'addons/website/static/src/js/editor/widget_link.js')
| -rw-r--r-- | addons/website/static/src/js/editor/widget_link.js | 104 |
1 files changed, 104 insertions, 0 deletions
diff --git a/addons/website/static/src/js/editor/widget_link.js b/addons/website/static/src/js/editor/widget_link.js new file mode 100644 index 00000000..de3c1d9c --- /dev/null +++ b/addons/website/static/src/js/editor/widget_link.js @@ -0,0 +1,104 @@ +odoo.define('website.editor.link', function (require) { +'use strict'; + +var weWidgets = require('wysiwyg.widgets'); +var wUtils = require('website.utils'); + +weWidgets.LinkDialog.include({ + xmlDependencies: (weWidgets.LinkDialog.prototype.xmlDependencies || []).concat( + ['/website/static/src/xml/website.editor.xml'] + ), + events: _.extend({}, weWidgets.LinkDialog.prototype.events || {}, { + 'change select[name="link_anchor"]': '_onAnchorChange', + 'input input[name="url"]': '_onURLInput', + }), + custom_events: _.extend({}, weWidgets.LinkDialog.prototype.custom_events || {}, { + website_url_chosen: '_onAutocompleteClose', + }), + LINK_DEBOUNCE: 1000, + + /** + * @constructor + */ + init: function () { + this._super.apply(this, arguments); + this._adaptPageAnchor = _.debounce(this._adaptPageAnchor, this.LINK_DEBOUNCE); + }, + /** + * Allows the URL input to propose existing website pages. + * + * @override + */ + start: function () { + var def = this._super.apply(this, arguments); + wUtils.autocompleteWithPages(this, this.$('input[name="url"]')); + this.opened(this._adaptPageAnchor.bind(this)); + return def; + }, + + //-------------------------------------------------------------------------- + // Private + //-------------------------------------------------------------------------- + + /** + * @private + */ + _adaptPageAnchor: function () { + var urlInputValue = this.$('input[name="url"]').val(); + var $pageAnchor = this.$('.o_link_dialog_page_anchor'); + var isFromWebsite = urlInputValue[0] === '/'; + var $selectMenu = this.$('select[name="link_anchor"]'); + var $anchorsLoading = this.$('.o_anchors_loading'); + + if ($selectMenu.data("anchor-for") !== urlInputValue) { // avoid useless query + $anchorsLoading.removeClass('d-none'); + $pageAnchor.toggleClass('d-none', !isFromWebsite); + $selectMenu.empty(); + wUtils.loadAnchors(urlInputValue).then(function (anchors) { + _.each(anchors, function (anchor) { + $selectMenu.append($('<option>', {text: anchor})); + }); + always(); + }).guardedCatch(always); + } else { + always(); + } + + function always() { + $anchorsLoading.addClass('d-none'); + $selectMenu.prop("selectedIndex", -1); + } + $selectMenu.data("anchor-for", urlInputValue); + }, + + //-------------------------------------------------------------------------- + // Handlers + //-------------------------------------------------------------------------- + + /** + * @private + */ + _onAutocompleteClose: function () { + this._onURLInput(); + }, + /** + * @private + */ + _onAnchorChange: function () { + var anchorValue = this.$('[name="link_anchor"]').val(); + var $urlInput = this.$('[name="url"]'); + var urlInputValue = $urlInput.val(); + if (urlInputValue.indexOf('#') > -1) { + urlInputValue = urlInputValue.substr(0, urlInputValue.indexOf('#')); + } + $urlInput.val(urlInputValue + anchorValue); + }, + /** + * @override + */ + _onURLInput: function () { + this._super.apply(this, arguments); + this._adaptPageAnchor(); + }, +}); +}); |
