/** * @output wp-includes/js/customize-views.js */ (function( $, wp, _ ) { if ( ! wp || ! wp.customize ) { return; } var api = wp.customize; /** * wp.customize.HeaderTool.CurrentView * * Displays the currently selected header image, or a placeholder in lack * thereof. * * Instantiate with model wp.customize.HeaderTool.currentHeader. * * @memberOf wp.customize.HeaderTool * @alias wp.customize.HeaderTool.CurrentView * * @constructor * @augments wp.Backbone.View */ api.HeaderTool.CurrentView = wp.Backbone.View.extend(/** @lends wp.customize.HeaderTool.CurrentView.prototype */{ template: wp.template('header-current'), initialize: function() { this.listenTo(this.model, 'change', this.render); this.render(); }, render: function() { this.$el.html(this.template(this.model.toJSON())); this.setButtons(); return this; }, setButtons: function() { var elements = $('#customize-control-header_image .actions .remove'); if (this.model.get('choice')) { elements.show(); } else { elements.hide(); } } }); /** * wp.customize.HeaderTool.ChoiceView * * Represents a choosable header image, be it user-uploaded, * theme-suggested or a special Randomize choice. * * Takes a wp.customize.HeaderTool.ImageModel. * * Manually changes model wp.customize.HeaderTool.currentHeader via the * `select` method. * * @memberOf wp.customize.HeaderTool * @alias wp.customize.HeaderTool.ChoiceView * * @constructor * @augments wp.Backbone.View */ api.HeaderTool.ChoiceView = wp.Backbone.View.extend(/** @lends wp.customize.HeaderTool.ChoiceView.prototype */{ template: wp.template('header-choice'), className: 'header-view', events: { 'click .choice,.random': 'select', 'click .close': 'removeImage' }, initialize: function() { var properties = [ this.model.get('header').url, this.model.get('choice') ]; this.listenTo(this.model, 'change:selected', this.toggleSelected); if (_.contains(properties, api.get().header_image)) { api.HeaderTool.currentHeader.set(this.extendedModel()); } }, render: function() { this.$el.html(this.template(this.extendedModel())); this.toggleSelected(); return this; }, toggleSelected: function() { this.$el.toggleClass('selected', this.model.get('selected')); }, extendedModel: function() { var c = this.model.get('collection'); return _.extend(this.model.toJSON(), { type: c.type }); }, select: function() { this.preventJump(); this.model.save(); api.HeaderTool.currentHeader.set(this.extendedModel()); }, preventJump: function() { var container = $('.wp-full-overlay-sidebar-content'), scroll = container.scrollTop(); _.defer(function() { container.scrollTop(scroll); }); }, removeImage: function(e) { e.stopPropagation(); this.model.destroy(); this.remove(); } }); /** * wp.customize.HeaderTool.ChoiceListView * * A container for ChoiceViews. These choices should be of one same type: * user-uploaded headers or theme-defined ones. * * Takes a wp.customize.HeaderTool.ChoiceList. * * @memberOf wp.customize.HeaderTool * @alias wp.customize.HeaderTool.ChoiceListView * * @constructor * @augments wp.Backbone.View */ api.HeaderTool.ChoiceListView = wp.Backbone.View.extend(/** @lends wp.customize.HeaderTool.ChoiceListView.prototype */{ initialize: function() { this.listenTo(this.collection, 'add', this.addOne); this.listenTo(this.collection, 'remove', this.render); this.listenTo(this.collection, 'sort', this.render); this.listenTo(this.collection, 'change', this.toggleList); this.render(); }, render: function() { this.$el.empty(); this.collection.each(this.addOne, this); this.toggleList(); }, addOne: function(choice) { var view; choice.set({ collection: this.collection }); view = new api.HeaderTool.ChoiceView({ model: choice }); this.$el.append(view.render().el); }, toggleList: function() { var title = this.$el.parents().prev('.customize-control-title'), randomButton = this.$el.find('.random').parent(); if (this.collection.shouldHideTitle()) { title.add(randomButton).hide(); } else { title.add(randomButton).show(); } } }); /** * wp.customize.HeaderTool.CombinedList * * Aggregates wp.customize.HeaderTool.ChoiceList collections (or any * Backbone object, really) and acts as a bus to feed them events. * * @memberOf wp.customize.HeaderTool * @alias wp.customize.HeaderTool.CombinedList * * @constructor * @augments wp.Backbone.View */ api.HeaderTool.CombinedList = wp.Backbone.View.extend(/** @lends wp.customize.HeaderTool.CombinedList.prototype */{ initialize: function(collections) { this.collections = collections; this.on('all', this.propagate, this); }, propagate: function(event, arg) { _.each(this.collections, function(collection) { collection.trigger(event, arg); }); } }); })( jQuery, window.wp, _ );
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
codemirror | Folder | 0555 |
|
|
crop | Folder | 0555 |
|
|
dist | Folder | 0555 |
|
|
imgareaselect | Folder | 0555 |
|
|
jcrop | Folder | 0555 |
|
|
jquery | Folder | 0555 |
|
|
mediaelement | Folder | 0555 |
|
|
plupload | Folder | 0555 |
|
|
swfupload | Folder | 0555 |
|
|
thickbox | Folder | 0555 |
|
|
tinymce | Folder | 0555 |
|
|
admin-bar.js | File | 10.3 KB | 0644 |
|
admin-bar.min.js | File | 3.41 KB | 0644 |
|
api-request.js | File | 3.25 KB | 0644 |
|
api-request.min.js | File | 1023 B | 0644 |
|
autosave.js | File | 21.95 KB | 0644 |
|
autosave.min.js | File | 5.67 KB | 0644 |
|
backbone.js | File | 77.87 KB | 0644 |
|
backbone.min.js | File | 23.57 KB | 0644 |
|
clipboard.js | File | 26.18 KB | 0644 |
|
clipboard.min.js | File | 8.8 KB | 0644 |
|
colorpicker.js | File | 28.4 KB | 0644 |
|
colorpicker.min.js | File | 16.13 KB | 0644 |
|
comment-reply.js | File | 12.17 KB | 0644 |
|
comment-reply.min.js | File | 2.91 KB | 0644 |
|
customize-base.js | File | 25.22 KB | 0644 |
|
customize-base.min.js | File | 7.67 KB | 0644 |
|
customize-loader.js | File | 7.72 KB | 0644 |
|
customize-loader.min.js | File | 3.47 KB | 0644 |
|
customize-models.js | File | 6.66 KB | 0644 |
|
customize-models.min.js | File | 3.59 KB | 0644 |
|
customize-preview-nav-menus.js | File | 14.67 KB | 0644 |
|
customize-preview-nav-menus.min.js | File | 4.92 KB | 0644 |
|
customize-preview-widgets.js | File | 22.71 KB | 0644 |
|
customize-preview-widgets.min.js | File | 7.64 KB | 0644 |
|
customize-preview.js | File | 27.3 KB | 0644 |
|
customize-preview.min.js | File | 10.45 KB | 0644 |
|
customize-selective-refresh.js | File | 32.55 KB | 0644 |
|
customize-selective-refresh.min.js | File | 10.44 KB | 0644 |
|
customize-views.js | File | 4.95 KB | 0644 |
|
customize-views.min.js | File | 2.39 KB | 0644 |
|
heartbeat.js | File | 23.39 KB | 0644 |
|
heartbeat.min.js | File | 5.87 KB | 0644 |
|
hoverIntent.js | File | 7.06 KB | 0644 |
|
hoverIntent.min.js | File | 1.46 KB | 0644 |
|
hoverintent-js.min.js | File | 1.68 KB | 0644 |
|
imagesloaded.min.js | File | 5.39 KB | 0644 |
|
json2.js | File | 17.99 KB | 0644 |
|
json2.min.js | File | 3.07 KB | 0644 |
|
masonry.min.js | File | 23.57 KB | 0644 |
|
mce-view.js | File | 25.24 KB | 0644 |
|
mce-view.min.js | File | 9.54 KB | 0644 |
|
media-audiovideo.js | File | 24.39 KB | 0644 |
|
media-audiovideo.min.js | File | 11.78 KB | 0644 |
|
media-editor.js | File | 28.44 KB | 0644 |
|
media-editor.min.js | File | 10.63 KB | 0644 |
|
media-grid.js | File | 26.18 KB | 0644 |
|
media-grid.min.js | File | 12.95 KB | 0644 |
|
media-models.js | File | 42.74 KB | 0644 |
|
media-models.min.js | File | 12.98 KB | 0644 |
|
media-views.js | File | 265.14 KB | 0644 |
|
media-views.min.js | File | 107.42 KB | 0644 |
|
quicktags.js | File | 22.07 KB | 0644 |
|
quicktags.min.js | File | 10.87 KB | 0644 |
|
shortcode.js | File | 10.51 KB | 0644 |
|
shortcode.min.js | File | 2.58 KB | 0644 |
|
swfobject.js | File | 9.99 KB | 0644 |
|
tw-sack.js | File | 4.85 KB | 0644 |
|
tw-sack.min.js | File | 3.21 KB | 0644 |
|
twemoji.js | File | 32.16 KB | 0644 |
|
twemoji.min.js | File | 15.42 KB | 0644 |
|
underscore.js | File | 66.77 KB | 0644 |
|
underscore.min.js | File | 18.39 KB | 0644 |
|
utils.js | File | 4.56 KB | 0644 |
|
utils.min.js | File | 1.82 KB | 0644 |
|
wp-ajax-response.js | File | 3.75 KB | 0644 |
|
wp-ajax-response.min.js | File | 2.45 KB | 0644 |
|
wp-api.js | File | 45.88 KB | 0644 |
|
wp-api.min.js | File | 14.34 KB | 0644 |
|
wp-auth-check.js | File | 4.11 KB | 0644 |
|
wp-auth-check.min.js | File | 1.62 KB | 0644 |
|
wp-backbone.js | File | 14.88 KB | 0644 |
|
wp-backbone.min.js | File | 2.97 KB | 0644 |
|
wp-custom-header.js | File | 10.22 KB | 0644 |
|
wp-custom-header.min.js | File | 4.34 KB | 0644 |
|
wp-embed-template.js | File | 6.62 KB | 0644 |
|
wp-embed-template.min.js | File | 3.1 KB | 0644 |
|
wp-embed.js | File | 3.14 KB | 0644 |
|
wp-embed.min.js | File | 1.22 KB | 0644 |
|
wp-emoji-loader.js | File | 11.92 KB | 0644 |
|
wp-emoji-loader.min.js | File | 2.86 KB | 0644 |
|
wp-emoji-release.min.js | File | 18.29 KB | 0644 |
|
wp-emoji.js | File | 8.76 KB | 0644 |
|
wp-emoji.min.js | File | 2.82 KB | 0644 |
|
wp-list-revisions.js | File | 970 B | 0644 |
|
wp-list-revisions.min.js | File | 597 B | 0644 |
|
wp-lists.js | File | 24.72 KB | 0644 |
|
wp-lists.min.js | File | 7.34 KB | 0644 |
|
wp-pointer.js | File | 9.99 KB | 0644 |
|
wp-pointer.min.js | File | 3.54 KB | 0644 |
|
wp-sanitize.js | File | 1.32 KB | 0644 |
|
wp-sanitize.min.js | File | 458 B | 0644 |
|
wp-util.js | File | 4.57 KB | 0644 |
|
wp-util.min.js | File | 1.39 KB | 0644 |
|
wpdialog.js | File | 569 B | 0644 |
|
wpdialog.min.js | File | 281 B | 0644 |
|
wplink.js | File | 20.76 KB | 0644 |
|
wplink.min.js | File | 11.07 KB | 0644 |
|
zxcvbn-async.js | File | 821 B | 0644 |
|
zxcvbn-async.min.js | File | 351 B | 0644 |
|
zxcvbn.min.js | File | 802.97 KB | 0644 |
|