├── .dev-lib
├── .editorconfig
├── .eslintrc
├── .gitattributes
├── .gitignore
├── .gitmodules
├── .jscsrc
├── .jshintignore
├── .jshintrc
├── .svnignore
├── .travis.yml
├── Gruntfile.js
├── better-code-editing.php
├── bin
└── verify-version-consistency.php
├── composer.json
├── composer.lock
├── contributing.md
├── core-commit-message.txt
├── package-lock.json
├── package.json
├── phpcs.xml
├── readme.md
├── readme.txt
├── wp-admin
├── css
│ ├── code-editor.css
│ ├── common.css
│ ├── customize-controls-addendum.css
│ └── widgets-addendum.css
├── file-editor-addendum.php
├── includes
│ └── user.php
├── js
│ ├── code-editor.js
│ ├── customize-controls-addendum.js
│ ├── theme-plugin-editor.js
│ └── widgets
│ │ └── custom-html-widgets.js
└── user-edit-addendum.php
├── wp-assets
├── icon-256.png
└── icon.svg
└── wp-includes
├── customize-manager-addendum.php
├── general-template-addendum.php
├── js
├── codemirror
│ └── codemirror.manifest.js
└── htmlhint-kses.js
├── script-loader-addendum.php
├── widgets-addendum.php
└── widgets
└── class-wp-widget-custom-html-codemirror.php
/.dev-lib:
--------------------------------------------------------------------------------
1 | CHECK_SCOPE=changed-files
2 | WPCS_GIT_TREE=develop
3 |
4 | if [[ ${TRAVIS_PHP_VERSION:0:3} == "5.2" ]]; then
5 | DEV_LIB_SKIP="phpcs,$DEV_LIB_SKIP"
6 | fi
7 |
--------------------------------------------------------------------------------
/.editorconfig:
--------------------------------------------------------------------------------
1 | dev-lib/.editorconfig
--------------------------------------------------------------------------------
/.eslintrc:
--------------------------------------------------------------------------------
1 | dev-lib/.eslintrc
--------------------------------------------------------------------------------
/.gitattributes:
--------------------------------------------------------------------------------
1 | # Auto detect text files and perform LF normalization
2 | * text=auto
3 |
4 | # Custom for Visual Studio
5 | *.cs diff=csharp
6 |
7 | # Standard to msysgit
8 | *.doc diff=astextplain
9 | *.DOC diff=astextplain
10 | *.docx diff=astextplain
11 | *.DOCX diff=astextplain
12 | *.dot diff=astextplain
13 | *.DOT diff=astextplain
14 | *.pdf diff=astextplain
15 | *.PDF diff=astextplain
16 | *.rtf diff=astextplain
17 | *.RTF diff=astextplain
18 |
--------------------------------------------------------------------------------
/.gitignore:
--------------------------------------------------------------------------------
1 |
2 | # CodeMirror sources
3 | wp-includes/js/codemirror/*.min.css
4 | wp-includes/js/codemirror/*.min.js
5 | wp-includes/js/codemirror/codemirror.js
6 | wp-includes/js/codemirror/codemirror.css
7 | wp-includes/js/csslint.js
8 | wp-includes/js/htmlhint.js
9 | wp-includes/js/jsonlint.js
10 | wp-includes/js/jshint.js
11 |
12 | build
13 | *.zip
14 | *-rtl.css
15 | ~*
16 |
17 | # Windows image file caches
18 | Thumbs.db
19 | ehthumbs.db
20 |
21 | # Folder config file
22 | Desktop.ini
23 |
24 | # Recycle Bin used on file shares
25 | $RECYCLE.BIN/
26 |
27 | # Windows Installer files
28 | *.cab
29 | *.msi
30 | *.msm
31 | *.msp
32 |
33 | # Windows shortcuts
34 | *.lnk
35 |
36 | # =========================
37 | # Operating System Files
38 | # =========================
39 |
40 | # OSX
41 | # =========================
42 |
43 | .DS_Store
44 | .AppleDouble
45 | .LSOverride
46 |
47 | # Thumbnails
48 | ._*
49 |
50 | # Files that might appear in the root of a volume
51 | .DocumentRevisions-V100
52 | .fseventsd
53 | .Spotlight-V100
54 | .TemporaryItems
55 | .Trashes
56 | .VolumeIcon.icns
57 |
58 | # Directories potentially created on remote AFP share
59 | .AppleDB
60 | .AppleDesktop
61 | Network Trash Folder
62 | Temporary Items
63 | .apdisk
64 | node_modules
65 |
66 | /vendor/
67 |
--------------------------------------------------------------------------------
/.gitmodules:
--------------------------------------------------------------------------------
1 | [submodule "dev-lib"]
2 | path = dev-lib
3 | url = https://github.com/xwp/wp-dev-lib.git
4 | branch = master
5 |
--------------------------------------------------------------------------------
/.jscsrc:
--------------------------------------------------------------------------------
1 | dev-lib/.jscsrc
--------------------------------------------------------------------------------
/.jshintignore:
--------------------------------------------------------------------------------
1 | **/*.min.js
2 | **/node_modules/**
3 | **/vendor/**
4 |
--------------------------------------------------------------------------------
/.jshintrc:
--------------------------------------------------------------------------------
1 | dev-lib/.jshintrc
--------------------------------------------------------------------------------
/.svnignore:
--------------------------------------------------------------------------------
1 | .git
2 | .gitattributes
3 | .gitignore
4 | .gitmodules
5 | .svnignore
6 | README.md
7 | bin
8 | node_modules
9 | .dev-lib
10 | .distignore
11 | .editorconfig
12 | .eslintrc
13 | .jscsrc
14 | .jshintignore
15 | .jshintrc
16 | .travis.yml
17 | dev-lib
18 | package-lock.json
19 | package.json
20 | phpcs.xml
21 | readme.md
22 | *.zip
23 | build
24 | contributing.md
25 | ~*
26 | Gruntfile.js
27 | .DS_Store
28 | wp-assets
29 | vendor
30 | composer.json
31 | composer.lock
32 | core-commit-message.txt
33 | wp-includes/js/codemirror/codemirror.js
34 | wp-includes/js/codemirror/codemirror.css
35 |
--------------------------------------------------------------------------------
/.travis.yml:
--------------------------------------------------------------------------------
1 | sudo: false
2 | dist: precise
3 |
4 | notifications:
5 | email:
6 | on_success: never
7 | on_failure: change
8 |
9 | cache:
10 | directories:
11 | - node_modules
12 | - vendor
13 | - $HOME/phpunit-bin
14 |
15 | language:
16 | - php
17 | - node_js
18 |
19 | php:
20 | - 5.2
21 | - 5.6
22 | - 7.0
23 |
24 | env:
25 | - WP_VERSION=trunk WP_MULTISITE=0
26 | - WP_VERSION=trunk WP_MULTISITE=1
27 |
28 | install:
29 | - nvm install 6 && nvm use 6
30 | - export DEV_LIB_PATH=dev-lib
31 | - if [ ! -e "$DEV_LIB_PATH" ] && [ -L .travis.yml ]; then export DEV_LIB_PATH=$( dirname $( readlink .travis.yml ) ); fi
32 | - if [ ! -e "$DEV_LIB_PATH" ]; then git clone https://github.com/xwp/wp-dev-lib.git $DEV_LIB_PATH; fi
33 | - source $DEV_LIB_PATH/travis.install.sh
34 |
35 | script:
36 | - source $DEV_LIB_PATH/travis.script.sh
37 |
38 | after_script:
39 | - source $DEV_LIB_PATH/travis.after_script.sh
40 |
--------------------------------------------------------------------------------
/Gruntfile.js:
--------------------------------------------------------------------------------
1 | /* eslint-env node */
2 | /* jshint node:true */
3 | /* eslint-disable no-param-reassign */
4 |
5 | module.exports = function( grunt ) {
6 | 'use strict';
7 |
8 | grunt.initConfig( {
9 |
10 | pkg: grunt.file.readJSON( 'package.json' ),
11 | pkgLock: grunt.file.readJSON( 'package-lock.json' ),
12 | codemirrorLicenseBlock: grunt.file.read( 'node_modules/codemirror/lib/codemirror.js' ).replace( /\(function(.|\s)+$/, '' ).replace( /(^|\n)\/\/ */g, '$1' ).trim(),
13 |
14 | browserify: {
15 | codemirror: {
16 | options: {
17 | banner: '/*! This file is auto-generated from CodeMirror - <%= pkgLock.dependencies.codemirror.version %>\n\n<%= codemirrorLicenseBlock %>\n*/\n\n'
18 | },
19 | src: 'wp-includes/js/codemirror/codemirror.manifest.js',
20 | dest: 'wp-includes/js/codemirror/codemirror.js'
21 | }
22 | },
23 |
24 | uglify: {
25 | options: {
26 | ASCIIOnly: true,
27 | screwIE8: false
28 | },
29 | codemirror: {
30 | options: {
31 |
32 | // Preserve comments that start with a bang.
33 | preserveComments: /^!/
34 | },
35 | src: 'wp-includes/js/codemirror/codemirror.js',
36 | dest: 'wp-includes/js/codemirror/codemirror.min.js'
37 | }
38 | },
39 |
40 | concat: {
41 | codemirror: {
42 | options: {
43 | banner: '/*! This file is auto-generated from CodeMirror - <%= pkgLock.dependencies.codemirror.version %>\n\n<%= codemirrorLicenseBlock %>\n*/\n\n',
44 | separator: '\n',
45 | process: function( src, filepath ) {
46 | return '/* Source: ' + filepath.replace( 'node_modules/', '' ) + '*/\n' + src;
47 | }
48 | },
49 | src: [
50 | 'node_modules/codemirror/lib/codemirror.css',
51 | 'node_modules/codemirror/addon/hint/show-hint.css',
52 | 'node_modules/codemirror/addon/lint/lint.css',
53 | 'node_modules/codemirror/addon/dialog/dialog.css',
54 | 'node_modules/codemirror/addon/display/fullscreen.css',
55 | 'node_modules/codemirror/addon/fold/foldgutter.css',
56 | 'node_modules/codemirror/addon/merge/merge.css',
57 | 'node_modules/codemirror/addon/scroll/simplescrollbars.css',
58 | 'node_modules/codemirror/addon/search/matchesonscrollbar.css',
59 | 'node_modules/codemirror/addon/tern/tern.css'
60 | ],
61 | dest: 'wp-includes/js/codemirror/codemirror.css'
62 | }
63 | },
64 |
65 | cssmin: {
66 | options: {
67 | compatibility: 'ie7'
68 | },
69 | codemirror: {
70 | expand: true,
71 | ext: '.min.css',
72 | src: [
73 | 'wp-includes/js/codemirror/codemirror.css'
74 | ]
75 | }
76 | },
77 |
78 | copy: {
79 | csslint: {
80 | src: 'node_modules/csslint/dist/csslint.js',
81 | dest: 'wp-includes/js/csslint.js'
82 | },
83 | htmlhint: {
84 | src: 'node_modules/htmlhint/lib/htmlhint.js',
85 | dest: 'wp-includes/js/htmlhint.js'
86 | },
87 | jshint: {
88 | src: 'node_modules/jshint/dist/jshint.js',
89 | dest: 'wp-includes/js/jshint.js'
90 | },
91 | jsonlint: {
92 | src: 'node_modules/jsonlint/lib/jsonlint.js',
93 | dest: 'wp-includes/js/jsonlint.js'
94 | }
95 | },
96 |
97 | rtlcss: {
98 | options: {
99 | opts: {
100 | clean: false,
101 | processUrls: { atrule: true, decl: false },
102 | stringMap: [
103 | {
104 | name: 'import-rtl-stylesheet',
105 | priority: 10,
106 | exclusive: true,
107 | search: [ '.css' ],
108 | replace: [ '-rtl.css' ],
109 | options: {
110 | scope: 'url',
111 | ignoreCase: false
112 | }
113 | }
114 | ]
115 | },
116 | saveUnmodified: true,
117 | plugins: [
118 | {
119 | name: 'swap-dashicons-left-right-arrows',
120 | priority: 10,
121 | directives: {
122 | control: {},
123 | value: []
124 | },
125 | processors: [
126 | {
127 | expr: /content/im,
128 | action: function( prop, value ) {
129 | if ( '"\\f141"' === value ) { // Glyph: dashicons-arrow-left.
130 | value = '"\\f139"';
131 | } else if ( '"\\f340"' === value ) { // Glyph: dashicons-arrow-left-alt.
132 | value = '"\\f344"';
133 | } else if ( '"\\f341"' === value ) { // Glyph: dashicons-arrow-left-alt2.
134 | value = '"\\f345"';
135 | } else if ( '"\\f139"' === value ) { // Glyph: dashicons-arrow-right.
136 | value = '"\\f141"';
137 | } else if ( '"\\f344"' === value ) { // Glyph: dashicons-arrow-right-alt.
138 | value = '"\\f340"';
139 | } else if ( '"\\f345"' === value ) { // Glyph: dashicons-arrow-right-alt2.
140 | value = '"\\f341"';
141 | }
142 | return { prop: prop, value: value };
143 | }
144 | }
145 | ]
146 | }
147 | ]
148 | },
149 | core: {
150 | expand: true,
151 | ext: '-rtl.css',
152 | src: [
153 | 'wp-admin/css/*.css',
154 | '!wp-admin/css/*-rtl.css'
155 | ]
156 | }
157 | },
158 |
159 | // Clean up the build
160 | clean: {
161 | build: {
162 | src: [ 'build' ]
163 | }
164 | },
165 |
166 | // Shell actions
167 | shell: {
168 | options: {
169 | stdout: true,
170 | stderr: true
171 | },
172 | readme: {
173 | command: 'php dev-lib/generate-markdown-readme' // Generate the readme.md
174 | },
175 | lint: {
176 | command: 'CHECK_SCOPE=all bash dev-lib/pre-commit'
177 | },
178 | build_release_zip: {
179 | command: 'if [ -e build ]; then rm -r build; fi; mkdir build; rsync -avz ./ build/ --exclude-from=.svnignore; if [ -e better-code-editing.zip ]; then rm better-code-editing.zip; fi; cd build; zip -r ../better-code-editing.zip .; cd ..; echo; echo "Please see: $(pwd)/better-code-editing.zip"'
180 | },
181 | verify_matching_versions: {
182 | command: 'php bin/verify-version-consistency.php'
183 | }
184 | },
185 |
186 | // Deploys a git Repo to the WordPress SVN repo
187 | wp_deploy: {
188 | deploy: {
189 | options: {
190 | plugin_slug: '<%= pkg.name %>',
191 | build_dir: 'build',
192 | assets_dir: 'wp-assets'
193 | }
194 | }
195 | }
196 |
197 | } );
198 |
199 | // Load tasks
200 | grunt.loadNpmTasks( 'grunt-contrib-clean' );
201 | grunt.loadNpmTasks( 'grunt-contrib-copy' );
202 | grunt.loadNpmTasks( 'grunt-shell' );
203 | grunt.loadNpmTasks( 'grunt-wp-deploy' );
204 | grunt.loadNpmTasks( 'grunt-rtlcss' );
205 | grunt.loadNpmTasks( 'grunt-browserify' );
206 | grunt.loadNpmTasks( 'grunt-contrib-concat' );
207 | grunt.loadNpmTasks( 'grunt-contrib-uglify' );
208 | grunt.loadNpmTasks( 'grunt-contrib-cssmin' );
209 |
210 | grunt.registerTask( 'rtl', [ 'rtlcss:core' ] );
211 |
212 | // Register tasks
213 | grunt.registerTask( 'default', [
214 | 'build'
215 | ] );
216 |
217 | grunt.registerTask( 'readme', [
218 | 'shell:readme'
219 | ] );
220 |
221 | grunt.registerTask( 'build', [
222 | 'readme',
223 | 'copy',
224 | 'shell:verify_matching_versions',
225 | 'shell:lint',
226 |
227 | 'browserify',
228 | 'uglify',
229 |
230 | 'concat',
231 | 'cssmin',
232 | 'rtl'
233 | ] );
234 |
235 | grunt.registerTask( 'build-release-zip', [
236 | 'build',
237 | 'shell:build_release_zip'
238 | ] );
239 |
240 | grunt.registerTask( 'deploy', [
241 | 'build',
242 | 'shell:build_release_zip',
243 | 'wp_deploy',
244 | 'clean'
245 | ] );
246 |
247 | };
248 |
--------------------------------------------------------------------------------
/better-code-editing.php:
--------------------------------------------------------------------------------
1 | base ) {
21 | return;
22 | }
23 | ?>
24 |
27 |
35 |
36 |
npm install from the command line. Otherwise, please install the plugin from WordPress.org or via a ZIP from the GitHub releases page..', 'better-code-editing' ); ?>
37 |
38 | version;
12 | $versions['package-lock.json'] = json_decode( file_get_contents( dirname( __FILE__ ) . '/../package-lock.json' ) )->version;
13 | $versions['composer.json'] = json_decode( file_get_contents( dirname( __FILE__ ) . '/../composer.json' ) )->version;
14 |
15 | $readme_txt = file_get_contents( dirname( __FILE__ ) . '/../readme.txt' );
16 | if ( ! preg_match( '/Stable tag:\s+(?P\S+)/i', $readme_txt, $matches ) ) {
17 | echo "Could not find stable tag in readme\n";
18 | exit( 1 );
19 | }
20 | $versions['readme.txt#stable-tag'] = $matches['version'];
21 |
22 | if ( ! preg_match( '/== Changelog ==\s+=\s+(?P\d+\.\d+(?:.\d+)?)/', $readme_txt, $matches ) ) {
23 | echo "Could not find version in readme.txt changelog\n";
24 | exit( 1 );
25 | }
26 | $versions['readme.txt#changelog'] = $matches['version'];
27 |
28 | $readme_md = file_get_contents( dirname( __FILE__ ) . '/../readme.md' );
29 | if ( ! preg_match( '/## Changelog ##\s+###\s+(?P\d+\.\d+(?:.\d+)?)/', $readme_md, $matches ) ) {
30 | echo "Could not find version in readme.md changelog\n";
31 | exit( 1 );
32 | }
33 | $versions['readme.md#changelog'] = $matches['version'];
34 |
35 | $plugin_file = file_get_contents( dirname( __FILE__ ) . '/../better-code-editing.php' );
36 | if ( ! preg_match( '/\*\s*Version:\s*(?P\d+\.\d+(?:.\d+)?)/', $plugin_file, $matches ) ) {
37 | echo "Could not find version in readme metadata\n";
38 | exit( 1 );
39 | }
40 | $versions['better-code-editing.php#metadata'] = $matches['version'];
41 |
42 | if ( ! preg_match( '/define\( \'BETTER_CODE_EDITING_PLUGIN_VERSION\', \'(?P\d+\.\d+(?:.\d+)?)\'/', $plugin_file, $matches ) ) {
43 | echo "Could not find version in BETTER_CODE_EDITING_PLUGIN_VERSION constant\n";
44 | exit( 1 );
45 | }
46 | $versions['BETTER_CODE_EDITING_PLUGIN_VERSION'] = $matches['version'];
47 |
48 | echo "Version references:\n";
49 | print_r( $versions );
50 |
51 | if ( 1 !== count( array_unique( $versions ) ) ) {
52 | echo "Not all version references have been updated\n.";
53 | exit( 1 );
54 | }
55 |
--------------------------------------------------------------------------------
/composer.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "wordpress/better-code-editing",
3 | "version": "0.7.0",
4 | "description": "Adding CodeMirror functionality to the Plugin and Theme file editors, as well as the Customizer Custom CSS box and Custom HTML widget.",
5 | "homepage": "https://github.com/WordPress/better-code-editing/",
6 | "type": "wordpress-plugin",
7 | "license": "GPL-2.0",
8 | "repositories": [
9 | {
10 | "type": "git",
11 | "url": "https://github.com/WordPress/better-code-editing.git"
12 | }
13 | ],
14 | "require": {
15 | "php": ">=5.2"
16 | },
17 | "require-dev": {
18 | "wp-coding-standards/wpcs": "*",
19 | "wimg/php-compatibility": "*",
20 | "dealerdirect/phpcodesniffer-composer-installer": "^0.4.2"
21 | },
22 | "dist": {
23 | "url": "https://downloads.wordpress.org/plugin/better-code-editing.zip",
24 | "type": "zip"
25 | }
26 | }
27 |
--------------------------------------------------------------------------------
/composer.lock:
--------------------------------------------------------------------------------
1 | {
2 | "_readme": [
3 | "This file locks the dependencies of your project to a known state",
4 | "Read more about it at https://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file",
5 | "This file is @generated automatically"
6 | ],
7 | "content-hash": "5a9063efcbeb166cbbf16b017996aade",
8 | "packages": [],
9 | "packages-dev": [
10 | {
11 | "name": "dealerdirect/phpcodesniffer-composer-installer",
12 | "version": "v0.4.2",
13 | "source": {
14 | "type": "git",
15 | "url": "https://github.com/DealerDirect/phpcodesniffer-composer-installer.git",
16 | "reference": "17130f536db62570bcfc5cce59464b36e82eb092"
17 | },
18 | "dist": {
19 | "type": "zip",
20 | "url": "https://api.github.com/repos/DealerDirect/phpcodesniffer-composer-installer/zipball/17130f536db62570bcfc5cce59464b36e82eb092",
21 | "reference": "17130f536db62570bcfc5cce59464b36e82eb092",
22 | "shasum": ""
23 | },
24 | "require": {
25 | "composer-plugin-api": "^1.0",
26 | "squizlabs/php_codesniffer": "*"
27 | },
28 | "require-dev": {
29 | "composer/composer": "*"
30 | },
31 | "suggest": {
32 | "dealerdirect/qa-tools": "All the PHP QA tools you'll need"
33 | },
34 | "type": "composer-plugin",
35 | "extra": {
36 | "class": "Dealerdirect\\Composer\\Plugin\\Installers\\PHPCodeSniffer\\Plugin"
37 | },
38 | "autoload": {
39 | "psr-4": {
40 | "Dealerdirect\\Composer\\Plugin\\Installers\\PHPCodeSniffer\\": "src/"
41 | }
42 | },
43 | "notification-url": "https://packagist.org/downloads/",
44 | "license": [
45 | "MIT"
46 | ],
47 | "authors": [
48 | {
49 | "name": "Franck Nijhof",
50 | "email": "f.nijhof@dealerdirect.nl",
51 | "homepage": "http://workingatdealerdirect.eu",
52 | "role": "Developer"
53 | }
54 | ],
55 | "description": "PHP_CodeSniffer Standards Composer Installer Plugin",
56 | "homepage": "http://workingatdealerdirect.eu",
57 | "keywords": [
58 | "PHPCodeSniffer",
59 | "PHP_CodeSniffer",
60 | "code quality",
61 | "codesniffer",
62 | "composer",
63 | "installer",
64 | "phpcs",
65 | "plugin",
66 | "qa",
67 | "quality",
68 | "standard",
69 | "standards",
70 | "style guide",
71 | "stylecheck",
72 | "tests"
73 | ],
74 | "time": "2017-08-16T10:25:17+00:00"
75 | },
76 | {
77 | "name": "squizlabs/php_codesniffer",
78 | "version": "3.0.2",
79 | "source": {
80 | "type": "git",
81 | "url": "https://github.com/squizlabs/PHP_CodeSniffer.git",
82 | "reference": "c7594a88ae75401e8f8d0bd4deb8431b39045c51"
83 | },
84 | "dist": {
85 | "type": "zip",
86 | "url": "https://api.github.com/repos/squizlabs/PHP_CodeSniffer/zipball/c7594a88ae75401e8f8d0bd4deb8431b39045c51",
87 | "reference": "c7594a88ae75401e8f8d0bd4deb8431b39045c51",
88 | "shasum": ""
89 | },
90 | "require": {
91 | "ext-simplexml": "*",
92 | "ext-tokenizer": "*",
93 | "ext-xmlwriter": "*",
94 | "php": ">=5.4.0"
95 | },
96 | "require-dev": {
97 | "phpunit/phpunit": "~4.0"
98 | },
99 | "bin": [
100 | "bin/phpcs",
101 | "bin/phpcbf"
102 | ],
103 | "type": "library",
104 | "extra": {
105 | "branch-alias": {
106 | "dev-master": "3.x-dev"
107 | }
108 | },
109 | "notification-url": "https://packagist.org/downloads/",
110 | "license": [
111 | "BSD-3-Clause"
112 | ],
113 | "authors": [
114 | {
115 | "name": "Greg Sherwood",
116 | "role": "lead"
117 | }
118 | ],
119 | "description": "PHP_CodeSniffer tokenizes PHP, JavaScript and CSS files and detects violations of a defined set of coding standards.",
120 | "homepage": "http://www.squizlabs.com/php-codesniffer",
121 | "keywords": [
122 | "phpcs",
123 | "standards"
124 | ],
125 | "time": "2017-07-18T01:12:32+00:00"
126 | },
127 | {
128 | "name": "wimg/php-compatibility",
129 | "version": "8.0.1",
130 | "source": {
131 | "type": "git",
132 | "url": "https://github.com/wimg/PHPCompatibility.git",
133 | "reference": "4c4385fb891dff0501009670f988d4fe36785249"
134 | },
135 | "dist": {
136 | "type": "zip",
137 | "url": "https://api.github.com/repos/wimg/PHPCompatibility/zipball/4c4385fb891dff0501009670f988d4fe36785249",
138 | "reference": "4c4385fb891dff0501009670f988d4fe36785249",
139 | "shasum": ""
140 | },
141 | "require": {
142 | "php": ">=5.3",
143 | "squizlabs/php_codesniffer": "^2.2 || ^3.0.2"
144 | },
145 | "conflict": {
146 | "squizlabs/php_codesniffer": "2.6.2"
147 | },
148 | "require-dev": {
149 | "phpunit/phpunit": "^4.0 || ^5.0 || ^6.0"
150 | },
151 | "suggest": {
152 | "dealerdirect/phpcodesniffer-composer-installer": "^0.4.1"
153 | },
154 | "type": "phpcodesniffer-standard",
155 | "autoload": {
156 | "psr-4": {
157 | "PHPCompatibility\\": "PHPCompatibility/"
158 | }
159 | },
160 | "notification-url": "https://packagist.org/downloads/",
161 | "license": [
162 | "LGPL-3.0"
163 | ],
164 | "authors": [
165 | {
166 | "name": "Wim Godden",
167 | "role": "lead"
168 | }
169 | ],
170 | "description": "A set of sniffs for PHP_CodeSniffer that checks for PHP version compatibility.",
171 | "homepage": "http://techblog.wimgodden.be/tag/codesniffer/",
172 | "keywords": [
173 | "compatibility",
174 | "phpcs",
175 | "standards"
176 | ],
177 | "time": "2017-08-07T19:39:05+00:00"
178 | },
179 | {
180 | "name": "wp-coding-standards/wpcs",
181 | "version": "0.13.1",
182 | "source": {
183 | "type": "git",
184 | "url": "https://github.com/WordPress-Coding-Standards/WordPress-Coding-Standards.git",
185 | "reference": "1f64b1a0b5b789822d0303436ee4e30e0135e4dc"
186 | },
187 | "dist": {
188 | "type": "zip",
189 | "url": "https://api.github.com/repos/WordPress-Coding-Standards/WordPress-Coding-Standards/zipball/1f64b1a0b5b789822d0303436ee4e30e0135e4dc",
190 | "reference": "1f64b1a0b5b789822d0303436ee4e30e0135e4dc",
191 | "shasum": ""
192 | },
193 | "require": {
194 | "php": ">=5.3",
195 | "squizlabs/php_codesniffer": "^2.9.0 || ^3.0.2"
196 | },
197 | "suggest": {
198 | "dealerdirect/phpcodesniffer-composer-installer": "^0.4.1"
199 | },
200 | "type": "phpcodesniffer-standard",
201 | "notification-url": "https://packagist.org/downloads/",
202 | "license": [
203 | "MIT"
204 | ],
205 | "authors": [
206 | {
207 | "name": "Contributors",
208 | "homepage": "https://github.com/WordPress-Coding-Standards/WordPress-Coding-Standards/graphs/contributors"
209 | }
210 | ],
211 | "description": "PHP_CodeSniffer rules (sniffs) to enforce WordPress coding conventions",
212 | "keywords": [
213 | "phpcs",
214 | "standards",
215 | "wordpress"
216 | ],
217 | "time": "2017-08-05T16:08:58+00:00"
218 | }
219 | ],
220 | "aliases": [],
221 | "minimum-stability": "stable",
222 | "stability-flags": [],
223 | "prefer-stable": false,
224 | "prefer-lowest": false,
225 | "platform": {
226 | "php": ">=5.2"
227 | },
228 | "platform-dev": []
229 | }
230 |
--------------------------------------------------------------------------------
/contributing.md:
--------------------------------------------------------------------------------
1 | # Getting Started
2 |
3 | You can locate a ZIP for this plugin on the [releases page](https://github.com/WordPress/better-code-editing/releases) on GitHub. To install, simply go to your WP Admin and Plugins > Add New. Then click "Upload Plugin" and select the `better-code-editing.zip` you downloaded from the releases page. Then click "Install Now" and on the next screen click "Activate Plugin". _Note on upgrading:_ If you want to update the plugin from a previous version, you must first deactivate it and uninstall it completely and then re-install and re-activate the new version (see [#9757](https://core.trac.wordpress.org/ticket/9757) for fixing this).
4 |
5 | Otherwise, to set up the plugin for development: clone this repository and run `npm install` to download CodeMirror and other assets.
6 |
7 | ```bash
8 | cd wp-content/plugins/
9 | git clone --recursive https://github.com/WordPress/better-code-editing.git
10 | cd better-code-editing
11 | npm install
12 | ```
13 |
14 | Also install the pre-commit hook via:
15 |
16 | ```bash
17 | cd .git/hooks && ln -s ../../dev-lib/pre-commit pre-commit && cd -
18 | ```
19 |
20 | # Creating a Release
21 |
22 | Contributors who want to make a new release, follow these steps:
23 |
24 | 1. Bump plugin versions in `package.json` (×1), `package-lock.json` (×1, just do `npm install` first), `composer.json` (×1), and in `better-code-editing.php` (×2: the metadata block in the header and also the `BETTER_CODE_EDITING_PLUGIN_VERSION` constant).
25 | 2. Run `grunt deploy` to create a `better-code-editing.zip` in the plugin's root directory and to commit the plugin to WordPress.org.
26 | 3. [Create new release](https://github.com/WordPress/better-code-editing/releases/new) on GitHub targeting `master`, with the new plugin version as the tag and release title, and upload the `better-code-editing.zip` as the associated binary. Publish the release.
27 |
--------------------------------------------------------------------------------
/core-commit-message.txt:
--------------------------------------------------------------------------------
1 | Editor: Add CodeMirror-powered code editor with syntax highlighting, linting, and auto-completion.
2 |
3 | * Code editor is integrated into the Theme/Plugin Editor, Additional CSS in Customizer, and Custom HTML widget.
4 | * The CodeMirror component in the Custom HTML widget is integrated in a similar way to TinyMCE being integrated into the Text widget, adopting the same approach for integrating dynamic JavaScript-initialized fields.
5 | * Linting is performed for JS, CSS, HTML, and JSON via JSHint, CSSLint, HTMLHint, and JSONLint respectively. Linting is not yet supported for PHP.
6 | * When user lacks `unfiltered_html` the capability, the Custom HTML widget will report any Kses-invalid elements and attributes as errors via a custom Kses rule for HTMLHint.
7 | * When linting errors are detected, the user will be prevented from saving the code until the errors are fixed, reducing instances of broken websites.
8 | * Code editor is not yet integrated into the post editor.
9 | * Placeholder value is removed from Custom CSS in favor of a fleshed-out section description which now auto-expands when the CSS field is empty. See #39892.
10 | * Introduces `wp.codeEditor.initialize()` in JS to convert a `textarea` into CodeMirror, with a `wp_enqueue_code_editor()` function in PHP to manage enqueueing the assets and settings needed to edit a given type of code.
11 | * User preference is added to manage whether or not "syntax highlighting" is enabled. The feature is opt-out, being enabled by default.
12 | * Update allowed file extensions in theme and plugin editors to include formats which CodeMirror has modes for: `conf`, `css`, `diff`, `patch`, `html`, `htm`, `http`, `js`, `json`, `jsx`, `less`, `md`, `php`, `phtml`, `php3`, `php4`, `php5`, `php7`, `phps`, `scss`, `sass`, `sh`, `bash`, `sql`, `svg`, `xml`, `yml`, `yaml`, `txt`.
13 |
14 | Props westonruter, georgestephanis, obenland, melchoyce, pixolin, mizejewski, michelleweber.
15 | See #38707.
16 | Fixes #12423, #39892.
17 |
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "better-code-editing",
3 | "version": "0.7.0",
4 | "description": "Adding CodeMirror functionality to the Plugin and Theme file editors, as well as the Customizer Custom CSS box and Custom HTML widget.",
5 | "scripts": {
6 | "test": "echo \"Error: no test specified\" && exit 1",
7 | "postinstall": "composer install; grunt build"
8 | },
9 | "repository": {
10 | "type": "git",
11 | "url": "git+https://github.com/WordPress/better-code-editing.git"
12 | },
13 | "author": "WordPress Contributors",
14 | "license": "GPL-2.0",
15 | "bugs": {
16 | "url": "https://github.com/WordPress/better-code-editing/issues"
17 | },
18 | "browserify": {
19 | "transform": [
20 | "browserify-shim"
21 | ]
22 | },
23 | "browserify-shim": {
24 | "htmlhint": "global:HTMLHint",
25 | "jshint": "global:JSHINT",
26 | "csslint": "global:CSSLint",
27 | "jsonlint": "global:JSONLint"
28 | },
29 | "homepage": "https://github.com/WordPress/better-code-editing#readme",
30 | "devDependencies": {
31 | "browserify-shim": "^3.8.14",
32 | "eslint": "^4.5.0",
33 | "grunt": "^1.0.1",
34 | "grunt-browserify": "^5.2.0",
35 | "grunt-cli": "^1.2.0",
36 | "grunt-contrib-clean": "^1.1.0",
37 | "grunt-contrib-concat": "^1.0.1",
38 | "grunt-contrib-copy": "^1.0.0",
39 | "grunt-contrib-cssmin": "~1.0.2",
40 | "grunt-contrib-uglify": "~2.0.0",
41 | "grunt-rtlcss": "^2.0.1",
42 | "grunt-shell": "^2.1.0",
43 | "grunt-wp-deploy": "^1.2.1",
44 | "jscs": "^3.0.7"
45 | },
46 | "dependencies": {
47 | "codemirror": "github:codemirror/CodeMirror",
48 | "csslint": "1.0.5",
49 | "htmlhint": "github:xwp/HTMLHint",
50 | "jshint": "^2.9.5",
51 | "jsonlint": "1.6.2"
52 | }
53 | }
54 |
--------------------------------------------------------------------------------
/phpcs.xml:
--------------------------------------------------------------------------------
1 |
2 |
3 | Generally-applicable sniffs for WordPress plugins
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
20 |
21 |
22 | .
23 |
24 |
25 | 0
26 |
27 |
28 | */dev-lib/*
29 | */node_modules/*
30 | */vendor/*
31 |
32 |
--------------------------------------------------------------------------------
/readme.md:
--------------------------------------------------------------------------------
1 |
2 | # Better Code Editing
3 |
4 | Adding CodeMirror functionality to the Plugin and Theme file editors, as well as the Customizer Custom CSS box and Custom HTML widget.
5 |
6 | **Contributors:** [georgestephanis](https://profiles.wordpress.org/georgestephanis), [westonruter](https://profiles.wordpress.org/westonruter), [obenland](https://profiles.wordpress.org/obenland), [melchoyce](https://profiles.wordpress.org/melchoyce), [wordpressdotorg](https://profiles.wordpress.org/wordpressdotorg)
7 | **Tags:** [codemirror](https://wordpress.org/plugins/tags/codemirror), [syntax-highlighter](https://wordpress.org/plugins/tags/syntax-highlighter), [linting](https://wordpress.org/plugins/tags/linting)
8 | **Requires at least:** 4.7
9 | **Tested up to:** 4.9-alpha
10 | **Stable tag:** 0.7.0
11 |
12 | [](https://travis-ci.org/WordPress/better-code-editing) [](http://gruntjs.com)
13 |
14 | ## Description ##
15 |
16 | *Notice*: This feature plugin has been merged into core via [r41376](https://core.trac.wordpress.org/changeset/41376). Please test on WordPress 4.9-alpha in a non-production environment. Read more about [beta testing](https://make.wordpress.org/core/handbook/testing/beta/). This plugin will do nothing on a nightly release.
17 |
18 | ***
19 |
20 | This project is adding CodeMirror functionality to the Plugin and Theme file editors, as well as the Customizer Custom CSS box and the Custom HTML widget.
21 |
22 | We're working around discussion on a Core ticket, [#12423](https://core.trac.wordpress.org/ticket/12423)
23 |
24 | Any questions, reach out to #core-customize on WordPress.org Slack or better open an issue on GitHub! See [contributing](https://github.com/WordPress/better-code-editing/blob/master/contributing.md).
25 |
26 | **Development of this plugin is done [on GitHub](https://github.com/WordPress/better-code-editing). Pull requests welcome. Please see [issues](https://github.com/WordPress/better-code-editing/issues) reported there.**
27 |
28 | ## Changelog ##
29 |
30 | ### 0.7.0 - 2017-09-12 ###
31 | * Create minified bundles for CodeMirror assets. See [#92](https://github.com/WordPress/better-code-editing/pull/92). Fixes [#71](https://github.com/WordPress/better-code-editing/issues/71).
32 | * Fix tabbing backward when Additional CSS section description is expanded, to focus on Close link instead of Help toggle. See [#91](https://github.com/WordPress/better-code-editing/pull/91). Fixes [#90](https://github.com/WordPress/better-code-editing/issues/90).
33 |
34 | ### 0.6.0 - 2017-09-08 ###
35 | * Improve frequency for when linting error notifications are shown and remove some overly-strict rules. See [#86](https://github.com/WordPress/better-code-editing/pull/86). Fixes [#13](https://github.com/WordPress/better-code-editing/pull/13).
36 | * Improve disabling of save button for Custom HTML widget. See [#87](https://github.com/WordPress/better-code-editing/pull/87).
37 | * Enable search addon so that attempting to do a find inside the editor will search contents of file and not use browser find dialog. See [#76](https://github.com/WordPress/better-code-editing/pull/76). Fixes [#75](https://github.com/WordPress/better-code-editing/pull/75).
38 | * Auto-show Custom CSS section description when value is empty, add close link to bottom of description, and remove default placeholder value for Custom CSS field. See [#84](https://github.com/WordPress/better-code-editing/pull/84). Fixes [#79](https://github.com/WordPress/better-code-editing/pull/79) and [core#39892](https://core.trac.wordpress.org/ticket/39892).
39 | * Improve passing of linting rulesets to CodeMirror and update CodeMirror to 5.29.1-alpha. See [#59](https://github.com/WordPress/better-code-editing/pull/59).
40 | * Merge `wp_code_editor_settings()` into `wp_enqueue_code_editor()`. See [#81](https://github.com/WordPress/better-code-editing/pull/81). Fixes [#55](https://github.com/WordPress/better-code-editing/pull/55).
41 | * Add support for RTL languages. See [#80](https://github.com/WordPress/better-code-editing/pull/80). Fixes [#72](https://github.com/WordPress/better-code-editing/pull/72).
42 | * Add admin notice to instruct `npm install` when plugin installed from source. See [#74](https://github.com/WordPress/better-code-editing/pull/74). Fixes [#73](https://github.com/WordPress/better-code-editing/pull/73).
43 | * Update dev-lib to use local tools and add PHPCompatibility sniffs. See [#82](https://github.com/WordPress/better-code-editing/pull/82).
44 | * See full commit log and diff: [0.5.0...0.6.0](https://github.com/WordPress/better-code-editing/compare/0.5.0...0.6.0).
45 |
46 | ### 0.5.0 - 2017-08-30 ###
47 | * Prevent saving when lint errors present. See [#69](https://github.com/WordPress/better-code-editing/pull/69). Fixes [#69](https://github.com/WordPress/better-code-editing/issues/69).
48 | * Remove unused assets; register likely-used assets; allow recognized file types to be edited; allow passing type when getting settings in addition to file. See [#66](https://github.com/WordPress/better-code-editing/pull/66). Fixes [#4](https://github.com/WordPress/better-code-editing/issues/4).
49 | * Add recognition for JSON mode.
50 | * Align styling matchbracket with matchtag. See [#63](https://github.com/WordPress/better-code-editing/pull/63). Fixes [#56](https://github.com/WordPress/better-code-editing/issues/56).
51 | * Redesign warning/error messages. See [#62](https://github.com/WordPress/better-code-editing/pull/62). Fixes [#44](https://github.com/WordPress/better-code-editing/issues/44), [#45](https://github.com/WordPress/better-code-editing/issues/45).
52 | * Improve help text in widgets admin screen and Additional CSS in Customizer. See [#65](https://github.com/WordPress/better-code-editing/pull/65). Fixes [#36](https://github.com/WordPress/better-code-editing/issues/36).
53 | * Add `wp_enqueue_code_editor` action. See [#68](https://github.com/WordPress/better-code-editing/pull/68).
54 | * See full commit log and diff: [0.4.0...0.5.0](https://github.com/WordPress/better-code-editing/compare/0.4.0...0.5.0)
55 |
56 | ### 0.4.0 - 2017-08-28 ###
57 | * Enable addon many goodies to improve UX and reduce accidental errors. See [#52](https://github.com/WordPress/better-code-editing/pull/52).
58 | * Add autocomplete hinting. See [#51](https://github.com/WordPress/better-code-editing/pull/51) and [#50](https://github.com/WordPress/better-code-editing/issues/50).
59 | * Improve mixed-mode autocomplete hints, including PHP. See [#58](https://github.com/WordPress/better-code-editing/issues/58).
60 | * Configure HTMLHint including KSES rule. See [#47](https://github.com/WordPress/better-code-editing/pull/47).
61 | * Configure JSHint with same rules as core. See [#46](https://github.com/WordPress/better-code-editing/pull/46).
62 | * Limit CSSLint rules. See [#38](https://github.com/WordPress/better-code-editing/pull/38) and [#26](https://github.com/WordPress/better-code-editing/issues/26).
63 | * Add tab trap escaping for CodeMirror in Custom HTML widget and theme/plugin editors. See [#43](https://github.com/WordPress/better-code-editing/pull/43) and [#37](https://github.com/WordPress/better-code-editing/issues/37).
64 | * Rename codemirror-wp to better-code-editing. See [#42](https://github.com/WordPress/better-code-editing/pull/42).
65 | * Add plugin icon. See [#40](https://github.com/WordPress/better-code-editing/pull/40).
66 | * Fix errors on small screens. See [#39](https://github.com/WordPress/better-code-editing/pull/39) and [#11](https://github.com/WordPress/better-code-editing/issues/11).
67 | * Refactor plugin class into include files to facilitate core patch creation. See [#54](https://github.com/WordPress/better-code-editing/pull/54).
68 | * Add admin notice when plugin is obsolete. See [#57](https://github.com/WordPress/better-code-editing/pull/57).
69 | * Upgrade CodeMirror to 5.29.0.
70 | * See full commit log and diff: [0.3.0...0.4.0](https://github.com/WordPress/better-code-editing/compare/0.3.0...0.4.0)
71 |
72 | ### 0.3.0 - 2017-08-18 ###
73 | * Enable line-wrapping and constrain width for file editor to match `textarea`. See [#33](https://github.com/WordPress/better-code-editing/pull/33), [#5](https://github.com/WordPress/better-code-editing/issues/5), [#32](https://github.com/WordPress/better-code-editing/issues/32).
74 | * Improve accessibility of CodeMirror in Customizer's Additional CSS, including escape method from Tab trap. See [#34](https://github.com/WordPress/better-code-editing/pull/34) and [#29](https://github.com/WordPress/better-code-editing/issues/29).
75 | * Improve file organization to prepare for core merge.
76 | * See full commit log and diff: [0.2.0...0.3.0](https://github.com/WordPress/better-code-editing/compare/0.2.0...0.3.0)
77 |
78 | ### 0.2.0 - 2017-08-16 ###
79 | * Add user setting for disabling Syntax Highlighting. See [#31](https://github.com/WordPress/better-code-editing/pull/31).
80 | * Improve release builds.
81 | * See full commit log and diff: [0.1.0...0.2.0](https://github.com/WordPress/better-code-editing/compare/0.1.0...0.2.0)
82 |
83 | ### 0.1.0 - 2017-08-14 ###
84 | Initial release.
85 |
86 |
87 |
--------------------------------------------------------------------------------
/readme.txt:
--------------------------------------------------------------------------------
1 | === Better Code Editing ===
2 | Contributors: georgestephanis, westonruter, obenland, melchoyce, wordpressdotorg
3 | Tags: codemirror, syntax-highlighter, linting
4 | Stable tag: 0.7.0
5 | Requires at least: 4.7
6 | Tested up to: 4.9-alpha
7 |
8 | Adding CodeMirror functionality to the Plugin and Theme file editors, as well as the Customizer Custom CSS box and Custom HTML widget.
9 |
10 | == Description ==
11 |
12 | *Notice*: This feature plugin has been merged into core via [r41376](https://core.trac.wordpress.org/changeset/41376). Please test on WordPress 4.9-alpha in a non-production environment. Read more about [beta testing](https://make.wordpress.org/core/handbook/testing/beta/). This plugin will do nothing on a nightly release.
13 |
14 | ***
15 |
16 | This project is adding CodeMirror functionality to the Plugin and Theme file editors, as well as the Customizer Custom CSS box and the Custom HTML widget.
17 |
18 | We're working around discussion on a Core ticket, [#12423](https://core.trac.wordpress.org/ticket/12423)
19 |
20 | Any questions, reach out to #core-customize on WordPress.org Slack or better open an issue on GitHub! See [contributing](https://github.com/WordPress/better-code-editing/blob/master/contributing.md).
21 |
22 | **Development of this plugin is done [on GitHub](https://github.com/WordPress/better-code-editing). Pull requests welcome. Please see [issues](https://github.com/WordPress/better-code-editing/issues) reported there.**
23 |
24 | == Changelog ==
25 |
26 | = 0.7.0 - 2017-09-12 =
27 |
28 | * Create minified bundles for CodeMirror assets. See [#92](https://github.com/WordPress/better-code-editing/pull/92). Fixes [#71](https://github.com/WordPress/better-code-editing/issues/71).
29 | * Fix tabbing backward when Additional CSS section description is expanded, to focus on Close link instead of Help toggle. See [#91](https://github.com/WordPress/better-code-editing/pull/91). Fixes [#90](https://github.com/WordPress/better-code-editing/issues/90).
30 |
31 | = 0.6.0 - 2017-09-08 =
32 |
33 | * Improve frequency for when linting error notifications are shown and remove some overly-strict rules. See [#86](https://github.com/WordPress/better-code-editing/pull/86). Fixes [#13](https://github.com/WordPress/better-code-editing/pull/13).
34 | * Improve disabling of save button for Custom HTML widget. See [#87](https://github.com/WordPress/better-code-editing/pull/87).
35 | * Enable search addon so that attempting to do a find inside the editor will search contents of file and not use browser find dialog. See [#76](https://github.com/WordPress/better-code-editing/pull/76). Fixes [#75](https://github.com/WordPress/better-code-editing/pull/75).
36 | * Auto-show Custom CSS section description when value is empty, add close link to bottom of description, and remove default placeholder value for Custom CSS field. See [#84](https://github.com/WordPress/better-code-editing/pull/84). Fixes [#79](https://github.com/WordPress/better-code-editing/pull/79) and [core#39892](https://core.trac.wordpress.org/ticket/39892).
37 | * Improve passing of linting rulesets to CodeMirror and update CodeMirror to 5.29.1-alpha. See [#59](https://github.com/WordPress/better-code-editing/pull/59).
38 | * Merge `wp_code_editor_settings()` into `wp_enqueue_code_editor()`. See [#81](https://github.com/WordPress/better-code-editing/pull/81). Fixes [#55](https://github.com/WordPress/better-code-editing/pull/55).
39 | * Add support for RTL languages. See [#80](https://github.com/WordPress/better-code-editing/pull/80). Fixes [#72](https://github.com/WordPress/better-code-editing/pull/72).
40 | * Add admin notice to instruct `npm install` when plugin installed from source. See [#74](https://github.com/WordPress/better-code-editing/pull/74). Fixes [#73](https://github.com/WordPress/better-code-editing/pull/73).
41 | * Update dev-lib to use local tools and add PHPCompatibility sniffs. See [#82](https://github.com/WordPress/better-code-editing/pull/82).
42 | * See full commit log and diff: [0.5.0...0.6.0](https://github.com/WordPress/better-code-editing/compare/0.5.0...0.6.0).
43 |
44 | = 0.5.0 - 2017-08-30 =
45 |
46 | * Prevent saving when lint errors present. See [#69](https://github.com/WordPress/better-code-editing/pull/69). Fixes [#69](https://github.com/WordPress/better-code-editing/issues/69).
47 | * Remove unused assets; register likely-used assets; allow recognized file types to be edited; allow passing type when getting settings in addition to file. See [#66](https://github.com/WordPress/better-code-editing/pull/66). Fixes [#4](https://github.com/WordPress/better-code-editing/issues/4).
48 | * Add recognition for JSON mode.
49 | * Align styling matchbracket with matchtag. See [#63](https://github.com/WordPress/better-code-editing/pull/63). Fixes [#56](https://github.com/WordPress/better-code-editing/issues/56).
50 | * Redesign warning/error messages. See [#62](https://github.com/WordPress/better-code-editing/pull/62). Fixes [#44](https://github.com/WordPress/better-code-editing/issues/44), [#45](https://github.com/WordPress/better-code-editing/issues/45).
51 | * Improve help text in widgets admin screen and Additional CSS in Customizer. See [#65](https://github.com/WordPress/better-code-editing/pull/65). Fixes [#36](https://github.com/WordPress/better-code-editing/issues/36).
52 | * Add `wp_enqueue_code_editor` action. See [#68](https://github.com/WordPress/better-code-editing/pull/68).
53 | * See full commit log and diff: [0.4.0...0.5.0](https://github.com/WordPress/better-code-editing/compare/0.4.0...0.5.0)
54 |
55 | = 0.4.0 - 2017-08-28 =
56 |
57 | * Enable addon many goodies to improve UX and reduce accidental errors. See [#52](https://github.com/WordPress/better-code-editing/pull/52).
58 | * Add autocomplete hinting. See [#51](https://github.com/WordPress/better-code-editing/pull/51) and [#50](https://github.com/WordPress/better-code-editing/issues/50).
59 | * Improve mixed-mode autocomplete hints, including PHP. See [#58](https://github.com/WordPress/better-code-editing/issues/58).
60 | * Configure HTMLHint including KSES rule. See [#47](https://github.com/WordPress/better-code-editing/pull/47).
61 | * Configure JSHint with same rules as core. See [#46](https://github.com/WordPress/better-code-editing/pull/46).
62 | * Limit CSSLint rules. See [#38](https://github.com/WordPress/better-code-editing/pull/38) and [#26](https://github.com/WordPress/better-code-editing/issues/26).
63 | * Add tab trap escaping for CodeMirror in Custom HTML widget and theme/plugin editors. See [#43](https://github.com/WordPress/better-code-editing/pull/43) and [#37](https://github.com/WordPress/better-code-editing/issues/37).
64 | * Rename codemirror-wp to better-code-editing. See [#42](https://github.com/WordPress/better-code-editing/pull/42).
65 | * Add plugin icon. See [#40](https://github.com/WordPress/better-code-editing/pull/40).
66 | * Fix errors on small screens. See [#39](https://github.com/WordPress/better-code-editing/pull/39) and [#11](https://github.com/WordPress/better-code-editing/issues/11).
67 | * Refactor plugin class into include files to facilitate core patch creation. See [#54](https://github.com/WordPress/better-code-editing/pull/54).
68 | * Add admin notice when plugin is obsolete. See [#57](https://github.com/WordPress/better-code-editing/pull/57).
69 | * Upgrade CodeMirror to 5.29.0.
70 | * See full commit log and diff: [0.3.0...0.4.0](https://github.com/WordPress/better-code-editing/compare/0.3.0...0.4.0)
71 |
72 | = 0.3.0 - 2017-08-18 =
73 |
74 | * Enable line-wrapping and constrain width for file editor to match `textarea`. See [#33](https://github.com/WordPress/better-code-editing/pull/33), [#5](https://github.com/WordPress/better-code-editing/issues/5), [#32](https://github.com/WordPress/better-code-editing/issues/32).
75 | * Improve accessibility of CodeMirror in Customizer's Additional CSS, including escape method from Tab trap. See [#34](https://github.com/WordPress/better-code-editing/pull/34) and [#29](https://github.com/WordPress/better-code-editing/issues/29).
76 | * Improve file organization to prepare for core merge.
77 | * See full commit log and diff: [0.2.0...0.3.0](https://github.com/WordPress/better-code-editing/compare/0.2.0...0.3.0)
78 |
79 | = 0.2.0 - 2017-08-16 =
80 |
81 | * Add user setting for disabling Syntax Highlighting. See [#31](https://github.com/WordPress/better-code-editing/pull/31).
82 | * Improve release builds.
83 | * See full commit log and diff: [0.1.0...0.2.0](https://github.com/WordPress/better-code-editing/compare/0.1.0...0.2.0)
84 |
85 | = 0.1.0 - 2017-08-14 =
86 |
87 | Initial release.
88 |
--------------------------------------------------------------------------------
/wp-admin/css/code-editor.css:
--------------------------------------------------------------------------------
1 | .cm-trailingspace {
2 | background: url() repeat-x bottom left;
3 | }
4 |
5 | .wrap [class*="CodeMirror-lint-marker"],
6 | .wp-core-ui [class*="CodeMirror-lint-message"],
7 | .wrap .CodeMirror-lint-marker-multiple {
8 | background-image: none;
9 | }
10 |
11 | .wrap [class*="CodeMirror-lint-marker"]:before {
12 | font: normal 18px/1 dashicons;
13 | position: relative;
14 | top: -2px;
15 | }
16 |
17 | /*rtl:ignore*/
18 | .wp-core-ui [class*="CodeMirror-lint-message"]:before {
19 | font: normal 16px/1 dashicons;
20 | left: 16px;
21 | position: absolute;
22 | }
23 |
24 | /*rtl:ignore*/
25 | .wp-core-ui .CodeMirror-lint-message-error,
26 | .wp-core-ui .CodeMirror-lint-message-warning {
27 | box-shadow: 0 1px 1px 0 rgba( 0, 0, 0, 0.1 );
28 | margin: 5px 0 2px;
29 | padding: 3px 12px 3px 28px;
30 | }
31 |
32 | /*rtl:ignore*/
33 | .wp-core-ui .CodeMirror-lint-message-warning {
34 | background-color: #fff8e5;
35 | border-left: 4px solid #ffb900;
36 | }
37 |
38 | /* rtl:ignore */
39 | .wrap .CodeMirror-lint-marker-warning:before,
40 | .wp-core-ui .CodeMirror-lint-message-warning:before {
41 | content: "\f534";
42 | color: #f6a306;
43 | }
44 |
45 | /*rtl:ignore*/
46 | .wp-core-ui .CodeMirror-lint-message-error {
47 | background-color: #fbeaea;
48 | border-left: 4px solid #dc3232;
49 | }
50 |
51 | /* rtl:ignore */
52 | .wrap .CodeMirror-lint-marker-error:before,
53 | .wp-core-ui .CodeMirror-lint-message-error:before {
54 | content: "\f153";
55 | color: #dc3232;
56 | }
57 |
58 | /* rtl:ignore */
59 | .wp-core-ui .CodeMirror-lint-tooltip {
60 | background: none;
61 | border: none;
62 | border-radius: 0;
63 | direction: ltr;
64 | }
65 |
66 | .wrap .CodeMirror .CodeMirror-matchingbracket {
67 | background: rgba(255, 150, 0, .3);
68 | color: inherit;
69 | }
70 | /* rtl:ignore */
71 | .CodeMirror {
72 | text-align: left;
73 | }
74 |
--------------------------------------------------------------------------------
/wp-admin/css/common.css:
--------------------------------------------------------------------------------
1 | /* 2 column liquid layout */
2 | #wpwrap {
3 | height: auto;
4 | min-height: 100%;
5 | width: 100%;
6 | position: relative;
7 | -webkit-font-smoothing: subpixel-antialiased;
8 | }
9 |
10 | #wpcontent {
11 | height: 100%;
12 | padding-left: 20px;
13 | }
14 |
15 | #wpcontent,
16 | #wpfooter {
17 | margin-left: 160px;
18 | }
19 |
20 | .folded #wpcontent,
21 | .folded #wpfooter {
22 | margin-left: 36px;
23 | }
24 |
25 | #wpbody-content {
26 | padding-bottom: 65px;
27 | float: left;
28 | width: 100%;
29 | overflow: visible !important;
30 | }
31 |
32 | /* inner 2 column liquid layout */
33 |
34 | .inner-sidebar {
35 | float: right;
36 | clear: right;
37 | display: none;
38 | width: 281px;
39 | position: relative;
40 | }
41 |
42 | .columns-2 .inner-sidebar {
43 | margin-right: auto;
44 | width: 286px;
45 | display: block;
46 | }
47 |
48 | .inner-sidebar #side-sortables,
49 | .columns-2 .inner-sidebar #side-sortables {
50 | min-height: 300px;
51 | width: 280px;
52 | padding: 0;
53 | }
54 |
55 | .has-right-sidebar .inner-sidebar {
56 | display: block;
57 | }
58 |
59 | .has-right-sidebar #post-body {
60 | float: left;
61 | clear: left;
62 | width: 100%;
63 | margin-right: -2000px;
64 | }
65 |
66 | .has-right-sidebar #post-body-content {
67 | margin-right: 300px;
68 | float: none;
69 | width: auto;
70 | }
71 |
72 | /* 2 columns main area */
73 |
74 | #col-left {
75 | float: left;
76 | width: 35%;
77 | }
78 |
79 | #col-right {
80 | float: right;
81 | width: 65%;
82 | }
83 |
84 | #col-left .col-wrap {
85 | padding: 0 6px 0 0;
86 | }
87 |
88 | #col-right .col-wrap {
89 | padding: 0 0 0 6px;
90 | }
91 |
92 | /* utility classes */
93 | .alignleft {
94 | float: left;
95 | }
96 |
97 | .alignright {
98 | float: right;
99 | }
100 |
101 | .textleft {
102 | text-align: left;
103 | }
104 |
105 | .textright {
106 | text-align: right;
107 | }
108 |
109 | .clear {
110 | clear: both;
111 | }
112 |
113 | /* modern clearfix */
114 | .wp-clearfix:after {
115 | content: "";
116 | display: table;
117 | clear: both;
118 | }
119 |
120 | /* Hide visually but not from screen readers */
121 | .screen-reader-text,
122 | .screen-reader-text span,
123 | .ui-helper-hidden-accessible {
124 | position: absolute;
125 | margin: -1px;
126 | padding: 0;
127 | height: 1px;
128 | width: 1px;
129 | overflow: hidden;
130 | clip: rect(0 0 0 0);
131 | border: 0;
132 | word-wrap: normal !important; /* many screen reader and browser combinations announce broken words as they would appear visually */
133 | }
134 |
135 | .screen-reader-shortcut {
136 | position: absolute;
137 | top: -1000em;
138 | }
139 |
140 | .screen-reader-shortcut:focus {
141 | left: 6px;
142 | top: -25px;
143 | height: auto;
144 | width: auto;
145 | display: block;
146 | font-size: 14px;
147 | font-weight: 600;
148 | padding: 15px 23px 14px;
149 | background: #f1f1f1;
150 | color: #0073aa;
151 | z-index: 100000;
152 | line-height: normal;
153 | box-shadow: 0 0 2px 2px rgba(0,0,0,.6);
154 | text-decoration: none;
155 | outline: none;
156 | }
157 |
158 | .hidden,
159 | .js .closed .inside,
160 | .js .hide-if-js,
161 | .no-js .hide-if-no-js,
162 | .js.wp-core-ui .hide-if-js,
163 | .js .wp-core-ui .hide-if-js,
164 | .no-js.wp-core-ui .hide-if-no-js,
165 | .no-js .wp-core-ui .hide-if-no-js {
166 | display: none;
167 | }
168 |
169 | /* @todo: Take a second look. Large chunks of shared color, from the colors.css merge */
170 | .widget-top,
171 | .menu-item-handle,
172 | .widget-inside,
173 | #menu-settings-column .accordion-container,
174 | #menu-management .menu-edit,
175 | .manage-menus,
176 | table.widefat,
177 | .stuffbox,
178 | p.popular-tags,
179 | .widgets-holder-wrap,
180 | .wp-editor-container,
181 | .popular-tags,
182 | .feature-filter,
183 | .imgedit-group,
184 | .comment-ays {
185 | border: 1px solid #e5e5e5;
186 | box-shadow: 0 1px 1px rgba(0,0,0,0.04);
187 | }
188 |
189 | table.widefat,
190 | .wp-editor-container,
191 | .stuffbox,
192 | p.popular-tags,
193 | .widgets-holder-wrap,
194 | .popular-tags,
195 | .feature-filter,
196 | .imgedit-group,
197 | .comment-ays {
198 | background: #fff;
199 | }
200 |
201 | /* general */
202 | html,
203 | body {
204 | height: 100%;
205 | margin: 0;
206 | padding: 0;
207 | }
208 |
209 | body {
210 | background: #f1f1f1;
211 | color: #444;
212 | font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
213 | font-size: 13px;
214 | line-height: 1.4em;
215 | min-width: 600px;
216 | }
217 |
218 | body.iframe {
219 | min-width: 0;
220 | padding-top: 1px;
221 | }
222 |
223 | body.modal-open {
224 | overflow: hidden;
225 | }
226 |
227 | body.mobile.modal-open #wpwrap {
228 | overflow: hidden;
229 | position: fixed;
230 | height: 100%;
231 | }
232 |
233 | iframe,
234 | img {
235 | border: 0;
236 | }
237 |
238 | td {
239 | font-family: inherit;
240 | font-size: inherit;
241 | font-weight: inherit;
242 | line-height: inherit;
243 | }
244 |
245 | /* Any change to the default link style must be applied to button-link too. */
246 | a {
247 | color: #0073aa;
248 | transition-property: border, background, color;
249 | transition-duration: .05s;
250 | transition-timing-function: ease-in-out;
251 | }
252 |
253 | a,
254 | div {
255 | outline: 0;
256 | }
257 |
258 | a:hover,
259 | a:active {
260 | color: #00a0d2;
261 | }
262 |
263 | a:focus,
264 | a:focus .media-icon img,
265 | .wp-person a:focus .gravatar {
266 | color: #124964;
267 | box-shadow:
268 | 0 0 0 1px #5b9dd9,
269 | 0 0 2px 1px rgba(30, 140, 190, .8);
270 | }
271 |
272 | .ie8 a:focus {
273 | outline: #5b9dd9 solid 1px;
274 | }
275 |
276 | #adminmenu a:focus,
277 | .screen-reader-text:focus {
278 | box-shadow: none;
279 | outline: none;
280 | }
281 |
282 | blockquote,
283 | q {
284 | quotes: none;
285 | }
286 |
287 | blockquote:before,
288 | blockquote:after,
289 | q:before,
290 | q:after {
291 | content: "";
292 | content: none;
293 | }
294 |
295 | p {
296 | font-size: 13px;
297 | line-height: 1.5;
298 | margin: 1em 0;
299 | }
300 |
301 | blockquote {
302 | margin: 1em;
303 | }
304 |
305 | li,
306 | dd {
307 | margin-bottom: 6px;
308 | }
309 |
310 | h1,
311 | h2,
312 | h3,
313 | h4,
314 | h5,
315 | h6 {
316 | display: block;
317 | font-weight: 600;
318 | }
319 |
320 | h1 {
321 | color: #23282d;
322 | font-size: 2em;
323 | margin: .67em 0;
324 | }
325 |
326 | h2,
327 | h3 {
328 | color: #23282d;
329 | font-size: 1.3em;
330 | margin: 1em 0;
331 | }
332 |
333 | .update-core-php h2 {
334 | margin-top: 2em;
335 | }
336 |
337 | .update-php h2,
338 | .update-messages h2,
339 | h4 {
340 | font-size: 1em;
341 | margin: 1.33em 0;
342 | }
343 |
344 | h5 {
345 | font-size: 0.83em;
346 | margin: 1.67em 0;
347 | }
348 |
349 | h6 {
350 | font-size: 0.67em;
351 | margin: 2.33em 0;
352 | }
353 |
354 | ul,
355 | ol {
356 | padding: 0;
357 | }
358 |
359 | ul {
360 | list-style: none;
361 | }
362 |
363 | ol {
364 | list-style-type: decimal;
365 | margin-left: 2em;
366 | }
367 |
368 | ul.ul-disc {
369 | list-style: disc outside;
370 | }
371 |
372 | ul.ul-square {
373 | list-style: square outside;
374 | }
375 |
376 | ol.ol-decimal {
377 | list-style: decimal outside;
378 | }
379 |
380 | ul.ul-disc,
381 | ul.ul-square,
382 | ol.ol-decimal {
383 | margin-left: 1.8em;
384 | }
385 |
386 | ul.ul-disc > li,
387 | ul.ul-square > li,
388 | ol.ol-decimal > li {
389 | margin: 0 0 0.5em;
390 | }
391 |
392 | /* rtl:ignore */
393 | .ltr {
394 | direction: ltr;
395 | }
396 |
397 | /* rtl:ignore */
398 | .code,
399 | code {
400 | font-family: Consolas, Monaco, monospace;
401 | direction: ltr;
402 | unicode-bidi: embed;
403 | }
404 |
405 | kbd,
406 | code {
407 | padding: 3px 5px 2px 5px;
408 | margin: 0 1px;
409 | background: #eaeaea;
410 | background: rgba(0,0,0,0.07);
411 | font-size: 13px;
412 | }
413 |
414 | .subsubsub {
415 | list-style: none;
416 | margin: 8px 0 0;
417 | padding: 0;
418 | font-size: 13px;
419 | float: left;
420 | color: #666;
421 | }
422 |
423 | .subsubsub a {
424 | line-height: 2;
425 | padding: .2em;
426 | text-decoration: none;
427 | }
428 |
429 | .subsubsub a .count,
430 | .subsubsub a.current .count {
431 | color: #555d66; /* #f1f1f1 background */
432 | font-weight: 400;
433 | }
434 |
435 | .subsubsub a.current {
436 | font-weight: 600;
437 | border: none;
438 | }
439 |
440 | .subsubsub li {
441 | display: inline-block;
442 | margin: 0;
443 | padding: 0;
444 | white-space: nowrap;
445 | }
446 |
447 | /* .widefat - main style for tables */
448 | .widefat {
449 | border-spacing: 0;
450 | width: 100%;
451 | clear: both;
452 | margin: 0;
453 | }
454 |
455 | .widefat * {
456 | word-wrap: break-word;
457 | }
458 |
459 | .widefat a,
460 | .widefat button.button-link {
461 | text-decoration: none;
462 | }
463 |
464 | .widefat td,
465 | .widefat th {
466 | padding: 8px 10px;
467 | }
468 |
469 | .widefat thead th,
470 | .widefat thead td {
471 | border-bottom: 1px solid #e1e1e1;
472 | }
473 |
474 | .widefat tfoot th,
475 | .widefat tfoot td {
476 | border-top: 1px solid #e1e1e1;
477 | border-bottom: none;
478 | }
479 |
480 | .widefat .no-items td {
481 | border-bottom-width: 0;
482 | }
483 |
484 | .widefat td {
485 | vertical-align: top;
486 | }
487 |
488 | .widefat td,
489 | .widefat td p,
490 | .widefat td ol,
491 | .widefat td ul {
492 | font-size: 13px;
493 | line-height: 1.5em;
494 | }
495 |
496 | .widefat th,
497 | .widefat thead td,
498 | .widefat tfoot td {
499 | text-align: left;
500 | line-height: 1.3em;
501 | font-size: 14px;
502 | }
503 |
504 | .widefat th input,
505 | .updates-table td input,
506 | .widefat thead td input,
507 | .widefat tfoot td input {
508 | margin: 0 0 0 8px;
509 | padding: 0;
510 | vertical-align: text-top;
511 | }
512 |
513 | .widefat .check-column {
514 | width: 2.2em;
515 | padding: 6px 0 25px;
516 | vertical-align: top;
517 | }
518 |
519 | .widefat tbody th.check-column {
520 | padding: 9px 0 22px;
521 | }
522 |
523 | .widefat thead td.check-column,
524 | .widefat tbody th.check-column,
525 | .updates-table tbody td.check-column,
526 | .widefat tfoot td.check-column {
527 | padding: 11px 0 0 3px;
528 | }
529 |
530 | .widefat thead td.check-column,
531 | .widefat tfoot td.check-column {
532 | padding-top: 4px;
533 | vertical-align: middle;
534 | }
535 |
536 | .update-php div.updated,
537 | .update-php div.error {
538 | margin-left: 0;
539 | }
540 |
541 | .no-js .widefat thead .check-column input,
542 | .no-js .widefat tfoot .check-column input {
543 | display: none;
544 | }
545 |
546 | .widefat .num,
547 | .column-comments,
548 | .column-links,
549 | .column-posts {
550 | text-align: center;
551 | }
552 |
553 | .widefat th#comments {
554 | vertical-align: middle;
555 | }
556 |
557 | .wrap {
558 | margin: 10px 20px 0 2px;
559 | }
560 |
561 | .wrap > h2:first-child, /* Back-compat for pre-4.4 */
562 | .wrap [class$="icon32"] + h2, /* Back-compat for pre-4.4 */
563 | .postbox .inside h2, /* Back-compat for pre-4.4 */
564 | .wrap h1 {
565 | font-size: 23px;
566 | font-weight: 400;
567 | margin: 0;
568 | padding: 9px 0 4px 0;
569 | line-height: 29px;
570 | }
571 |
572 | .wrap h1.wp-heading-inline {
573 | display: inline-block;
574 | margin-right: 5px;
575 | }
576 |
577 | .wp-header-end {
578 | visibility: hidden;
579 | margin: -2px 0 0;
580 | }
581 |
582 | .subtitle {
583 | margin: 0;
584 | padding-left: 25px;
585 | color: #555d66;
586 | font-size: 14px;
587 | font-weight: 400;
588 | line-height: 1;
589 | }
590 |
591 | .wrap .add-new-h2, /* deprecated */
592 | .wrap .add-new-h2:active, /* deprecated */
593 | .wrap .page-title-action,
594 | .wrap .page-title-action:active {
595 | margin-left: 4px;
596 | padding: 4px 8px;
597 | position: relative;
598 | top: -3px;
599 | text-decoration: none;
600 | border: none;
601 | border: 1px solid #ccc;
602 | border-radius: 2px;
603 | background: #f7f7f7;
604 | text-shadow: none;
605 | font-weight: 600;
606 | font-size: 13px;
607 | line-height: normal; /* IE8-IE11 need this for buttons */
608 | color: #0073aa; /* some of these controls are button elements and don't inherit from links */
609 | cursor: pointer;
610 | outline: 0;
611 | }
612 |
613 | .wrap .wp-heading-inline + .page-title-action {
614 | margin-left: 0;
615 | }
616 |
617 | .wrap .add-new-h2:hover, /* deprecated */
618 | .wrap .page-title-action:hover {
619 | border-color: #008EC2;
620 | background: #00a0d2;
621 | color: #fff;
622 | }
623 |
624 | /* lower specificity: color needs to be overridden by :hover and :active */
625 | .page-title-action:focus {
626 | color: #124964;
627 | }
628 |
629 | .wrap .page-title-action:focus {
630 | border-color: #5b9dd9;
631 | box-shadow: 0 0 2px rgba( 30, 140, 190, 0.8 );
632 | }
633 |
634 | .wrap h1.long-header {
635 | padding-right: 0;
636 | }
637 |
638 | .wp-dialog {
639 | background-color: #fff;
640 | }
641 |
642 | .widgets-chooser ul,
643 | #widgets-left .widget-in-question .widget-top,
644 | #available-widgets .widget-top:hover,
645 | div#widgets-right .widget-top:hover,
646 | #widgets-left .widget-top:hover {
647 | border-color: #999;
648 | box-shadow: 0 1px 2px rgba(0,0,0,0.1);
649 | }
650 |
651 | .sorthelper {
652 | background-color: #ccf3fa;
653 | }
654 |
655 | .ac_match,
656 | .subsubsub a.current {
657 | color: #000;
658 | }
659 |
660 | .striped > tbody > :nth-child(odd),
661 | ul.striped > :nth-child(odd),
662 | .alternate {
663 | background-color: #f9f9f9;
664 | }
665 |
666 | .bar {
667 | background-color: #e8e8e8;
668 | border-right-color: #99d;
669 | }
670 |
671 | /* Helper classes for plugins to leverage the active WordPress color scheme */
672 |
673 | .highlight {
674 | background-color: #e4f2fd;
675 | color: #000;
676 | }
677 |
678 | .wp-ui-primary {
679 | color: #fff;
680 | background-color: #32373c;
681 | }
682 | .wp-ui-text-primary {
683 | color: #32373c;
684 | }
685 |
686 | .wp-ui-highlight {
687 | color: #fff;
688 | background-color: #1e8cbe;
689 | }
690 | .wp-ui-text-highlight {
691 | color: #1e8cbe;
692 | }
693 |
694 | .wp-ui-notification {
695 | color: #fff;
696 | background-color: #d54e21;
697 | }
698 | .wp-ui-text-notification {
699 | color: #d54e21;
700 | }
701 |
702 | .wp-ui-text-icon {
703 | color: #82878c; /* same as new icons */
704 | }
705 |
706 | /* For emoji replacement images */
707 | img.emoji {
708 | display: inline !important;
709 | border: none !important;
710 | height: 1em !important;
711 | width: 1em !important;
712 | margin: 0 .07em !important;
713 | vertical-align: -0.1em !important;
714 | background: none !important;
715 | padding: 0 !important;
716 | box-shadow: none !important;
717 | }
718 |
719 | /*------------------------------------------------------------------------------
720 | 1.0 - Text Styles
721 | ------------------------------------------------------------------------------*/
722 |
723 | .widget .widget-top,
724 | .postbox .hndle,
725 | .stuffbox .hndle,
726 | .control-section .accordion-section-title,
727 | .sidebar-name,
728 | #nav-menu-header,
729 | #nav-menu-footer,
730 | .menu-item-handle,
731 | .checkbox,
732 | .side-info,
733 | #your-profile #rich_editing,
734 | .widefat thead th,
735 | .widefat thead td,
736 | .widefat tfoot th,
737 | .widefat tfoot td {
738 | line-height: 1.4em;
739 | }
740 |
741 | .widget .widget-top,
742 | .menu-item-handle {
743 | background: #fafafa;
744 | color: #23282d;
745 | }
746 |
747 | .postbox .hndle,
748 | .stuffbox .hndle {
749 | border-bottom: 1px solid #eee;
750 | }
751 |
752 | .quicktags,
753 | .search {
754 | background-color: #ccc;
755 | color: #000;
756 | font-size: 12px;
757 | }
758 |
759 | .icon32 {
760 | display: none;
761 | }
762 |
763 | /* @todo can we combine these into a class or use an existing dashicon one? */
764 | .welcome-panel .welcome-panel-close:before,
765 | .tagchecklist .ntdelbutton .remove-tag-icon:before,
766 | #bulk-titles div a:before,
767 | .notice-dismiss:before {
768 | background: none;
769 | color: #72777c;
770 | content: "\f153";
771 | display: block;
772 | font: normal 16px/20px dashicons;
773 | speak: none;
774 | height: 20px;
775 | text-align: center;
776 | width: 20px;
777 | -webkit-font-smoothing: antialiased;
778 | -moz-osx-font-smoothing: grayscale;
779 | }
780 |
781 | .welcome-panel .welcome-panel-close:before {
782 | margin: 0;
783 | }
784 |
785 | #bulk-titles div a:before {
786 | margin: 1px 0;
787 | }
788 |
789 | .tagchecklist .ntdelbutton .remove-tag-icon:before {
790 | margin-left: 2px;
791 | border-radius: 50%;
792 | color: #0073aa;
793 | /* vertically center the icon cross browsers */
794 | line-height: 1.28;
795 | }
796 |
797 | .tagchecklist .ntdelbutton:focus {
798 | outline: 0;
799 | }
800 |
801 | .welcome-panel .welcome-panel-close:hover:before,
802 | .welcome-panel .welcome-panel-close:focus:before,
803 | .tagchecklist .ntdelbutton:hover .remove-tag-icon:before,
804 | .tagchecklist .ntdelbutton:focus .remove-tag-icon:before,
805 | #bulk-titles div a:hover:before,
806 | #bulk-titles div a:focus:before {
807 | color: #c00;
808 | }
809 |
810 | .tagchecklist .ntdelbutton:focus .remove-tag-icon:before {
811 | box-shadow:
812 | 0 0 0 1px #5b9dd9,
813 | 0 0 2px 1px rgba(30, 140, 190, .8);
814 | }
815 |
816 | .key-labels label {
817 | line-height: 24px;
818 | }
819 |
820 | strong, b {
821 | font-weight: 600;
822 | }
823 |
824 | .pre {
825 | /* https://developer.mozilla.org/en-US/docs/CSS/white-space */
826 | white-space: pre-wrap; /* css-3 */
827 | word-wrap: break-word; /* IE 5.5 - 7 */
828 | }
829 |
830 | .howto {
831 | color: #666;
832 | font-style: italic;
833 | display: block;
834 | }
835 |
836 | p.install-help {
837 | margin: 8px 0;
838 | font-style: italic;
839 | }
840 |
841 | .no-break {
842 | white-space: nowrap;
843 | }
844 |
845 | hr {
846 | border: 0;
847 | border-top: 1px solid #ddd;
848 | border-bottom: 1px solid #fafafa;
849 | }
850 |
851 | .row-actions span.delete a,
852 | .row-actions span.trash a,
853 | .row-actions span.spam a,
854 | .plugins a.delete,
855 | #all-plugins-table .plugins a.delete,
856 | #search-plugins-table .plugins a.delete,
857 | .submitbox .submitdelete,
858 | #media-items a.delete,
859 | #media-items a.delete-permanently,
860 | #nav-menu-footer .menu-delete,
861 | #delete-link a.delete {
862 | color: #a00;
863 | }
864 |
865 | abbr.required,
866 | span.required,
867 | .file-error,
868 | .row-actions .delete a:hover,
869 | .row-actions .trash a:hover,
870 | .row-actions .spam a:hover,
871 | .plugins a.delete:hover,
872 | #all-plugins-table .plugins a.delete:hover,
873 | #search-plugins-table .plugins a.delete:hover,
874 | .submitbox .submitdelete:hover,
875 | #media-items a.delete:hover,
876 | #media-items a.delete-permanently:hover,
877 | #nav-menu-footer .menu-delete:hover,
878 | #delete-link a.delete:hover {
879 | color: #dc3232;
880 | border: none;
881 | }
882 |
883 | /*------------------------------------------------------------------------------
884 | 3.0 - Actions
885 | ------------------------------------------------------------------------------*/
886 |
887 | #major-publishing-actions {
888 | padding: 10px;
889 | clear: both;
890 | border-top: 1px solid #ddd;
891 | background: #f5f5f5;
892 | }
893 |
894 | #delete-action {
895 | float: left;
896 | line-height: 28px;
897 | }
898 |
899 | #delete-link {
900 | line-height: 28px;
901 | vertical-align: middle;
902 | text-align: left;
903 | margin-left: 8px;
904 | }
905 |
906 | #delete-link a {
907 | text-decoration: none;
908 | }
909 |
910 | #publishing-action {
911 | text-align: right;
912 | float: right;
913 | line-height: 23px;
914 | }
915 |
916 | #publishing-action .spinner {
917 | float: left;
918 | }
919 |
920 | #misc-publishing-actions {
921 | padding: 6px 0 0;
922 | }
923 |
924 | .misc-pub-section {
925 | padding: 6px 10px 8px;
926 | }
927 |
928 | .misc-pub-filename {
929 | word-wrap: break-word;
930 | }
931 |
932 | #minor-publishing-actions {
933 | padding: 10px 10px 0 10px;
934 | text-align: right;
935 | }
936 |
937 | #save-post {
938 | float: left;
939 | }
940 |
941 | .preview {
942 | float: right;
943 | }
944 |
945 | #sticky-span {
946 | margin-left: 18px;
947 | }
948 |
949 | .approve,
950 | .unapproved .unapprove {
951 | display: none;
952 | }
953 |
954 | .unapproved .approve,
955 | .spam .approve,
956 | .trash .approve {
957 | display: inline;
958 | }
959 |
960 | td.action-links,
961 | th.action-links {
962 | text-align: right;
963 | }
964 |
965 | /* Filter bar */
966 | .wp-filter {
967 | display: inline-block;
968 | position: relative;
969 | box-sizing: border-box;
970 | margin: 12px 0 25px;
971 | padding: 0 10px;
972 | width: 100%;
973 | box-shadow: 0 1px 1px rgba(0,0,0,0.04);
974 | border: 1px solid #e5e5e5;
975 | background: #fff;
976 | color: #555;
977 | font-size: 13px;
978 | }
979 |
980 | .wp-filter a {
981 | text-decoration: none;
982 | }
983 |
984 | .filter-count {
985 | display: inline-block;
986 | vertical-align: middle;
987 | min-width: 4em;
988 | }
989 |
990 | .title-count,
991 | .filter-count .count {
992 | display: inline-block;
993 | position: relative;
994 | top: -1px;
995 | padding: 4px 10px;
996 | border-radius: 30px;
997 | background: #72777c;
998 | color: #fff;
999 | font-size: 14px;
1000 | font-weight: 600;
1001 | }
1002 |
1003 | /* not a part of filter bar, but derived from it, so here for now */
1004 | .title-count {
1005 | display: inline;
1006 | top: -3px;
1007 | margin-left: 5px;
1008 | margin-right: 20px;
1009 | }
1010 |
1011 | .filter-items {
1012 | float: left;
1013 | }
1014 |
1015 | .filter-links {
1016 | display: inline-block;
1017 | margin: 0;
1018 | }
1019 |
1020 | .filter-links li {
1021 | display: inline-block;
1022 | margin: 0;
1023 | }
1024 |
1025 | .filter-links li > a {
1026 | display: inline-block;
1027 | margin: 0 10px;
1028 | padding: 15px 0;
1029 | border-bottom: 4px solid #fff;
1030 | color: #666;
1031 | cursor: pointer;
1032 | }
1033 |
1034 | .filter-links .current {
1035 | box-shadow: none;
1036 | border-bottom: 4px solid #666;
1037 | color: #23282d;
1038 | }
1039 |
1040 | .filter-links li > a:hover,
1041 | .filter-links li > a:focus,
1042 | .show-filters .filter-links a.current:hover,
1043 | .show-filters .filter-links a.current:focus {
1044 | color: #00a0d2;
1045 | }
1046 |
1047 | .wp-filter .search-form {
1048 | float: right;
1049 | margin: 10px 0;
1050 | }
1051 |
1052 | .wp-filter .search-form input[type="search"] {
1053 | margin: 0;
1054 | padding: 3px 5px;
1055 | width: 280px;
1056 | max-width: 100%;
1057 | font-size: 16px;
1058 | font-weight: 300;
1059 | line-height: 1.5;
1060 | }
1061 |
1062 | .wp-filter .search-form select {
1063 | margin: 0;
1064 | height: 32px;
1065 | vertical-align: top;
1066 | }
1067 |
1068 | .wp-filter .search-form.search-plugins {
1069 | display: inline-block;
1070 | }
1071 |
1072 | .wp-filter .button.drawer-toggle {
1073 | margin: 10px 9px 0;
1074 | padding: 0 10px 0 6px;
1075 | border-color: transparent;
1076 | background-color: transparent;
1077 | color: #666;
1078 | vertical-align: baseline;
1079 | box-shadow: none;
1080 | }
1081 |
1082 | .wp-filter .drawer-toggle:before {
1083 | content: "\f111";
1084 | margin: 0 5px 0 0;
1085 | color: #72777c;
1086 | font: normal 16px/1 dashicons;
1087 | vertical-align: text-bottom;
1088 | -webkit-font-smoothing: antialiased;
1089 | -moz-osx-font-smoothing: grayscale;
1090 | }
1091 |
1092 | .wp-filter .button.drawer-toggle:hover,
1093 | .wp-filter .drawer-toggle:hover:before,
1094 | .wp-filter .button.drawer-toggle:focus,
1095 | .wp-filter .drawer-toggle:focus:before {
1096 | background-color: transparent;
1097 | color: #00a0d2;
1098 | }
1099 |
1100 | .wp-filter .button.drawer-toggle:hover,
1101 | .wp-filter .button.drawer-toggle:focus:active {
1102 | border-color: transparent;
1103 | }
1104 |
1105 | .wp-filter .button.drawer-toggle:focus {
1106 | border-color: #5b9dd9;
1107 | }
1108 |
1109 | .wp-filter .button.drawer-toggle:active {
1110 | background: transparent;
1111 | box-shadow: none;
1112 | -webkit-transform: none;
1113 | transform: none;
1114 | }
1115 |
1116 | .wp-filter .drawer-toggle.current:before {
1117 | color: #fff;
1118 | }
1119 |
1120 | .filter-drawer,
1121 | .wp-filter .favorites-form {
1122 | display: none;
1123 | margin: 0 -10px 0 -20px;
1124 | padding: 20px;
1125 | border-top: 1px solid #eee;
1126 | background: #fafafa;
1127 | overflow: hidden;
1128 | }
1129 |
1130 | .show-filters .filter-drawer,
1131 | .show-favorites-form .favorites-form {
1132 | display: block;
1133 | }
1134 |
1135 | .show-filters .filter-links a.current {
1136 | border-bottom: none;
1137 | }
1138 |
1139 | .show-filters .wp-filter .button.drawer-toggle {
1140 | border-radius: 2px;
1141 | background: #72777c;
1142 | color: #fff;
1143 | }
1144 |
1145 | .show-filters .wp-filter .drawer-toggle:hover,
1146 | .show-filters .wp-filter .drawer-toggle:focus {
1147 | background: rgb(46, 162, 204);
1148 | }
1149 |
1150 | .show-filters .wp-filter .drawer-toggle:before {
1151 | color: #fff;
1152 | }
1153 |
1154 | .filter-group {
1155 | box-sizing: border-box;
1156 | position: relative;
1157 | float: left;
1158 | margin: 0 1% 0 0;
1159 | padding: 20px 10px 10px;
1160 | width: 24%;
1161 | background: #fff;
1162 | border: 1px solid #e5e5e5;
1163 | box-shadow: 0 1px 1px rgba(0,0,0,0.04);
1164 | }
1165 |
1166 | .filter-group legend {
1167 | position: absolute;
1168 | top: 10px;
1169 | display: block;
1170 | margin: 0;
1171 | padding: 0;
1172 | font-size: 1em;
1173 | font-weight: 600;
1174 | }
1175 |
1176 | .filter-drawer .filter-group-feature {
1177 | margin: 28px 0 0;
1178 | list-style-type: none;
1179 | font-size: 12px;
1180 | }
1181 |
1182 | .filter-drawer .filter-group-feature input,
1183 | .filter-drawer .filter-group-feature label {
1184 | display: inline-block;
1185 | margin: 7px 4px 7px 0;
1186 | line-height: 16px;
1187 | }
1188 |
1189 | .filter-drawer .buttons {
1190 | clear: both;
1191 | margin-bottom: 20px;
1192 | }
1193 |
1194 | .filter-drawer .filter-group + .buttons {
1195 | margin-bottom: 0;
1196 | padding-top: 20px;
1197 | }
1198 |
1199 | .filter-drawer .buttons .button span {
1200 | display: inline-block;
1201 | opacity: 0.8;
1202 | font-size: 12px;
1203 | text-indent: 10px;
1204 | }
1205 |
1206 | .wp-filter .button.clear-filters {
1207 | display: none;
1208 | margin-left: 10px;
1209 | }
1210 |
1211 | .wp-filter .button-link.edit-filters {
1212 | padding: 0 5px;
1213 | line-height: 28px;
1214 | }
1215 |
1216 | .filtered-by {
1217 | display: none;
1218 | margin: 0;
1219 | }
1220 |
1221 | .filtered-by > span {
1222 | font-weight: 600;
1223 | }
1224 |
1225 | .filtered-by a {
1226 | margin-left: 10px;
1227 | }
1228 |
1229 | .filtered-by .tags {
1230 | display: inline;
1231 | }
1232 |
1233 | .filtered-by .tag {
1234 | margin: 0 5px;
1235 | padding: 4px 8px;
1236 | border: 1px solid #e5e5e5;
1237 | box-shadow: 0 1px 1px rgba(0,0,0,0.04);
1238 | background: #fff;
1239 | font-size: 11px;
1240 | }
1241 |
1242 | .filters-applied .filter-group,
1243 | .filters-applied .filter-drawer .buttons,
1244 | .filters-applied .filter-drawer br {
1245 | display: none !important;
1246 | }
1247 |
1248 | .filters-applied .filtered-by {
1249 | display: block;
1250 | }
1251 |
1252 | .filters-applied .filter-drawer {
1253 | padding: 20px;
1254 | }
1255 |
1256 | .show-filters .favorites-form,
1257 | .show-filters .content-filterable,
1258 | .show-filters.filters-applied.loading-content .content-filterable,
1259 | .loading-content .content-filterable,
1260 | .error .content-filterable {
1261 | display: none;
1262 | }
1263 |
1264 | .show-filters.filters-applied .content-filterable {
1265 | display: block;
1266 | }
1267 |
1268 | .loading-content .spinner {
1269 | display: block;
1270 | margin: 40px auto 0;
1271 | float: none;
1272 | }
1273 |
1274 | @media only screen and (max-width: 1120px) {
1275 | .filter-drawer {
1276 | border-bottom: 1px solid #eee;
1277 | }
1278 |
1279 | .filter-group {
1280 | margin-bottom: 0;
1281 | margin-top: 5px;
1282 | width: 100%;
1283 | }
1284 |
1285 | .filter-group li {
1286 | margin: 10px 0;
1287 | }
1288 | }
1289 |
1290 | @media only screen and (max-width: 1000px) {
1291 | .filter-items {
1292 | float: none;
1293 | }
1294 |
1295 | .wp-filter .media-toolbar-primary,
1296 | .wp-filter .media-toolbar-secondary,
1297 | .wp-filter .search-form {
1298 | float: none; /* Remove float from media-views.css */
1299 | position: relative;
1300 | max-width: 100%;
1301 | }
1302 | }
1303 |
1304 | @media only screen and (max-width: 782px) {
1305 | .filter-group li {
1306 | padding: 0;
1307 | width: 50%;
1308 | }
1309 | }
1310 |
1311 | @media only screen and (max-width: 320px) {
1312 | .filter-count {
1313 | display: none;
1314 | }
1315 |
1316 | .wp-filter .drawer-toggle {
1317 | margin: 10px 0;
1318 | }
1319 |
1320 | .filter-group li,
1321 | .wp-filter .search-form input[type="search"] {
1322 | width: 100%;
1323 | }
1324 | }
1325 |
1326 | /*------------------------------------------------------------------------------
1327 | 4.0 - Notifications
1328 | ------------------------------------------------------------------------------*/
1329 |
1330 | .notice,
1331 | div.updated,
1332 | div.error {
1333 | background: #fff;
1334 | border-left: 4px solid #fff;
1335 | box-shadow: 0 1px 1px 0 rgba( 0, 0, 0, 0.1 );
1336 | margin: 5px 15px 2px;
1337 | padding: 1px 12px;
1338 | }
1339 |
1340 | div[class="update-message"] { /* back-compat for pre-4.6 */
1341 | padding: 0.5em 12px 0.5em 0;
1342 | }
1343 |
1344 | .notice p,
1345 | .notice-title,
1346 | div.updated p,
1347 | div.error p,
1348 | .form-table td .notice p {
1349 | margin: 0.5em 0;
1350 | padding: 2px;
1351 | }
1352 |
1353 | .error a {
1354 | text-decoration: underline;
1355 | }
1356 |
1357 | .updated a {
1358 | padding-bottom: 2px;
1359 | }
1360 |
1361 | .notice-alt {
1362 | box-shadow: none;
1363 | }
1364 |
1365 | .notice-large {
1366 | padding: 10px 20px;
1367 | }
1368 |
1369 | .notice-title {
1370 | display: inline-block;
1371 | color: #23282d;
1372 | font-size: 18px;
1373 | }
1374 |
1375 | .wp-core-ui .notice.is-dismissible {
1376 | padding-right: 38px;
1377 | position: relative;
1378 | }
1379 |
1380 | .notice-dismiss {
1381 | position: absolute;
1382 | top: 0;
1383 | right: 1px;
1384 | border: none;
1385 | margin: 0;
1386 | padding: 9px;
1387 | background: none;
1388 | color: #72777c;
1389 | cursor: pointer;
1390 | }
1391 |
1392 | .notice-dismiss:hover:before,
1393 | .notice-dismiss:active:before,
1394 | .notice-dismiss:focus:before {
1395 | color: #c00;
1396 | }
1397 |
1398 | .notice-dismiss:focus {
1399 | outline: none;
1400 | box-shadow: 0 0 0 1px #5b9dd9, 0 0 2px 1px rgba(30, 140, 190, .8);
1401 | }
1402 |
1403 | .ie8 .notice-dismiss:focus {
1404 | outline: 1px solid #5b9dd9;
1405 | }
1406 |
1407 | .notice-success,
1408 | div.updated {
1409 | border-left-color: #46b450;
1410 | }
1411 |
1412 | .notice-success.notice-alt {
1413 | background-color: #ecf7ed;
1414 | }
1415 |
1416 | .notice-warning {
1417 | border-left-color: #ffb900;
1418 | }
1419 |
1420 | .notice-warning.notice-alt {
1421 | background-color: #fff8e5;
1422 | }
1423 |
1424 | .notice-error,
1425 | div.error {
1426 | border-left-color: #dc3232;
1427 | }
1428 |
1429 | .notice-error.notice-alt {
1430 | background-color: #fbeaea;
1431 | }
1432 |
1433 | .notice-info {
1434 | border-left-color: #00a0d2;
1435 | }
1436 |
1437 | .notice-info.notice-alt {
1438 | background-color: #e5f5fa;
1439 | }
1440 |
1441 | .update-message p:before,
1442 | .updating-message p:before,
1443 | .updated-message p:before,
1444 | .import-php .updating-message:before,
1445 | .button.updating-message:before,
1446 | .button.updated-message:before,
1447 | .button.installed:before,
1448 | .button.installing:before {
1449 | display: inline-block;
1450 | font: normal 20px/1 'dashicons';
1451 | -webkit-font-smoothing: antialiased;
1452 | -moz-osx-font-smoothing: grayscale;
1453 | vertical-align: top;
1454 | }
1455 |
1456 | .wrap .notice,
1457 | .wrap div.updated,
1458 | .wrap div.error,
1459 | .media-upload-form .notice,
1460 | .media-upload-form div.error {
1461 | margin: 5px 0 15px;
1462 | }
1463 |
1464 | /* Update icon. */
1465 | .update-message p:before,
1466 | .updating-message p:before,
1467 | .import-php .updating-message:before,
1468 | .button.updating-message:before,
1469 | .button.installing:before {
1470 | color: #f56e28;
1471 | content: "\f463";
1472 | }
1473 |
1474 | /* Spins the update icon. */
1475 | .updating-message p:before,
1476 | .import-php .updating-message:before,
1477 | .button.updating-message:before,
1478 | .button.installing:before {
1479 | -webkit-animation: rotation 2s infinite linear;
1480 | animation: rotation 2s infinite linear;
1481 | }
1482 |
1483 | /* Updated icon (check mark). */
1484 | .updated-message p:before,
1485 | .installed p:before,
1486 | .button.updated-message:before {
1487 | color: #79ba49;
1488 | content: '\f147';
1489 | }
1490 |
1491 | /* Error icon. */
1492 | .update-message.notice-error p:before {
1493 | color: #dc3232;
1494 | content: "\f534";
1495 | }
1496 |
1497 | .wrap .notice p:before,
1498 | .import-php .updating-message:before {
1499 | margin-right: 6px;
1500 | vertical-align: bottom;
1501 | }
1502 |
1503 | #update-nag,
1504 | .update-nag {
1505 | display: inline-block;
1506 | line-height: 19px;
1507 | padding: 11px 15px;
1508 | font-size: 14px;
1509 | text-align: left;
1510 | margin: 25px 20px 0 2px;
1511 | background-color: #fff;
1512 | border-left: 4px solid #ffba00;
1513 | box-shadow: 0 1px 1px 0 rgba(0,0,0,0.1);
1514 | }
1515 |
1516 | ul#dismissed-updates {
1517 | display: none;
1518 | }
1519 |
1520 | form.upgrade {
1521 | margin-top: 8px;
1522 | }
1523 |
1524 | form.upgrade .hint {
1525 | font-style: italic;
1526 | font-size: 85%;
1527 | margin: -0.5em 0 2em 0;
1528 | }
1529 |
1530 | .update-php .spinner {
1531 | float: none;
1532 | margin: -4px 0;
1533 | }
1534 |
1535 | #ajax-loading,
1536 | .ajax-loading,
1537 | .ajax-feedback,
1538 | .imgedit-wait-spin,
1539 | .list-ajax-loading { /* deprecated */
1540 | visibility: hidden;
1541 | }
1542 |
1543 | #ajax-response.alignleft {
1544 | margin-left: 2em;
1545 | }
1546 |
1547 | .button.updating-message:before,
1548 | .button.updated-message:before,
1549 | .button.installed:before,
1550 | .button.installing:before {
1551 | margin: 3px 5px 0 -2px;
1552 | }
1553 |
1554 | .button-primary.updating-message:before {
1555 | color: #fff;
1556 | }
1557 |
1558 | .button-primary.updated-message:before {
1559 | color: #66c6e4;
1560 | }
1561 |
1562 | .button.updated-message {
1563 | transition-property: border, background, color;
1564 | transition-duration: .05s;
1565 | transition-timing-function: ease-in-out;
1566 | }
1567 |
1568 | @media aural {
1569 | .wrap .notice p:before,
1570 | .button.installing:before,
1571 | .button.installed:before,
1572 | .update-message p:before {
1573 | speak: none;
1574 | }
1575 | }
1576 |
1577 |
1578 | /* @todo: this does not need its own section anymore */
1579 | /*------------------------------------------------------------------------------
1580 | 6.0 - Admin Header
1581 | ------------------------------------------------------------------------------*/
1582 | #adminmenu a,
1583 | #taglist a,
1584 | #catlist a {
1585 | text-decoration: none;
1586 | }
1587 |
1588 | /*------------------------------------------------------------------------------
1589 | 6.1 - Screen Options Tabs
1590 | ------------------------------------------------------------------------------*/
1591 |
1592 | #screen-options-wrap,
1593 | #contextual-help-wrap {
1594 | margin: 0;
1595 | padding: 8px 20px 12px;
1596 | position: relative;
1597 | }
1598 |
1599 | #contextual-help-wrap {
1600 | overflow: auto;
1601 | margin-left: 0 !important;
1602 | }
1603 |
1604 | #screen-meta .screen-reader-text {
1605 | visibility: hidden;
1606 | }
1607 |
1608 | #screen-meta-links {
1609 | margin: 0 20px 0 0;
1610 | }
1611 |
1612 | /* screen options and help tabs revert */
1613 | #screen-meta {
1614 | display: none;
1615 | margin: 0 20px -1px 0px;
1616 | position: relative;
1617 | background-color: #fff;
1618 | border: 1px solid #ddd;
1619 | border-top: none;
1620 | box-shadow: 0 1px 0 rgba(0,0,0,.025);
1621 | }
1622 |
1623 | #screen-options-link-wrap,
1624 | #contextual-help-link-wrap {
1625 | float: right;
1626 | height: 28px;
1627 | margin: 0 0 0 6px;
1628 | border: 1px solid #ddd;
1629 | border-top: none;
1630 | background: #fff;
1631 | box-shadow: 0 1px 1px -1px rgba(0,0,0,0.1);
1632 | }
1633 |
1634 | #screen-meta-links .screen-meta-toggle {
1635 | position: relative;
1636 | top: 0;
1637 | }
1638 |
1639 | #screen-meta-links .show-settings {
1640 | border: 0;
1641 | background: none;
1642 | border-radius: 0;
1643 | color: #72777c;
1644 | line-height: 1.7;
1645 | padding: 3px 6px 3px 16px;
1646 | }
1647 |
1648 | #screen-meta-links .show-settings:hover,
1649 | #screen-meta-links .show-settings:active,
1650 | #screen-meta-links .show-settings:focus {
1651 | color: #32373c;
1652 | }
1653 |
1654 | #screen-meta-links .show-settings:active {
1655 | box-shadow: none;
1656 | -webkit-transform: none;
1657 | transform: none;
1658 | }
1659 |
1660 | #screen-meta-links .show-settings:after {
1661 | right: 0;
1662 | content: "\f140";
1663 | font: normal 20px/1 dashicons;
1664 | speak: none;
1665 | display: inline-block;
1666 | padding: 0 5px 0 0;
1667 | bottom: 2px;
1668 | position: relative;
1669 | vertical-align: bottom;
1670 | -webkit-font-smoothing: antialiased;
1671 | -moz-osx-font-smoothing: grayscale;
1672 | text-decoration: none !important;
1673 | color: #72777c;
1674 | }
1675 |
1676 | #screen-meta-links .screen-meta-active:after {
1677 | content: "\f142";
1678 | }
1679 |
1680 | /* end screen options and help tabs */
1681 |
1682 | .toggle-arrow {
1683 | background-repeat: no-repeat;
1684 | background-position: top left;
1685 | background-color: transparent;
1686 | height: 22px;
1687 | line-height: 22px;
1688 | display: block;
1689 | }
1690 |
1691 | .toggle-arrow-active {
1692 | background-position: bottom left;
1693 | }
1694 |
1695 | #screen-options-wrap h5, /* Back-compat for old plugins */
1696 | #screen-options-wrap legend,
1697 | #contextual-help-wrap h5 {
1698 | margin: 0;
1699 | padding: 8px 0;
1700 | font-size: 13px;
1701 | font-weight: 600;
1702 | }
1703 |
1704 | .ie8 #screen-options-wrap legend {
1705 | color: inherit;
1706 | }
1707 |
1708 | .metabox-prefs label {
1709 | display: inline-block;
1710 | padding-right: 15px;
1711 | line-height: 30px;
1712 | }
1713 |
1714 | #number-of-columns {
1715 | display: inline-block;
1716 | vertical-align: middle;
1717 | line-height: 30px;
1718 | }
1719 |
1720 | .metabox-prefs input[type=checkbox] {
1721 | margin-top: 0;
1722 | margin-right: 6px;
1723 | }
1724 |
1725 | .metabox-prefs label input,
1726 | .metabox-prefs label input[type=checkbox] {
1727 | margin: -4px 5px 0 0;
1728 | }
1729 |
1730 | .metabox-prefs .columns-prefs label input {
1731 | margin: -1px 2px 0 0;
1732 | }
1733 |
1734 | .metabox-prefs label a {
1735 | display: none;
1736 | }
1737 |
1738 | .metabox-prefs .screen-options input,
1739 | .metabox-prefs .screen-options label {
1740 | margin-top: 0;
1741 | margin-bottom: 0;
1742 | vertical-align: middle;
1743 | }
1744 |
1745 | .metabox-prefs .screen-options .screen-per-page {
1746 | margin-right: 15px;
1747 | }
1748 |
1749 | .metabox-prefs .screen-options label {
1750 | line-height: 28px;
1751 | padding-right: 0;
1752 | }
1753 |
1754 | .screen-options + .screen-options {
1755 | margin-top: 10px;
1756 | }
1757 |
1758 | .metabox-prefs .submit {
1759 | margin-top: 1em;
1760 | padding: 0;
1761 | }
1762 |
1763 | /*------------------------------------------------------------------------------
1764 | 6.2 - Help Menu
1765 | ------------------------------------------------------------------------------*/
1766 |
1767 | #contextual-help-wrap {
1768 | padding: 0;
1769 | }
1770 |
1771 | #contextual-help-columns {
1772 | position: relative;
1773 | }
1774 |
1775 | #contextual-help-back {
1776 | position: absolute;
1777 | top: 0;
1778 | bottom: 0;
1779 | left: 150px;
1780 | right: 170px;
1781 | border: 1px solid #e1e1e1;
1782 | border-top: none;
1783 | border-bottom: none;
1784 | background: #f6fbfd;
1785 | }
1786 |
1787 | #contextual-help-wrap.no-sidebar #contextual-help-back {
1788 | right: 0;
1789 | border-right-width: 0;
1790 | border-bottom-right-radius: 2px;
1791 | }
1792 |
1793 | .contextual-help-tabs {
1794 | float: left;
1795 | width: 150px;
1796 | margin: 0;
1797 | }
1798 |
1799 | .contextual-help-tabs ul {
1800 | margin: 1em 0;
1801 | }
1802 |
1803 | .contextual-help-tabs li {
1804 | margin-bottom: 0;
1805 | list-style-type: none;
1806 | border-style: solid;
1807 | border-width: 0 0 0 2px;
1808 | border-color: transparent;
1809 | }
1810 |
1811 | .contextual-help-tabs a {
1812 | display: block;
1813 | padding: 5px 5px 5px 12px;
1814 | line-height: 18px;
1815 | text-decoration: none;
1816 | border: 1px solid transparent;
1817 | border-right: none;
1818 | border-left: none;
1819 | }
1820 |
1821 | .contextual-help-tabs a:hover {
1822 | color: #32373c;
1823 | }
1824 |
1825 | .contextual-help-tabs .active {
1826 | padding: 0;
1827 | margin: 0 -1px 0 0;
1828 | border-left: 2px solid #00a0d2;
1829 | background: #f6fbfd;
1830 | box-shadow: 0 2px 0 rgba(0,0,0,0.02), 0 1px 0 rgba(0,0,0,0.02);
1831 | }
1832 |
1833 | .contextual-help-tabs .active a {
1834 | border-color: #e1e1e1;
1835 | color: #32373c;
1836 | }
1837 |
1838 | .contextual-help-tabs-wrap {
1839 | padding: 0 20px;
1840 | overflow: auto;
1841 | }
1842 |
1843 | .help-tab-content {
1844 | display: none;
1845 | margin: 0 22px 12px 0;
1846 | line-height: 1.6em;
1847 | }
1848 |
1849 | .help-tab-content.active {
1850 | display: block;
1851 | }
1852 |
1853 | .help-tab-content ul li {
1854 | list-style-type: disc;
1855 | margin-left: 18px;
1856 | }
1857 |
1858 | .contextual-help-sidebar {
1859 | width: 150px;
1860 | float: right;
1861 | padding: 0 8px 0 12px;
1862 | overflow: auto;
1863 | }
1864 |
1865 | /*------------------------------------------------------------------------------
1866 | 8.0 - Layout Blocks
1867 | ------------------------------------------------------------------------------*/
1868 |
1869 | html.wp-toolbar {
1870 | padding-top: 32px;
1871 | box-sizing: border-box;
1872 | }
1873 |
1874 | .widefat th,
1875 | .widefat td {
1876 | color: #555;
1877 | }
1878 |
1879 | .widefat th,
1880 | .widefat thead td,
1881 | .widefat tfoot td {
1882 | font-weight: 400;
1883 | }
1884 |
1885 | .widefat thead tr th,
1886 | .widefat thead tr td,
1887 | .widefat tfoot tr th,
1888 | .widefat tfoot tr td {
1889 | color: #32373c;
1890 | }
1891 |
1892 | .widefat td p {
1893 | margin: 2px 0 0.8em;
1894 | }
1895 |
1896 | .widefat p,
1897 | .widefat ol,
1898 | .widefat ul {
1899 | color: #32373c;
1900 | }
1901 |
1902 | .widefat .column-comment p {
1903 | margin: 0.6em 0;
1904 | }
1905 |
1906 | .widefat .column-comment ul {
1907 | list-style: initial;
1908 | margin-left: 2em;
1909 | }
1910 |
1911 | /* Screens with postboxes */
1912 | .postbox-container {
1913 | float: left;
1914 | }
1915 |
1916 | .postbox-container .meta-box-sortables {
1917 | box-sizing: border-box;
1918 | }
1919 |
1920 | #wpbody-content .metabox-holder {
1921 | padding-top: 10px;
1922 | }
1923 |
1924 | .metabox-holder .postbox-container .empty-container {
1925 | border: 3px dashed #b4b9be;
1926 | height: 250px;
1927 | position: relative;
1928 | }
1929 |
1930 | .metabox-holder .postbox-container .empty-container:after {
1931 | content: attr(data-emptystring);
1932 | margin: auto;
1933 | position: absolute;
1934 | top: 0;
1935 | left: 0;
1936 | bottom: 0;
1937 | right: 0;
1938 | height: 1em;
1939 | width: 200px;
1940 | text-align: center;
1941 | color: #ccc;
1942 | font-size:18px;
1943 | display: none;
1944 | }
1945 |
1946 | .metabox-holder.columns-1 .postbox-container .empty-container,
1947 | .columns-2 #postbox-container-3 .empty-container,
1948 | .columns-2 #postbox-container-4 .empty-container,
1949 | .columns-3 #postbox-container-4 .empty-container {
1950 | border: 0 none;
1951 | height: 0;
1952 | min-height: 0;
1953 | }
1954 |
1955 | #post-body-content {
1956 | width: 100%;
1957 | min-width: 463px;
1958 | float: left;
1959 | }
1960 |
1961 | #post-body.columns-2 #postbox-container-1 {
1962 | float: right;
1963 | margin-right: -300px;
1964 | width: 280px;
1965 | }
1966 |
1967 | #post-body.columns-2 #side-sortables {
1968 | min-height: 250px;
1969 | }
1970 |
1971 | /* one column on the dash */
1972 | @media only screen and (max-width: 799px) {
1973 | #wpbody-content .metabox-holder .postbox-container .empty-container {
1974 | border: 0 none;
1975 | height: 0;
1976 | min-height: 0;
1977 | }
1978 | }
1979 |
1980 | .js .widget .widget-top,
1981 | .js .postbox .hndle {
1982 | cursor: move;
1983 | }
1984 |
1985 | .hndle a {
1986 | font-size: 11px;
1987 | font-weight: 400;
1988 | }
1989 |
1990 | .postbox .handlediv {
1991 | display: none;
1992 | float: right;
1993 | width: 36px;
1994 | height: 36px;
1995 | margin: 0;
1996 | padding: 0;
1997 | border: 0;
1998 | background: none;
1999 | cursor: pointer;
2000 | }
2001 |
2002 | .js .postbox .handlediv {
2003 | display: block;
2004 | }
2005 |
2006 | .sortable-placeholder {
2007 | border: 1px dashed #b4b9be;
2008 | margin-bottom: 20px;
2009 | }
2010 |
2011 | .postbox,
2012 | .stuffbox {
2013 | margin-bottom: 20px;
2014 | padding: 0;
2015 | line-height: 1;
2016 | }
2017 |
2018 | /* user-select is not a part of the CSS standard - may change behavior in the future */
2019 | .postbox .hndle,
2020 | .stuffbox .hndle {
2021 | -webkit-user-select: none;
2022 | -moz-user-select: none;
2023 | -ms-user-select: none;
2024 | user-select: none;
2025 | }
2026 |
2027 | .postbox .inside,
2028 | .stuffbox .inside {
2029 | padding: 0 12px 12px;
2030 | line-height: 1.4em;
2031 | font-size: 13px;
2032 | }
2033 |
2034 | .postbox .inside {
2035 | margin: 11px 0;
2036 | position: relative;
2037 | }
2038 |
2039 | .postbox .inside > p:last-child,
2040 | .rss-widget ul li:last-child {
2041 | margin-bottom: 1px !important;
2042 | }
2043 |
2044 | .postbox.closed h3 {
2045 | border: none;
2046 | box-shadow: none;
2047 | }
2048 |
2049 | .postbox table.form-table {
2050 | margin-bottom: 0;
2051 | }
2052 |
2053 | .postbox table.widefat {
2054 | box-shadow: none;
2055 | }
2056 |
2057 | .temp-border {
2058 | border: 1px dotted #ccc;
2059 | }
2060 |
2061 | .columns-prefs label {
2062 | padding: 0 10px 0 0;
2063 | }
2064 |
2065 | /* @todo: what is this doing here */
2066 | #dashboard_right_now .versions .b,
2067 | #post-status-display,
2068 | #post-visibility-display,
2069 | #adminmenu .wp-submenu li.current,
2070 | #adminmenu .wp-submenu li.current a,
2071 | #adminmenu .wp-submenu li.current a:hover,
2072 | .media-item .percent,
2073 | .plugins .name,
2074 | #pass-strength-result.strong,
2075 | #pass-strength-result.short,
2076 | #ed_reply_toolbar #ed_reply_strong,
2077 | .item-controls .item-order a,
2078 | .feature-filter .feature-name {
2079 | font-weight: 600;
2080 | }
2081 |
2082 | /*------------------------------------------------------------------------------
2083 | 21.0 - Admin Footer
2084 | ------------------------------------------------------------------------------*/
2085 |
2086 | #wpfooter {
2087 | position: absolute;
2088 | bottom: 0;
2089 | left: 0;
2090 | right: 0;
2091 | padding: 10px 20px;
2092 | color: #555d66;
2093 | }
2094 |
2095 | #wpfooter p {
2096 | font-size: 13px;
2097 | margin: 0;
2098 | line-height: 20px;
2099 | }
2100 |
2101 | #footer-thankyou {
2102 | font-style: italic;
2103 | }
2104 |
2105 | /*------------------------------------------------------------------------------
2106 | 25.0 - Tabbed Admin Screen Interface (Experimental)
2107 | ------------------------------------------------------------------------------*/
2108 |
2109 | .nav-tab {
2110 | float: left;
2111 | border: 1px solid #ccc;
2112 | border-bottom: none;
2113 | margin-left: 0.5em; /* half the font size so set the font size properly */
2114 | padding: 5px 10px;
2115 | font-size: 14px;
2116 | line-height: 24px;
2117 | font-weight: 600;
2118 | background: #e5e5e5;
2119 | color: #555;
2120 | text-decoration: none;
2121 | white-space: nowrap;
2122 | }
2123 |
2124 | h3 .nav-tab, /* Back-compat for pre-4.4 */
2125 | .nav-tab-small .nav-tab {
2126 | padding: 5px 14px;
2127 | font-size: 12px;
2128 | line-height: 16px;
2129 | }
2130 |
2131 | .nav-tab:hover,
2132 | .nav-tab:focus {
2133 | background-color: #fff;
2134 | color: #444;
2135 | }
2136 |
2137 | .nav-tab-active,
2138 | .nav-tab:focus:active {
2139 | box-shadow: none;
2140 | }
2141 |
2142 | .nav-tab-active {
2143 | margin-bottom: -1px;
2144 | color: #444;
2145 | }
2146 |
2147 | .nav-tab-active,
2148 | .nav-tab-active:hover,
2149 | .nav-tab-active:focus,
2150 | .nav-tab-active:focus:active {
2151 | border-bottom: 1px solid #f1f1f1;
2152 | background: #f1f1f1;
2153 | color: #000;
2154 | }
2155 |
2156 | h1.nav-tab-wrapper, /* Back-compat for pre-4.4 */
2157 | .wrap h2.nav-tab-wrapper, /* higher specificity to override .wrap > h2:first-child */
2158 | .nav-tab-wrapper {
2159 | border-bottom: 1px solid #ccc;
2160 | margin: 0;
2161 | padding-top: 9px;
2162 | padding-bottom: 0;
2163 | line-height: inherit;
2164 | }
2165 |
2166 | /* Back-compat for plugins. Deprecated. Use .wp-clearfix instead. */
2167 | .nav-tab-wrapper:not(.wp-clearfix):after {
2168 | content: "";
2169 | display: table;
2170 | clear: both;
2171 | }
2172 |
2173 | .ie8 .nav-tab-wrapper {
2174 | /* contain floats establishing a new block formatting context */
2175 | display: inline-block;
2176 | width: 100%;
2177 | vertical-align: top;
2178 | }
2179 |
2180 | /*------------------------------------------------------------------------------
2181 | 26.0 - Misc
2182 | ------------------------------------------------------------------------------*/
2183 |
2184 | .spinner {
2185 | background: url(../../../../../wp-admin/images/spinner.gif) no-repeat;
2186 | background-size: 20px 20px;
2187 | display: inline-block;
2188 | visibility: hidden;
2189 | float: right;
2190 | vertical-align: middle;
2191 | opacity: 0.7;
2192 | filter: alpha(opacity=70);
2193 | width: 20px;
2194 | height: 20px;
2195 | margin: 4px 10px 0;
2196 | }
2197 |
2198 | .spinner.is-active,
2199 | .loading-content .spinner {
2200 | visibility: visible;
2201 | }
2202 |
2203 | #template > div {
2204 | margin-right: 190px;
2205 | }
2206 |
2207 | .metabox-holder .stuffbox > h3, /* Back-compat for pre-4.4 */
2208 | .metabox-holder .postbox > h3, /* Back-compat for pre-4.4 */
2209 | .metabox-holder h3.hndle, /* Back-compat for pre-4.4 */
2210 | .metabox-holder h2.hndle {
2211 | font-size: 14px;
2212 | padding: 8px 12px;
2213 | margin: 0;
2214 | line-height: 1.4;
2215 | }
2216 |
2217 | /* Back-compat for nav-menus screen */
2218 | .nav-menus-php .metabox-holder h3 {
2219 | padding: 10px 10px 11px 14px;
2220 | line-height: 21px;
2221 | }
2222 |
2223 | #templateside ul li a {
2224 | text-decoration: none;
2225 | }
2226 |
2227 | .plugin-install #description,
2228 | .plugin-install-network #description {
2229 | width: 60%;
2230 | }
2231 |
2232 | table .vers,
2233 | table .column-visible,
2234 | table .column-rating {
2235 | text-align: left;
2236 | }
2237 |
2238 | .attention,
2239 | .error-message {
2240 | color: red;
2241 | font-weight: 600;
2242 | }
2243 |
2244 | /* Scrollbar fix for bulk upgrade iframe */
2245 | body.iframe {
2246 | height: 98%;
2247 | }
2248 |
2249 | /* Upgrader styles, Specific to Language Packs */
2250 | .lp-show-latest p {
2251 | display: none;
2252 | }
2253 | .lp-show-latest p:last-child,
2254 | .lp-show-latest .lp-error p {
2255 | display: block;
2256 | }
2257 |
2258 | /* - Only used once or twice in all of WP - deprecate for global style
2259 | ------------------------------------------------------------------------------*/
2260 | .media-icon {
2261 | width: 62px; /* icon + border */
2262 | text-align: center;
2263 | }
2264 |
2265 | .media-icon img {
2266 | border: 1px solid #e5e5e5;
2267 | border: 1px solid rgba(0, 0, 0, 0.07);
2268 | }
2269 |
2270 | #howto {
2271 | font-size: 11px;
2272 | margin: 0 5px;
2273 | display: block;
2274 | }
2275 |
2276 | .importers {
2277 | font-size: 16px;
2278 | width: auto;
2279 | }
2280 |
2281 | .importers td {
2282 | padding-right: 14px;
2283 | line-height: 1.5em;
2284 | }
2285 |
2286 | .importers .import-system {
2287 | max-width: 250px;
2288 | }
2289 |
2290 | .importers td.desc {
2291 | max-width: 500px;
2292 | }
2293 |
2294 | .importer-title,
2295 | .importer-desc,
2296 | .importer-action {
2297 | display: block;
2298 | }
2299 |
2300 | .importer-title {
2301 | color: #000;
2302 | font-size: 14px;
2303 | font-weight: 400;
2304 | margin-bottom: .2em;
2305 | }
2306 |
2307 | .importer-action {
2308 | line-height: 20px; /* Same as with .updating-message */
2309 | color: #555;
2310 | margin-bottom: 1em;
2311 | }
2312 |
2313 | #post-body #post-body-content #namediv h3, /* Back-compat for pre-4.4 */
2314 | #post-body #post-body-content #namediv h2 {
2315 | margin-top: 0;
2316 | }
2317 |
2318 | .edit-comment-author {
2319 | font-size: 14px;
2320 | line-height: 1.4;
2321 | font-weight: 600;
2322 | color: #222;
2323 | margin: 2px 0 0 9px;
2324 | }
2325 |
2326 | #namediv h3 label, /* Back-compat for pre-4.4 */
2327 | #namediv h2 label {
2328 | vertical-align: baseline;
2329 | }
2330 |
2331 | #namediv table {
2332 | width: 100%;
2333 | }
2334 |
2335 | #namediv td.first {
2336 | width: 10px;
2337 | white-space: nowrap;
2338 | }
2339 |
2340 | #namediv input {
2341 | width: 98%;
2342 | }
2343 |
2344 | #namediv p {
2345 | margin: 10px 0;
2346 | }
2347 |
2348 | #submitdiv h3 {
2349 | margin-bottom: 0 !important;
2350 | }
2351 |
2352 | /* - Used - but could/should be deprecated with a CSS reset
2353 | ------------------------------------------------------------------------------*/
2354 | .zerosize {
2355 | height: 0;
2356 | width: 0;
2357 | margin: 0;
2358 | border: 0;
2359 | padding: 0;
2360 | overflow: hidden;
2361 | position: absolute;
2362 | }
2363 |
2364 | br.clear {
2365 | height: 2px;
2366 | line-height: 2px;
2367 | }
2368 |
2369 | .checkbox {
2370 | border: none;
2371 | margin: 0;
2372 | padding: 0;
2373 | }
2374 |
2375 | fieldset {
2376 | border: 0;
2377 | padding: 0;
2378 | margin: 0;
2379 | }
2380 |
2381 | .post-categories {
2382 | display: inline;
2383 | margin: 0;
2384 | padding: 0;
2385 | }
2386 |
2387 | .post-categories li {
2388 | display: inline;
2389 | }
2390 |
2391 | /* Star Ratings - Back-compat for pre-3.8 */
2392 | div.star-holder {
2393 | position: relative;
2394 | height: 17px;
2395 | width: 100px;
2396 | background: url(../images/stars.png?ver=20121108) repeat-x bottom left;
2397 | }
2398 |
2399 | div.star-holder .star-rating {
2400 | background: url(../images/stars.png?ver=20121108) repeat-x top left;
2401 | height: 17px;
2402 | float: left;
2403 | }
2404 |
2405 | /* Star Ratings */
2406 | .star-rating {
2407 | white-space: nowrap;
2408 | }
2409 | .star-rating .star {
2410 | display: inline-block;
2411 | width: 20px;
2412 | height: 20px;
2413 | -webkit-font-smoothing: antialiased;
2414 | font-size: 20px;
2415 | line-height: 1;
2416 | font-family: dashicons;
2417 | text-decoration: inherit;
2418 | font-weight: 400;
2419 | font-style: normal;
2420 | vertical-align: top;
2421 | transition: color .1s ease-in 0;
2422 | text-align: center;
2423 | color: #ffb900;
2424 | }
2425 |
2426 | .star-rating .star-full:before {
2427 | content: "\f155";
2428 | }
2429 |
2430 | .star-rating .star-half:before {
2431 | content: "\f459";
2432 | }
2433 |
2434 | .rtl .star-rating .star-half {
2435 | -webkit-transform: rotateY(180deg);
2436 | transform: rotateY(180deg);
2437 | }
2438 |
2439 | .star-rating .star-empty:before {
2440 | content: "\f154";
2441 | }
2442 |
2443 | div.action-links {
2444 | font-weight: 400;
2445 | margin: 6px 0 0;
2446 | }
2447 |
2448 | /* Plugin install thickbox */
2449 | #plugin-information {
2450 | background: #fff;
2451 | position: fixed;
2452 | top: 0;
2453 | right: 0;
2454 | bottom: 0;
2455 | left: 0;
2456 | height: 100%;
2457 | padding: 0;
2458 | }
2459 |
2460 | #plugin-information-scrollable {
2461 | overflow: auto;
2462 | -webkit-overflow-scrolling: touch;
2463 | height: 100%;
2464 | }
2465 |
2466 | #plugin-information-title {
2467 | padding: 0 26px;
2468 | background: #f5f5f5;
2469 | font-size: 22px;
2470 | font-weight: 600;
2471 | line-height: 56px;
2472 | position: relative;
2473 | height: 56px;
2474 | }
2475 |
2476 | #plugin-information-title.with-banner {
2477 | margin-right: 0;
2478 | height: 250px;
2479 | background-size: cover;
2480 | }
2481 |
2482 | #plugin-information-title h2 {
2483 | font-size: 1em;
2484 | font-weight: 600;
2485 | padding: 0;
2486 | margin: 0;
2487 | overflow: hidden;
2488 | text-overflow: ellipsis;
2489 | white-space: nowrap;
2490 | }
2491 |
2492 | #plugin-information-title.with-banner h2 {
2493 | position: relative;
2494 | font-family: "Helvetica Neue", sans-serif;
2495 | display: inline-block;
2496 | font-size: 30px;
2497 | line-height: 50px;
2498 | box-sizing: border-box;
2499 | max-width: 100%;
2500 | padding: 0 15px;
2501 | margin-top: 174px;
2502 | color: #fff;
2503 | background: rgba( 30, 30, 30, 0.9 );
2504 | text-shadow: 0 1px 3px rgba( 0, 0, 0, 0.4 );
2505 | box-shadow: 0 0 30px rgba( 255, 255, 255, 0.1 );
2506 | border-radius: 8px;
2507 | }
2508 |
2509 | #plugin-information-title div.vignette {
2510 | display: none;
2511 | }
2512 |
2513 | #plugin-information-title.with-banner div.vignette {
2514 | position: absolute;
2515 | display: block;
2516 | top: 0;
2517 | left: 0;
2518 | height: 250px;
2519 | width: 100%;
2520 | background: transparent;
2521 | box-shadow: inset 0 0 50px 4px rgba( 0, 0, 0, 0.2 ), inset 0 -1px 0 rgba( 0, 0, 0, 0.1 );
2522 | }
2523 |
2524 | #plugin-information-tabs {
2525 | padding: 0 16px;
2526 | position: relative;
2527 | right: 0;
2528 | left: 0;
2529 | min-height: 36px;
2530 | font-size: 0;
2531 | z-index: 1;
2532 | border-bottom: 1px solid #ddd;
2533 | background: #f3f3f3;
2534 | }
2535 |
2536 | #plugin-information-tabs a {
2537 | position: relative;
2538 | display: inline-block;
2539 | padding: 9px 10px;
2540 | margin: 0;
2541 | height: 18px;
2542 | line-height: 18px;
2543 | font-size: 14px;
2544 | text-decoration: none;
2545 | transition: none;
2546 | }
2547 |
2548 | #plugin-information-tabs a.current {
2549 | margin: 0 -1px -1px;
2550 | background: #fff;
2551 | border: 1px solid #ddd;
2552 | border-bottom-color: #fff;
2553 | padding-top: 8px;
2554 | color: #32373c;
2555 | }
2556 |
2557 | #plugin-information-tabs.with-banner a.current {
2558 | border-top: none;
2559 | padding-top: 9px;
2560 | }
2561 |
2562 | #plugin-information-tabs a:active,
2563 | #plugin-information-tabs a:focus {
2564 | outline: none;
2565 | }
2566 |
2567 | #plugin-information-content {
2568 | overflow: hidden; /* equal height column trick */
2569 | background: #fff;
2570 | position: relative;
2571 | top: 0;
2572 | right: 0;
2573 | left: 0;
2574 | min-height: 100%;
2575 | /* Height of title + tabs + install now */
2576 | min-height: calc( 100% - 152px );
2577 | }
2578 |
2579 | #plugin-information-content.with-banner {
2580 | /* Height of banner + tabs + install now */
2581 | min-height: calc( 100% - 346px );
2582 | }
2583 |
2584 | #section-holder {
2585 | position: relative;
2586 | top: 0;
2587 | right: 250px;
2588 | bottom: 0;
2589 | left: 0;
2590 | margin-right: 250px; /* FYI box */
2591 | padding: 10px 26px;
2592 | margin-bottom: -99939px; /* 60px less than the padding below to accommodate footer */
2593 | padding-bottom: 99999px; /* equal height column trick */
2594 | }
2595 |
2596 | #section-holder .updated {
2597 | margin: 16px 0;
2598 | }
2599 |
2600 | #plugin-information .fyi {
2601 | float: right;
2602 | position: relative;
2603 | top: 0;
2604 | right: 0;
2605 | padding: 16px;
2606 | margin-bottom: -99939px; /* 60px less than the padding below to accommodate footer */
2607 | padding-bottom: 99999px; /* equal height column trick */
2608 | width: 217px;
2609 | border-left: 1px solid #ddd;
2610 | background: #f3f3f3;
2611 | color: #666;
2612 | }
2613 |
2614 | #plugin-information .fyi strong {
2615 | color: #444;
2616 | }
2617 |
2618 | #plugin-information .fyi h3 {
2619 | font-weight: 600;
2620 | text-transform: uppercase;
2621 | font-size: 12px;
2622 | color: #666;
2623 | margin: 24px 0 8px;
2624 | }
2625 |
2626 | #plugin-information .fyi h2 {
2627 | font-size: 0.9em;
2628 | margin-bottom: 0;
2629 | margin-right: 0;
2630 | }
2631 |
2632 | #plugin-information .fyi ul {
2633 | padding: 0;
2634 | margin: 0;
2635 | list-style: none;
2636 | }
2637 |
2638 | #plugin-information .fyi li {
2639 | margin: 0 0 10px;
2640 | }
2641 |
2642 | #plugin-information .fyi-description {
2643 | margin-top: 0;
2644 | }
2645 |
2646 | #plugin-information .counter-container {
2647 | margin: 3px 0;
2648 | }
2649 |
2650 | #plugin-information .counter-label {
2651 | float: left;
2652 | margin-right: 5px;
2653 | min-width: 55px;
2654 | }
2655 |
2656 | #plugin-information .counter-back {
2657 | height: 17px;
2658 | width: 92px;
2659 | background-color: #e5e5e5;
2660 | float: left;
2661 | }
2662 |
2663 | #plugin-information .counter-bar {
2664 | height: 17px;
2665 | background-color: #ffc733; /* slightly lighter than stars due to larger expanse */
2666 | float: left;
2667 | }
2668 |
2669 | #plugin-information .counter-count {
2670 | margin-left: 5px;
2671 | }
2672 |
2673 | #plugin-information .fyi ul.contributors {
2674 | margin-top: 10px;
2675 | }
2676 |
2677 | #plugin-information .fyi ul.contributors li {
2678 | display: inline-block;
2679 | margin-right: 8px;
2680 | vertical-align: middle;
2681 | }
2682 |
2683 | #plugin-information .fyi ul.contributors li {
2684 | display: inline-block;
2685 | margin-right: 8px;
2686 | vertical-align: middle;
2687 | }
2688 |
2689 | #plugin-information .fyi ul.contributors li img {
2690 | vertical-align: middle;
2691 | margin-right: 4px;
2692 | }
2693 |
2694 | #plugin-information-footer {
2695 | padding: 13px 16px;
2696 | position: absolute;
2697 | right: 0;
2698 | bottom: 0;
2699 | left: 0;
2700 | height: 33px; /* 33+13+13+1=60 */
2701 | border-top: 1px solid #ddd;
2702 | background: #f3f3f3;
2703 | }
2704 |
2705 | /* rtl:ignore */
2706 | #plugin-information .section {
2707 | direction: ltr;
2708 | }
2709 |
2710 | /* rtl:ignore */
2711 | #plugin-information .section ul,
2712 | #plugin-information .section ol {
2713 | list-style-type: disc;
2714 | margin-left: 24px;
2715 | }
2716 |
2717 | #plugin-information .section,
2718 | #plugin-information .section p {
2719 | font-size: 14px;
2720 | line-height: 1.7;
2721 | }
2722 |
2723 | #plugin-information #section-screenshots ol {
2724 | list-style: none;
2725 | margin: 0;
2726 | }
2727 |
2728 | #plugin-information #section-screenshots li img {
2729 | vertical-align: text-top;
2730 | margin-top: 16px;
2731 | max-width: 100%;
2732 | width: auto;
2733 | height: auto;
2734 | box-shadow: 0 1px 2px rgba( 0, 0, 0, 0.3 );
2735 | }
2736 |
2737 | /* rtl:ignore */
2738 | #plugin-information #section-screenshots li p {
2739 | font-style: italic;
2740 | padding-left: 20px;
2741 | }
2742 |
2743 | #plugin-information pre {
2744 | padding: 7px;
2745 | overflow: auto;
2746 | border: 1px solid #ccc;
2747 | }
2748 |
2749 | #plugin-information blockquote {
2750 | border-left: 2px solid #ddd;
2751 | color: #666;
2752 | font-style: italic;
2753 | margin: 1em 0;
2754 | padding: 0 0 0 1em;
2755 | }
2756 |
2757 | /* rtl:ignore */
2758 | #plugin-information .review {
2759 | overflow: hidden; /* clearfix */
2760 | width: 100%;
2761 | margin-bottom: 20px;
2762 | border-bottom: 1px solid #e5e5e5;
2763 | }
2764 |
2765 | #plugin-information .review-title-section {
2766 | overflow: hidden; /* clearfix */
2767 | }
2768 |
2769 | /* rtl:ignore */
2770 | #plugin-information .review-title-section h4 {
2771 | display: inline-block;
2772 | float: left;
2773 | margin: 0 6px 0 0;
2774 | }
2775 |
2776 | #plugin-information .reviewer-info p {
2777 | clear: both;
2778 | margin: 0;
2779 | padding-top: 2px;
2780 | }
2781 |
2782 | /* rtl:ignore */
2783 | #plugin-information .reviewer-info .avatar {
2784 | float: left;
2785 | margin: 4px 6px 0 0;
2786 | }
2787 |
2788 | /* rtl:ignore */
2789 | #plugin-information .reviewer-info .star-rating {
2790 | float: left;
2791 | }
2792 |
2793 | /* rtl:ignore */
2794 | #plugin-information .review-meta {
2795 | float: left;
2796 | margin-left: 0.75em;
2797 | }
2798 |
2799 | /* rtl:ignore */
2800 | #plugin-information .review-body {
2801 | float: left;
2802 | width: 100%;
2803 | }
2804 |
2805 | .plugin-version-author-uri {
2806 | font-size: 13px;
2807 | }
2808 |
2809 | /* For non-js plugin installation screen ticket #36430. */
2810 | .update-php .button.button-primary {
2811 | margin-right: 1em;
2812 | }
2813 |
2814 | @media screen and ( max-width: 771px ) {
2815 | #plugin-information-title.with-banner {
2816 | height: 100px;
2817 | }
2818 |
2819 | #plugin-information-title.with-banner h2 {
2820 | margin-top: 30px;
2821 | font-size: 20px;
2822 | line-height: 40px;
2823 | max-width: 85%;
2824 | }
2825 |
2826 | #plugin-information-title.with-banner div.vignette {
2827 | height: 100px;
2828 | }
2829 |
2830 | #plugin-information-tabs {
2831 | overflow: hidden; /* clearfix */
2832 | padding: 0;
2833 | height: auto; /* let tabs wrap */
2834 | }
2835 |
2836 | #plugin-information-tabs a.current {
2837 | margin-bottom: 0;
2838 | border-bottom: none;
2839 | }
2840 |
2841 | #plugin-information .fyi {
2842 | float: none;
2843 | border: 1px solid #ddd;
2844 | position: static;
2845 | width: auto;
2846 | margin: 26px 26px 0;
2847 | padding-bottom: 0; /* reset from the two column height fix */
2848 | }
2849 |
2850 | #section-holder {
2851 | position: static;
2852 | margin: 0;
2853 | padding-bottom: 70px; /* reset from the two column height fix, plus accommodate footer */
2854 | }
2855 |
2856 | #plugin-information .fyi h3,
2857 | #plugin-information .fyi small {
2858 | display: none;
2859 | }
2860 |
2861 | #plugin-information-footer {
2862 | padding: 12px 16px 0;
2863 | height: 46px;
2864 | }
2865 | }
2866 |
2867 | /* Thickbox for Plugin Install screen */
2868 | body.about-php #TB_window,
2869 | body.plugin-install-php #TB_window,
2870 | body.import-php #TB_window,
2871 | body.plugins-php #TB_window,
2872 | body.update-core-php #TB_window,
2873 | body.index-php #TB_window {
2874 | background: #fcfcfc;
2875 | }
2876 |
2877 | /* IE 8 needs a change in the pseudo element content */
2878 | .ie8 body.about-php #TB_window:before,
2879 | .ie8 body.plugin-install-php #TB_window:before,
2880 | .ie8 body.import-php #TB_window:before,
2881 | .ie8 body.plugins-php #TB_window:before,
2882 | .ie8 body.update-core-php #TB_window:before,
2883 | .ie8 body.index-php #TB_window:before {
2884 | content: " ";
2885 | background: none;
2886 | }
2887 |
2888 | body.about-php #TB_window.thickbox-loading:before,
2889 | body.plugin-install-php #TB_window.thickbox-loading:before,
2890 | body.import-php #TB_window.thickbox-loading:before,
2891 | body.plugins-php #TB_window.thickbox-loading:before,
2892 | body.update-core-php #TB_window.thickbox-loading:before,
2893 | body.index-php #TB_window.thickbox-loading:before {
2894 | content: "";
2895 | display: block;
2896 | width: 20px;
2897 | height: 20px;
2898 | position: absolute;
2899 | left: 50%;
2900 | top: 50%;
2901 | z-index: -1;
2902 | margin: -10px 0 0 -10px;
2903 | background: #fcfcfc url(../../../../../wp-admin/images/spinner.gif) no-repeat center;
2904 | background-size: 20px 20px;
2905 | -webkit-transform: translateZ(0);
2906 | transform: translateZ(0);
2907 | }
2908 |
2909 | @media print,
2910 | (-webkit-min-device-pixel-ratio: 1.25),
2911 | (min-resolution: 120dpi) {
2912 |
2913 | body.about-php #TB_window.thickbox-loading:before,
2914 | body.plugin-install-php #TB_window.thickbox-loading:before,
2915 | body.import-php #TB_window.thickbox-loading:before,
2916 | body.plugins-php #TB_window.thickbox-loading:before,
2917 | body.update-core-php #TB_window.thickbox-loading:before,
2918 | body.index-php #TB_window.thickbox-loading:before {
2919 | background-image: url(../../../../../wp-admin/images/spinner-2x.gif);
2920 | }
2921 | }
2922 |
2923 | body.about-php #TB_title,
2924 | body.plugin-install-php #TB_title,
2925 | body.import-php #TB_title,
2926 | body.plugins-php #TB_title,
2927 | body.update-core-php #TB_title,
2928 | body.index-php #TB_title {
2929 | float: left;
2930 | height: 1px;
2931 | }
2932 |
2933 | body.about-php #TB_ajaxWindowTitle,
2934 | body.plugin-install-php #TB_ajaxWindowTitle,
2935 | body.import-php #TB_ajaxWindowTitle,
2936 | body.plugins-php #TB_ajaxWindowTitle,
2937 | body.update-core-php #TB_ajaxWindowTitle,
2938 | body.index-php #TB_ajaxWindowTitle {
2939 | display: none;
2940 | }
2941 |
2942 | /* only on these screens */
2943 | .about-php #TB_closeWindowButton,
2944 | .plugin-install-php #TB_closeWindowButton,
2945 | .import-php #TB_closeWindowButton,
2946 | .plugins-php #TB_closeWindowButton,
2947 | .update-core-php #TB_closeWindowButton,
2948 | .index-php #TB_closeWindowButton {
2949 | left: auto;
2950 | right: -30px;
2951 | color: #eee;
2952 | }
2953 |
2954 |
2955 | body.about-php #TB_closeWindowButton:hover,
2956 | body.about-php #TB_closeWindowButton:focus,
2957 | body.plugin-install-php #TB_closeWindowButton:hover,
2958 | body.plugin-install-php #TB_closeWindowButton:focus,
2959 | body.import-php #TB_closeWindowButton:hover,
2960 | body.import-php #TB_closeWindowButton:focus,
2961 | body.plugins-php #TB_closeWindowButton:hover,
2962 | body.plugins-php #TB_closeWindowButton:focus,
2963 | body.update-core-php #TB_closeWindowButton:hover,
2964 | body.update-core-php #TB_closeWindowButton:focus,
2965 | body.index-php #TB_closeWindowButton:hover,
2966 | body.index-php #TB_closeWindowButton:focus {
2967 | color: #00a0d2;
2968 | outline: none;
2969 | box-shadow: none;
2970 | }
2971 |
2972 | body.about-php .tb-close-icon,
2973 | body.plugin-install-php .tb-close-icon,
2974 | body.import-php .tb-close-icon,
2975 | body.plugins-php .tb-close-icon,
2976 | body.update-core-php .tb-close-icon,
2977 | body.index-php .tb-close-icon {
2978 | display: none;
2979 | }
2980 |
2981 | body.about-php #TB_closeWindowButton:after,
2982 | body.plugin-install-php #TB_closeWindowButton:after,
2983 | body.import-php #TB_closeWindowButton:after,
2984 | body.plugins-php #TB_closeWindowButton:after,
2985 | body.update-core-php #TB_closeWindowButton:after,
2986 | body.index-php #TB_closeWindowButton:after {
2987 | content: "\f335";
2988 | font: normal 32px/29px 'dashicons';
2989 | speak: none;
2990 | -webkit-font-smoothing: antialiased;
2991 | -moz-osx-font-smoothing: grayscale;
2992 | }
2993 |
2994 | /* move plugin install close icon to top on narrow screens */
2995 | @media screen and ( max-width: 830px ) {
2996 | body.about-php #TB_closeWindowButton,
2997 | body.plugin-install-php #TB_closeWindowButton,
2998 | body.import-php #TB_closeWindowButton,
2999 | body.plugins-php #TB_closeWindowButton,
3000 | body.update-core-php #TB_closeWindowButton,
3001 | body.index-php #TB_closeWindowButton {
3002 | right: 0;
3003 | top: -30px;
3004 | }
3005 | }
3006 |
3007 | /* @todo: move this. */
3008 | img {
3009 | border: none;
3010 | }
3011 |
3012 | /* Metabox collapse arrow indicators */
3013 | .js .sidebar-name .sidebar-name-arrow:before,
3014 | .js .meta-box-sortables .postbox .toggle-indicator:before,
3015 | .bulk-action-notice .toggle-indicator:before {
3016 | content: "\f142";
3017 | display: inline-block;
3018 | font: normal 20px/1 dashicons;
3019 | speak: none;
3020 | -webkit-font-smoothing: antialiased;
3021 | -moz-osx-font-smoothing: grayscale;
3022 | text-decoration: none !important;
3023 | }
3024 |
3025 | .js .widgets-holder-wrap.closed .sidebar-name-arrow:before,
3026 | .js .meta-box-sortables .postbox.closed .handlediv .toggle-indicator:before,
3027 | .bulk-action-notice .bulk-action-errors-collapsed .toggle-indicator:before {
3028 | content: "\f140";
3029 | }
3030 |
3031 | .js .sidebar-name .sidebar-name-arrow:before {
3032 | padding: 10px;
3033 | left: 0;
3034 | }
3035 |
3036 | .js #widgets-left .sidebar-name .sidebar-name-arrow {
3037 | display: none;
3038 | }
3039 |
3040 | .js #widgets-left .widgets-holder-wrap.closed .sidebar-name .sidebar-name-arrow,
3041 | .js #widgets-left .sidebar-name:hover .sidebar-name-arrow {
3042 | display: block;
3043 | }
3044 |
3045 | .js .postbox .handlediv .toggle-indicator:before {
3046 | margin-top: 4px;
3047 | width: 20px;
3048 | border-radius: 50%;
3049 | text-indent: -1px; /* account for the dashicon alignment */
3050 | }
3051 |
3052 | .rtl.js .postbox .handlediv .toggle-indicator:before {
3053 | text-indent: 1px; /* account for the dashicon alignment */
3054 | }
3055 |
3056 | .bulk-action-notice .toggle-indicator:before {
3057 | line-height: 16px;
3058 | vertical-align: top;
3059 | color: #72777c;
3060 | }
3061 |
3062 | .js .postbox .handlediv:focus {
3063 | box-shadow: none;
3064 | outline: none;
3065 | }
3066 |
3067 | .js .postbox .handlediv:focus .toggle-indicator:before {
3068 | box-shadow:
3069 | 0 0 0 1px #5b9dd9,
3070 | 0 0 2px 1px rgba(30, 140, 190, .8);
3071 | }
3072 |
3073 | /* @todo: appears to be Press This only and overridden */
3074 | #photo-add-url-div input[type="text"] {
3075 | width: 300px;
3076 | }
3077 |
3078 | /* Theme/Plugin Editor */
3079 | .alignleft h2 {
3080 | margin: 0;
3081 | }
3082 |
3083 | #template textarea {
3084 | font-family: Consolas, Monaco, monospace;
3085 | font-size: 13px;
3086 | background: #f9f9f9;
3087 | -moz-tab-size: 4;
3088 | -o-tab-size: 4;
3089 | tab-size: 4;
3090 | }
3091 |
3092 | #template textarea,
3093 | #template .CodeMirror {
3094 | width: 97%;
3095 | height: calc( 100vh - 220px );
3096 | }
3097 |
3098 | /* rtl:ignore */
3099 | #template textarea,
3100 | #docs-list {
3101 | direction: ltr;
3102 | }
3103 |
3104 | #template p {
3105 | width: 97%;
3106 | }
3107 |
3108 | #file-editor-linting-error {
3109 | margin-top: 1em;
3110 | margin-bottom: 1em;
3111 | }
3112 | #file-editor-linting-error > .notice {
3113 | margin: 0;
3114 | display: inline-block;
3115 | }
3116 | #file-editor-linting-error > .notice > p {
3117 | width: auto;
3118 | }
3119 | #template .submit {
3120 | margin-top: 1em;
3121 | padding: 0;
3122 | }
3123 |
3124 | #template .submit input[type=submit][disabled] {
3125 | cursor: not-allowed;
3126 | }
3127 | #templateside {
3128 | float: right;
3129 | width: 190px;
3130 | word-wrap: break-word;
3131 | }
3132 |
3133 | #templateside h2,
3134 | #postcustomstuff p.submit {
3135 | margin: 0;
3136 | }
3137 |
3138 | #templateside h4 {
3139 | margin: 1em 0 0;
3140 | }
3141 |
3142 | #templateside ol,
3143 | #templateside ul {
3144 | margin: .5em 0;
3145 | padding: 0;
3146 | }
3147 |
3148 | #templateside li {
3149 | margin: 4px 0;
3150 | }
3151 |
3152 | #templateside li a,
3153 | .theme-editor-php .highlight {
3154 | display: block;
3155 | padding: 3px 3px 3px 12px;
3156 | text-decoration: none;
3157 | }
3158 |
3159 | .theme-editor-php .highlight {
3160 | margin: -3px 3px -3px -12px;
3161 | }
3162 |
3163 | #templateside .highlight {
3164 | border: none;
3165 | font-weight: 600;
3166 | }
3167 |
3168 | .nonessential {
3169 | color: #666;
3170 | font-size: 11px;
3171 | font-style: italic;
3172 | padding-left: 12px;
3173 | }
3174 |
3175 | #documentation {
3176 | margin-top: 10px;
3177 | }
3178 |
3179 | #documentation label {
3180 | line-height: 22px;
3181 | vertical-align: baseline;
3182 | font-weight: 600;
3183 | }
3184 |
3185 | .fileedit-sub {
3186 | padding: 10px 0 8px;
3187 | line-height: 180%;
3188 | }
3189 |
3190 | /* @todo: can we use a common class for these? */
3191 | .nav-menus-php .item-edit:before,
3192 | .widget-top .widget-action .toggle-indicator:before,
3193 | .control-section .accordion-section-title:after,
3194 | .accordion-section-title:after {
3195 | content: "\f140";
3196 | font: normal 20px/1 dashicons;
3197 | speak: none;
3198 | display: block;
3199 | -webkit-font-smoothing: antialiased;
3200 | -moz-osx-font-smoothing: grayscale;
3201 | text-decoration: none !important;
3202 | }
3203 |
3204 | .widget-top .widget-action .toggle-indicator:before {
3205 | padding: 1px 2px 1px 0px;
3206 | border-radius: 50%;
3207 | }
3208 |
3209 | .handlediv,
3210 | .postbox .handlediv.button-link,
3211 | .item-edit,
3212 | .sidebar-name-arrow,
3213 | .accordion-section-title:after {
3214 | color: #72777c;
3215 | }
3216 |
3217 | .widget-action {
3218 | color: #555d66; /* #fafafa background in the Widgets screen */
3219 | }
3220 |
3221 | .widget-top:hover .widget-action,
3222 | .widget-action:focus,
3223 | .handlediv:hover,
3224 | .handlediv:focus,
3225 | .postbox .handlediv.button-link:hover,
3226 | .postbox .handlediv.button-link:focus,
3227 | .item-edit:hover,
3228 | .item-edit:focus,
3229 | .sidebar-name:hover .sidebar-name-arrow,
3230 | .accordion-section-title:hover:after {
3231 | color: #23282d;
3232 | }
3233 |
3234 | .widget-top .widget-action:focus .toggle-indicator:before {
3235 | box-shadow:
3236 | 0 0 0 1px #5b9dd9,
3237 | 0 0 2px 1px rgba(30,140,190,.8);
3238 | }
3239 |
3240 | .control-section .accordion-section-title:after,
3241 | .accordion-section-title:after {
3242 | float: right;
3243 | right: 20px;
3244 | top: -2px;
3245 | }
3246 |
3247 | .control-section.open .accordion-section-title:after,
3248 | #customize-info.open .accordion-section-title:after,
3249 | .nav-menus-php .menu-item-edit-active .item-edit:before,
3250 | .widget.open .widget-top .widget-action .toggle-indicator:before {
3251 | content: "\f142";
3252 | }
3253 |
3254 | /*!
3255 | * jQuery UI Draggable/Sortable 1.11.4
3256 | * http://jqueryui.com
3257 | *
3258 | * Copyright jQuery Foundation and other contributors
3259 | * Released under the MIT license.
3260 | * http://jquery.org/license
3261 | */
3262 | .ui-draggable-handle,
3263 | .ui-sortable-handle {
3264 | touch-action: none;
3265 | }
3266 |
3267 | /* Accordion */
3268 | .accordion-section {
3269 | border-bottom: 1px solid #ddd;
3270 | margin: 0;
3271 | }
3272 |
3273 | .accordion-section.open .accordion-section-content,
3274 | .no-js .accordion-section .accordion-section-content {
3275 | display: block;
3276 | }
3277 |
3278 | .accordion-section.open:hover {
3279 | border-bottom-color: #ddd;
3280 | }
3281 |
3282 | .accordion-section-content {
3283 | display: none;
3284 | padding: 10px 20px 15px;
3285 | overflow: hidden;
3286 | background: #fff;
3287 | }
3288 |
3289 | .accordion-section-title {
3290 | margin: 0;
3291 | padding: 12px 15px 15px;
3292 | position: relative;
3293 | border-left: 1px solid #ddd;
3294 | border-right: 1px solid #ddd;
3295 | -webkit-user-select: none;
3296 | -moz-user-select: none;
3297 | -ms-user-select: none;
3298 | user-select: none;
3299 | }
3300 |
3301 | .js .accordion-section-title {
3302 | cursor: pointer;
3303 | }
3304 |
3305 | .js .accordion-section-title:after {
3306 | position: absolute;
3307 | top: 12px;
3308 | right: 10px;
3309 | z-index: 1;
3310 | }
3311 |
3312 | .accordion-section-title:focus {
3313 | outline: none;
3314 | }
3315 |
3316 | .accordion-section-title:hover:after,
3317 | .accordion-section-title:focus:after {
3318 | border-color: #a0a5aa transparent;
3319 | }
3320 |
3321 | .cannot-expand .accordion-section-title {
3322 | cursor: auto;
3323 | }
3324 |
3325 | .cannot-expand .accordion-section-title:after {
3326 | display: none;
3327 | }
3328 |
3329 | .control-section .accordion-section-title,
3330 | .customize-pane-child .accordion-section-title {
3331 | border-left: none;
3332 | border-right: none;
3333 | padding: 10px 10px 11px 14px;
3334 | line-height: 21px;
3335 | background: #fff;
3336 | }
3337 |
3338 | .control-section .accordion-section-title:after,
3339 | .customize-pane-child .accordion-section-title:after {
3340 | top: 11px;
3341 | }
3342 |
3343 | .js .control-section:hover .accordion-section-title,
3344 | .js .control-section .accordion-section-title:hover,
3345 | .js .control-section.open .accordion-section-title,
3346 | .js .control-section .accordion-section-title:focus {
3347 | color: #23282d;
3348 | background: #f5f5f5;
3349 | }
3350 |
3351 | .control-section.open .accordion-section-title {
3352 | /* When expanded */
3353 | border-bottom: 1px solid #ddd;
3354 | }
3355 |
3356 | /* Edit Site */
3357 | .network-admin .edit-site-actions {
3358 | margin-top: 0;
3359 | }
3360 |
3361 | /* My Sites */
3362 | .my-sites {
3363 | display: block;
3364 | overflow: auto;
3365 | zoom: 1;
3366 | }
3367 |
3368 | .my-sites li {
3369 | display: block;
3370 | padding: 8px 3%;
3371 | min-height: 130px;
3372 | margin: 0;
3373 | }
3374 |
3375 | @media only screen and (max-width: 599px) {
3376 | .my-sites li {
3377 | min-height: 0;
3378 | }
3379 | }
3380 |
3381 | @media only screen and (min-width: 600px) {
3382 | .my-sites.striped li {
3383 | background-color: #fff;
3384 | position: relative;
3385 | }
3386 | .my-sites.striped li:after {
3387 | content: "";
3388 | width: 1px;
3389 | height: 100%;
3390 | position: absolute;
3391 | top: 0;
3392 | right: 0;
3393 | background: #ccc;
3394 | }
3395 |
3396 | }
3397 | @media only screen and (min-width: 600px) and (max-width: 699px) {
3398 | .my-sites li{
3399 | float: left;
3400 | width: 44%;
3401 | }
3402 | .my-sites.striped li {
3403 | background-color: #fff;
3404 | }
3405 | .my-sites.striped li:nth-of-type(2n+1) {
3406 | clear: left;
3407 | }
3408 | .my-sites.striped li:nth-of-type(2n+2):after {
3409 | content: none;
3410 | }
3411 | .my-sites li:nth-of-type(4n+1),
3412 | .my-sites li:nth-of-type(4n+2) {
3413 | background-color: #f9f9f9;
3414 | }
3415 |
3416 | }
3417 |
3418 | @media only screen and (min-width: 700px) and (max-width: 1199px) {
3419 | .my-sites li {
3420 | float: left;
3421 | width: 27.333333%;
3422 | background-color: #fff;
3423 | }
3424 | .my-sites.striped li:nth-of-type(3n+3):after {
3425 | content: none;
3426 | }
3427 | .my-sites li:nth-of-type(6n+1),
3428 | .my-sites li:nth-of-type(6n+2),
3429 | .my-sites li:nth-of-type(6n+3) {
3430 | background-color: #f9f9f9;
3431 | }
3432 | }
3433 |
3434 | @media only screen and (min-width: 1200px) and (max-width: 1399px) {
3435 | .my-sites li {
3436 | float: left;
3437 | width: 21%;
3438 | padding: 8px 2%;
3439 | background-color: #fff;
3440 | }
3441 | .my-sites.striped li:nth-of-type(4n+1) {
3442 | clear: left;
3443 | }
3444 | .my-sites.striped li:nth-of-type(4n+4):after {
3445 | content: none;
3446 | }
3447 | .my-sites li:nth-of-type(8n+1),
3448 | .my-sites li:nth-of-type(8n+2),
3449 | .my-sites li:nth-of-type(8n+3),
3450 | .my-sites li:nth-of-type(8n+4) {
3451 | background-color: #f9f9f9;
3452 | }
3453 | }
3454 |
3455 | @media only screen and (min-width: 1400px) and (max-width: 1599px) {
3456 | .my-sites li {
3457 | float: left;
3458 | width: 16%;
3459 | padding: 8px 2%;
3460 | background-color: #fff;
3461 | }
3462 | .my-sites.striped li:nth-of-type(5n+1) {
3463 | clear: left;
3464 | }
3465 | .my-sites.striped li:nth-of-type(5n+5):after {
3466 | content: none;
3467 | }
3468 | .my-sites li:nth-of-type(10n+1),
3469 | .my-sites li:nth-of-type(10n+2),
3470 | .my-sites li:nth-of-type(10n+3),
3471 | .my-sites li:nth-of-type(10n+4),
3472 | .my-sites li:nth-of-type(10n+5) {
3473 | background-color: #f9f9f9;
3474 | }
3475 | }
3476 |
3477 | @media only screen and (min-width: 1600px) {
3478 | .my-sites li {
3479 | float: left;
3480 | width: 12.666666%;
3481 | padding: 8px 2%;
3482 | background-color: #fff;
3483 | }
3484 | .my-sites.striped li:nth-of-type(6n+1) {
3485 | clear: left;
3486 | }
3487 | .my-sites.striped li:nth-of-type(6n+6):after {
3488 | content: none;
3489 | }
3490 | .my-sites li:nth-of-type(12n+1),
3491 | .my-sites li:nth-of-type(12n+2),
3492 | .my-sites li:nth-of-type(12n+3),
3493 | .my-sites li:nth-of-type(12n+4),
3494 | .my-sites li:nth-of-type(12n+5),
3495 | .my-sites li:nth-of-type(12n+6) {
3496 | background-color: #f9f9f9;
3497 | }
3498 | }
3499 |
3500 | .my-sites li a {
3501 | text-decoration: none;
3502 | }
3503 |
3504 | /* =Media Queries
3505 | -------------------------------------------------------------- */
3506 |
3507 | /**
3508 | * HiDPI Displays
3509 | */
3510 | @media print,
3511 | (-webkit-min-device-pixel-ratio: 1.25),
3512 | (min-resolution: 120dpi) {
3513 | /* Back-compat for pre-3.8 */
3514 | div.star-holder,
3515 | div.star-holder .star-rating {
3516 | background: url(../images/stars-2x.png?ver=20121108) repeat-x bottom left;
3517 | background-size: 21px 37px;
3518 | }
3519 |
3520 | .spinner {
3521 | background-image: url(../../../../../wp-admin/images/spinner-2x.gif);
3522 | }
3523 |
3524 | /* @todo: evaluate - most of these were likely replaced by dashicons */
3525 | .curtime #timestamp,
3526 | #screen-meta-links a.show-settings,
3527 | .widget-top .widget-action,
3528 | .widget-top .widget-action:hover,
3529 | .sidebar-name-arrow,
3530 | .sidebar-name:hover .sidebar-name-arrow,
3531 | .meta-box-sortables .postbox:hover .handlediv,
3532 | #bulk-titles div a,
3533 | #bulk-titles div a:hover {
3534 | background: none !important;
3535 | }
3536 |
3537 | }
3538 |
3539 | @-ms-viewport {
3540 | width: device-width;
3541 | }
3542 |
3543 | @media screen and ( max-width: 782px ) {
3544 | html.wp-toolbar {
3545 | padding-top: 46px;
3546 | }
3547 |
3548 | body {
3549 | min-width: 240px;
3550 | overflow-x: hidden;
3551 | }
3552 |
3553 | body * {
3554 | -webkit-tap-highlight-color: rgba(0, 0, 0, 0) !important;
3555 | }
3556 |
3557 | #wpcontent {
3558 | position: relative;
3559 | margin-left: 0;
3560 | padding-left: 10px;
3561 | }
3562 |
3563 | #wpbody-content {
3564 | padding-bottom: 100px;
3565 | }
3566 |
3567 | .wrap {
3568 | margin-right: 12px;
3569 | margin-left: 0;
3570 | }
3571 |
3572 | /* categories */
3573 | #col-left,
3574 | #col-right {
3575 | float: none;
3576 | width: auto;
3577 | }
3578 |
3579 | #col-left .col-wrap,
3580 | #col-right .col-wrap {
3581 | padding: 0;
3582 | }
3583 |
3584 | /* Hidden Elements */
3585 | #screen-meta,
3586 | #screen-meta-links,
3587 | #collapse-menu,
3588 | .post-format-select {
3589 | display: none !important;
3590 | }
3591 |
3592 | .wrap h1.wp-heading-inline {
3593 | margin-bottom: 0.5em;
3594 | }
3595 |
3596 | .wrap .add-new-h2, /* deprecated */
3597 | .wrap .add-new-h2:active, /* deprecated */
3598 | .wrap .page-title-action,
3599 | .wrap .page-title-action:active {
3600 | padding: 10px 15px;
3601 | font-size: 14px;
3602 | white-space: nowrap;
3603 | }
3604 |
3605 | .wp-color-result {
3606 | height: auto;
3607 | padding-left: 45px;
3608 | }
3609 |
3610 | .wp-color-result:after {
3611 | font-size: 14px;
3612 | height: auto;
3613 | padding: 6px 14px;
3614 | }
3615 |
3616 | /* Feedback Messages */
3617 | .notice,
3618 | .wrap div.updated,
3619 | .wrap div.error,
3620 | .media-upload-form div.error {
3621 | margin: 20px 0 10px 0;
3622 | padding: 5px 10px;
3623 | font-size: 14px;
3624 | line-height: 175%;
3625 | }
3626 |
3627 | .wp-core-ui .notice.is-dismissible {
3628 | padding-right: 46px;
3629 | }
3630 |
3631 | .notice-dismiss {
3632 | padding: 13px;
3633 | }
3634 |
3635 | .wrap .icon32 + h2 {
3636 | margin-top: -2px;
3637 | }
3638 |
3639 | .wp-responsive-open #wpbody {
3640 | right: -190px;
3641 | }
3642 |
3643 | code {
3644 | word-wrap: break-word;
3645 | }
3646 |
3647 | /* General Metabox */
3648 | .postbox {
3649 | font-size: 14px;
3650 | }
3651 |
3652 | .metabox-holder h3.hndle, /* Back-compat for pre-4.4 */
3653 | .metabox-holder .stuffbox > h3, /* Back-compat for pre-4.4 */
3654 | .metabox-holder .postbox > h3, /* Back-compat for pre-4.4 */
3655 | .metabox-holder h2 {
3656 | padding: 12px;
3657 | }
3658 |
3659 | .postbox .handlediv {
3660 | margin-top: 3px;
3661 | }
3662 |
3663 | /* Subsubsub Nav */
3664 | .subsubsub {
3665 | font-size: 16px;
3666 | text-align: center;
3667 | margin-bottom: 15px;
3668 | }
3669 |
3670 | /* Theme/Plugin File Editor */
3671 | #templateside {
3672 | float: none;
3673 | width: auto;
3674 | }
3675 |
3676 | #templateside li {
3677 | margin: 0;
3678 | }
3679 |
3680 | #templateside li a {
3681 | display: block;
3682 | padding: 5px;
3683 | }
3684 |
3685 | #templateside .highlight {
3686 | padding: 5px;
3687 | margin-left: -5px;
3688 | margin-top: -5px;
3689 | }
3690 |
3691 | #template > div {
3692 | float: none;
3693 | margin: 0;
3694 | width: auto;
3695 | }
3696 |
3697 | #template .CodeMirror,
3698 | #template textarea {
3699 | width: 100%;
3700 | }
3701 |
3702 | .fileedit-sub .alignright {
3703 | margin-top: 15px;
3704 | }
3705 |
3706 | #wpfooter {
3707 | display: none;
3708 | }
3709 |
3710 | #comments-form .checkforspam {
3711 | display: none;
3712 | }
3713 |
3714 | .edit-comment-author {
3715 | margin: 2px 0 0;
3716 | }
3717 |
3718 | .filter-drawer .filter-group-feature input,
3719 | .filter-drawer .filter-group-feature label {
3720 | line-height: 25px;
3721 | }
3722 |
3723 | .wp-filter .button.drawer-toggle {
3724 | font-size: 13px;
3725 | line-height: 26px;
3726 | height: 28px;
3727 | }
3728 | }
3729 |
3730 | /* Smartphone */
3731 | @media screen and (max-width: 600px) {
3732 | /* Disable horizontal scroll when responsive menu is open
3733 | since we push the main content off to the right. */
3734 | #wpwrap.wp-responsive-open {
3735 | overflow-x: hidden;
3736 | }
3737 |
3738 | html.wp-toolbar {
3739 | padding-top: 0;
3740 | }
3741 |
3742 | #wpbody {
3743 | padding-top: 46px;
3744 | }
3745 |
3746 | /* Keep full-width boxes on Edit Post page from causing horizontal scroll */
3747 | div#post-body.metabox-holder.columns-1 {
3748 | overflow-x: hidden;
3749 | }
3750 |
3751 | h1.nav-tab-wrapper,
3752 | .wrap h2.nav-tab-wrapper,
3753 | .nav-tab-wrapper {
3754 | border-bottom: 0;
3755 | }
3756 |
3757 | h1 .nav-tab,
3758 | h2 .nav-tab,
3759 | h3 .nav-tab {
3760 | margin: 10px 10px 0 0;
3761 | border-bottom: 1px solid #ccc;
3762 | }
3763 | }
3764 |
3765 | @media screen and (max-width: 320px) {
3766 | /* Prevent default center alignment and larger font for the Right Now widget when
3767 | the network dashboard is viewed on a small mobile device. */
3768 | #network_dashboard_right_now .subsubsub {
3769 | font-size: 14px;
3770 | text-align: left;
3771 | }
3772 | }
3773 |
--------------------------------------------------------------------------------
/wp-admin/css/customize-controls-addendum.css:
--------------------------------------------------------------------------------
1 | .customize-section-description-container + #customize-control-custom_css:last-child .CodeMirror {
2 | height: calc( 100vh - 185px );
3 | }
4 | .CodeMirror-lint-tooltip,
5 | .CodeMirror-hints {
6 | z-index: 500000 !important;
7 | }
8 |
9 | .customize-section-description ul {
10 | margin-left: 1em;
11 | }
12 | .customize-section-description ul > li {
13 | list-style: disc;
14 | }
15 |
16 | .customize-section-description-container + #customize-control-custom_css:last-child .customize-control-notifications-container {
17 | margin-left: 12px;
18 | margin-right: 12px;
19 | }
20 |
21 | .section-description-buttons {
22 | text-align: right;
23 | }
24 |
25 | .section-description-buttons button.button-link {
26 | color: #0073aa; /* @todo Color scheme? */
27 | text-decoration: underline;
28 | }
29 |
--------------------------------------------------------------------------------
/wp-admin/css/widgets-addendum.css:
--------------------------------------------------------------------------------
1 | /* To be added under "Specific widget styling" */
2 |
3 | .custom-html-widget-fields > p > .CodeMirror {
4 | border: 1px solid #e5e5e5;
5 | }
6 | .custom-html-widget-fields code {
7 | padding-top: 1px;
8 | padding-bottom: 1px;
9 | }
10 | ul.CodeMirror-hints {
11 | z-index: 101; /* Due to z-index 100 set on .widget.open */
12 | }
13 | .widget-control-actions .custom-html-widget-save-button.button.validation-blocked {
14 | cursor: not-allowed;
15 | }
16 |
--------------------------------------------------------------------------------
/wp-admin/file-editor-addendum.php:
--------------------------------------------------------------------------------
1 | errors() ) {
69 | wp_die( $theme->errors()->get_error_message() );
70 | }
71 |
72 | if ( isset( $_REQUEST['file'] ) ) {
73 | $args['file'] = sanitize_text_field( wp_unslash( $_REQUEST['file'] ) );
74 | } else {
75 | $args['file'] = 'style.css';
76 | }
77 | } elseif ( 'plugin-editor.php' === $hook ) {
78 | $args['plugin'] = isset( $_REQUEST['plugin'] ) ? sanitize_text_field( wp_unslash( $_REQUEST['plugin'] ) ) : '';
79 | $args['file'] = isset( $_REQUEST['file'] ) ? sanitize_text_field( wp_unslash( $_REQUEST['file'] ) ) : '';
80 |
81 | if ( empty( $args['plugin'] ) ) {
82 | $file_paths = array_keys( get_plugins() );
83 | $args['plugin'] = $args['file'] ? $args['file'] : array_shift( $file_paths );
84 | } elseif ( 0 !== validate_file( $args['plugin'] ) ) {
85 | wp_die( __( 'Sorry, that file cannot be edited.', 'better-code-editing' ) );
86 | }
87 |
88 | $plugin_files = get_plugin_files( $args['plugin'] );
89 | if ( empty( $args['file'] ) ) {
90 | $args['file'] = $plugin_files[0];
91 | }
92 |
93 | $args['file'] = validate_file_to_edit( $args['file'], $plugin_files );
94 | }
95 |
96 | $settings = wp_enqueue_code_editor( $args );
97 | if ( empty( $settings ) ) {
98 | return;
99 | }
100 |
101 | wp_enqueue_script( 'wp-theme-plugin-editor' );
102 |
103 | $l10n = wp_array_slice_assoc(
104 | /* translators: placeholder is error count */
105 | _n_noop( 'There is %d error which must be fixed before you can save.', 'There are %d errors which must be fixed before you can save.', 'better-code-editing' ),
106 | array( 'singular', 'plural' )
107 | );
108 | wp_add_inline_script( 'wp-theme-plugin-editor', sprintf( 'wp.themePluginEditor.l10n = %s;', wp_json_encode( $l10n ) ) );
109 | wp_add_inline_script( 'wp-theme-plugin-editor', sprintf( 'jQuery( function() { wp.themePluginEditor.init( %s ); } )', wp_json_encode( $settings ) ) );
110 | }
111 |
--------------------------------------------------------------------------------
/wp-admin/includes/user.php:
--------------------------------------------------------------------------------
1 | .
59 | if ( ! lintOptions.options ) {
60 | lintOptions.options = {};
61 | }
62 |
63 | // Configure JSHint.
64 | if ( 'javascript' === settings.codemirror.mode && settings.jshint ) {
65 | $.extend( lintOptions.options, settings.jshint );
66 | }
67 |
68 | // Configure CSSLint.
69 | if ( 'css' === settings.codemirror.mode && settings.csslint ) {
70 | $.extend( lintOptions.options, settings.csslint );
71 | }
72 |
73 | // Configure HTMLHint.
74 | if ( 'htmlmixed' === settings.codemirror.mode && settings.htmlhint ) {
75 | lintOptions.options.rules = $.extend( {}, settings.htmlhint );
76 |
77 | if ( settings.jshint ) {
78 | lintOptions.options.rules.jshint = settings.jshint;
79 | }
80 | if ( settings.csslint ) {
81 | lintOptions.options.rules.csslint = settings.csslint;
82 | }
83 | }
84 |
85 | /**
86 | * Call the onUpdateErrorNotice if there are new errors to show.
87 | *
88 | * @returns {void}
89 | */
90 | updateErrorNotice = function() {
91 | if ( settings.onUpdateErrorNotice && ! _.isEqual( currentErrorAnnotations, previouslyShownErrorAnnotations ) ) {
92 | settings.onUpdateErrorNotice( currentErrorAnnotations, editor );
93 | previouslyShownErrorAnnotations = currentErrorAnnotations;
94 | }
95 | };
96 |
97 | // Wrap the onUpdateLinting CodeMirror event to route to onChangeLintingErrors and onUpdateErrorNotice.
98 | lintOptions.onUpdateLinting = (function( onUpdateLintingOverridden ) {
99 | return function( annotations, annotationsSorted, cm ) {
100 | var errorAnnotations = _.filter( annotations, function( annotation ) {
101 | return 'error' === annotation.severity;
102 | } );
103 |
104 | if ( onUpdateLintingOverridden ) {
105 | onUpdateLintingOverridden.apply( annotations, annotationsSorted, cm );
106 | }
107 |
108 | // Skip if there are no changes to the errors.
109 | if ( _.isEqual( errorAnnotations, currentErrorAnnotations ) ) {
110 | return;
111 | }
112 |
113 | currentErrorAnnotations = errorAnnotations;
114 |
115 | if ( settings.onChangeLintingErrors ) {
116 | settings.onChangeLintingErrors( errorAnnotations, annotations, annotationsSorted, cm );
117 | }
118 |
119 | /*
120 | * Update notifications when the editor is not focused to prevent error message
121 | * from overwhelming the user during input, unless there are now no errors or there
122 | * were previously errors shown. In these cases, update immediately so they can know
123 | * that they fixed the errors.
124 | */
125 | if ( ! cm.state.focused || 0 === currentErrorAnnotations.length || previouslyShownErrorAnnotations.length > 0 ) {
126 | updateErrorNotice();
127 | }
128 | };
129 | })( lintOptions.onUpdateLinting );
130 |
131 | editor.setOption( 'lint', lintOptions );
132 |
133 | // Update error notice when leaving the editor.
134 | editor.on( 'blur', updateErrorNotice );
135 |
136 | // Work around hint selection with mouse causing focus to leave editor.
137 | editor.on( 'startCompletion', function() {
138 | editor.off( 'blur', updateErrorNotice );
139 | } );
140 | editor.on( 'endCompletion', function() {
141 | var editorRefocusWait = 500;
142 | editor.on( 'blur', updateErrorNotice );
143 |
144 | // Wait for editor to possibly get re-focused after selection.
145 | _.delay( function() {
146 | if ( ! editor.state.focused ) {
147 | updateErrorNotice();
148 | }
149 | }, editorRefocusWait );
150 | });
151 |
152 | /*
153 | * Make sure setting validities are set if the user tries to click Publish
154 | * while an autocomplete dropdown is still open. The Customizer will block
155 | * saving when a setting has an error notifications on it. This is only
156 | * necessary for mouse interactions because keyboards will have already
157 | * blurred the field and cause onUpdateErrorNotice to have already been
158 | * called.
159 | */
160 | $( document.body ).on( 'mousedown', function( event ) {
161 | if ( editor.state.focused && ! $.contains( editor.display.wrapper, event.target ) && ! $( event.target ).hasClass( 'CodeMirror-hint' ) ) {
162 | updateErrorNotice();
163 | }
164 | });
165 | }
166 |
167 | /**
168 | * Configure tabbing.
169 | *
170 | * @param {CodeMirror} codemirror - Editor.
171 | * @param {object} settings - Code editor settings.
172 | * @param {object} settings.codeMirror - Settings for CodeMirror.
173 | * @param {Function} settings.onTabNext - Callback to handle tabbing to the next tabbable element.
174 | * @param {Function} settings.onTabPrevious - Callback to handle tabbing to the previous tabbable element.
175 | * @returns {void}
176 | */
177 | function configureTabbing( codemirror, settings ) {
178 | var $textarea = $( codemirror.getTextArea() );
179 |
180 | codemirror.on( 'blur', function() {
181 | $textarea.data( 'next-tab-blurs', false );
182 | });
183 | codemirror.on( 'focus', function() {
184 | if ( codemirror.display.wrapper.scrollIntoViewIfNeeded ) {
185 | codemirror.display.wrapper.scrollIntoViewIfNeeded();
186 | } else {
187 | codemirror.display.wrapper.scrollIntoView();
188 | }
189 | });
190 | codemirror.on( 'keydown', function onKeydown( editor, event ) {
191 | var tabKeyCode = 9, escKeyCode = 27;
192 |
193 | // Take note of the ESC keypress so that the next TAB can focus outside the editor.
194 | if ( escKeyCode === event.keyCode ) {
195 | $textarea.data( 'next-tab-blurs', true );
196 | return;
197 | }
198 |
199 | // Short-circuit if tab key is not being pressed or the tab key press should move focus.
200 | if ( tabKeyCode !== event.keyCode || ! $textarea.data( 'next-tab-blurs' ) ) {
201 | return;
202 | }
203 |
204 | // Focus on previous or next focusable item.
205 | if ( event.shiftKey ) {
206 | settings.onTabPrevious( codemirror, event );
207 | } else {
208 | settings.onTabNext( codemirror, event );
209 | }
210 |
211 | // Reset tab state.
212 | $textarea.data( 'next-tab-blurs', false );
213 |
214 | // Prevent tab character from being added.
215 | event.preventDefault();
216 | });
217 | }
218 |
219 | /**
220 | * Initialize Code Editor (CodeMirror) for an existing textarea.
221 | *
222 | * @since 4.9.0
223 | *
224 | * @param {string|jQuery|Element} textarea - The HTML id, jQuery object, or DOM Element for the textarea that is used for the editor.
225 | * @param {object} [settings] - Settings to override defaults.
226 | * @param {Function} [settings.onChangeLintingErrors] - Callback for when the linting errors have changed.
227 | * @param {Function} [settings.onUpdateErrorNotice] - Callback for when error notice should be displayed.
228 | * @param {Function} [settings.onTabPrevious] - Callback to handle tabbing to the previous tabbable element.
229 | * @param {Function} [settings.onTabNext] - Callback to handle tabbing to the next tabbable element.
230 | * @param {object} [settings.codemirror] - Options for CodeMirror.
231 | * @param {object} [settings.csslint] - Rules for CSSLint.
232 | * @param {object} [settings.htmlhint] - Rules for HTMLHint.
233 | * @param {object} [settings.jshint] - Rules for JSHint.
234 | * @returns {CodeMirror} CodeMirror instance.
235 | */
236 | wp.codeEditor.initialize = function initialize( textarea, settings ) {
237 | var $textarea, codemirror, instanceSettings, instance;
238 | if ( 'string' === typeof textarea ) {
239 | $textarea = $( '#' + textarea );
240 | } else {
241 | $textarea = $( textarea );
242 | }
243 |
244 | instanceSettings = $.extend( {}, wp.codeEditor.defaultSettings, settings );
245 | instanceSettings.codemirror = $.extend( {}, instanceSettings.codemirror );
246 |
247 | codemirror = wp.CodeMirror.fromTextArea( $textarea[0], instanceSettings.codemirror );
248 |
249 | configureLinting( codemirror, instanceSettings );
250 |
251 | instance = {
252 | settings: instanceSettings,
253 | codemirror: codemirror
254 | };
255 |
256 | // Keep track of the instances that have been created.
257 | wp.codeEditor.instances.push( instance );
258 |
259 | if ( codemirror.showHint ) {
260 | codemirror.on( 'keyup', function( editor, event ) { // eslint-disable-line complexity
261 | var shouldAutocomplete, isAlphaKey = /^[a-zA-Z]$/.test( event.key ), lineBeforeCursor, innerMode, token;
262 | if ( codemirror.state.completionActive && isAlphaKey ) {
263 | return;
264 | }
265 |
266 | // Prevent autocompletion in string literals or comments.
267 | token = codemirror.getTokenAt( codemirror.getCursor() );
268 | if ( 'string' === token.type || 'comment' === token.type ) {
269 | return;
270 | }
271 |
272 | innerMode = wp.CodeMirror.innerMode( codemirror.getMode(), token.state ).mode.name;
273 | lineBeforeCursor = codemirror.doc.getLine( codemirror.doc.getCursor().line ).substr( 0, codemirror.doc.getCursor().ch );
274 | if ( 'html' === innerMode || 'xml' === innerMode ) {
275 | shouldAutocomplete =
276 | '<' === event.key ||
277 | '/' === event.key && 'tag' === token.type ||
278 | isAlphaKey && 'tag' === token.type ||
279 | isAlphaKey && 'attribute' === token.type ||
280 | '=' === token.string && token.state.htmlState && token.state.htmlState.tagName;
281 | } else if ( 'css' === innerMode ) {
282 | shouldAutocomplete =
283 | isAlphaKey ||
284 | ':' === event.key ||
285 | ' ' === event.key && /:\s+$/.test( lineBeforeCursor );
286 | } else if ( 'javascript' === innerMode ) {
287 | shouldAutocomplete = isAlphaKey || '.' === event.key;
288 | } else if ( 'clike' === innerMode && 'application/x-httpd-php' === codemirror.options.mode ) {
289 | shouldAutocomplete = 'keyword' === token.type || 'variable' === token.type;
290 | }
291 | if ( shouldAutocomplete ) {
292 | codemirror.showHint( { completeSingle: false } );
293 | }
294 | });
295 | }
296 |
297 | // Facilitate tabbing out of the editor.
298 | configureTabbing( codemirror, settings );
299 |
300 | return instance;
301 | };
302 |
303 | })( window.jQuery, window.wp );
304 |
--------------------------------------------------------------------------------
/wp-admin/js/customize-controls-addendum.js:
--------------------------------------------------------------------------------
1 | /* eslint no-magic-numbers: ["error", { "ignore": [0, 1] }] */
2 | (function( api, $ ) {
3 | 'use strict';
4 |
5 | api.section( 'custom_css', function( section ) {
6 | if ( ! api.settings.customCss ) {
7 | return;
8 | }
9 |
10 | // Close the section description when clicking the close button.
11 | section.container.find( '.section-description-buttons .section-description-close' ).on( 'click', function() {
12 | section.container.find( '.section-meta .customize-section-description:first' )
13 | .removeClass( 'open' )
14 | .slideUp()
15 | .attr( 'aria-expanded', 'false' );
16 | });
17 |
18 | api.control( 'custom_css', function( control ) {
19 | var onceExpanded, onExpandedChange;
20 |
21 | // Abort if CodeMirror disabled via customizer_custom_css_codemirror_opts filter.
22 | if ( ! api.settings.customCss.codeEditor ) {
23 | return;
24 | }
25 |
26 | // Workaround for disabling server-sent syntax checking notifications. This can be removed from core in the merge.
27 | control.setting.notifications.add = (function( originalAdd ) { // eslint-disable-line max-nested-callbacks
28 | return function( id, notification ) { // eslint-disable-line max-nested-callbacks
29 | if ( 'imbalanced_curly_brackets' === id && notification.fromServer ) {
30 | return null;
31 | } else {
32 | return originalAdd.call( this, id, notification );
33 | }
34 | };
35 | })( control.setting.notifications.add );
36 |
37 | // Make sure editor gets focused when control is focused.
38 | control.focus = (function( originalFocus ) { // eslint-disable-line max-nested-callbacks
39 | return function( params ) { // eslint-disable-line max-nested-callbacks
40 | var extendedParams = _.extend( {}, params ), originalCompleteCallback;
41 | originalCompleteCallback = extendedParams.completeCallback;
42 | extendedParams.completeCallback = function() {
43 | if ( originalCompleteCallback ) {
44 | originalCompleteCallback();
45 | }
46 | if ( control.editor ) {
47 | control.editor.codemirror.focus();
48 | }
49 | };
50 | originalFocus.call( this, extendedParams );
51 | };
52 | })( control.focus );
53 |
54 | onceExpanded = function() {
55 | var $textarea = control.container.find( 'textarea' ), settings, suspendEditorUpdate = false;
56 |
57 | if ( ! control.setting.get() ) {
58 | section.container.find( '.section-meta .customize-section-description:first' )
59 | .addClass( 'open' )
60 | .show()
61 | .attr( 'aria-expanded', 'true' );
62 | }
63 |
64 | settings = _.extend( {}, api.settings.customCss.codeEditor, {
65 |
66 | /**
67 | * Handle tabbing to the field after the editor.
68 | *
69 | * @returns {void}
70 | */
71 | onTabNext: function onTabNext() {
72 | var controls, controlIndex;
73 | controls = section.controls();
74 | controlIndex = controls.indexOf( control );
75 | if ( controls.length === controlIndex + 1 ) {
76 | $( '#customize-footer-actions .collapse-sidebar' ).focus();
77 | } else {
78 | controls[ controlIndex + 1 ].container.find( ':focusable:first' ).focus();
79 | }
80 | },
81 |
82 | /**
83 | * Handle tabbing to the field before the editor.
84 | *
85 | * @returns {void}
86 | */
87 | onTabPrevious: function onTabPrevious() {
88 | var controls, controlIndex;
89 | controls = section.controls();
90 | controlIndex = controls.indexOf( control );
91 | if ( 0 === controlIndex ) {
92 | section.contentContainer.find( '.customize-section-title .customize-help-toggle, .customize-section-title .customize-section-description.open .section-description-close' ).last().focus();
93 | } else {
94 | controls[ controlIndex - 1 ].contentContainer.find( ':focusable:first' ).focus();
95 | }
96 | },
97 |
98 | /**
99 | * Update error notice.
100 | *
101 | * @param {Array} errorAnnotations - Error annotations.
102 | * @returns {void}
103 | */
104 | onUpdateErrorNotice: function onUpdateErrorNotice( errorAnnotations ) {
105 | var message;
106 | control.setting.notifications.remove( 'csslint_error' );
107 |
108 | if ( 0 !== errorAnnotations.length ) {
109 | if ( 1 === errorAnnotations.length ) {
110 | message = api.l10n.customCssErrorNotice.singular.replace( '%d', '1' );
111 | } else {
112 | message = api.l10n.customCssErrorNotice.plural.replace( '%d', String( errorAnnotations.length ) );
113 | }
114 | control.setting.notifications.add( 'csslint_error', new api.Notification( 'csslint_error', {
115 | message: message,
116 | type: 'error'
117 | } ) );
118 | }
119 | }
120 | });
121 |
122 | control.editor = wp.codeEditor.initialize( $textarea, settings );
123 |
124 | // Refresh when receiving focus.
125 | control.editor.codemirror.on( 'focus', function( codemirror ) {
126 | codemirror.refresh();
127 | });
128 |
129 | /*
130 | * When the CodeMirror instance changes, mirror to the textarea,
131 | * where we have our "true" change event handler bound.
132 | */
133 | control.editor.codemirror.on( 'change', function( codemirror ) {
134 | suspendEditorUpdate = true;
135 | $textarea.val( codemirror.getValue() ).trigger( 'change' );
136 | suspendEditorUpdate = false;
137 | });
138 |
139 | // Update CodeMirror when the setting is changed by another plugin.
140 | control.setting.bind( function( value ) {
141 | if ( ! suspendEditorUpdate ) {
142 | control.editor.codemirror.setValue( value );
143 | }
144 | });
145 |
146 | // Prevent collapsing section when hitting Esc to tab out of editor.
147 | control.editor.codemirror.on( 'keydown', function onKeydown( codemirror, event ) {
148 | var escKeyCode = 27;
149 | if ( escKeyCode === event.keyCode ) {
150 | event.stopPropagation();
151 | }
152 | });
153 | };
154 |
155 | onExpandedChange = function( isExpanded ) {
156 | if ( isExpanded ) {
157 | onceExpanded();
158 | section.expanded.unbind( onExpandedChange );
159 | }
160 | };
161 | control.deferred.embedded.done( function() {
162 | if ( section.expanded() ) {
163 | onceExpanded();
164 | } else {
165 | section.expanded.bind( onExpandedChange );
166 | }
167 | });
168 | });
169 | });
170 | })( wp.customize, jQuery );
171 |
--------------------------------------------------------------------------------
/wp-admin/js/theme-plugin-editor.js:
--------------------------------------------------------------------------------
1 | /* eslint no-magic-numbers: ["error", { "ignore": [-1, 0, 1] }] */
2 |
3 | if ( ! window.wp ) {
4 | window.wp = {};
5 | }
6 |
7 | wp.themePluginEditor = (function( $ ) {
8 | 'use strict';
9 |
10 | var component = {
11 | l10n: {
12 | lintError: {
13 | singular: '',
14 | plural: ''
15 | }
16 | },
17 | instance: null
18 | };
19 |
20 | /**
21 | * Initialize component.
22 | *
23 | * @param {object} settings Settings.
24 | * @returns {void}
25 | */
26 | component.init = function( settings ) {
27 | var codeEditorSettings, noticeContainer, errorNotice = [], editor;
28 |
29 | codeEditorSettings = $.extend( {}, settings );
30 |
31 | /**
32 | * Handle tabbing to the field before the editor.
33 | *
34 | * @returns {void}
35 | */
36 | codeEditorSettings.onTabPrevious = function() {
37 | $( '#templateside' ).find( ':tabbable' ).last().focus();
38 | };
39 |
40 | /**
41 | * Handle tabbing to the field after the editor.
42 | *
43 | * @returns {void}
44 | */
45 | codeEditorSettings.onTabNext = function() {
46 | $( '#template' ).find( ':tabbable:not(.CodeMirror-code)' ).first().focus();
47 | };
48 |
49 | // Create the error notice container.
50 | noticeContainer = $( '
' );
51 | errorNotice = $( '
' );
52 | noticeContainer.append( errorNotice );
53 | noticeContainer.hide();
54 | $( 'p.submit' ).before( noticeContainer );
55 |
56 | /**
57 | * Update error notice.
58 | *
59 | * @param {Array} errorAnnotations - Error annotations.
60 | * @returns {void}
61 | */
62 | codeEditorSettings.onUpdateErrorNotice = function onUpdateErrorNotice( errorAnnotations ) {
63 | var message;
64 |
65 | $( '#submit' ).prop( 'disabled', 0 !== errorAnnotations.length );
66 |
67 | if ( 0 !== errorAnnotations.length ) {
68 | errorNotice.empty();
69 | if ( 1 === errorAnnotations.length ) {
70 | message = component.l10n.singular.replace( '%d', '1' );
71 | } else {
72 | message = component.l10n.plural.replace( '%d', String( errorAnnotations.length ) );
73 | }
74 | errorNotice.append( $( '
', {
75 | text: message
76 | } ) );
77 | noticeContainer.slideDown( 'fast' );
78 | wp.a11y.speak( message );
79 | } else {
80 | noticeContainer.slideUp( 'fast' );
81 | }
82 | };
83 |
84 | editor = wp.codeEditor.initialize( $( '#newcontent' ), codeEditorSettings );
85 |
86 | component.instance = editor;
87 | };
88 |
89 | return component;
90 | })( jQuery );
91 |
--------------------------------------------------------------------------------
/wp-admin/js/widgets/custom-html-widgets.js:
--------------------------------------------------------------------------------
1 | /* global wp */
2 | /* eslint consistent-this: [ "error", "control" ] */
3 | /* eslint no-magic-numbers: ["error", { "ignore": [0,1,-1] }] */
4 | wp.customHtmlWidgets = ( function( $ ) {
5 | 'use strict';
6 |
7 | var component = {
8 | idBases: [ 'custom_html' ],
9 | codeEditorSettings: {},
10 | l10n: {
11 | errorNotice: {
12 | singular: '',
13 | plural: ''
14 | }
15 | }
16 | };
17 |
18 | /**
19 | * Text widget control.
20 | *
21 | * @class CustomHtmlWidgetControl
22 | * @constructor
23 | * @abstract
24 | */
25 | component.CustomHtmlWidgetControl = Backbone.View.extend({
26 |
27 | /**
28 | * View events.
29 | *
30 | * @type {Object}
31 | */
32 | events: {},
33 |
34 | /**
35 | * Initialize.
36 | *
37 | * @param {Object} options - Options.
38 | * @param {jQuery} options.el - Control field container element.
39 | * @param {jQuery} options.syncContainer - Container element where fields are synced for the server.
40 | * @returns {void}
41 | */
42 | initialize: function initialize( options ) {
43 | var control = this;
44 |
45 | if ( ! options.el ) {
46 | throw new Error( 'Missing options.el' );
47 | }
48 | if ( ! options.syncContainer ) {
49 | throw new Error( 'Missing options.syncContainer' );
50 | }
51 |
52 | Backbone.View.prototype.initialize.call( control, options );
53 | control.syncContainer = options.syncContainer;
54 | control.widgetIdBase = control.syncContainer.parent().find( '.id_base' ).val();
55 | control.widgetNumber = control.syncContainer.parent().find( '.widget_number' ).val();
56 | control.customizeSettingId = 'widget_' + control.widgetIdBase + '[' + String( control.widgetNumber ) + ']';
57 |
58 | control.$el.addClass( 'custom-html-widget-fields' );
59 | control.$el.html( wp.template( 'widget-custom-html-control-fields' )( { codeEditorDisabled: component.codeEditorSettings.disabled } ) );
60 |
61 | control.errorNoticeContainer = control.$el.find( '.code-editor-error-container' );
62 | control.currentErrorAnnotations = [];
63 | control.saveButton = control.syncContainer.add( control.syncContainer.parent().find( '.widget-control-actions' ) ).find( '.widget-control-save, #savewidget' );
64 | control.saveButton.addClass( 'custom-html-widget-save-button' ); // To facilitate style targeting.
65 |
66 | control.fields = {
67 | title: control.$el.find( '.title' ),
68 | content: control.$el.find( '.content' )
69 | };
70 |
71 | // Sync input fields to hidden sync fields which actually get sent to the server.
72 | _.each( control.fields, function( fieldInput, fieldName ) {
73 | fieldInput.on( 'input change', function updateSyncField() {
74 | var syncInput = control.syncContainer.find( '.sync-input.' + fieldName );
75 | if ( syncInput.val() !== fieldInput.val() ) {
76 | syncInput.val( fieldInput.val() );
77 | syncInput.trigger( 'change' );
78 | }
79 | });
80 |
81 | // Note that syncInput cannot be re-used because it will be destroyed with each widget-updated event.
82 | fieldInput.val( control.syncContainer.find( '.sync-input.' + fieldName ).val() );
83 | });
84 | },
85 |
86 | /**
87 | * Update input fields from the sync fields.
88 | *
89 | * This function is called at the widget-updated and widget-synced events.
90 | * A field will only be updated if it is not currently focused, to avoid
91 | * overwriting content that the user is entering.
92 | *
93 | * @returns {void}
94 | */
95 | updateFields: function updateFields() {
96 | var control = this, syncInput;
97 |
98 | if ( ! control.fields.title.is( document.activeElement ) ) {
99 | syncInput = control.syncContainer.find( '.sync-input.title' );
100 | control.fields.title.val( syncInput.val() );
101 | }
102 |
103 | /*
104 | * Prevent updating content when the editor is focused or if there are current error annotations,
105 | * to prevent the editor's contents from getting sanitized as soon as a user removes focus from
106 | * the editor. This is particularly important for users who cannot unfiltered_html.
107 | */
108 | control.contentUpdateBypassed = control.fields.content.is( document.activeElement ) || control.editor && control.editor.codemirror.state.focused || 0 !== control.currentErrorAnnotations;
109 | if ( ! control.contentUpdateBypassed ) {
110 | syncInput = control.syncContainer.find( '.sync-input.content' );
111 | control.fields.content.val( syncInput.val() ).trigger( 'change' );
112 | }
113 | },
114 |
115 | /**
116 | * Show linting error notice.
117 | *
118 | * @param {Array} errorAnnotations - Error annotations.
119 | * @returns {void}
120 | */
121 | updateErrorNotice: function( errorAnnotations ) {
122 | var control = this, errorNotice, message = '', customizeSetting;
123 |
124 | if ( 1 === errorAnnotations.length ) {
125 | message = component.l10n.errorNotice.singular.replace( '%d', '1' );
126 | } else if ( errorAnnotations.length > 1 ) {
127 | message = component.l10n.errorNotice.plural.replace( '%d', String( errorAnnotations.length ) );
128 | }
129 |
130 | if ( control.fields.content[0].setCustomValidity ) {
131 | control.fields.content[0].setCustomValidity( message );
132 | }
133 |
134 | if ( wp.customize && wp.customize.has( control.customizeSettingId ) ) {
135 | customizeSetting = wp.customize( control.customizeSettingId );
136 | customizeSetting.notifications.remove( 'htmlhint_error' );
137 | if ( 0 !== errorAnnotations.length ) {
138 | customizeSetting.notifications.add( 'htmlhint_error', new wp.customize.Notification( 'htmlhint_error', {
139 | message: message,
140 | type: 'error'
141 | } ) );
142 | }
143 | } else if ( 0 !== errorAnnotations.length ) {
144 | errorNotice = $( '
' );
145 | errorNotice.append( $( '
', {
146 | text: message
147 | } ) );
148 | control.errorNoticeContainer.empty();
149 | control.errorNoticeContainer.append( errorNotice );
150 | control.errorNoticeContainer.slideDown( 'fast' );
151 | wp.a11y.speak( message );
152 | } else {
153 | control.errorNoticeContainer.slideUp( 'fast' );
154 | }
155 | },
156 |
157 | /**
158 | * Initialize editor.
159 | *
160 | * @returns {void}
161 | */
162 | initializeEditor: function initializeEditor() {
163 | var control = this, settings;
164 |
165 | if ( component.codeEditorSettings.disabled ) {
166 | return;
167 | }
168 |
169 | settings = _.extend( {}, component.codeEditorSettings, {
170 |
171 | /**
172 | * Handle tabbing to the field before the editor.
173 | *
174 | * @returns {void}
175 | */
176 | onTabPrevious: function onTabPrevious() {
177 | control.fields.title.focus();
178 | },
179 |
180 | /**
181 | * Handle tabbing to the field after the editor.
182 | *
183 | * @returns {void}
184 | */
185 | onTabNext: function onTabNext() {
186 | var tabbables = control.syncContainer.add( control.syncContainer.parent().find( '.widget-position, .widget-control-actions' ) ).find( ':tabbable' );
187 | tabbables.first().focus();
188 | },
189 |
190 | /**
191 | * Disable save button and store linting errors for use in updateFields.
192 | *
193 | * @param {Array} errorAnnotations - Error notifications.
194 | * @returns {void}
195 | */
196 | onChangeLintingErrors: function onChangeLintingErrors( errorAnnotations ) {
197 | control.currentErrorAnnotations = errorAnnotations;
198 | },
199 |
200 | /**
201 | * Update error notice.
202 | *
203 | * @param {Array} errorAnnotations - Error annotations.
204 | * @returns {void}
205 | */
206 | onUpdateErrorNotice: function onUpdateErrorNotice( errorAnnotations ) {
207 | control.saveButton.toggleClass( 'validation-blocked', errorAnnotations.length );
208 | control.updateErrorNotice( errorAnnotations );
209 | }
210 | });
211 |
212 | control.editor = wp.codeEditor.initialize( control.fields.content, settings );
213 | control.fields.content.on( 'change', function() {
214 | if ( this.value !== control.editor.codemirror.getValue() ) {
215 | control.editor.codemirror.setValue( this.value );
216 | }
217 | });
218 | control.editor.codemirror.on( 'change', function() {
219 | var value = control.editor.codemirror.getValue();
220 | if ( value !== control.fields.content.val() ) {
221 | control.fields.content.val( value ).trigger( 'change' );
222 | }
223 | });
224 |
225 | // Make sure the editor gets updated if the content was updated on the server (sanitization) but not updated in the editor since it was focused.
226 | control.editor.codemirror.on( 'blur', function() {
227 | if ( control.contentUpdateBypassed ) {
228 | control.syncContainer.find( '.sync-input.content' ).trigger( 'change' );
229 | }
230 | });
231 |
232 | // Prevent hitting Esc from collapsing the widget control.
233 | if ( wp.customize ) {
234 | control.editor.codemirror.on( 'keydown', function onKeydown( codemirror, event ) {
235 | var escKeyCode = 27;
236 | if ( escKeyCode === event.keyCode ) {
237 | event.stopPropagation();
238 | }
239 | });
240 | }
241 | }
242 | });
243 |
244 | /**
245 | * Mapping of widget ID to instances of CustomHtmlWidgetControl subclasses.
246 | *
247 | * @type {Object.}
248 | */
249 | component.widgetControls = {};
250 |
251 | /**
252 | * Handle widget being added or initialized for the first time at the widget-added event.
253 | *
254 | * @param {jQuery.Event} event - Event.
255 | * @param {jQuery} widgetContainer - Widget container element.
256 | * @returns {void}
257 | */
258 | component.handleWidgetAdded = function handleWidgetAdded( event, widgetContainer ) {
259 | var widgetForm, idBase, widgetControl, widgetId, animatedCheckDelay = 50, renderWhenAnimationDone, fieldContainer, syncContainer;
260 | widgetForm = widgetContainer.find( '> .widget-inside > .form, > .widget-inside > form' ); // Note: '.form' appears in the customizer, whereas 'form' on the widgets admin screen.
261 |
262 | idBase = widgetForm.find( '> .id_base' ).val();
263 | if ( -1 === component.idBases.indexOf( idBase ) ) {
264 | return;
265 | }
266 |
267 | // Prevent initializing already-added widgets.
268 | widgetId = widgetForm.find( '.widget-id' ).val();
269 | if ( component.widgetControls[ widgetId ] ) {
270 | return;
271 | }
272 |
273 | /*
274 | * Create a container element for the widget control fields.
275 | * This is inserted into the DOM immediately before the the .widget-content
276 | * element because the contents of this element are essentially "managed"
277 | * by PHP, where each widget update cause the entire element to be emptied
278 | * and replaced with the rendered output of WP_Widget::form() which is
279 | * sent back in Ajax request made to save/update the widget instance.
280 | * To prevent a "flash of replaced DOM elements and re-initialized JS
281 | * components", the JS template is rendered outside of the normal form
282 | * container.
283 | */
284 | fieldContainer = $( '
' );
285 | syncContainer = widgetContainer.find( '.widget-content:first' );
286 | syncContainer.before( fieldContainer );
287 |
288 | widgetControl = new component.CustomHtmlWidgetControl({
289 | el: fieldContainer,
290 | syncContainer: syncContainer
291 | });
292 |
293 | component.widgetControls[ widgetId ] = widgetControl;
294 |
295 | /*
296 | * Render the widget once the widget parent's container finishes animating,
297 | * as the widget-added event fires with a slideDown of the container.
298 | * This ensures that the textarea is visible and the editor can be initialized.
299 | */
300 | renderWhenAnimationDone = function() {
301 | if ( ! ( wp.customize ? widgetContainer.parent().hasClass( 'expanded' ) : widgetContainer.hasClass( 'open' ) ) ) { // Core merge: The wp.customize condition can be eliminated with this change being in core: https://github.com/xwp/wordpress-develop/pull/247/commits/5322387d
302 | setTimeout( renderWhenAnimationDone, animatedCheckDelay );
303 | } else {
304 | widgetControl.initializeEditor();
305 | }
306 | };
307 | renderWhenAnimationDone();
308 | };
309 |
310 | /**
311 | * Setup widget in accessibility mode.
312 | *
313 | * @returns {void}
314 | */
315 | component.setupAccessibleMode = function setupAccessibleMode() {
316 | var widgetForm, idBase, widgetControl, fieldContainer, syncContainer;
317 | widgetForm = $( '.editwidget > form' );
318 | if ( 0 === widgetForm.length ) {
319 | return;
320 | }
321 |
322 | idBase = widgetForm.find( '> .widget-control-actions > .id_base' ).val();
323 | if ( -1 === component.idBases.indexOf( idBase ) ) {
324 | return;
325 | }
326 |
327 | fieldContainer = $( '
' );
328 | syncContainer = widgetForm.find( '> .widget-inside' );
329 | syncContainer.before( fieldContainer );
330 |
331 | widgetControl = new component.CustomHtmlWidgetControl({
332 | el: fieldContainer,
333 | syncContainer: syncContainer
334 | });
335 |
336 | widgetControl.initializeEditor();
337 | };
338 |
339 | /**
340 | * Sync widget instance data sanitized from server back onto widget model.
341 | *
342 | * This gets called via the 'widget-updated' event when saving a widget from
343 | * the widgets admin screen and also via the 'widget-synced' event when making
344 | * a change to a widget in the customizer.
345 | *
346 | * @param {jQuery.Event} event - Event.
347 | * @param {jQuery} widgetContainer - Widget container element.
348 | * @returns {void}
349 | */
350 | component.handleWidgetUpdated = function handleWidgetUpdated( event, widgetContainer ) {
351 | var widgetForm, widgetId, widgetControl, idBase;
352 | widgetForm = widgetContainer.find( '> .widget-inside > .form, > .widget-inside > form' );
353 |
354 | idBase = widgetForm.find( '> .id_base' ).val();
355 | if ( -1 === component.idBases.indexOf( idBase ) ) {
356 | return;
357 | }
358 |
359 | widgetId = widgetForm.find( '> .widget-id' ).val();
360 | widgetControl = component.widgetControls[ widgetId ];
361 | if ( ! widgetControl ) {
362 | return;
363 | }
364 |
365 | widgetControl.updateFields();
366 | };
367 |
368 | /**
369 | * Initialize functionality.
370 | *
371 | * This function exists to prevent the JS file from having to boot itself.
372 | * When WordPress enqueues this script, it should have an inline script
373 | * attached which calls wp.textWidgets.init().
374 | *
375 | * @param {object} settings - Options for code editor, exported from PHP.
376 | * @returns {void}
377 | */
378 | component.init = function init( settings ) {
379 | var $document = $( document );
380 | _.extend( component.codeEditorSettings, settings );
381 |
382 | $document.on( 'widget-added', component.handleWidgetAdded );
383 | $document.on( 'widget-synced widget-updated', component.handleWidgetUpdated );
384 |
385 | /*
386 | * Manually trigger widget-added events for media widgets on the admin
387 | * screen once they are expanded. The widget-added event is not triggered
388 | * for each pre-existing widget on the widgets admin screen like it is
389 | * on the customizer. Likewise, the customizer only triggers widget-added
390 | * when the widget is expanded to just-in-time construct the widget form
391 | * when it is actually going to be displayed. So the following implements
392 | * the same for the widgets admin screen, to invoke the widget-added
393 | * handler when a pre-existing media widget is expanded.
394 | */
395 | $( function initializeExistingWidgetContainers() {
396 | var widgetContainers;
397 | if ( 'widgets' !== window.pagenow ) {
398 | return;
399 | }
400 | widgetContainers = $( '.widgets-holder-wrap:not(#available-widgets)' ).find( 'div.widget' );
401 | widgetContainers.one( 'click.toggle-widget-expanded', function toggleWidgetExpanded() {
402 | var widgetContainer = $( this );
403 | component.handleWidgetAdded( new jQuery.Event( 'widget-added' ), widgetContainer );
404 | });
405 |
406 | // Accessibility mode.
407 | $( window ).on( 'load', function() {
408 | component.setupAccessibleMode();
409 | });
410 | });
411 | };
412 |
413 | return component;
414 | })( jQuery );
415 |
--------------------------------------------------------------------------------
/wp-admin/user-edit-addendum.php:
--------------------------------------------------------------------------------
1 |
32 |
33 |
34 |
35 | syntax_highlighting ); ?> />
36 |
42 |
43 |
44 |
2 |
3 |
4 | Artboard
5 | Created with Sketch.
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
28 |
29 |
30 |
31 |
32 |
--------------------------------------------------------------------------------
/wp-includes/customize-manager-addendum.php:
--------------------------------------------------------------------------------
1 | syntax_highlighting ) {
19 | return;
20 | }
21 |
22 | $section = $wp_customize->get_section( 'custom_css' );
23 | if ( ! $section ) {
24 | return;
25 | }
26 |
27 | // Remove default value from Custom CSS setting.
28 | foreach ( $wp_customize->settings() as $setting ) {
29 | if ( $setting instanceof WP_Customize_Custom_CSS_Setting ) {
30 | $setting->default = '';
31 | }
32 | }
33 |
34 | $section->description = '';
35 | $section->description .= __( 'Add your own CSS code here to customize the appearance and layout of your site.', 'better-code-editing' );
36 | $section->description .= sprintf(
37 | ' %2$s%3$s ',
38 | esc_url( __( 'https://codex.wordpress.org/CSS', 'default' ) ),
39 | __( 'Learn more about CSS', 'default' ),
40 | /* translators: accessibility text */
41 | __( '(opens in a new window)', 'default' )
42 | );
43 | $section->description .= '
';
44 |
45 | $section->description .= '' . __( 'When using a keyboard to navigate:', 'better-code-editing' ) . '
';
46 | $section->description .= '';
47 | $section->description .= '' . __( 'In the CSS edit field, Tab enters a tab character.', 'better-code-editing' ) . ' ';
48 | $section->description .= '' . __( 'To move keyboard focus, press Esc then Tab for the next element, or Esc then Shift+Tab for the previous element.', 'better-code-editing' ) . ' ';
49 | $section->description .= ' ';
50 |
51 | $section->description .= '';
52 | $section->description .= sprintf(
53 | /* translators: placeholder is link to user profile */
54 | __( 'The edit field automatically highlights code syntax. You can disable this in your %s to work in plain text mode.', 'better-code-editing' ),
55 | sprintf(
56 | ' %2$s%3$s ',
57 | esc_url( get_edit_profile_url() . '#syntax_highlighting' ),
58 | __( 'user profile', 'better-code-editing' ),
59 | /* translators: accessibility text */
60 | __( '(opens in a new window)', 'default' )
61 | )
62 | );
63 | $section->description .= '
';
64 |
65 | $section->description .= '';
66 | $section->description .= '' . __( 'Close', 'default' ) . ' ';
67 | $section->description .= '
';
68 | }
69 |
70 | /**
71 | * Enqueue assets for Customizer.
72 | *
73 | * @global WP_Customize_Manager $wp_customize
74 | */
75 | function _better_code_editing_customize_controls_enqueue_scripts() {
76 | global $wp_customize;
77 | $wp_customize->custom_css_code_editor_settings = wp_enqueue_code_editor( array(
78 | 'type' => 'text/css',
79 | ) );
80 | wp_add_inline_script( 'customize-controls', file_get_contents( dirname( BETTER_CODE_EDITING_PLUGIN_FILE ) . '/wp-admin/js/customize-controls-addendum.js' ) );
81 | }
82 |
83 | /**
84 | * Add Customizer integration.
85 | *
86 | * @see WP_Customize_Manager::customize_pane_settings()
87 | * @global WP_Customize_Manager $wp_customize
88 | */
89 | function _better_code_editing_amend_customize_pane_settings() {
90 | global $wp_customize;
91 | if ( empty( $wp_customize->custom_css_code_editor_settings ) ) {
92 | return;
93 | }
94 | $custom_css_setting = $wp_customize->get_setting( sprintf( 'custom_css[%s]', get_stylesheet() ) );
95 | if ( ! $custom_css_setting ) {
96 | return;
97 | }
98 |
99 | $settings = array(
100 | 'codeEditor' => $wp_customize->custom_css_code_editor_settings,
101 | );
102 |
103 | printf( ';', wp_json_encode( $settings ) );
104 |
105 | /* translators: placeholder is error count */
106 | $l10n = _n_noop( 'There is %d error which must be fixed before you can save.', 'There are %d errors which must be fixed before you can save.', 'better-code-editing' );
107 | printf( ';', wp_json_encode( wp_array_slice_assoc( $l10n, array( 'singular', 'plural' ) ) ) );
108 | }
109 |
--------------------------------------------------------------------------------
/wp-includes/general-template-addendum.php:
--------------------------------------------------------------------------------
1 | syntax_highlighting ) {
29 | return false;
30 | }
31 |
32 | $settings = array(
33 | 'codemirror' => array(
34 | 'indentUnit' => 4,
35 | 'indentWithTabs' => true,
36 | 'inputStyle' => 'contenteditable',
37 | 'lineNumbers' => true,
38 | 'lineWrapping' => true,
39 | 'styleActiveLine' => true,
40 | 'continueComments' => true,
41 | 'extraKeys' => array(
42 | 'Ctrl-Space' => 'autocomplete',
43 | 'Ctrl-/' => 'toggleComment',
44 | 'Cmd-/' => 'toggleComment',
45 | 'Alt-F' => 'findPersistent',
46 | ),
47 | 'direction' => 'ltr', // Code is shown in LTR even in RTL languages.
48 | ),
49 | 'csslint' => array(
50 | 'errors' => true, // Parsing errors.
51 | 'box-model' => true,
52 | 'display-property-grouping' => true,
53 | 'duplicate-properties' => true,
54 | 'known-properties' => true,
55 | 'outline-none' => true,
56 | ),
57 | 'jshint' => array(
58 | // The following are copied from .
59 | 'boss' => true,
60 | 'curly' => true,
61 | 'eqeqeq' => true,
62 | 'eqnull' => true,
63 | 'es3' => true,
64 | 'expr' => true,
65 | 'immed' => true,
66 | 'noarg' => true,
67 | 'nonbsp' => true,
68 | 'onevar' => true,
69 | 'quotmark' => 'single',
70 | 'trailing' => true,
71 | 'undef' => true,
72 | 'unused' => true,
73 |
74 | 'browser' => true,
75 |
76 | 'globals' => array(
77 | '_' => false,
78 | 'Backbone' => false,
79 | 'jQuery' => false,
80 | 'JSON' => false,
81 | 'wp' => false,
82 | ),
83 | ),
84 | 'htmlhint' => array(
85 | 'tagname-lowercase' => true,
86 | 'attr-lowercase' => true,
87 | 'attr-value-double-quotes' => true,
88 | 'doctype-first' => false,
89 | 'tag-pair' => true,
90 | 'spec-char-escape' => true,
91 | 'id-unique' => true,
92 | 'src-not-empty' => true,
93 | 'attr-no-duplication' => true,
94 | 'alt-require' => true,
95 | 'space-tab-mixed-disabled' => 'tab',
96 | 'attr-unsafe-chars' => true,
97 | ),
98 | );
99 |
100 | $type = '';
101 | if ( isset( $args['type'] ) ) {
102 | $type = $args['type'];
103 |
104 | // Remap MIME types to ones that CodeMirror modes will recognize.
105 | if ( 'application/x-patch' === $type || 'text/x-patch' === $type ) {
106 | $type = 'text/x-diff';
107 | }
108 | } elseif ( isset( $args['file'] ) && false !== strpos( basename( $args['file'] ), '.' ) ) {
109 | $extension = strtolower( pathinfo( $args['file'], PATHINFO_EXTENSION ) );
110 | foreach ( wp_get_mime_types() as $exts => $mime ) {
111 | if ( preg_match( '!^(' . $exts . ')$!i', $extension ) ) {
112 | $type = $mime;
113 | break;
114 | }
115 | }
116 |
117 | // Supply any types that are not matched by wp_get_mime_types().
118 | if ( empty( $type ) ) {
119 | switch ( $extension ) {
120 | case 'conf':
121 | $type = 'text/nginx';
122 | break;
123 | case 'css':
124 | $type = 'text/css';
125 | break;
126 | case 'diff':
127 | case 'patch':
128 | $type = 'text/x-diff';
129 | break;
130 | case 'html':
131 | case 'htm':
132 | $type = 'text/html';
133 | break;
134 | case 'http':
135 | $type = 'message/http';
136 | break;
137 | case 'js':
138 | $type = 'text/javascript';
139 | break;
140 | case 'json':
141 | $type = 'application/json';
142 | break;
143 | case 'jsx':
144 | $type = 'text/jsx';
145 | break;
146 | case 'less':
147 | $type = 'text/x-less';
148 | break;
149 | case 'md':
150 | $type = 'text/x-gfm';
151 | break;
152 | case 'php':
153 | case 'phtml':
154 | case 'php3':
155 | case 'php4':
156 | case 'php5':
157 | case 'php7':
158 | case 'phps':
159 | $type = 'application/x-httpd-php';
160 | break;
161 | case 'scss':
162 | $type = 'text/x-scss';
163 | break;
164 | case 'sass':
165 | $type = 'text/x-sass';
166 | break;
167 | case 'sh':
168 | case 'bash':
169 | $type = 'text/x-sh';
170 | break;
171 | case 'sql':
172 | $type = 'text/x-sql';
173 | break;
174 | case 'svg':
175 | $type = 'application/svg+xml';
176 | break;
177 | case 'xml':
178 | $type = 'text/xml';
179 | break;
180 | case 'yml':
181 | case 'yaml':
182 | $type = 'text/x-yaml';
183 | break;
184 | case 'txt':
185 | default:
186 | $type = 'text/plain';
187 | break;
188 | }
189 | }
190 | }
191 |
192 | if ( 'text/css' === $type ) {
193 | $settings['codemirror'] = array_merge( $settings['codemirror'], array(
194 | 'mode' => 'css',
195 | 'lint' => true,
196 | 'autoCloseBrackets' => true,
197 | 'matchBrackets' => true,
198 | ) );
199 | } elseif ( 'text/x-scss' === $type || 'text/x-less' === $type || 'text/x-sass' === $type ) {
200 | $settings['codemirror'] = array_merge( $settings['codemirror'], array(
201 | 'mode' => $type,
202 | 'autoCloseBrackets' => true,
203 | 'matchBrackets' => true,
204 | ) );
205 | } elseif ( 'text/x-diff' === $type ) {
206 | $settings['codemirror'] = array_merge( $settings['codemirror'], array(
207 | 'mode' => 'diff',
208 | ) );
209 | } elseif ( 'text/html' === $type ) {
210 | $settings['codemirror'] = array_merge( $settings['codemirror'], array(
211 | 'mode' => 'htmlmixed',
212 | 'lint' => true,
213 | 'autoCloseBrackets' => true,
214 | 'autoCloseTags' => true,
215 | 'matchTags' => array(
216 | 'bothTags' => true,
217 | ),
218 | ) );
219 |
220 | if ( ! current_user_can( 'unfiltered_html' ) ) {
221 | $settings['htmlhint']['kses'] = wp_kses_allowed_html( 'post' );
222 | }
223 | } elseif ( 'text/x-gfm' === $type ) {
224 | $settings['codemirror'] = array_merge( $settings['codemirror'], array(
225 | 'mode' => 'gfm',
226 | 'highlightFormatting' => true,
227 | ) );
228 | } elseif ( 'application/javascript' === $type || 'text/javascript' === $type ) {
229 | $settings['codemirror'] = array_merge( $settings['codemirror'], array(
230 | 'mode' => 'javascript',
231 | 'lint' => true,
232 | 'autoCloseBrackets' => true,
233 | 'matchBrackets' => true,
234 | ) );
235 | } elseif ( false !== strpos( $type, 'json' ) ) {
236 | $settings['codemirror'] = array_merge( $settings['codemirror'], array(
237 | 'mode' => array(
238 | 'name' => 'javascript',
239 | ),
240 | 'lint' => true,
241 | 'autoCloseBrackets' => true,
242 | 'matchBrackets' => true,
243 | ) );
244 | if ( 'application/ld+json' === $type ) {
245 | $settings['codemirror']['mode']['jsonld'] = true;
246 | } else {
247 | $settings['codemirror']['mode']['json'] = true;
248 | }
249 | } elseif ( false !== strpos( $type, 'jsx' ) ) {
250 | $settings['codemirror'] = array_merge( $settings['codemirror'], array(
251 | 'mode' => 'jsx',
252 | 'autoCloseBrackets' => true,
253 | 'matchBrackets' => true,
254 | ) );
255 | } elseif ( 'text/x-markdown' === $type ) {
256 | $settings['codemirror'] = array_merge( $settings['codemirror'], array(
257 | 'mode' => 'markdown',
258 | 'highlightFormatting' => true,
259 | ) );
260 | } elseif ( 'text/nginx' === $type ) {
261 | $settings['codemirror'] = array_merge( $settings['codemirror'], array(
262 | 'mode' => 'nginx',
263 | ) );
264 | } elseif ( 'application/x-httpd-php' === $type ) {
265 | $settings['codemirror'] = array_merge( $settings['codemirror'], array(
266 | 'mode' => 'php',
267 | 'autoCloseBrackets' => true,
268 | 'autoCloseTags' => true,
269 | 'matchBrackets' => true,
270 | 'matchTags' => array(
271 | 'bothTags' => true,
272 | ),
273 | ) );
274 | } elseif ( 'text/x-sql' === $type || 'text/x-mysql' === $type ) {
275 | $settings['codemirror'] = array_merge( $settings['codemirror'], array(
276 | 'mode' => 'sql',
277 | 'autoCloseBrackets' => true,
278 | 'matchBrackets' => true,
279 | ) );
280 | } elseif ( false !== strpos( $type, 'xml' ) ) {
281 | $settings['codemirror'] = array_merge( $settings['codemirror'], array(
282 | 'mode' => 'xml',
283 | 'autoCloseBrackets' => true,
284 | 'autoCloseTags' => true,
285 | 'matchTags' => array(
286 | 'bothTags' => true,
287 | ),
288 | ) );
289 | } elseif ( 'text/x-yaml' === $type ) {
290 | $settings['codemirror'] = array_merge( $settings['codemirror'], array(
291 | 'mode' => 'yaml',
292 | ) );
293 | } else {
294 | $settings['codemirror']['mode'] = $type;
295 | }
296 |
297 | if ( ! empty( $settings['codemirror']['lint'] ) ) {
298 | $settings['codemirror']['gutters'][] = 'CodeMirror-lint-markers';
299 | }
300 |
301 | // Let settings supplied via args override any defaults.
302 | if ( isset( $args['settings'] ) ) {
303 | foreach ( $args['settings'] as $key => $value ) {
304 | $settings[ $key ] = array_merge(
305 | $settings[ $key ],
306 | $value
307 | );
308 | }
309 | }
310 |
311 | /**
312 | * Filters settings that are passed into the code editor.
313 | *
314 | * Returning a falsey value will disable the syntax-highlighting code editor.
315 | *
316 | * @since 4.9.0
317 | *
318 | * @param array $settings The array of settings passed to the code editor. A falsey value disables the editor.
319 | * @param array $args {
320 | * Args passed when calling `wp_enqueue_code_editor()`.
321 | *
322 | * @type string $type The MIME type of the file to be edited.
323 | * @type string $file Filename being edited.
324 | * @type array $settings Settings to merge on top of defaults which derive from `$type` or `$file` args.
325 | * @type WP_Theme $theme Theme being edited when on theme editor.
326 | * @type string $plugin Plugin being edited when on plugin editor.
327 | * }
328 | */
329 | $settings = apply_filters( 'wp_code_editor_settings', $settings, $args );
330 |
331 | if ( empty( $settings ) || empty( $settings['codemirror'] ) ) {
332 | return false;
333 | }
334 |
335 | wp_enqueue_script( 'code-editor' );
336 | wp_enqueue_style( 'code-editor' );
337 |
338 | wp_enqueue_script( 'codemirror' );
339 | wp_enqueue_style( 'codemirror' );
340 |
341 | if ( isset( $settings['codemirror']['mode'] ) ) {
342 | $mode = $settings['codemirror']['mode'];
343 | if ( is_string( $mode ) ) {
344 | $mode = array(
345 | 'name' => $mode,
346 | );
347 | }
348 |
349 | if ( ! empty( $settings['codemirror']['lint'] ) ) {
350 | switch ( $mode['name'] ) {
351 | case 'css':
352 | case 'text/css':
353 | case 'text/x-scss':
354 | case 'text/x-less':
355 | wp_enqueue_script( 'csslint' );
356 | break;
357 | case 'htmlmixed':
358 | case 'text/html':
359 | case 'php':
360 | case 'application/x-httpd-php':
361 | case 'text/x-php':
362 | wp_enqueue_script( 'htmlhint' );
363 | wp_enqueue_script( 'csslint' );
364 | wp_enqueue_script( 'jshint' );
365 | if ( ! current_user_can( 'unfiltered_html' ) ) {
366 | wp_enqueue_script( 'htmlhint-kses' );
367 | }
368 | break;
369 | case 'javascript':
370 | case 'application/ecmascript':
371 | case 'application/json':
372 | case 'application/javascript':
373 | case 'application/ld+json':
374 | case 'text/typescript':
375 | case 'application/typescript':
376 | wp_enqueue_script( 'jshint' );
377 | wp_enqueue_script( 'jsonlint' );
378 | break;
379 | }
380 | }
381 | }
382 |
383 | wp_add_inline_script( 'code-editor', sprintf( 'jQuery.extend( wp.codeEditor.defaultSettings, %s );', wp_json_encode( $settings ) ) );
384 |
385 | /**
386 | * Fires when scripts and styles are enqueued for the code editor.
387 | *
388 | * @since 4.9.0
389 | *
390 | * @param array $settings Settings for the enqueued code editor.
391 | */
392 | do_action( 'wp_enqueue_code_editor', $settings );
393 |
394 | return $settings;
395 | }
396 |
--------------------------------------------------------------------------------
/wp-includes/js/codemirror/codemirror.manifest.js:
--------------------------------------------------------------------------------
1 | /* global require */
2 |
3 | var CodeMirror = require( '../../../node_modules/codemirror/lib/codemirror' );
4 |
5 | require( '../../../node_modules/codemirror/lib/codemirror.js' );
6 | require( '../../../node_modules/codemirror/keymap/emacs.js' );
7 | require( '../../../node_modules/codemirror/keymap/sublime.js' );
8 | require( '../../../node_modules/codemirror/keymap/vim.js' );
9 | require( '../../../node_modules/codemirror/addon/hint/show-hint.js' );
10 | require( '../../../node_modules/codemirror/addon/hint/anyword-hint.js' );
11 | require( '../../../node_modules/codemirror/addon/hint/css-hint.js' );
12 | require( '../../../node_modules/codemirror/addon/hint/html-hint.js' );
13 | require( '../../../node_modules/codemirror/addon/hint/javascript-hint.js' );
14 | require( '../../../node_modules/codemirror/addon/hint/sql-hint.js' );
15 | require( '../../../node_modules/codemirror/addon/hint/xml-hint.js' );
16 | require( '../../../node_modules/codemirror/addon/lint/lint.js' );
17 | require( '../../../node_modules/codemirror/addon/lint/css-lint.js' );
18 | require( '../../../node_modules/codemirror/addon/lint/html-lint.js' );
19 | require( '../../../node_modules/codemirror/addon/lint/javascript-lint.js' );
20 | require( '../../../node_modules/codemirror/addon/lint/json-lint.js' );
21 | require( '../../../node_modules/codemirror/addon/comment/comment.js' );
22 | require( '../../../node_modules/codemirror/addon/comment/continuecomment.js' );
23 | require( '../../../node_modules/codemirror/addon/fold/xml-fold.js' );
24 | require( '../../../node_modules/codemirror/addon/mode/overlay.js' );
25 | require( '../../../node_modules/codemirror/addon/edit/closebrackets.js' );
26 | require( '../../../node_modules/codemirror/addon/edit/closetag.js' );
27 | require( '../../../node_modules/codemirror/addon/edit/continuelist.js' );
28 | require( '../../../node_modules/codemirror/addon/edit/matchbrackets.js' );
29 | require( '../../../node_modules/codemirror/addon/edit/matchtags.js' );
30 | require( '../../../node_modules/codemirror/addon/edit/trailingspace.js' );
31 | require( '../../../node_modules/codemirror/addon/dialog/dialog.js' );
32 | require( '../../../node_modules/codemirror/addon/display/autorefresh.js' );
33 | require( '../../../node_modules/codemirror/addon/display/fullscreen.js' );
34 | require( '../../../node_modules/codemirror/addon/display/panel.js' );
35 | require( '../../../node_modules/codemirror/addon/display/placeholder.js' );
36 | require( '../../../node_modules/codemirror/addon/display/rulers.js' );
37 | require( '../../../node_modules/codemirror/addon/fold/brace-fold.js' );
38 | require( '../../../node_modules/codemirror/addon/fold/comment-fold.js' );
39 | require( '../../../node_modules/codemirror/addon/fold/foldcode.js' );
40 | require( '../../../node_modules/codemirror/addon/fold/foldgutter.js' );
41 | require( '../../../node_modules/codemirror/addon/fold/indent-fold.js' );
42 | require( '../../../node_modules/codemirror/addon/fold/markdown-fold.js' );
43 | require( '../../../node_modules/codemirror/addon/merge/merge.js' );
44 | require( '../../../node_modules/codemirror/addon/mode/loadmode.js' );
45 | require( '../../../node_modules/codemirror/addon/mode/multiplex.js' );
46 | require( '../../../node_modules/codemirror/addon/mode/simple.js' );
47 | require( '../../../node_modules/codemirror/addon/runmode/runmode.js' );
48 | require( '../../../node_modules/codemirror/addon/runmode/colorize.js' );
49 | require( '../../../node_modules/codemirror/addon/runmode/runmode-standalone.js' );
50 | require( '../../../node_modules/codemirror/addon/scroll/annotatescrollbar.js' );
51 | require( '../../../node_modules/codemirror/addon/scroll/scrollpastend.js' );
52 | require( '../../../node_modules/codemirror/addon/scroll/simplescrollbars.js' );
53 | require( '../../../node_modules/codemirror/addon/search/search.js' );
54 | require( '../../../node_modules/codemirror/addon/search/jump-to-line.js' );
55 | require( '../../../node_modules/codemirror/addon/search/match-highlighter.js' );
56 | require( '../../../node_modules/codemirror/addon/search/matchesonscrollbar.js' );
57 | require( '../../../node_modules/codemirror/addon/search/searchcursor.js' );
58 | require( '../../../node_modules/codemirror/addon/tern/tern.js' );
59 | require( '../../../node_modules/codemirror/addon/tern/worker.js' );
60 | require( '../../../node_modules/codemirror/addon/wrap/hardwrap.js' );
61 | require( '../../../node_modules/codemirror/addon/selection/active-line.js' );
62 | require( '../../../node_modules/codemirror/addon/selection/mark-selection.js' );
63 | require( '../../../node_modules/codemirror/addon/selection/selection-pointer.js' );
64 | require( '../../../node_modules/codemirror/mode/meta.js' );
65 | require( '../../../node_modules/codemirror/mode/clike/clike.js' );
66 | require( '../../../node_modules/codemirror/mode/css/css.js' );
67 | require( '../../../node_modules/codemirror/mode/diff/diff.js' );
68 | require( '../../../node_modules/codemirror/mode/htmlmixed/htmlmixed.js' );
69 | require( '../../../node_modules/codemirror/mode/http/http.js' );
70 | require( '../../../node_modules/codemirror/mode/javascript/javascript.js' );
71 | require( '../../../node_modules/codemirror/mode/jsx/jsx.js' );
72 | require( '../../../node_modules/codemirror/mode/markdown/markdown.js' );
73 | require( '../../../node_modules/codemirror/mode/gfm/gfm.js' );
74 | require( '../../../node_modules/codemirror/mode/nginx/nginx.js' );
75 | require( '../../../node_modules/codemirror/mode/php/php.js' );
76 | require( '../../../node_modules/codemirror/mode/sass/sass.js' );
77 | require( '../../../node_modules/codemirror/mode/shell/shell.js' );
78 | require( '../../../node_modules/codemirror/mode/sql/sql.js' );
79 | require( '../../../node_modules/codemirror/mode/xml/xml.js' );
80 | require( '../../../node_modules/codemirror/mode/yaml/yaml.js' );
81 |
82 | if ( ! window.wp ) {
83 | window.wp = {};
84 | }
85 | window.wp.CodeMirror = CodeMirror;
86 |
--------------------------------------------------------------------------------
/wp-includes/js/htmlhint-kses.js:
--------------------------------------------------------------------------------
1 | /* global HTMLHint */
2 | /* eslint no-magic-numbers: ["error", { "ignore": [0, 1] }] */
3 | HTMLHint.addRule({
4 | id: 'kses',
5 | description: 'Element or attribute cannot be used.',
6 | init: function( parser, reporter, options ) {
7 | 'use strict';
8 |
9 | var self = this;
10 | parser.addListener( 'tagstart', function( event ) {
11 | var attr, col, attrName, allowedAttributes, i, len, tagName;
12 |
13 | tagName = event.tagName.toLowerCase();
14 | if ( ! options[ tagName ] ) {
15 | reporter.error( 'Tag <' + event.tagName + '> is not allowed.', event.line, event.col, self, event.raw );
16 | return;
17 | }
18 |
19 | allowedAttributes = options[ tagName ];
20 | col = event.col + event.tagName.length + 1;
21 | for ( i = 0, len = event.attrs.length; i < len; i++ ) {
22 | attr = event.attrs[ i ];
23 | attrName = attr.name.toLowerCase();
24 | if ( ! allowedAttributes[ attrName ] ) {
25 | reporter.error( 'Tag attribute [' + attr.raw + ' ] is not allowed.', event.line, col + attr.index, self, attr.raw );
26 | }
27 | }
28 | });
29 | }
30 | });
31 |
--------------------------------------------------------------------------------
/wp-includes/script-loader-addendum.php:
--------------------------------------------------------------------------------
1 | add( 'codemirror', plugins_url( 'wp-includes/js/codemirror/codemirror.min.js', BETTER_CODE_EDITING_PLUGIN_FILE ), array(), $codemirror_version );
20 |
21 | // The linting engines for the lint addons...
22 | $scripts->add( 'csslint', plugins_url( 'wp-includes/js/csslint.js', BETTER_CODE_EDITING_PLUGIN_FILE ), array(), '1.0.5' );
23 | $scripts->add( 'jshint', plugins_url( 'wp-includes/js/jshint.js', BETTER_CODE_EDITING_PLUGIN_FILE ), array(), '2.9.5' );
24 | $scripts->add( 'jsonlint', plugins_url( 'wp-includes/js/jsonlint.js', BETTER_CODE_EDITING_PLUGIN_FILE ), array(), '1.6.2' );
25 | $scripts->add( 'htmlhint', plugins_url( 'wp-includes/js/htmlhint.js', BETTER_CODE_EDITING_PLUGIN_FILE ), array(), '0.9.14-xwp' );
26 | $scripts->add( 'htmlhint-kses', plugins_url( 'wp-includes/js/htmlhint-kses.js', BETTER_CODE_EDITING_PLUGIN_FILE ), array( 'htmlhint' ), BETTER_CODE_EDITING_PLUGIN_VERSION );
27 |
28 | $scripts->add( 'code-editor', plugins_url( 'wp-admin/js/code-editor.js', BETTER_CODE_EDITING_PLUGIN_FILE ), array( 'jquery', 'codemirror' ), BETTER_CODE_EDITING_PLUGIN_VERSION );
29 |
30 | $scripts->add( 'custom-html-widgets', plugins_url( 'wp-admin/js/widgets/custom-html-widgets.js', BETTER_CODE_EDITING_PLUGIN_FILE ), array( 'code-editor', 'jquery', 'backbone', 'wp-util', 'jquery-ui-core', 'wp-a11y' ), BETTER_CODE_EDITING_PLUGIN_VERSION );
31 | $scripts->add( 'wp-theme-plugin-editor', plugins_url( 'wp-admin/js/theme-plugin-editor.js', BETTER_CODE_EDITING_PLUGIN_FILE ), array( 'code-editor', 'jquery', 'jquery-ui-core', 'wp-a11y', 'underscore' ), BETTER_CODE_EDITING_PLUGIN_VERSION );
32 | }
33 |
34 | /**
35 | * Register styles.
36 | *
37 | * @param WP_Styles $styles Styles.
38 | */
39 | function _better_code_editing_register_styles( WP_Styles $styles ) {
40 | $codemirror_version = '5.29.1-alpha-ee20357-' . BETTER_CODE_EDITING_PLUGIN_VERSION;
41 |
42 | /*
43 | * Override common.css with patched version that has proper styling for CodeMirror and textarea.
44 | */
45 | $styles->registered['common']->src = plugins_url( 'wp-admin/css/common.css', BETTER_CODE_EDITING_PLUGIN_FILE );
46 | $styles->registered['common']->ver = BETTER_CODE_EDITING_PLUGIN_VERSION;
47 | unset( $styles->registered['common']->extra['suffix'] ); // Prevent minified version from being attempted.
48 |
49 | $styles->add( 'codemirror', plugins_url( 'wp-includes/js/codemirror/codemirror.min.css', BETTER_CODE_EDITING_PLUGIN_FILE ), array(), $codemirror_version );
50 | $styles->add( 'code-editor', plugins_url( 'wp-admin/css/code-editor.css', BETTER_CODE_EDITING_PLUGIN_FILE ), array( 'codemirror' ), BETTER_CODE_EDITING_PLUGIN_VERSION );
51 |
52 | // RTL CSS.
53 | $rtl_styles = array(
54 | 'code-editor',
55 | );
56 | foreach ( $rtl_styles as $rtl_style ) {
57 | $styles->add_data( $rtl_style, 'rtl', 'replace' );
58 | }
59 |
60 | // Patch the stylesheets.
61 | if ( function_exists( 'is_rtl' ) && is_rtl() && file_exists( plugin_dir_path( BETTER_CODE_EDITING_PLUGIN_FILE ) . 'wp-admin/css/common-rtl.css' ) ) {
62 | $suffix = '-rtl.css';
63 | } else {
64 | $suffix = '.css';
65 | }
66 | $styles->add_inline_style( 'widgets', file_get_contents( dirname( BETTER_CODE_EDITING_PLUGIN_FILE ) . '/wp-admin/css/widgets-addendum' . $suffix ) );
67 | $styles->add_inline_style( 'customize-controls', file_get_contents( dirname( BETTER_CODE_EDITING_PLUGIN_FILE ) . '/wp-admin/css/customize-controls-addendum' . $suffix ) );
68 | }
69 |
--------------------------------------------------------------------------------
/wp-includes/widgets-addendum.php:
--------------------------------------------------------------------------------
1 | registered ) {
36 | return;
37 | }
38 | $this->registered = true;
39 |
40 | wp_add_inline_script( 'custom-html-widgets', sprintf( 'wp.customHtmlWidgets.idBases.push( %s );', wp_json_encode( $this->id_base ) ) );
41 |
42 | // Note that the widgets component in the customizer will also do the 'admin_print_scripts-widgets.php' action in WP_Customize_Widgets::print_scripts().
43 | add_action( 'admin_print_scripts-widgets.php', array( $this, 'enqueue_admin_scripts' ) );
44 |
45 | // Note that the widgets component in the customizer will also do the 'admin_footer-widgets.php' action in WP_Customize_Widgets::print_footer_scripts().
46 | add_action( 'admin_footer-widgets.php', array( 'WP_Widget_Custom_HTML_CodeMirror', 'render_control_template_scripts' ) );
47 |
48 | // Note this action is used to ensure the help text is added to the end.
49 | add_action( 'admin_head-widgets.php', array( 'WP_Widget_Custom_HTML_CodeMirror', 'add_help_text' ) );
50 | }
51 |
52 | /**
53 | * Loads the required scripts and styles for the widget control.
54 | *
55 | * @since 4.9.0
56 | */
57 | public function enqueue_admin_scripts() {
58 | $settings = wp_enqueue_code_editor( array(
59 | 'type' => 'text/html',
60 | ) );
61 |
62 | wp_enqueue_script( 'custom-html-widgets' );
63 | if ( empty( $settings ) ) {
64 | $settings = array(
65 | 'disabled' => true,
66 | );
67 | }
68 | wp_add_inline_script( 'custom-html-widgets', sprintf( 'wp.customHtmlWidgets.init( %s );', wp_json_encode( $settings ) ), 'after' );
69 |
70 | $l10n = array(
71 | 'errorNotice' => wp_array_slice_assoc(
72 | /* translators: placeholder is error count */
73 | _n_noop( 'There is %d error which must be fixed before you can save.', 'There are %d errors which must be fixed before you can save.', 'better-code-editing' ),
74 | array( 'singular', 'plural' )
75 | ),
76 | );
77 | wp_add_inline_script( 'custom-html-widgets', sprintf( 'jQuery.extend( wp.customHtmlWidgets.l10n, %s );', wp_json_encode( $l10n ) ), 'after' );
78 | }
79 |
80 | /**
81 | * Outputs the Custom HTML widget settings form.
82 | *
83 | * @since 4.8.1
84 | *
85 | * @param array $instance Current instance.
86 | * @returns void
87 | */
88 | public function form( $instance ) {
89 | $instance = wp_parse_args( (array) $instance, $this->default_instance );
90 | ?>
91 |
92 |
93 |
103 |
133 | ';
145 | $content .= __( 'Use the Custom HTML widget to add arbitrary HTML code to your widget areas.', 'better-code-editing' );
146 | $content .= '';
147 |
148 | $content .= '' . __( 'When using a keyboard to navigate:', 'better-code-editing' ) . '
';
149 | $content .= '';
150 | $content .= '' . __( 'In the HTML edit field, Tab enters a tab character.', 'better-code-editing' ) . ' ';
151 | $content .= '' . __( 'To move keyboard focus, press Esc then Tab for the next element, or Esc then Shift+Tab for the previous element.', 'better-code-editing' ) . ' ';
152 | $content .= ' ';
153 |
154 | $content .= '';
155 | $content .= sprintf(
156 | /* translators: placeholder is link to user profile */
157 | __( 'The edit field automatically highlights code syntax. You can disable this in your %s to work in plan text mode.', 'better-code-editing' ),
158 | sprintf(
159 | ' %2$s%3$s ',
160 | esc_url( get_edit_profile_url() . '#syntax_highlighting' ),
161 | __( 'user profile', 'better-code-editing' ),
162 | /* translators: accessibility text */
163 | __( '(opens in a new window)', 'default' )
164 | )
165 | );
166 | $content .= '
';
167 |
168 | $screen->add_help_tab( array(
169 | 'id' => 'custom_html_widget',
170 | 'title' => __( 'Custom HTML Widget', 'better-code-editing' ),
171 | 'content' => $content,
172 | ) );
173 | }
174 | }
175 |
--------------------------------------------------------------------------------